:root{--bg-base: #050a18;--bg-primary: #0a1128;--bg-surface: #111d3a;--bg-elevated: #162040;--bg-hover: #1a2747;--bg-active: #1e2f52;--accent: #00d4ff;--accent-hover: #33ddff;--accent-muted: #0891b2;--accent-dim: #065f78;--accent-glow: rgba(0, 212, 255, .12);--accent-glow-strong: rgba(0, 212, 255, .25);--color-success: #10b981;--color-success-bg: rgba(16, 185, 129, .1);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .1);--color-danger: #ef4444;--color-danger-bg: rgba(239, 68, 68, .1);--color-critical: #dc2626;--color-critical-bg: rgba(220, 38, 38, .12);--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .1);--score-excellent: #10b981;--score-good: #3b82f6;--score-attention: #f59e0b;--score-concerning: #f97316;--score-critical: #ef4444;--severity-critical-text: #fca5a5;--severity-critical-bg: rgba(220, 38, 38, .15);--severity-critical-border: rgba(220, 38, 38, .3);--severity-high-text: #fdba74;--severity-high-bg: rgba(249, 115, 22, .12);--severity-high-border: rgba(249, 115, 22, .3);--severity-medium-text: #fde047;--severity-medium-bg: rgba(245, 158, 11, .1);--severity-medium-border: rgba(245, 158, 11, .25);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--text-disabled: #475569;--text-inverse: #0a1128;--text-accent: #00d4ff;--glass-bg: rgba(17, 29, 58, .55);--glass-bg-hover: rgba(26, 39, 71, .65);--glass-border: rgba(0, 212, 255, .08);--glass-border-hover: rgba(0, 212, 255, .18);--glass-blur: 16px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--fs-xs: .6875rem;--fs-sm: .8125rem;--fs-base: .9375rem;--fs-lg: 1.0625rem;--fs-xl: 1.25rem;--fs-2xl: 1.5rem;--fs-3xl: 1.875rem;--fs-4xl: 2.25rem;--fs-5xl: 3rem;--fw-light: 300;--fw-normal: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-extrabold: 800;--lh-tight: 1.2;--lh-normal: 1.5;--lh-relaxed: 1.65;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .35);--shadow-lg: 0 10px 24px rgba(0, 0, 0, .35);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .4);--shadow-glow: 0 0 24px rgba(0, 212, 255, .12);--shadow-glow-strong: 0 0 40px rgba(0, 212, 255, .2);--shadow-inner: inset 0 1px 4px rgba(0, 0, 0, .3);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-base: .25s;--duration-slow: .4s;--duration-slower: .6s;--sidebar-w: 260px;--sidebar-w-collapsed: 72px;--header-h: 64px;--content-max-w: 1400px;--z-sidebar: 100;--z-header: 110;--z-modal-backdrop: 200;--z-modal: 210;--z-tooltip: 300;--z-toast: 400}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--fs-base);font-weight:var(--fw-normal);line-height:var(--lh-normal);color:var(--text-primary);background:var(--bg-base);min-height:100vh;overflow-x:hidden}a{color:var(--accent);text-decoration:none;transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--accent-hover)}img,svg{display:block;max-width:100%}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background:transparent;border:none;outline:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:var(--fw-semibold);line-height:var(--lh-tight);color:var(--text-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent-dim)}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-base);z-index:9999;transition:opacity var(--duration-slow) var(--ease-out),visibility var(--duration-slow) var(--ease-out)}.loading-screen.fade-out{opacity:0;visibility:hidden}.loading-content{text-align:center;animation:loadingFadeIn .6s var(--ease-out) both}.loading-logo{margin-bottom:var(--space-6);animation:loadingPulse 2s ease-in-out infinite}.loading-title{font-size:var(--fs-2xl);font-weight:var(--fw-extrabold);background:linear-gradient(135deg,#1f3a5f,#06b6d4,#00d4ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-2);letter-spacing:.02em}.loading-subtitle{font-size:var(--fs-sm);color:var(--text-muted);margin-bottom:var(--space-8)}.loading-bar{width:200px;height:3px;background:var(--bg-surface);border-radius:var(--radius-full);overflow:hidden;margin:0 auto}.loading-bar-fill{height:100%;width:40%;background:linear-gradient(90deg,var(--accent),var(--accent-muted));border-radius:var(--radius-full);animation:loadingSlide 1.2s ease-in-out infinite}.app-layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--header-h) 1fr;grid-template-areas:"sidebar header" "sidebar content";min-height:100vh}.sidebar{grid-area:sidebar;background:linear-gradient(180deg,#1f3a5f,#0f172a 40%,#0a0e1a);border-right:1px solid rgba(0,212,255,.1);display:flex;flex-direction:column;padding:var(--space-6) 0;position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);z-index:var(--z-sidebar);overflow-y:auto}.sidebar-brand{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-6);margin-bottom:var(--space-10)}.sidebar-brand svg{flex-shrink:0}.sidebar-brand-text{display:flex;flex-direction:column}.sidebar-brand-name{font-size:var(--fs-lg);font-weight:var(--fw-extrabold);background:linear-gradient(135deg,#1f3a5f,#06b6d4,#00d4ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2;letter-spacing:.04em}.sidebar-brand-tag{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:var(--space-1);padding:0 var(--space-3)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);transition:all var(--duration-fast) var(--ease-out);cursor:pointer;position:relative}.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-item.active{color:var(--accent);background:var(--accent-glow)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--accent);border-radius:var(--radius-full)}.nav-item svg{width:20px;height:20px;flex-shrink:0}.nav-item .badge{margin-left:auto}.sidebar-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--glass-border);margin-top:auto;display:flex;flex-direction:column;gap:var(--space-2)}.sidebar-footer-brand{display:flex;align-items:center;gap:var(--space-2)}.sidebar-footer-company{font-size:var(--fs-base);font-weight:var(--fw-bold);color:var(--text-primary);letter-spacing:.02em}.sidebar-footer-text{font-size:var(--fs-xs);color:var(--text-muted)}.sidebar-brand svg{filter:drop-shadow(0 0 8px rgba(0,212,255,.4))}.header{grid-area:header;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);background:#050a18cc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--glass-border);position:sticky;top:0;z-index:var(--z-header)}.header-title{font-size:var(--fs-xl);font-weight:var(--fw-semibold)}.header-actions{display:flex;align-items:center;gap:var(--space-3)}.content{grid-area:content;padding:var(--space-8);max-width:calc(var(--content-max-w) + var(--space-8) * 2);animation:contentFadeIn .4s var(--ease-out) both}.card{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:border-color var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out),transform var(--duration-base) var(--ease-out)}.card:hover{border-color:var(--glass-border-hover)}.card.interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.card-title{font-size:var(--fs-base);font-weight:var(--fw-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.card-value{font-size:var(--fs-3xl);font-weight:var(--fw-bold);line-height:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-size:var(--fs-sm);font-weight:var(--fw-medium);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;height:40px}.btn svg{width:18px;height:18px}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-muted));color:var(--text-inverse);box-shadow:var(--shadow-sm),0 0 16px #00d4ff33}.btn-primary:hover{box-shadow:var(--shadow-md),0 0 24px #00d4ff59;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--glass-border)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--glass-border-hover)}.btn-danger{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:#ef444426}.btn-sm{height:32px;padding:var(--space-1) var(--space-3);font-size:var(--fs-xs);border-radius:var(--radius-md)}.btn-lg{height:48px;padding:var(--space-3) var(--space-8);font-size:var(--fs-base);border-radius:var(--radius-xl)}.btn.loading{pointer-events:none;opacity:.7}.btn.loading:after{content:"";width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--fs-xs);font-weight:var(--fw-semibold);border-radius:var(--radius-full);line-height:1.4}.badge-critical{color:var(--severity-critical-text);background:var(--severity-critical-bg);border:1px solid var(--severity-critical-border)}.badge-high{color:var(--severity-high-text);background:var(--severity-high-bg);border:1px solid var(--severity-high-border)}.badge-medium{color:var(--severity-medium-text);background:var(--severity-medium-bg);border:1px solid var(--severity-medium-border)}.badge-info{color:#93c5fd;background:#3b82f61a;border:1px solid rgba(59,130,246,.25)}.badge-success{color:#6ee7b7;background:#10b9811a;border:1px solid rgba(16,185,129,.25)}.badge-low{color:#93c5fd;background:#3b82f61a;border:1px solid rgba(59,130,246,.2)}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--glass-border)}table{width:100%;border-collapse:collapse}th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:var(--bg-primary);border-bottom:1px solid var(--glass-border);white-space:nowrap;position:sticky;top:0}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{color:var(--text-secondary)}th.sorted{color:var(--accent)}td{padding:var(--space-3) var(--space-4);font-size:var(--fs-sm);color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}tr{transition:background var(--duration-fast) var(--ease-out)}tbody tr:hover{background:var(--bg-hover)}tbody tr.clickable{cursor:pointer}.progress-bar{width:100%;height:6px;background:var(--bg-primary);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-out)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);opacity:0;visibility:hidden;transition:opacity var(--duration-base) var(--ease-out),visibility var(--duration-base) var(--ease-out)}.modal-backdrop.visible{opacity:1;visibility:visible}.modal-panel{position:fixed;top:0;right:0;bottom:0;width:min(580px,90vw);background:var(--bg-primary);border-left:1px solid var(--glass-border);z-index:var(--z-modal);transform:translate(100%);transition:transform var(--duration-slow) var(--ease-out);overflow-y:auto;display:flex;flex-direction:column}.modal-panel.visible{transform:translate(0)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--glass-border);flex-shrink:0}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-muted);transition:all var(--duration-fast) var(--ease-out)}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:var(--space-6);flex:1}.filters{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);-webkit-user-select:none;user-select:none}.filter-chip:hover{color:var(--text-primary);border-color:var(--glass-border-hover)}.filter-chip.active{color:var(--accent);background:var(--accent-glow);border-color:#00d4ff4d}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);padding:var(--space-1) var(--space-3);font-size:var(--fs-xs);color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--glass-border);border-radius:var(--radius-md);white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;transition:all var(--duration-fast) var(--ease-out);z-index:var(--z-tooltip)}.tooltip:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.stat{display:flex;flex-direction:column;gap:var(--space-1)}.stat-label{font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:var(--fs-2xl);font-weight:var(--fw-bold);line-height:1}.stat-change{font-size:var(--fs-xs);font-weight:var(--fw-medium);display:inline-flex;align-items:center;gap:var(--space-1)}.stat-change.positive{color:var(--color-success)}.stat-change.negative{color:var(--color-danger)}.divider{width:100%;height:1px;background:var(--glass-border);margin:var(--space-4) 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center}.empty-state svg{width:64px;height:64px;color:var(--text-muted);margin-bottom:var(--space-4);opacity:.5}.empty-state-title{font-size:var(--fs-lg);font-weight:var(--fw-semibold);margin-bottom:var(--space-2)}.empty-state-text{font-size:var(--fs-sm);color:var(--text-muted);max-width:360px}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2);z-index:var(--z-toast)}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--bg-elevated);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:var(--fs-sm);color:var(--text-primary);animation:toastIn .3s var(--ease-spring) both;min-width:280px}.toast.toast-out{animation:toastOut .25s var(--ease-out) both}.grid{display:grid;gap:var(--space-6)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.text-xs{font-size:var(--fs-xs)}.text-sm{font-size:var(--fs-sm)}.text-lg{font-size:var(--fs-lg)}.text-xl{font-size:var(--fs-xl)}.text-2xl{font-size:var(--fs-2xl)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.font-medium{font-weight:var(--fw-medium)}.font-semibold{font-weight:var(--fw-semibold)}.font-bold{font-weight:var(--fw-bold)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.scan-pulse{position:relative}.scan-pulse:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:inherit;border:2px solid var(--accent);opacity:0;animation:scanPulse 2s var(--ease-out) infinite}@keyframes loadingFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes loadingPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes loadingSlide{0%{transform:translate(-100%)}to{transform:translate(350%)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scanPulse{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.15)}}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(40px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(40px) scale(.95)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.animate-fade-in-up{animation:fadeInUp .5s var(--ease-out) both}.animate-slide-in-right{animation:slideInRight .4s var(--ease-out) both}@media(max-width:1024px){:root{--sidebar-w: 0px}.sidebar{transform:translate(-100%);transition:transform var(--duration-slow) var(--ease-out)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-xl)}.header{margin-left:0}.content{margin-left:0;padding:var(--space-4)}.header-menu-toggle{display:flex}.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.content{padding:var(--space-3)}.card{padding:var(--space-4)}.header{padding:0 var(--space-4)}.modal-panel{width:100vw}}.dashboard-grid{display:flex;flex-direction:column;gap:var(--space-8)}.score-section{display:grid;grid-template-columns:260px 1fr;gap:var(--space-6);align-items:start;animation:fadeInUp .5s var(--ease-out) both}.gauge-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);position:relative;overflow:hidden}.gauge-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,var(--accent-glow) 0%,transparent 60%);opacity:.3;pointer-events:none}.gauge-canvas-wrap{position:relative;width:220px;height:220px}.gauge-number{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);font-size:var(--fs-5xl);font-weight:var(--fw-extrabold);line-height:1;letter-spacing:-.02em;text-align:center;color:var(--text-primary)}.gauge-label{font-size:var(--fs-sm);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.06em;margin-top:var(--space-2);text-align:center}.gauge-subtitle{font-size:var(--fs-xs);color:var(--text-muted);margin-top:var(--space-1);text-align:center}.category-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.category-card{display:flex;flex-direction:column;gap:var(--space-3)}.category-card .card-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:var(--accent-glow);color:var(--accent);flex-shrink:0}.category-card .card-icon svg{width:20px;height:20px}.category-card-header{display:flex;align-items:center;gap:var(--space-3)}.category-card-name{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-secondary)}.category-card-score{font-size:var(--fs-3xl);font-weight:var(--fw-bold);line-height:1}.category-card-bar{margin-top:auto}.summary-section{animation:fadeInUp .5s var(--ease-out) .1s both}.summary-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-4)}.summary-item{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4) var(--space-5);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);transition:border-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.summary-item:hover{border-color:var(--glass-border-hover);transform:translateY(-1px)}.summary-item-label{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--fw-medium)}.summary-item-value{font-size:var(--fs-2xl);font-weight:var(--fw-bold);line-height:1}.summary-item-detail{font-size:var(--fs-xs);color:var(--text-muted)}.charts-section{animation:fadeInUp .5s var(--ease-out) .2s both}.chart-card{min-height:340px;display:flex;flex-direction:column}.chart-card .card-header{margin-bottom:var(--space-4)}.chart-wrap{position:relative;flex:1;min-height:300px}.chart-wrap canvas{width:100%!important;height:100%!important}.risk-flags-section{animation:fadeInUp .5s var(--ease-out) .15s both}.risk-flags-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.risk-flag{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);transition:all var(--duration-base) var(--ease-out)}.risk-flag.active{border-color:#ef44444d;background:#ef44440d}.risk-flag.active .risk-flag-indicator{background:var(--color-danger);box-shadow:0 0 12px #ef444466;animation:riskPulse 2s ease-in-out infinite}.risk-flag.inactive .risk-flag-indicator{background:var(--color-success)}.risk-flag-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0}.risk-flag-icon{font-size:var(--fs-lg);flex-shrink:0}.risk-flag-content{display:flex;flex-direction:column;min-width:0}.risk-flag-label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.risk-flag-status{font-size:var(--fs-xs);color:var(--text-muted)}.risk-flag.active .risk-flag-status{color:var(--color-danger)}.risk-flag.inactive .risk-flag-status{color:var(--color-success)}@keyframes riskPulse{0%,to{box-shadow:0 0 8px #ef44444d}50%{box-shadow:0 0 16px #ef444499}}.dashboard-actions{display:flex;justify-content:flex-end;gap:var(--space-3);animation:fadeInUp .5s var(--ease-out) .3s both}.roi-section{animation:fadeInUp .5s var(--ease-out) .25s both}.roi-hero{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);background:linear-gradient(135deg,#06b6d414,#8b5cf614);border:1px solid rgba(6,182,212,.2);border-radius:var(--radius-xl);margin-bottom:var(--space-4);gap:var(--space-6);flex-wrap:wrap}.roi-hero-main{display:flex;flex-direction:column;gap:var(--space-2)}.roi-hero-label{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:var(--fw-semibold)}.roi-hero-value{font-size:var(--fs-4xl);font-weight:var(--fw-extrabold);background:linear-gradient(135deg,var(--accent) 0%,#a78bfa 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1}.roi-hero-subtitle{font-size:var(--fs-sm);color:var(--text-secondary)}.roi-savings{display:flex;gap:var(--space-6)}.roi-savings-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-5);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);min-width:120px}.roi-savings-value{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--color-success)}.roi-savings-label{font-size:var(--fs-xs);color:var(--text-muted);text-align:center}.roi-opportunities{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-3)}.roi-opportunity{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);transition:all var(--duration-base) var(--ease-out)}.roi-opportunity:hover{border-color:var(--glass-border-hover);transform:translateY(-1px)}.roi-opportunity.priority-high{border-left:3px solid var(--color-danger)}.roi-opportunity.priority-medium{border-left:3px solid var(--color-warning)}.roi-opportunity.priority-low{border-left:3px solid var(--color-success)}.roi-opp-icon{font-size:var(--fs-2xl);flex-shrink:0;line-height:1}.roi-opp-content{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.roi-opp-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary)}.roi-opp-desc{font-size:var(--fs-xs);color:var(--text-muted)}.roi-opp-value{font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--accent)}.storage-growth-section{animation:fadeInUp .5s var(--ease-out) .28s both}.growth-projections{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-3);margin-top:var(--space-3)}.growth-item{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.growth-item-label{font-size:var(--fs-xs);color:var(--text-muted);font-weight:var(--fw-medium)}.growth-item-value{font-size:var(--fs-xl);font-weight:var(--fw-bold);line-height:1}.growth-item-value.text-warning{color:var(--color-warning)}.growth-item-value.text-danger{color:var(--color-danger)}@media(max-width:1200px){.score-section{grid-template-columns:1fr}.category-cards-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:1024px){.category-cards-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.score-section,.category-cards-grid{grid-template-columns:1fr}.summary-bar{grid-template-columns:repeat(2,1fr)}}.findings-header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.findings-filters-row{display:flex;align-items:center;gap:var(--space-6);flex-wrap:wrap}.findings-filter-group{display:flex;flex-direction:column;gap:var(--space-2)}.findings-filter-label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.findings-summary{display:flex;align-items:center;gap:var(--space-6);padding:var(--space-3) var(--space-5);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.findings-summary-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--fs-sm);color:var(--text-secondary)}.findings-summary-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.findings-summary-dot.critical{background:var(--color-critical)}.findings-summary-dot.high{background:var(--color-warning)}.findings-summary-dot.medium{background:#f59e0b}.findings-summary-count{font-weight:var(--fw-bold);color:var(--text-primary)}.findings-table{animation:fadeInUp .4s var(--ease-out) both}.finding-row{cursor:pointer;position:relative}.finding-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;opacity:0;transition:opacity var(--duration-fast) var(--ease-out)}.finding-row:hover:before{opacity:1}.finding-row.severity-critical:before{background:var(--color-critical)}.finding-row.severity-high:before{background:var(--color-warning)}.finding-row.severity-medium:before{background:#f59e0b}.finding-title-cell{font-weight:var(--fw-medium);color:var(--text-primary);max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.finding-impact{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap}.finding-location{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--fs-xs);color:var(--text-secondary);background:var(--bg-surface);border-radius:var(--radius-sm);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.finding-action-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--accent);background:var(--accent-glow);border:1px solid rgba(0,212,255,.2);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.finding-action-btn:hover{background:var(--accent-glow-strong);border-color:#00d4ff66}.finding-action-btn svg{width:14px;height:14px}.severity-indicator{width:3px;height:24px;border-radius:var(--radius-full);flex-shrink:0}.severity-indicator.critical{background:var(--color-critical)}.severity-indicator.high{background:var(--color-warning)}.severity-indicator.medium{background:#f59e0b}.finding-detail-title{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary);line-height:var(--lh-tight);margin-bottom:var(--space-4)}.finding-detail-description{font-size:var(--fs-sm);color:var(--text-secondary);line-height:var(--lh-relaxed);margin-bottom:var(--space-6)}.finding-detail-section{margin-bottom:var(--space-6)}.finding-detail-section-title{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.finding-detail-section-title svg{width:16px;height:16px;color:var(--accent)}.impact-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}.impact-item{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-md)}.impact-item-label{font-size:var(--fs-xs);color:var(--text-muted);font-weight:var(--fw-medium)}.impact-item-value{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary)}.recommendation-card{padding:var(--space-4) var(--space-5);background:var(--color-info-bg);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-lg);font-size:var(--fs-sm);color:var(--text-secondary);line-height:var(--lh-relaxed);display:flex;gap:var(--space-3);align-items:flex-start}.recommendation-card svg{width:20px;height:20px;color:var(--color-info);flex-shrink:0;margin-top:2px}.location-list{display:flex;flex-direction:column;gap:var(--space-2)}.location-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);transition:border-color var(--duration-fast) var(--ease-out)}.location-item:hover{border-color:var(--glass-border-hover)}.location-item-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent-glow);color:var(--accent);flex-shrink:0}.location-item-icon svg{width:16px;height:16px}.location-item-info{display:flex;flex-direction:column;min-width:0}.location-item-name{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location-item-url{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.findings-filters-row{flex-direction:column;align-items:stretch}.findings-summary{flex-wrap:wrap;gap:var(--space-3)}.impact-grid{grid-template-columns:repeat(2,1fr)}}.export-dropdown{position:relative;display:inline-flex}.export-dropdown-menu{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:200px;background:var(--bg-elevated);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-2);z-index:50;opacity:0;visibility:hidden;transform:translateY(-4px) scale(.97);transition:all var(--duration-fast) var(--ease-out);pointer-events:none}.export-dropdown.open .export-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0) scale(1);pointer-events:auto}.export-dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);text-align:left}.export-dropdown-item:hover{color:var(--text-primary);background:var(--bg-hover)}.export-dropdown-item svg{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.export-dropdown-item:hover svg{color:var(--accent)}.export-dropdown-divider{height:1px;background:var(--glass-border);margin:var(--space-1) 0}@media print{body{background:#fff;color:#1a1a1a;font-size:12pt}.sidebar,.header,.export-dropdown,.btn,.filter-chip,.toast-container,.modal-backdrop,.modal-panel,#loading-screen{display:none!important}.content{margin-left:0!important;padding:0!important;max-width:100%!important}.app-layout{display:block}.card{background:#fff;border:1px solid #e5e7eb;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;break-inside:avoid;page-break-inside:avoid}.badge{border:1px solid currentColor}table{border:1px solid #e5e7eb}th{background:#f3f4f6;color:#374151}td{color:#374151;border-bottom:1px solid #e5e7eb}.progress-bar{border:1px solid #d1d5db}.gauge-container,.summary-item{background:#fff;border:1px solid #e5e7eb}a{color:#1a1a1a;text-decoration:underline}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}
