:root{--color-primary-50: #e6f5ed;--color-primary-100: #9cf5c1;--color-primary-200: #7adba3;--color-primary-300: #5cc085;--color-primary-400: #3ea868;--color-primary-500: #005232;--color-primary-600: #006d44;--color-primary-700: #004328;--color-primary-800: #003820;--color-primary-900: #002418;--color-secondary-container: #cde6d6;--color-on-secondary-container: #51685b;--color-tertiary: #254c5b;--color-tertiary-light: #3a7189;--color-accent-400: #3a7189;--color-accent-500: #254c5b;--color-success: #006d44;--color-warning: #92400E;--color-danger: #93000a;--color-info: #254c5b;--color-error-container: #ffdad6;--color-on-error-container: #93000a;--color-bg-primary: #f8faf8;--color-bg-secondary: #f2f4f2;--color-bg-tertiary: #eceeec;--color-bg-focus: #ffffff;--color-bg-hover: #e4e8e4;--color-border: rgba(190, 201, 191, .15);--color-border-light: rgba(190, 201, 191, .08);--color-text-primary: #191c1b;--color-text-secondary: #51685b;--color-text-muted: #8a9a90;--glass-bg: rgba(255, 255, 255, .65);--glass-border: rgba(190, 201, 191, .12);--glass-blur: blur(20px);--font-display: "Manrope", system-ui, -apple-system, sans-serif;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", monospace;--text-xs: .6875rem;--text-sm: .75rem;--text-base: .875rem;--text-lg: 1rem;--text-xl: 1.25rem;--text-2xl: 1.75rem;--text-3xl: 2.25rem;--text-4xl: 3.5rem;--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;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(25, 28, 27, .04);--shadow-md: 0 4px 12px rgba(25, 28, 27, .06);--shadow-lg: 0 8px 24px rgba(25, 28, 27, .08);--shadow-xl: 0 16px 48px rgba(25, 28, 27, .06);--shadow-glow: 0 0 24px rgba(0, 82, 50, .12);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box}body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}ul[role=list],ol[role=list]{list-style:none}html:focus-within{scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5;font-family:var(--font-sans);background-color:var(--color-bg-primary);color:var(--color-text-primary)}a:not([class]){text-decoration-skip-ink:auto}img,picture{max-width:100%;display:block}input,button,textarea,select{font:inherit}@media(prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@font-face{font-family:Material Symbols Outlined;font-style:normal;font-weight:100 700;font-display:block;src:url(https://fonts.gstatic.com/s/materialsymbolsoutlined/v253/kJEhBvYX7BgnkSrUwT8OhrdQw4oELdPIeeII9v6oFsI.woff2) format("woff2")}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";font-feature-settings:"liga";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;max-width:1em;max-height:1em;vertical-align:text-bottom}body{font-family:var(--font-sans);font-size:var(--text-base);background-color:var(--color-bg-primary);color:var(--color-text-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--color-text-primary);font-weight:800;line-height:1.15;letter-spacing:-.02em}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{color:var(--color-text-secondary);font-size:var(--text-base);line-height:1.6}a{color:var(--color-primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-800)}button{background:none;border:none;padding:0;cursor:pointer}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.glass-card{background:var(--color-bg-focus);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.glass-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-weight:600;font-family:var(--font-sans);border-radius:var(--radius-xl);border:none;transition:all var(--transition-fast);text-align:center;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--color-primary-500) 0%,var(--color-primary-600) 100%);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:linear-gradient(135deg,var(--color-primary-700) 0%,var(--color-primary-500) 100%);box-shadow:var(--shadow-md),var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background-color:var(--color-secondary-container);color:var(--color-on-secondary-container);border:none}.btn-secondary:hover{background-color:#bdd6c6;box-shadow:var(--shadow-sm)}.btn-danger{background:var(--color-error-container);color:var(--color-on-error-container)}.btn-danger:hover{filter:brightness(.95)}.btn-icon{width:2.5rem;height:2.5rem;padding:0;border-radius:var(--radius-full)}.form-group{margin-bottom:var(--space-4)}.label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.05em}.input,.textarea,.select{width:100%;padding:var(--space-3) var(--space-4);background-color:var(--color-bg-tertiary);border:1px solid rgba(190,201,191,.15);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-sans);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--color-primary-500);background:var(--color-bg-focus);box-shadow:0 0 0 3px #00523214}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:var(--text-xs);font-weight:700;border-radius:var(--radius-full);text-transform:capitalize;letter-spacing:.02em}.badge-success{background:#9cf5c14d;color:var(--color-primary-700)}.badge-warning{background:#fef3c799;color:#92400e}.badge-error{background:var(--color-error-container);color:var(--color-on-error-container)}.badge-info{background:#254c5b1a;color:var(--color-tertiary)}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px}.status-dot-active{background-color:var(--color-primary-100);box-shadow:0 0 10px #9cf5c199}.status-dot-inactive{background-color:var(--color-text-muted)}.user-profile-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg-tertiary);border-radius:var(--radius-lg);margin:0 var(--space-1);transition:all var(--transition-fast)}.user-profile-card:hover{background:var(--color-bg-hover);transform:translateY(-1px)}.user-avatar{width:2.5rem;height:2.5rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);display:grid;place-items:center;color:var(--color-primary-500)}.user-details{flex:1;min-width:0}.user-name{font-size:.875rem;font-weight:700;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.02em}.logout-minimal-btn{width:2rem;height:2rem;display:grid;place-items:center;border-radius:var(--radius-md);color:var(--color-text-muted);transition:all var(--transition-fast);background:transparent;border:none;cursor:pointer}.logout-minimal-btn:hover{background:var(--color-error-container);color:var(--color-on-error-container)}.logout-minimal-btn span{font-size:18px}.user-profile-header:hover{background:var(--color-bg-hover)!important}.user-profile-header:hover .user-avatar{background:var(--color-bg-secondary)!important}.hidden{display:none!important}.app-shell{display:flex;min-height:100vh;background-color:var(--color-bg-primary)}.sidebar{width:260px;background:var(--color-bg-secondary);border-right:none;display:flex;flex-direction:column;height:100vh;position:sticky;top:0;transition:transform var(--transition-base);z-index:50}.sidebar-header{padding:var(--space-6);border-bottom:none}.brand{display:flex;align-items:center;gap:var(--space-3)}.brand-icon{width:2.5rem;height:2.5rem;background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));border-radius:var(--radius-md);display:grid;place-items:center;color:#fff;font-weight:800;font-family:var(--font-display);box-shadow:var(--shadow-sm)}.brand-name{font-size:1.25rem;font-weight:800;font-family:var(--font-display);color:var(--color-text-primary);letter-spacing:-.03em}.sidebar-nav{flex:1;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1)}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--color-text-secondary);border-radius:var(--radius-md);text-decoration:none;font-weight:500;font-size:var(--text-base);transition:all var(--transition-fast)}.nav-link:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.nav-link.active{background-color:#00523214;color:var(--color-primary-500);font-weight:600}.sidebar-footer{padding:var(--space-6);border-top:none}.main-content{flex:1;min-width:0;display:flex;flex-direction:column}.top-bar{height:64px;padding:0 var(--space-8);background:var(--color-bg-primary);border-bottom:none;box-shadow:0 1px #bec9bf1a;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:40}.content-body{flex:1;padding:var(--space-8);max-width:1440px;margin:0 auto;width:100%}.mobile-nav{position:fixed;bottom:0;left:0;right:0;height:64px;background:#f8faf8d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:none;box-shadow:0 -1px #bec9bf1a;display:none;justify-content:space-around;align-items:center;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.mobile-nav-link{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--color-text-muted);text-decoration:none;font-size:.65rem;font-weight:600;transition:color var(--transition-fast)}.mobile-nav-link.active{color:var(--color-primary-500)}@media(max-width:1024px){.sidebar{display:none}.mobile-nav{display:flex}.content-body{padding:var(--space-4);padding-bottom:calc(64px + var(--space-8))}}.login-split-layout{min-height:100vh;display:flex;background:var(--color-bg-primary);overflow:hidden;font-family:Inter,sans-serif}.login-visual-side{flex:1.1;position:relative;display:none;background-color:var(--color-primary-950);background-size:cover;background-position:center;overflow:hidden;color:#fff;padding:80px}@media(min-width:1024px){.login-visual-side{display:flex;flex-direction:column;justify-content:space-between}}.login-visual-side:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#022c22cc,#022c2266);z-index:1}.login-visual-content{position:relative;z-index:2;max-width:500px}.visual-category{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:var(--color-primary-300);margin-bottom:40px;display:flex;align-items:center;gap:12px}.visual-category:before{content:"";width:40px;height:2px;background:var(--color-primary-300)}.visual-headline{font-family:Manrope,sans-serif;font-size:72px;line-height:1.1;font-weight:800;margin-bottom:32px;letter-spacing:-2px;color:#fff}.visual-description{font-size:18px;line-height:1.6;color:#fffc;font-weight:500}.visual-footer{position:relative;z-index:2}.live-badge{display:inline-flex;align-items:center;gap:10px;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 24px;border-radius:100px;border:1px solid rgba(255,255,255,.1);font-size:14px;font-weight:700;color:#fff}.live-dot{width:10px;height:10px;background:#9cf5c1;border-radius:50%;position:relative;box-shadow:0 0 12px #9cf5c180}.live-dot:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:inherit;border-radius:inherit;animation:animate-ping 1.5s cubic-bezier(0,0,.2,1) infinite}@keyframes animate-ping{75%,to{transform:scale(2.5);opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animation-spin{animation:spin 1s linear infinite}.login-form-side{flex:1;display:flex;flex-direction:column;padding:40px;position:relative}.login-nav-header{display:flex;justify-content:flex-end;gap:32px;padding-bottom:40px}.login-nav-header a{font-size:14px;font-weight:700;color:var(--color-text-muted);text-decoration:none;transition:color .2s}.login-nav-header a.active{color:var(--color-primary-500)}.login-nav-header a:hover{color:var(--color-primary-700)}.login-form-container{max-width:440px;width:100%;margin:auto}.login-form-header{margin-bottom:48px}.login-form-header .headline{font-size:32px;font-weight:800;margin-bottom:8px;color:var(--color-text-primary);letter-spacing:-.5px}.login-form-header .subline{color:var(--color-text-muted);font-weight:500}.login-input-group{margin-bottom:24px}.login-input-group label{display:block;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-primary);margin-bottom:8px}.login-capsule-input{width:100%;height:56px;border-radius:100px;border:1px solid var(--color-border);background:var(--color-bg-focus);padding:0 28px;font-size:16px;color:var(--color-text-primary);transition:all .2s}.login-capsule-input::placeholder{color:var(--color-text-muted)}.login-capsule-input:focus{outline:none;border-color:var(--color-primary-600);background:#fff;box-shadow:0 0 0 4px var(--color-primary-50)}.login-forgot-pwd{float:right;font-size:12px;font-weight:700;color:var(--color-text-muted);text-decoration:none}.login-capsule-btn{width:100%;height:56px;border-radius:100px;background:linear-gradient(135deg,#005232,#006d44);color:#fff;font-family:Manrope,sans-serif;font-weight:700;font-size:18px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:12px;box-shadow:0 4px 12px #00523226}.login-capsule-btn:hover{background:#004328;transform:translateY(-2px);box-shadow:0 8px 16px #00523233}.login-capsule-btn svg{transition:transform .2s}.login-capsule-btn:hover svg{transform:translate(4px)}.login-divider{text-align:center;margin:32px 0;position:relative}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--color-border)}.login-divider span{position:relative;background:var(--color-bg-primary);padding:0 16px;font-size:11px;font-weight:800;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px}.login-social-btn{width:100%;height:56px;border-radius:100px;border:1px solid var(--color-border);background:var(--color-bg-focus);display:flex;align-items:center;justify-content:center;gap:12px;font-weight:700;cursor:pointer;transition:all .2s}.login-social-btn:hover{background:var(--color-bg-secondary);border-color:var(--color-border)}.login-demo-section{margin-top:48px;background:var(--color-bg-secondary);border-radius:24px;padding:24px}.demo-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-primary);margin-bottom:20px;display:flex;align-items:center;gap:8px}.demo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:16px;margin-top:16px}.demo-btn{background:var(--color-bg-focus);border-radius:20px;padding:20px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;border:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #00000005}.demo-btn span{font-size:24px!important;margin-bottom:4px}.demo-role-name{font-size:11px;font-weight:800;color:var(--color-text-primary);letter-spacing:.5px;text-transform:uppercase}.demo-role-desc{font-size:10px;font-weight:500;color:var(--color-text-muted)}.demo-btn:hover{background:var(--color-bg-focus);border-color:var(--color-primary-500);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.demo-btn:hover .demo-role-name{color:var(--color-primary-500)}.demo-btn:hover .demo-role-desc{color:var(--color-primary-500);opacity:.8}.login-page-footer{margin-top:auto;padding-top:40px;display:flex;justify-content:space-between;font-size:12px;font-weight:600;color:var(--color-text-muted);border-top:1px solid var(--color-border)}.login-page-footer div{display:flex;gap:24px}.login-page-footer a{color:var(--color-text-muted);text-decoration:none}.login-page-footer a:hover{color:var(--color-text-primary)}.eco-dashboard{display:flex;flex-direction:column;gap:var(--space-4)}.dash-hero{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2)}.dash-greeting{font-size:var(--text-base);color:var(--color-text-muted);margin-bottom:4px}.dash-greeting strong{color:var(--color-text-primary)}.dash-headline{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--color-text-primary);letter-spacing:-.03em;margin-bottom:2px}.dash-date{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.dash-live-indicator{display:flex;align-items:center;gap:8px;background:#006d440f;padding:8px 16px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;color:var(--color-primary-600);letter-spacing:.02em}.live-orb{width:8px;height:8px;background:var(--color-primary-100);border-radius:50%;box-shadow:0 0 8px #9cf5c199;animation:orb-pulse 2s ease-in-out infinite}@keyframes orb-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.dash-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.dash-kpi-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg-focus);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.dash-kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-icon-wrap{width:44px;height:44px;border-radius:var(--radius-md);display:grid;place-items:center;flex-shrink:0}.kpi-icon-wrap .material-symbols-outlined{font-size:22px}.kpi-data{display:flex;flex-direction:column;min-width:0}.kpi-label{font-size:var(--text-xs);font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.kpi-value{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--color-text-primary);line-height:1.1;letter-spacing:-.02em}.kpi-value small{font-size:.55em;font-weight:600;color:var(--color-text-muted)}.kpi-trend{display:flex;align-items:center;gap:4px;font-size:.6875rem;font-weight:600;margin-top:4px}.kpi-trend .material-symbols-outlined{font-size:14px!important;max-width:14px;max-height:14px}.kpi-up{color:var(--color-success)}.kpi-down{color:#e65100}.kpi-neutral{color:var(--color-text-muted)}.dash-charts-row{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-4)}.dash-chart-card{background:var(--color-bg-focus);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-3) var(--space-4);display:flex;flex-direction:column}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4)}.chart-header h4{font-family:var(--font-display);font-size:1rem;font-weight:800;margin-bottom:2px}.chart-subtitle{font-size:var(--text-xs)!important;color:var(--color-text-muted)!important;margin:0!important}.chart-legend-inline{font-size:.6875rem;color:var(--color-text-muted);display:flex;align-items:center;gap:4px;font-weight:500;flex-shrink:0}.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.chart-filter{padding:4px 10px;border-radius:var(--radius-full);border:none;background:var(--color-bg-secondary);font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-sans)}.chart-body{flex:1;min-height:180px;position:relative}.chart-body canvas{max-height:100%}.dash-bottom-row{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--space-4)}.dash-activity-card,.dash-summary-card{background:var(--color-bg-focus);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-3) var(--space-4);display:flex;flex-direction:column}.dash-see-all{font-size:var(--text-xs);font-weight:700;color:var(--color-primary-500);text-decoration:none;letter-spacing:.02em}.dash-see-all:hover{color:var(--color-primary-700)}.activity-list{display:flex;flex-direction:column}.activity-item{display:flex;align-items:center;gap:var(--space-3);padding:10px 0;border-bottom:1px solid rgba(190,201,191,.08)}.activity-item:last-child{border-bottom:none}.activity-icon{width:36px;height:36px;border-radius:var(--radius-md);display:grid;place-items:center;flex-shrink:0}.activity-icon .material-symbols-outlined{font-size:18px}.activity-info{flex:1;min-width:0}.activity-text{font-size:var(--text-base);color:var(--color-text-primary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-time{font-size:var(--text-xs);color:var(--color-text-muted)}.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-4)}.summary-item{text-align:center;padding:var(--space-3);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.summary-number{font-family:var(--font-display);font-size:1.25rem;font-weight:800;color:var(--color-text-primary);display:block;line-height:1.2}.summary-number small{font-size:.65em;color:var(--color-text-muted)}.summary-label{font-size:.6rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;display:block;margin-top:2px}@media(max-width:1024px){.dash-kpi-row{grid-template-columns:repeat(2,1fr)}.dash-charts-row,.dash-bottom-row{grid-template-columns:1fr}}@media(max-width:640px){.dash-kpi-row{grid-template-columns:1fr}.dash-hero{flex-direction:column;gap:var(--space-3)}.summary-grid{grid-template-columns:repeat(2,1fr)}}.scanner-viewport{width:100%;aspect-ratio:1 / 1;border-radius:var(--radius-xl);overflow:hidden;position:relative;background:#000;box-shadow:var(--shadow-xl)}.scanner-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60%;height:60%;border:2px solid var(--color-primary-400);border-radius:var(--radius-lg);box-shadow:0 0 0 1000px #0006}.scanner-bar{position:absolute;top:0;left:0;width:100%;height:2px;background:var(--color-primary-400);box-shadow:0 0 15px var(--color-primary-400);animation:scan 2s linear infinite}@keyframes scan{0%{top:0}to{top:100%}}
