:root{--bg: #ffffff;--surface: #ffffff;--surface-alt: #f3f6fb;--text: #0f1f34;--text-muted: #50627d;--border: #d5e0ee;--primary: #0b6f95;--primary-contrast: #e8f5fb;--accent: #f59e0b;--success: #198f67;--warning: #bf741d;--danger: #c83f3f;--shadow: 0 12px 28px rgba(11, 35, 63, .08);--radius: 16px;--radius-sm: 11px;--ring: 0 0 0 3px rgba(11, 111, 149, .2);--tone-1: #0b6f95;--tone-2: #198f67;--tone-3: #ba7100;--tone-4: #d9480f;--tone-5: #0f766e;--tone-6: #3358bc}html.dark{--bg: #0a1424;--surface: #101d33;--surface-alt: #172742;--text: #ecf2ff;--text-muted: #a5b7d3;--border: #2a4060;--primary: #3cb8ea;--primary-contrast: #0f2841;--accent: #fbbf24;--success: #38b887;--warning: #e6a336;--danger: #f17171;--shadow: 0 18px 42px rgba(2, 10, 20, .45);--ring: 0 0 0 3px rgba(60, 184, 234, .24);--tone-1: #3cb8ea;--tone-2: #43c693;--tone-3: #fbbf24;--tone-4: #f7964a;--tone-5: #2dc7b4;--tone-6: #66a6f3}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-width:320px;font-family:Manrope,Segoe UI,Noto Sans,sans-serif;background:var(--bg);color:var(--text);line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}html.dark body{background:radial-gradient(circle at 7% -8%,color-mix(in srgb,var(--accent) 12%,transparent),transparent 42%),radial-gradient(circle at 96% 0%,color-mix(in srgb,var(--primary) 13%,transparent),transparent 48%),radial-gradient(circle at 88% 96%,color-mix(in srgb,var(--success) 9%,transparent),transparent 45%),var(--bg)}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.6}input,select,textarea{color:var(--text)}a{color:inherit;text-decoration:none}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:10px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-shell{display:grid;grid-template-columns:1fr;min-height:100vh}.app-content{width:min(100%,1280px);margin:0 auto;padding:14px 14px 92px}.page-shell{display:grid;gap:16px}.page-shell>*{animation:page-enter .36s cubic-bezier(.22,1,.36,1) both}.page-shell>*:nth-child(2){animation-delay:40ms}.page-shell>*:nth-child(3){animation-delay:80ms}.page-shell>*:nth-child(4){animation-delay:.12s}.page-shell>*:nth-child(5){animation-delay:.16s}.page-shell>*:nth-child(6){animation-delay:.2s}.page-shell>*:nth-child(7){animation-delay:.24s}.page-shell>*:nth-child(8){animation-delay:.28s}.page-shell>.ui-card,.home-action-card,.list-row,.sidebar-link,.bottom-nav-item,.stat-card{--item-accent: var(--primary)}.page-shell>.ui-card:nth-of-type(6n+1),.home-action-grid>.home-action-card:nth-child(6n+1),.list-stack>.list-row:nth-child(6n+1),.sidebar-group>.sidebar-link:nth-of-type(6n+1),.bottom-nav-list>.bottom-nav-item:nth-child(6n+1),.stat-grid>.stat-card:nth-child(6n+1){--item-accent: var(--tone-1)}.page-shell>.ui-card:nth-of-type(6n+2),.home-action-grid>.home-action-card:nth-child(6n+2),.list-stack>.list-row:nth-child(6n+2),.sidebar-group>.sidebar-link:nth-of-type(6n+2),.bottom-nav-list>.bottom-nav-item:nth-child(6n+2),.stat-grid>.stat-card:nth-child(6n+2){--item-accent: var(--tone-2)}.page-shell>.ui-card:nth-of-type(6n+3),.home-action-grid>.home-action-card:nth-child(6n+3),.list-stack>.list-row:nth-child(6n+3),.sidebar-group>.sidebar-link:nth-of-type(6n+3),.bottom-nav-list>.bottom-nav-item:nth-child(6n+3),.stat-grid>.stat-card:nth-child(6n+3){--item-accent: var(--tone-3)}.page-shell>.ui-card:nth-of-type(6n+4),.home-action-grid>.home-action-card:nth-child(6n+4),.list-stack>.list-row:nth-child(6n+4),.sidebar-group>.sidebar-link:nth-of-type(6n+4),.bottom-nav-list>.bottom-nav-item:nth-child(6n+4),.stat-grid>.stat-card:nth-child(6n+4){--item-accent: var(--tone-4)}.page-shell>.ui-card:nth-of-type(6n+5),.home-action-grid>.home-action-card:nth-child(6n+5),.list-stack>.list-row:nth-child(6n+5),.sidebar-group>.sidebar-link:nth-of-type(6n+5),.bottom-nav-list>.bottom-nav-item:nth-child(6n+5),.stat-grid>.stat-card:nth-child(6n+5){--item-accent: var(--tone-5)}.page-shell>.ui-card:nth-of-type(6n),.home-action-grid>.home-action-card:nth-child(6n),.list-stack>.list-row:nth-child(6n),.sidebar-group>.sidebar-link:nth-of-type(6n),.bottom-nav-list>.bottom-nav-item:nth-child(6n),.stat-grid>.stat-card:nth-child(6n){--item-accent: var(--tone-6)}@keyframes page-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-title{margin:0;font-family:Space Grotesk,Manrope,Segoe UI,sans-serif;font-size:1.15rem;font-weight:700;letter-spacing:.01em}.page-subtitle{margin:4px 0 0;color:var(--text-muted);font-size:.9rem}.ui-card{position:relative;overflow:hidden;background:linear-gradient(156deg,color-mix(in srgb,var(--item-accent) 8%,var(--surface)),color-mix(in srgb,var(--surface) 94%,transparent));border:1px solid color-mix(in srgb,var(--item-accent) 24%,var(--border));border-radius:var(--radius);box-shadow:var(--shadow)}.ui-card:before{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--item-accent) 55%,white),transparent);pointer-events:none}.ui-card--flat{box-shadow:none}.ui-card-body{padding:15px}.ui-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:13px;border:1px solid transparent;padding:10px 12px;font-weight:600;transition:transform .14s ease,background-color .14s ease,border-color .14s ease,box-shadow .14s ease,opacity .12s ease}.ui-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px color-mix(in srgb,var(--primary) 22%,transparent)}.ui-button:active:not(:disabled){transform:translateY(0)}.ui-button--primary{background:linear-gradient(145deg,color-mix(in srgb,var(--primary) 94%,white 3%),color-mix(in srgb,var(--primary) 82%,black 8%));border-color:color-mix(in srgb,var(--primary) 55%,var(--border));color:#fff}.ui-button--secondary{background:color-mix(in srgb,var(--surface) 92%,var(--surface-alt));color:var(--text);border-color:var(--border)}.ui-button--ghost{background:color-mix(in srgb,var(--surface) 72%,transparent);color:var(--text);border-color:var(--border)}.ui-button--danger{background:linear-gradient(145deg,color-mix(in srgb,var(--danger) 88%,white 5%),color-mix(in srgb,var(--danger) 78%,black 10%));border-color:color-mix(in srgb,var(--danger) 55%,var(--border));color:#fff}.ui-button--sm{padding:8px 10px;border-radius:10px;font-size:.9rem}.ui-button--lg{padding:12px 14px}.ui-input,.ui-select,.ui-textarea{width:100%;border-radius:13px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 88%,var(--surface-alt));padding:10px 12px;color:var(--text);transition:border-color .14s ease,box-shadow .14s ease,background-color .14s ease}.ui-input:focus,.ui-select:focus,.ui-textarea:focus{border-color:color-mix(in srgb,var(--primary) 45%,var(--border));box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 20%,transparent);background:color-mix(in srgb,var(--surface) 92%,var(--surface-alt))}.ui-input::placeholder,.ui-textarea::placeholder{color:var(--text-muted)}.ui-field{display:grid;gap:6px}.ui-field-label{font-size:.85rem;color:var(--text-muted);font-weight:600}.ui-badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:700;border:1px solid transparent}.ui-badge--neutral{background:var(--surface-alt);color:var(--text-muted);border-color:var(--border)}.ui-badge--success{background:color-mix(in srgb,var(--success) 18%,transparent);color:color-mix(in srgb,var(--success) 65%,white);border-color:color-mix(in srgb,var(--success) 35%,var(--border))}.ui-badge--warning{background:color-mix(in srgb,var(--warning) 18%,transparent);color:color-mix(in srgb,var(--warning) 72%,white);border-color:color-mix(in srgb,var(--warning) 35%,var(--border))}.ui-badge--danger{background:color-mix(in srgb,var(--danger) 16%,transparent);color:color-mix(in srgb,var(--danger) 78%,white);border-color:color-mix(in srgb,var(--danger) 35%,var(--border))}.ui-tabs{display:inline-flex;gap:4px;background:color-mix(in srgb,var(--surface-alt) 90%,transparent);border:1px solid var(--border);border-radius:13px;padding:4px;flex-wrap:wrap}.ui-tab{border:0;background:transparent;color:var(--text-muted);padding:8px 10px;border-radius:9px;font-weight:600}.ui-tab.is-active{background:color-mix(in srgb,var(--surface) 94%,transparent);color:var(--text);border:1px solid color-mix(in srgb,var(--primary) 32%,var(--border))}.stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stat-card{padding:12px;display:grid;gap:6px;border:1px solid color-mix(in srgb,var(--item-accent) 24%,var(--border));border-radius:13px;background:linear-gradient(150deg,color-mix(in srgb,var(--surface) 92%,transparent),color-mix(in srgb,var(--item-accent) 12%,var(--surface-alt)))}.stat-label{font-size:.75rem;color:var(--text-muted);font-weight:600}.stat-value{font-size:1.05rem;font-weight:700;color:var(--text)}.list-stack{display:grid;gap:12px}.home-intro{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.home-shortcut-count{border:1px solid color-mix(in srgb,var(--primary) 32%,var(--border));background:color-mix(in srgb,var(--primary) 14%,transparent);color:color-mix(in srgb,var(--primary) 78%,white);border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:700}.home-action-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.home-action-card{width:100%;text-align:left;border:1px solid color-mix(in srgb,var(--item-accent) 26%,var(--border));background:linear-gradient(150deg,color-mix(in srgb,var(--item-accent) 12%,var(--surface)),color-mix(in srgb,var(--surface-alt) 58%,var(--surface)));border-radius:14px;padding:12px;display:grid;gap:10px;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,box-shadow .16s ease}.home-action-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--item-accent) 48%,var(--border));box-shadow:0 12px 24px color-mix(in srgb,var(--item-accent) 18%,transparent)}.home-action-card:active{transform:translateY(0)}.home-action-card__head{display:flex;align-items:center;justify-content:space-between}.home-action-card__icon{width:34px;height:34px;border-radius:10px;border:1px solid color-mix(in srgb,var(--item-accent) 36%,var(--border));background:color-mix(in srgb,var(--item-accent) 22%,transparent);color:color-mix(in srgb,var(--item-accent) 88%,white);display:inline-flex;align-items:center;justify-content:center}.home-action-card__arrow{color:var(--text-muted)}.home-action-card__title{font-weight:700}.home-action-card__subtitle{font-size:.82rem;color:var(--text-muted);line-height:1.4}.list-row{width:100%;text-align:left;border:1px solid color-mix(in srgb,var(--item-accent) 22%,var(--border));border-left-width:3px;background:linear-gradient(145deg,color-mix(in srgb,var(--item-accent) 10%,var(--surface)),color-mix(in srgb,var(--surface) 94%,transparent));border-radius:12px;padding:12px;display:flex;justify-content:space-between;gap:10px;align-items:center;transition:transform .14s ease,background-color .14s ease,border-color .14s ease,box-shadow .14s ease}.list-row--stacked{flex-direction:column;align-items:stretch}.list-row-main{display:flex;justify-content:space-between;gap:10px;align-items:center;width:100%}.list-row-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;width:100%}.list-row-actions .ui-row-actions{width:100%}.list-row:hover{background:linear-gradient(145deg,color-mix(in srgb,var(--item-accent) 14%,var(--surface)),color-mix(in srgb,var(--surface-alt) 68%,var(--surface)));transform:translateY(-1px);border-color:color-mix(in srgb,var(--item-accent) 38%,var(--border));box-shadow:0 8px 20px color-mix(in srgb,var(--item-accent) 14%,transparent)}.list-row:active{transform:scale(.995)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}.page-header-main{display:grid;gap:2px}.inline-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.section-grid{display:grid;gap:16px}.control-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.table-wrap{width:100%;overflow-x:auto;border-radius:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 86%,transparent)}.ui-table{width:100%;border-collapse:collapse;min-width:720px;background:color-mix(in srgb,var(--surface) 95%,transparent)}.ui-table th,.ui-table td{text-align:left;padding:10px;border-top:1px solid var(--border);vertical-align:top;color:var(--text)}.ui-table th{border-top:0;background:color-mix(in srgb,var(--surface-alt) 85%,transparent);color:var(--text-muted);font-size:.75rem;white-space:nowrap}.mobile-cards{display:grid;gap:12px}.hide-mobile{display:none}.empty-state{display:grid;place-items:center;text-align:center;gap:8px;padding:18px;color:var(--text-muted);border:1px dashed color-mix(in srgb,var(--primary) 25%,var(--border));border-radius:14px;background:color-mix(in srgb,var(--surface-alt) 62%,transparent)}.toast-region{position:fixed;right:12px;left:12px;top:12px;z-index:60;display:grid;gap:8px;pointer-events:none}.toast{pointer-events:auto;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 90%,transparent);border-radius:12px;padding:10px 12px;box-shadow:var(--shadow);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;animation:toast-in .22s cubic-bezier(.2,.9,.2,1)}@keyframes toast-in{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.toast--success{border-color:color-mix(in srgb,var(--success) 35%,var(--border))}.toast--error{border-color:color-mix(in srgb,var(--danger) 35%,var(--border))}.toast--warning{border-color:color-mix(in srgb,var(--warning) 35%,var(--border))}.toast-title{font-weight:700;font-size:.9rem}.toast-message{color:var(--text-muted);font-size:.85rem}.skeleton{position:relative;overflow:hidden;background:color-mix(in srgb,var(--surface-alt) 85%,var(--surface));border-radius:10px}.skeleton:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);animation:shimmer 1.2s infinite}html.dark .skeleton:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}@keyframes shimmer{to{transform:translate(100%)}}.app-topbar{position:sticky;top:0;z-index:40;border-bottom:1px solid var(--border);background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 90%,transparent),color-mix(in srgb,var(--surface-alt) 65%,transparent));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 14px color-mix(in srgb,var(--primary) 7%,transparent)}.app-topbar-inner{width:100%;margin:0;padding:6px max(8px,env(safe-area-inset-right)) 6px max(8px,env(safe-area-inset-left));display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px}.topbar-start{display:flex;align-items:center;gap:6px;flex:0 1 auto;min-width:0;justify-self:start}.topbar-start>.topbar-brand{margin-left:2px}.mobile-menu-toggle,.topbar-back-button{min-width:32px;min-height:32px}.topbar-page-meta{min-width:0}.app-topbar-title{margin:0;font-family:Space Grotesk,Manrope,Segoe UI,sans-serif;font-size:.94rem;font-weight:700;letter-spacing:.01em}.app-topbar-subtitle{margin:2px 0 0;font-size:.7rem;color:var(--text-muted)}.topbar-search-shell{display:none;min-width:0}.topbar-search{display:flex;align-items:center;gap:8px;border-radius:16px;border:1px solid color-mix(in srgb,var(--primary) 16%,var(--border));background:linear-gradient(145deg,color-mix(in srgb,var(--surface) 94%,transparent),color-mix(in srgb,var(--surface-alt) 82%,transparent));padding:7px 12px;box-shadow:inset 0 1px #ffffff5c,0 8px 20px color-mix(in srgb,var(--primary) 9%,transparent);transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.topbar-search svg{color:var(--text-muted);flex:0 0 auto}.topbar-search.is-active{border-color:color-mix(in srgb,var(--primary) 34%,var(--border));box-shadow:inset 0 1px #ffffff73,0 14px 28px color-mix(in srgb,var(--primary) 14%,transparent)}.topbar-search-input{width:100%;min-width:0;border:0;padding:0;background:transparent;color:var(--text);outline:0}.topbar-search-input::placeholder{color:color-mix(in srgb,var(--text-muted) 72%,transparent)}.topbar-search-shortcut{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:48px;padding:4px 8px;border-radius:999px;border:1px solid color-mix(in srgb,var(--primary) 14%,var(--border));background:color-mix(in srgb,var(--surface-alt) 78%,transparent);color:var(--text-muted);font-size:.72rem;font-weight:700;letter-spacing:.02em}.topbar-search-panel{position:absolute;top:calc(100% + 10px);left:0;right:0;z-index:60;display:grid;gap:6px;padding:10px;border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));border-radius:18px;background:color-mix(in srgb,var(--surface) 96%,transparent);box-shadow:0 18px 40px #020c1c2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-search-result{width:100%;border:1px solid transparent;border-radius:14px;background:color-mix(in srgb,var(--surface-alt) 52%,transparent);padding:10px;text-align:left;display:flex;align-items:center;gap:10px;color:var(--text);transition:transform .14s ease,border-color .14s ease,background-color .14s ease}.topbar-search-result:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--primary) 24%,var(--border));background:color-mix(in srgb,var(--primary) 10%,transparent)}.topbar-search-result__icon{width:36px;height:36px;flex:0 0 auto;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--primary) 14%,transparent);color:color-mix(in srgb,var(--primary) 76%,white)}.topbar-search-result__content{min-width:0;display:grid;gap:2px}.topbar-search-result__content strong,.topbar-search-result__content small{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-search-result__content strong{font-size:.92rem}.topbar-search-result__content small{color:var(--text-muted);font-size:.78rem}.topbar-search-empty{padding:10px 12px;border-radius:14px;background:color-mix(in srgb,var(--surface-alt) 56%,transparent);color:var(--text-muted);font-size:.84rem}.topbar-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto;justify-self:end}.topbar-theme-dropdown{position:relative}.topbar-theme-dropdown .theme-dropdown__trigger--icon{border-color:color-mix(in srgb,var(--primary) 16%,var(--border));background:linear-gradient(145deg,color-mix(in srgb,var(--surface) 96%,transparent),color-mix(in srgb,var(--surface-alt) 84%,transparent));box-shadow:0 8px 20px color-mix(in srgb,var(--primary) 9%,transparent)}.topbar-theme-dropdown .theme-dropdown__panel{margin-top:2px}.topbar-icon-button{position:relative;min-width:36px;min-height:36px;border-radius:14px;border-color:color-mix(in srgb,var(--primary) 16%,var(--border));background:linear-gradient(145deg,color-mix(in srgb,var(--surface) 96%,transparent),color-mix(in srgb,var(--surface-alt) 84%,transparent));box-shadow:0 8px 20px color-mix(in srgb,var(--primary) 9%,transparent)}.topbar-icon-button.is-active{border-color:color-mix(in srgb,var(--primary) 28%,var(--border));background:color-mix(in srgb,var(--primary) 14%,transparent)}.topbar-icon-indicator{position:absolute;top:7px;right:7px;width:8px;height:8px;border-radius:999px;background:var(--accent);border:2px solid var(--surface)}.topbar-profile-wrap{position:relative}.topbar-profile{min-width:0;max-width:min(72vw,280px);border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));border-radius:16px;background:linear-gradient(145deg,color-mix(in srgb,var(--surface) 96%,transparent),color-mix(in srgb,var(--surface-alt) 86%,transparent));padding:4px;display:flex;align-items:center;gap:8px;box-shadow:0 8px 22px color-mix(in srgb,var(--primary) 9%,transparent);transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.topbar-profile:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--primary) 28%,var(--border));box-shadow:0 16px 32px color-mix(in srgb,var(--primary) 14%,transparent)}.topbar-profile-avatar{width:34px;height:34px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;background:linear-gradient(145deg,color-mix(in srgb,var(--primary) 82%,white 8%),color-mix(in srgb,var(--accent) 70%,var(--primary)));color:#fff;font-size:.78rem;font-weight:800;letter-spacing:.03em}.topbar-profile-copy{min-width:0;display:none}.topbar-profile-name,.topbar-profile-meta{display:block;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-profile-name{color:var(--text);font-size:.88rem;font-weight:800}.topbar-profile-meta{margin-top:1px;color:var(--text-muted);font-size:.72rem}.topbar-brand{display:inline-flex;align-items:center;gap:7px;flex:0 1 auto;min-width:0;padding:4px 8px 4px 4px;border:1px solid color-mix(in srgb,var(--primary) 16%,var(--border));border-radius:14px;background:color-mix(in srgb,var(--surface) 90%,transparent);box-shadow:0 6px 18px color-mix(in srgb,var(--primary) 8%,transparent)}.topbar-brand__icon{width:30px;height:30px;display:block;flex:0 0 auto}.topbar-brand__name{display:block;width:126px;white-space:normal;text-wrap:balance;color:var(--text);font-size:.76rem;font-weight:800;letter-spacing:.01em;line-height:1.08}.topbar-profile-menu{position:absolute;top:calc(100% + 10px);right:0;z-index:60;width:min(92vw,340px);display:grid;gap:4px;padding:8px;border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));border-radius:18px;background:color-mix(in srgb,var(--surface) 96%,transparent);box-shadow:0 18px 40px #020c1c2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-profile-menu__item{width:100%;border:1px solid transparent;border-radius:12px;background:color-mix(in srgb,var(--surface-alt) 56%,transparent);padding:10px 12px;text-align:left;color:var(--text);font-weight:600;transition:transform .14s ease,border-color .14s ease,background-color .14s ease}.topbar-profile-menu__item:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--primary) 22%,var(--border));background:color-mix(in srgb,var(--primary) 10%,transparent)}.topbar-profile-menu__item.is-danger{color:var(--danger)}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:45;padding:8px 10px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:linear-gradient(180deg,color-mix(in srgb,var(--surface-alt) 56%,transparent),color-mix(in srgb,var(--surface) 92%,transparent));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.bottom-nav-list{width:min(100%,720px);margin:0 auto;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.bottom-nav-item{border:1px solid color-mix(in srgb,var(--item-accent) 16%,var(--border));background:linear-gradient(150deg,color-mix(in srgb,var(--item-accent) 10%,transparent),color-mix(in srgb,var(--surface) 70%,transparent));border-radius:12px;padding:9px 4px;color:var(--text-muted);display:grid;justify-items:center;gap:3px;font-size:.72rem;font-weight:600;transition:transform .14s ease,border-color .14s ease,background-color .14s ease}.bottom-nav-item:hover{transform:translateY(-1px)}.bottom-nav-item.is-active{background:color-mix(in srgb,var(--item-accent) 18%,transparent);border-color:color-mix(in srgb,var(--item-accent) 36%,var(--border));box-shadow:0 8px 16px color-mix(in srgb,var(--item-accent) 14%,transparent);color:var(--text)}.sidebar{position:fixed;inset:0;z-index:55;pointer-events:none}.sidebar-scrim{position:absolute;inset:0;border:0;padding:0;margin:0;opacity:0;pointer-events:none;background:#040f1e75;transition:opacity .16s ease}.sidebar-panel{position:absolute;top:0;left:0;bottom:0;width:min(86vw,326px);max-width:100%;padding:12px 10px calc(96px + env(safe-area-inset-bottom));overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-padding-bottom:120px;display:flex;flex-direction:column;gap:12px;transform:translate(-105%);transition:transform .18s cubic-bezier(.2,.9,.2,1);background:linear-gradient(180deg,color-mix(in srgb,var(--bg) 76%,var(--surface)),color-mix(in srgb,var(--surface) 84%,transparent));box-shadow:0 16px 30px #02081447;isolation:isolate}.sidebar-panel:before{content:"";position:absolute;inset:0 0 auto;height:180px;background:radial-gradient(circle at 12% 0%,color-mix(in srgb,var(--primary) 18%,transparent),transparent 58%),linear-gradient(180deg,color-mix(in srgb,white 6%,transparent),transparent 72%);pointer-events:none;z-index:0}.sidebar.is-open{pointer-events:auto}.sidebar.is-open .sidebar-scrim{opacity:1;pointer-events:auto}.sidebar.is-open .sidebar-panel{transform:translate(0)}.mobile-menu-open .bottom-nav{display:none;opacity:0;transform:translateY(120%);pointer-events:none}.sidebar-panel>.sidebar-group{--group-accent: var(--primary)}.sidebar-panel>.sidebar-group:nth-child(6n+1){--group-accent: var(--tone-1)}.sidebar-panel>.sidebar-group:nth-child(6n+2){--group-accent: var(--tone-2)}.sidebar-panel>.sidebar-group:nth-child(6n+3){--group-accent: var(--tone-3)}.sidebar-panel>.sidebar-group:nth-child(6n+4){--group-accent: var(--tone-4)}.sidebar-panel>.sidebar-group:nth-child(6n+5){--group-accent: var(--tone-5)}.sidebar-panel>.sidebar-group:nth-child(6n){--group-accent: var(--tone-6)}.sidebar-group{display:flex;flex-direction:column;flex:0 0 auto;min-height:fit-content;gap:4px;position:relative;overflow:visible;border:0;background:transparent;border-radius:0;padding:0;box-shadow:none}.sidebar-panel>.sidebar-group+.sidebar-group{margin-top:2px;padding-top:14px;border-top:1px solid color-mix(in srgb,var(--border) 92%,transparent)}.sidebar-group--collapsible.is-section-active{border-color:color-mix(in srgb,var(--group-accent) 34%,var(--border))}.sidebar-group-toggle{width:100%;appearance:none;border:0;border-radius:0;background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:auto;padding:0 8px 8px;cursor:pointer;transition:background-color .14s ease,color .14s ease}.sidebar-group-toggle:hover,.sidebar-group-toggle.is-active,.sidebar-group-toggle.is-expanded{color:var(--text)}.sidebar-group-toggle-icon{color:var(--text-muted);flex:0 0 auto;transition:transform .16s ease,color .16s ease}.sidebar-group-toggle-icon.is-expanded{transform:rotate(90deg);color:var(--text)}.sidebar-group--collapsible .sidebar-subnav .sidebar-link{position:relative;border:0;border-left:0;border-radius:10px;min-height:42px;padding:10px 36px 10px 12px;background:transparent;color:var(--text);box-shadow:none}.sidebar-group--collapsible .sidebar-subnav .sidebar-link+.sidebar-link{box-shadow:inset 0 1px color-mix(in srgb,var(--group-accent) 12%,var(--border))}.sidebar-group--collapsible .sidebar-subnav .sidebar-link:before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:999px;background:color-mix(in srgb,var(--group-accent) 62%,white);opacity:0;transform:scaleY(.4);transition:opacity .14s ease,transform .14s ease}.sidebar-group--collapsible .sidebar-subnav .sidebar-link:hover{transform:none;background:color-mix(in srgb,var(--group-accent) 9%,transparent);color:var(--text)}.sidebar-group--collapsible .sidebar-subnav .sidebar-link.is-active{background:color-mix(in srgb,var(--group-accent) 13%,transparent);color:var(--text)}.sidebar-group-title{display:flex;align-items:center;gap:10px;width:100%;padding:0;color:currentColor;font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.sidebar-group-title:after{content:"";flex:1 1 auto;height:1px;background:linear-gradient(90deg,color-mix(in srgb,currentColor 18%,transparent),transparent);opacity:.65}.sidebar-group:before{display:none}.sidebar-link{width:100%;text-align:left;border:1px solid transparent;border-left-width:0;background:transparent;padding:10px 12px;border-radius:12px;color:var(--text-muted);display:flex;align-items:center;justify-content:flex-start;gap:8px;min-height:44px;height:auto;font-weight:600;transition:transform .14s ease,border-color .14s ease,background-color .14s ease,color .14s ease}.sidebar-link>span{min-width:0;flex:1 1 auto}.sidebar-link-content{display:flex;align-items:center;gap:12px;min-width:0;width:100%}.sidebar-link-icon{width:26px;height:26px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;color:color-mix(in srgb,var(--item-accent) 72%,var(--text));background:transparent;border:1px solid transparent;box-shadow:none;transition:background-color .14s ease,border-color .14s ease,color .14s ease}.sidebar-link-label{display:block;min-width:0;white-space:normal;word-break:break-word;overflow-wrap:anywhere;line-height:1.24;letter-spacing:-.01em}.sidebar-link:hover{transform:none;border-color:color-mix(in srgb,var(--item-accent) 14%,transparent);background:color-mix(in srgb,var(--item-accent) 8%,transparent);color:var(--text)}.sidebar-link.is-active{background:color-mix(in srgb,var(--item-accent) 14%,transparent);border-color:color-mix(in srgb,var(--item-accent) 28%,transparent);box-shadow:none;color:var(--text)}.sidebar-link:hover .sidebar-link-icon,.sidebar-link.is-active .sidebar-link-icon{color:var(--text);border-color:color-mix(in srgb,var(--item-accent) 20%,transparent);background:color-mix(in srgb,var(--item-accent) 12%,transparent)}.sidebar-group--collapsible .sidebar-subnav .sidebar-link .sidebar-link-icon{width:24px;height:24px;border-radius:7px;background:transparent;border-color:transparent;box-shadow:none;color:color-mix(in srgb,var(--group-accent) 70%,var(--text))}.sidebar-group .ui-button--danger{background:color-mix(in srgb,var(--danger) 10%,transparent);border-color:color-mix(in srgb,var(--danger) 20%,transparent);color:color-mix(in srgb,var(--danger) 78%,var(--text))}.sidebar-version{margin-top:auto;padding:18px 8px 0;display:flex;align-items:center;min-height:42px;border-top:1px solid color-mix(in srgb,var(--border) 88%,transparent)}.sidebar-version__label{display:inline-flex;align-items:center;gap:8px;color:var(--text-muted);font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.sidebar-version__label:before{content:"";width:7px;height:7px;border-radius:999px;background:color-mix(in srgb,var(--primary) 72%,white);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 12%,transparent)}.modal-backdrop{position:fixed;inset:0;background:#0206178c;display:grid;align-items:end;z-index:70;padding:12px}.modal-panel{width:min(100%,560px);margin:0 auto;background:color-mix(in srgb,var(--surface) 96%,transparent);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:12px;max-height:calc(100vh - 24px);display:flex;flex-direction:column;overflow:hidden}.modal-panel--full{width:min(100%,980px);max-height:calc(100vh - 24px)}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}.modal-body{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden}.modal-footer{margin-top:12px;justify-content:flex-end;flex-shrink:0}.epsi-school-picker{display:grid;gap:10px}.epsi-school-picker__toolbar{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center}.epsi-school-picker__selected{min-height:34px;border:1px solid color-mix(in srgb,var(--primary) 22%,var(--border));border-radius:12px;padding:8px 10px;color:var(--text-muted);background:color-mix(in srgb,var(--surface-alt) 72%,transparent);font-size:.88rem}.epsi-school-picker__list{display:grid;gap:8px;max-height:min(34vh,300px);overflow-y:auto;padding:4px;border:1px solid color-mix(in srgb,var(--primary) 24%,var(--border));border-radius:16px;background:color-mix(in srgb,var(--surface-alt) 58%,transparent)}.epsi-school-picker__empty{padding:18px 12px;color:var(--text-muted);text-align:center}.epsi-school-option{width:100%;border:1px solid color-mix(in srgb,var(--border) 80%,transparent);border-radius:14px;padding:10px;display:grid;grid-template-columns:28px minmax(0,1fr);gap:10px;align-items:center;color:var(--text);background:color-mix(in srgb,var(--surface) 82%,transparent);text-align:left;cursor:pointer}.epsi-school-option:hover{border-color:color-mix(in srgb,var(--primary) 42%,var(--border));background:color-mix(in srgb,var(--primary) 9%,var(--surface))}.epsi-school-option.is-selected{border-color:color-mix(in srgb,var(--success) 48%,var(--primary));background:color-mix(in srgb,var(--success) 12%,var(--surface))}.epsi-school-option__check{width:26px;height:26px;border-radius:8px;border:1px solid color-mix(in srgb,var(--primary) 32%,var(--border));display:inline-flex;align-items:center;justify-content:center;color:#fff;background:color-mix(in srgb,var(--surface-alt) 70%,transparent);font-weight:800}.epsi-school-option.is-selected .epsi-school-option__check{border-color:color-mix(in srgb,var(--success) 70%,var(--primary));background:color-mix(in srgb,var(--success) 78%,var(--primary))}.epsi-school-option__text{min-width:0;display:grid;gap:3px}.epsi-school-option__text strong,.epsi-school-option__text span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.epsi-school-option__text span{color:var(--text-muted);font-size:.82rem}@media(max-width:640px){.epsi-school-picker__toolbar{grid-template-columns:minmax(0,1fr)}}.toggle{position:relative;display:inline-flex;align-items:center;gap:10px;min-height:28px}.ui-toggle{appearance:none;-webkit-appearance:none;border:0;background:transparent;margin:0;padding:0;display:inline-flex;align-items:center;justify-content:center;width:46px;height:28px;border-radius:999px;cursor:pointer;flex:0 0 auto}.ui-toggle:disabled{cursor:not-allowed;opacity:.6}.ui-toggle:focus-visible{outline:2px solid color-mix(in srgb,var(--primary) 65%,white);outline-offset:2px}.ui-toggle-track{width:44px;height:24px;border-radius:999px;border:1px solid var(--border);background:var(--surface-alt);position:relative;transition:background-color .16s ease,border-color .16s ease}.ui-toggle[data-on=true] .ui-toggle-track{background:color-mix(in srgb,var(--primary) 35%,var(--surface-alt));border-color:color-mix(in srgb,var(--primary) 40%,var(--border))}.ui-toggle-thumb{position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:999px;background:#fff;box-shadow:0 1px 3px #02061747;transition:transform .16s ease}.ui-toggle[data-on=true] .ui-toggle-thumb{transform:translate(20px)}.sticky-footer{position:sticky;bottom:74px;z-index:20;background:color-mix(in srgb,var(--surface) 84%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:14px;padding:10px}.attendance-student{border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;gap:10px}.attendance-student.is-present{border-color:color-mix(in srgb,var(--success) 35%,var(--border));background:color-mix(in srgb,var(--success) 10%,var(--surface))}.attendance-student.is-absent{border-color:color-mix(in srgb,var(--danger) 25%,var(--border));background:color-mix(in srgb,var(--danger) 6%,var(--surface))}.kbd{border:1px solid var(--border);background:var(--surface-alt);border-radius:8px;padding:2px 6px;font-size:.75rem;color:var(--text-muted)}.camera-preview{width:100%;aspect-ratio:4 / 3;min-height:220px;object-fit:cover;border-radius:14px;background:#0b1220;border:1px solid var(--border);display:block;transform:translateZ(0);backface-visibility:hidden}.camera-preview--mirror{transform:translateZ(0) scaleX(-1)}.camera-placeholder{min-height:220px;border-radius:14px;border:1px dashed var(--border);background:color-mix(in srgb,var(--surface-alt) 75%,transparent);color:var(--text-muted);display:grid;place-items:center;text-align:center;padding:16px}.ocr-camera-grid{display:grid;gap:12px}.ocr-camera-stage{display:grid;gap:10px}.scan-progress-bar{margin-top:8px;height:8px;border-radius:999px;background:color-mix(in srgb,var(--surface-alt) 80%,transparent);overflow:hidden;border:1px solid var(--border)}.scan-progress-bar__fill{height:100%;background:linear-gradient(90deg,color-mix(in srgb,var(--primary) 88%,white 5%),color-mix(in srgb,var(--success) 75%,white 8%));transition:width .14s ease}.ocr-raw-text{white-space:pre-wrap;word-break:break-word;font-size:12px;line-height:1.45;color:var(--text-muted);margin:10px 0 0;padding:10px;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface-alt) 70%,transparent)}.ocr-edit-list{display:grid;gap:10px}.ocr-edit-card{border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:10px;display:grid;gap:8px}.ocr-summary-list{display:grid;gap:8px}.ocr-summary-item{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:10px;display:grid;gap:4px}.face-enroll-stage{display:grid;gap:12px}.face-camera-frame{position:relative}.face-oval-guide{position:absolute;inset:8% 20%;border-radius:50%/46%;border:2px dashed rgba(255,255,255,.8);box-shadow:0 0 0 9999px #0f172a3d,inset 0 0 0 1px #ffffff40;pointer-events:none}@media(max-width:720px){.face-oval-guide{box-shadow:inset 0 0 0 1px #ffffff40}.face-enroll-stage{gap:10px}.face-enroll-stage .section-grid{gap:12px}.face-enroll-stage .inline-actions{gap:8px}.camera-preview{min-height:180px}}.face-scan-backdrop{padding:0}.face-scan-modal-panel{width:100%;max-width:100%;height:100vh;max-height:100vh;border-radius:0;border-left:0;border-right:0;display:grid;gap:12px}.face-scan-layout{display:grid;gap:12px}.face-scan-camera-shell{position:relative}.face-grid-overlay{position:absolute;inset:8px;border-radius:14px;pointer-events:none;border:1px solid rgba(255,255,255,.22);background-image:linear-gradient(to right,rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.08) 1px,transparent 1px);background-size:20px 20px;mix-blend-mode:screen}.face-detected-list{display:grid;gap:8px}.face-detected-row{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:10px}.face-detected-row.is-accepted{border-color:color-mix(in srgb,var(--success) 35%,var(--border));background:color-mix(in srgb,var(--success) 8%,var(--surface))}.face-detected-row.is-rejected{border-color:color-mix(in srgb,var(--warning) 35%,var(--border));background:color-mix(in srgb,var(--warning) 8%,var(--surface))}@media(min-width:768px){.toast-region{left:auto;width:360px}.mobile-menu-toggle{display:none}.app-shell{grid-template-columns:260px 1fr;min-height:calc(100vh - 68px)}.sidebar{position:static;inset:auto;z-index:auto;pointer-events:auto;align-self:stretch;min-height:calc(100vh - 68px);padding:0}.sidebar-scrim{display:none}.sidebar-panel{position:sticky;top:68px;left:auto;bottom:auto;width:100%;height:calc(100vh - 68px);max-height:calc(100vh - 68px);padding:12px 10px 16px 12px;overflow-x:visible;overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable;display:flex;flex-direction:column;transform:none;transition:none;background:linear-gradient(180deg,color-mix(in srgb,var(--bg) 76%,var(--surface)),color-mix(in srgb,var(--surface) 84%,transparent));box-shadow:none}.app-content{padding:14px 16px 24px}.app-topbar-inner{padding:8px max(10px,env(safe-area-inset-right)) 8px max(10px,env(safe-area-inset-left));gap:10px}.topbar-page-meta{display:none}.topbar-search-shell{position:relative;display:block;width:min(100%,560px);max-width:560px;min-width:240px;justify-self:center}.topbar-profile{padding:4px 8px 4px 4px}.topbar-profile-avatar{width:32px;height:32px}.topbar-profile-copy{display:block}.topbar-brand__icon{width:34px;height:34px}.topbar-brand__name{width:140px;font-size:.8rem}.bottom-nav{display:none}.sticky-footer{bottom:12px}.hide-mobile{display:initial}.mobile-cards{display:none}.modal-backdrop{align-items:center}.face-scan-modal-panel{width:min(100%,980px);height:calc(100vh - 24px);max-height:calc(100vh - 24px);border:1px solid var(--border);border-radius:18px}.ocr-camera-grid{grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);align-items:start}.face-enroll-stage{grid-template-columns:minmax(0,1.05fr) minmax(280px,.95fr);align-items:start}}@media(min-width:960px){.stat-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.topbar-notification-wrap{position:relative}.topbar-notification-count{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(145deg,color-mix(in srgb,var(--accent) 88%,white 8%),color-mix(in srgb,var(--danger) 76%,var(--accent)));color:#fff;border:2px solid var(--surface);font-size:.68rem;font-weight:800;letter-spacing:.01em;box-shadow:0 10px 18px color-mix(in srgb,var(--danger) 18%,transparent)}.topbar-notification-menu{position:absolute;top:calc(100% + 10px);right:0;z-index:60;width:min(92vw,390px);display:grid;gap:12px;padding:12px;border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));border-radius:20px;background:color-mix(in srgb,var(--surface) 96%,transparent);box-shadow:0 24px 48px #020c1c2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-notification-menu__head,.topbar-notification-menu__footer,.notification-page-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.topbar-notification-menu__head strong{display:block;color:var(--text);font-size:.96rem}.topbar-notification-menu__head small{color:var(--text-muted);font-size:.76rem}.notification-list{display:grid;gap:10px}.notification-list.is-compact{gap:8px}.notification-entry{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:flex-start;padding:12px;border-radius:16px;border:1px solid color-mix(in srgb,var(--primary) 12%,var(--border));background:linear-gradient(155deg,color-mix(in srgb,var(--surface-alt) 78%,transparent),color-mix(in srgb,var(--surface) 94%,transparent))}.notification-entry.is-unread{border-color:color-mix(in srgb,var(--primary) 28%,var(--border));box-shadow:0 12px 24px color-mix(in srgb,var(--primary) 10%,transparent)}.notification-entry__main{width:100%;display:grid;gap:8px;padding:0;border:0;background:transparent;text-align:left;color:inherit}.notification-entry__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.notification-entry__time{color:var(--text-muted);font-size:.76rem;font-weight:600}.notification-entry__title{display:flex;align-items:center;gap:8px;color:var(--text);font-size:.92rem;line-height:1.35}.notification-entry__body{color:var(--text-muted);font-size:.84rem;line-height:1.45}.notification-entry__unread-dot{width:9px;height:9px;border-radius:999px;flex:0 0 auto;background:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 18%,transparent)}.notification-entry__mark{align-self:center;white-space:nowrap}.notification-empty,.notification-error{display:grid;gap:4px;justify-items:start;padding:16px;border-radius:16px;border:1px dashed color-mix(in srgb,var(--primary) 18%,var(--border));background:color-mix(in srgb,var(--surface-alt) 74%,transparent)}.notification-empty strong,.notification-error{color:var(--text)}.notification-empty span{color:var(--text-muted);font-size:.84rem}.notification-error{color:var(--danger);font-size:.84rem}.notification-page-card{max-width:980px}.notification-page-footer{margin-top:14px;padding-top:14px;border-top:1px solid color-mix(in srgb,var(--primary) 10%,var(--border))}@media(max-width:720px){.topbar-notification-menu{right:-10px;width:min(96vw,360px)}.notification-entry{grid-template-columns:1fr}.notification-entry__mark{justify-self:start}}:root{--primary: #1f5ca8;--primary-contrast: #ecf2ff;--surface-alt: #f6f8fc;--shadow: 0 2px 10px rgba(15, 23, 42, .06);--ring: 0 0 0 3px rgba(31, 92, 168, .18);--topbar-bg-start: #e8eff9;--topbar-bg-end: #dae6f6;--topbar-border: #c4d5ea;--topbar-title: #163252;--topbar-subtitle: #4e6787;--sidebar-panel-bg-start: #e7eff9;--sidebar-panel-bg-end: #dce8f5;--sidebar-panel-border: #b8cbe2;--sidebar-group-bg: #f8fbff;--sidebar-group-border: #c8d8ec;--sidebar-link-bg: #edf4fc;--sidebar-link-hover: #e0ecfa;--sidebar-link-active: #d2e4fb;--sidebar-text: #1d3553;--sidebar-muted: #607a99}html.dark{--bg: #101826;--surface: #162236;--surface-alt: #1e2d45;--text: #e8eef8;--text-muted: #a7b3c5;--border: #314762;--primary: #74a6f7;--primary-contrast: #0f213f;--shadow: 0 6px 18px rgba(1, 8, 20, .36);--ring: 0 0 0 3px rgba(116, 166, 247, .22);--topbar-bg-start: #132843;--topbar-bg-end: #10233a;--topbar-border: #2c4769;--topbar-title: #edf4ff;--topbar-subtitle: #b6c8e2;--sidebar-panel-bg-start: #0f223a;--sidebar-panel-bg-end: #122844;--sidebar-panel-border: #2c486b;--sidebar-group-bg: #162e4c;--sidebar-group-border: #335579;--sidebar-link-bg: #1d3a5f;--sidebar-link-hover: #24446c;--sidebar-link-active: #2b5282;--sidebar-text: #edf4ff;--sidebar-muted: #acc0d9}body,html.dark body{background:var(--bg)}.page-shell>.ui-card,.home-action-card,.list-row,.sidebar-link,.bottom-nav-item,.stat-card{--item-accent: var(--primary) !important}.sidebar-panel>.sidebar-group,.sidebar-group{--group-accent: var(--primary) !important}.page-title{font-family:Manrope,Segoe UI,Noto Sans,sans-serif;font-size:clamp(1.2rem,1.05rem + .55vw,1.55rem);line-height:1.2;letter-spacing:0}.app-topbar-title{font-family:Manrope,Segoe UI,Noto Sans,sans-serif;letter-spacing:0}.page-subtitle{font-size:.92rem;line-height:1.5;color:var(--text-muted)}.page-header-title-row{flex-wrap:wrap}.page-header-actions{margin-left:auto}.page-header-actions>.inline-actions{justify-content:flex-end}.page-header-actions .ui-button--primary{min-width:128px}.stat-label{font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;font-weight:700}.stat-value{font-size:clamp(1.2rem,1rem + .35vw,1.45rem);line-height:1.2}.ui-field-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;font-weight:700}.ui-badge{font-size:.73rem;letter-spacing:.02em}.ui-card,.stat-card,.home-action-card,.list-row,.sidebar-group,.bottom-nav-item,.table-wrap,.ui-table,.toast,.modal-panel,.sticky-footer,.ocr-edit-card,.ocr-summary-item,.face-detected-row,.attendance-student{background:var(--surface);border-color:var(--border);box-shadow:var(--shadow)}.ui-card:before,.sidebar-group:before{display:none}.app-topbar{background:linear-gradient(180deg,var(--topbar-bg-start),var(--topbar-bg-end));border-bottom:1px solid var(--topbar-border);-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:0 1px color-mix(in srgb,var(--topbar-border) 58%,transparent)}.app-topbar-title{color:var(--topbar-title)}.app-topbar-subtitle{color:var(--topbar-subtitle)}.bottom-nav{background:var(--surface);-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none}.bottom-nav{border-top:1px solid var(--border)}.sidebar-panel{background:linear-gradient(180deg,var(--sidebar-panel-bg-start),var(--sidebar-panel-bg-end));border:1px solid var(--sidebar-panel-border);box-shadow:0 14px 28px #172a4629;isolation:isolate}.sidebar-panel:before{content:"";position:absolute;inset:0 0 auto;height:180px;background:radial-gradient(circle at 12% 0%,color-mix(in srgb,var(--primary) 18%,transparent),transparent 58%),linear-gradient(180deg,color-mix(in srgb,white 7%,transparent),transparent 72%);pointer-events:none;z-index:0}.sidebar-panel>*{position:relative;z-index:1}.ui-button:hover:not(:disabled),.home-action-card:hover,.list-row:hover,.bottom-nav-item:hover,.sidebar-link:hover{transform:none}.ui-button:hover:not(:disabled),.home-action-card:hover,.list-row:hover,.bottom-nav-item:hover{box-shadow:var(--shadow)}.ui-button--primary{background:var(--primary);border-color:var(--primary);color:var(--primary-contrast)}.ui-button--secondary,.ui-button--ghost{background:var(--surface-alt);border-color:var(--border)}.ui-button--danger{background:var(--danger);border-color:var(--danger);color:#fff}.ui-badge--success{background:color-mix(in srgb,var(--success) 16%,var(--surface));border-color:color-mix(in srgb,var(--success) 36%,var(--border));color:color-mix(in srgb,var(--success) 78%,black 12%)}.ui-badge--warning{background:color-mix(in srgb,var(--warning) 16%,var(--surface));border-color:color-mix(in srgb,var(--warning) 36%,var(--border));color:color-mix(in srgb,var(--warning) 78%,black 12%)}.ui-badge--danger{background:color-mix(in srgb,var(--danger) 14%,var(--surface));border-color:color-mix(in srgb,var(--danger) 36%,var(--border));color:color-mix(in srgb,var(--danger) 76%,black 12%)}html.dark .ui-badge--success{color:color-mix(in srgb,var(--success) 80%,white 20%)}html.dark .ui-badge--warning{color:color-mix(in srgb,var(--warning) 82%,white 18%)}html.dark .ui-badge--danger{color:color-mix(in srgb,var(--danger) 80%,white 20%)}.home-action-card,.list-row,.stat-card,.bottom-nav-item,.sidebar-group{background:var(--surface)}.home-action-card:hover,.list-row:hover{border-color:color-mix(in srgb,var(--primary) 34%,var(--border));background:var(--surface-alt)}.principal-analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.principal-analytics-card{min-height:100%}.principal-analytics-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.principal-analytics-card__title{margin:0;font-size:1rem;line-height:1.3}.principal-analytics-card__meta{font-size:.74rem;color:var(--text-muted);white-space:nowrap}.principal-segment-bar{display:flex;width:100%;height:10px;border-radius:999px;overflow:hidden;background:var(--surface-alt);margin-top:8px}.principal-segment-bar__segment{min-width:0}.principal-segment-bar__segment.is-primary{background:color-mix(in srgb,var(--primary) 78%,white 4%)}.principal-segment-bar__segment.is-success{background:color-mix(in srgb,var(--success) 82%,white 5%)}.principal-segment-bar__segment.is-warning{background:color-mix(in srgb,var(--warning) 84%,white 5%)}.principal-segment-bar__segment.is-danger{background:color-mix(in srgb,var(--danger) 84%,white 4%)}.principal-segment-bar__segment.is-neutral{background:color-mix(in srgb,var(--text-muted) 78%,white 6%)}.principal-segment-legend{display:grid;gap:6px;margin:8px 0 12px}.principal-segment-legend__item{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:.79rem}.principal-segment-legend__item strong{margin-left:auto;color:var(--text)}.principal-segment-legend__dot{width:8px;height:8px;border-radius:999px;flex:0 0 auto}.principal-segment-legend__dot.is-primary{background:color-mix(in srgb,var(--primary) 82%,white 3%)}.principal-segment-legend__dot.is-success{background:color-mix(in srgb,var(--success) 86%,white 4%)}.principal-segment-legend__dot.is-warning{background:color-mix(in srgb,var(--warning) 86%,white 3%)}.principal-segment-legend__dot.is-danger{background:color-mix(in srgb,var(--danger) 86%,white 3%)}.principal-segment-legend__dot.is-neutral{background:color-mix(in srgb,var(--text-muted) 84%,white 6%)}.principal-group-bars{display:grid;gap:8px}.principal-group-bars__row{display:grid;grid-template-columns:minmax(90px,1fr) minmax(0,3fr) auto;gap:8px;align-items:center;font-size:.78rem}.principal-group-bars__label{color:var(--text-muted)}.principal-group-bars__track{height:8px;border-radius:999px;background:var(--surface-alt);overflow:hidden}.principal-group-bars__fill{height:100%;border-radius:inherit;background:color-mix(in srgb,var(--primary) 80%,white 5%)}.principal-group-bars__value{color:var(--text);font-weight:700}.principal-risk-list{display:grid;gap:8px;margin-top:4px}.principal-risk-row{border:1px solid var(--border);border-radius:12px;background:var(--surface-alt);padding:8px;display:grid;gap:6px}.principal-risk-row__head{display:flex;align-items:center;justify-content:space-between;gap:8px}.principal-risk-row__name{font-size:.86rem;font-weight:700}.principal-risk-row__meta{display:flex;justify-content:space-between;gap:8px;color:var(--text-muted);font-size:.74rem}.principal-risk-row__bar-wrap{height:7px;border-radius:999px;overflow:hidden;background:color-mix(in srgb,var(--danger) 12%,var(--surface))}.principal-risk-row__bar{height:100%;border-radius:inherit;background:linear-gradient(90deg,color-mix(in srgb,var(--danger) 84%,white 4%),color-mix(in srgb,var(--warning) 78%,white 5%))}.principal-insights-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.principal-insight-item{border:1px solid var(--border);border-radius:12px;background:var(--surface-alt);padding:10px;display:grid;gap:4px}.principal-insight-item__label{color:var(--text-muted);font-size:.75rem;line-height:1.3}.principal-insight-item__value{color:var(--text);font-size:1.05rem;font-weight:800}.principal-insight-item__hint{color:var(--text-muted);font-size:.73rem;line-height:1.3}.dashboard-page-shell{background:var(--dashboard-page-bg);border-radius:16px;padding:12px}.principal-v3-shell{display:grid;gap:14px}.principal-metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.principal-metric-tile{border:1px solid color-mix(in srgb,var(--primary) 24%,var(--border));border-radius:14px;background:linear-gradient(150deg,color-mix(in srgb,var(--primary) 7%,var(--surface)),color-mix(in srgb,var(--surface) 94%,transparent));padding:12px 14px;display:grid;gap:10px;min-height:128px}.dashboard-page-shell .principal-metric-tile{background:var(--dashboard-metric-bg);background-image:none;border-color:var(--dashboard-metric-border);box-shadow:0 8px 18px color-mix(in srgb,var(--primary) 10%,transparent)}.principal-metric-tile__head{display:grid;grid-template-columns:minmax(0,1fr) 132px;gap:10px;align-items:end}.principal-metric-tile__meta{display:grid;gap:4px}.principal-metric-tile__icon{width:30px;height:30px;border-radius:999px;border:1px solid var(--border);background:var(--surface-alt);display:inline-flex;align-items:center;justify-content:center}.principal-metric-tile__icon.is-primary{color:color-mix(in srgb,var(--primary) 88%,white 4%);background:color-mix(in srgb,var(--primary) 14%,var(--surface));border-color:color-mix(in srgb,var(--primary) 32%,var(--border))}.principal-metric-tile__icon.is-success{color:color-mix(in srgb,var(--success) 88%,white 4%);background:color-mix(in srgb,var(--success) 14%,var(--surface));border-color:color-mix(in srgb,var(--success) 32%,var(--border))}.principal-metric-tile__icon.is-warning{color:color-mix(in srgb,var(--warning) 88%,white 4%);background:color-mix(in srgb,var(--warning) 14%,var(--surface));border-color:color-mix(in srgb,var(--warning) 32%,var(--border))}.principal-metric-tile__icon.is-danger{color:color-mix(in srgb,var(--danger) 88%,white 4%);background:color-mix(in srgb,var(--danger) 14%,var(--surface));border-color:color-mix(in srgb,var(--danger) 32%,var(--border))}.principal-metric-tile__icon.is-neutral{color:var(--text-muted);background:color-mix(in srgb,var(--text-muted) 12%,var(--surface));border-color:color-mix(in srgb,var(--text-muted) 26%,var(--border))}.principal-metric-tile__footer{display:flex;justify-content:space-between;gap:10px;align-items:end}.principal-metric-tile__footer-label{font-size:.79rem;color:var(--text-muted)}.principal-metric-tile__change{display:grid;gap:2px;text-align:right;font-size:.76rem}.principal-metric-tile__change strong{font-size:.95rem;line-height:1.05}.principal-metric-tile__change small{color:var(--text-muted);font-size:.71rem}.principal-metric-tile__change.is-positive strong{color:var(--success)}.principal-metric-tile__change.is-negative strong{color:var(--danger)}.principal-metric-tile__change.is-neutral strong{color:var(--text)}html.dark .principal-metric-tile__change.is-neutral strong{color:color-mix(in srgb,var(--warning) 84%,white 10%)}.principal-metric-tile__label{font-size:.78rem;color:var(--text-muted);line-height:1.25}.principal-metric-tile__value{font-size:1.75rem;line-height:1.1;font-weight:800;color:var(--text)}.principal-sparkline{width:132px;height:52px;justify-self:end;align-self:end}.principal-chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:12px}.principal-chart-card{min-height:100%}.principal-donut-pair{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.principal-donut-block{display:grid;gap:10px;justify-items:center}.principal-donut{width:132px;height:132px;border-radius:999px;position:relative;border:1px solid color-mix(in srgb,var(--text-muted) 20%,var(--border));display:grid;place-items:center}.principal-donut__inner{width:82px;height:82px;border-radius:999px;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;text-align:center;padding:4px}.principal-donut__inner strong{font-size:1.05rem;line-height:1.05;color:var(--text)}.principal-donut__inner span{font-size:.67rem;color:var(--text-muted)}.principal-monthly-chart{display:grid;gap:8px}.principal-monthly-chart svg{width:100%;height:192px;overflow:visible}.principal-monthly-chart__canvas{position:relative}.principal-monthly-chart__grid-line{stroke:var(--chart-grid);stroke-width:1;stroke-dasharray:4 6}.principal-monthly-chart__axis-line{stroke:var(--chart-axis);stroke-width:1.1}.principal-monthly-chart__y-label{fill:var(--chart-label);font-size:8.6px;font-weight:600}.principal-monthly-chart__line{fill:none;stroke-linecap:round;stroke-linejoin:round}.principal-monthly-chart__line--attendance{stroke:var(--chart-line-attendance);stroke-width:2.35;filter:drop-shadow(0 0 2px color-mix(in srgb,var(--chart-line-attendance) 28%,transparent))}.principal-monthly-chart__line--coverage{stroke:var(--chart-line-coverage);stroke-width:2.25;stroke-dasharray:5 6;filter:drop-shadow(0 0 2px color-mix(in srgb,var(--chart-line-coverage) 30%,transparent))}.principal-monthly-chart__hover-line{stroke:var(--chart-hover-line);stroke-width:1.1;stroke-dasharray:4 4}.principal-monthly-chart__hover-dot{stroke:var(--surface);stroke-width:2.6;filter:drop-shadow(0 0 6px color-mix(in srgb,currentColor 48%,transparent))}.principal-monthly-chart__hover-dot--attendance{fill:color-mix(in srgb,var(--chart-line-attendance) 84%,white 16%);color:var(--chart-line-attendance)}.principal-monthly-chart__hover-dot--coverage{fill:color-mix(in srgb,var(--chart-line-coverage) 84%,white 16%);color:var(--chart-line-coverage)}.principal-monthly-chart__hover-dot-glow{fill:none;stroke-width:3;opacity:.9}.principal-monthly-chart__hover-dot-glow--attendance{stroke:color-mix(in srgb,var(--chart-line-attendance) 58%,white 12%)}.principal-monthly-chart__hover-dot-glow--coverage{stroke:color-mix(in srgb,var(--chart-line-coverage) 58%,white 12%)}.principal-monthly-chart__tooltip{position:absolute;top:0;transform:none;min-width:164px;border-radius:10px;border:1px solid var(--chart-tooltip-border);background:var(--chart-tooltip-bg);box-shadow:var(--chart-tooltip-shadow);padding:8px 10px;z-index:3;pointer-events:none;transition:left 80ms linear,top 80ms linear}.principal-monthly-chart__tooltip-title{font-size:.77rem;color:var(--text);font-weight:700;margin-bottom:6px}.principal-monthly-chart__tooltip-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:7px;font-size:.74rem;color:var(--text-muted)}.principal-monthly-chart__tooltip-row strong{color:var(--text);font-size:.75rem}.principal-monthly-chart__tooltip-dot{width:8px;height:8px;border-radius:999px;display:inline-block}.principal-monthly-chart__tooltip-dot.is-attendance{background:var(--chart-line-attendance)}.principal-monthly-chart__tooltip-dot.is-coverage{background:var(--chart-line-coverage)}.principal-monthly-chart__labels{position:relative;height:16px;color:var(--text-muted);font-size:.72rem}.principal-monthly-chart__labels span{position:absolute;transform:translate(-50%);white-space:nowrap}.principal-monthly-chart__active-label{position:absolute;top:0;transform:translate(-50%);white-space:nowrap;font-size:.71rem;color:var(--text);background:color-mix(in srgb,var(--surface) 96%,transparent);border:1px solid color-mix(in srgb,var(--chart-axis) 68%,transparent);border-radius:6px;padding:2px 7px;box-shadow:0 4px 10px color-mix(in srgb,var(--chart-axis) 22%,transparent)}.principal-monthly-chart__hint{color:var(--text-muted);font-size:.72rem}.principal-inline-legend{display:flex;align-items:center;gap:12px;flex-wrap:wrap;color:var(--text-muted);font-size:.76rem}.principal-inline-legend span{display:inline-flex;align-items:center;gap:6px}.principal-inline-legend i{width:10px;height:10px;border-radius:999px;display:inline-block}.home-accordion-stack{display:grid;gap:12px}.home-accordion{border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:var(--shadow);overflow:hidden}.home-accordion-summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px}.home-accordion-summary::-webkit-details-marker{display:none}.home-accordion-summary__main{min-width:0;display:grid;gap:2px}.home-accordion-summary__title{font-weight:800;color:var(--text);line-height:1.25}.home-accordion-summary__subtitle{color:var(--text-muted);font-size:.78rem;line-height:1.35}.home-accordion-summary__meta{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto}.home-accordion-chevron{color:var(--text-muted);transition:transform .14s ease}.home-accordion[open] .home-accordion-chevron{transform:rotate(90deg)}.home-accordion-content{border-top:1px solid var(--border);padding:12px}.home-accordion-content .home-action-grid{gap:12px}.zone-dashboard-shell{position:relative}.zone-dashboard-shell:before{content:"";position:absolute;inset:0 0 auto;height:240px;pointer-events:none;background:radial-gradient(circle at top left,color-mix(in srgb,var(--primary) 16%,transparent),transparent 42%),radial-gradient(circle at top right,color-mix(in srgb,var(--accent) 12%,transparent),transparent 38%);opacity:.9}.zone-dashboard-shell>*{position:relative;z-index:1}.zone-dashboard-hero{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.zone-summary-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.zone-dashboard-control-card,.zone-dashboard-panel,.zone-summary-card{transition:transform .14s ease,box-shadow .16s ease,border-color .16s ease}.zone-dashboard-control-card:hover,.zone-dashboard-panel:hover,.zone-summary-card:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--primary) 28%,var(--border));box-shadow:0 18px 30px #02061729}.zone-dashboard-shell .home-accordion-stack{gap:10px}.zone-dashboard-shell .home-accordion{border-radius:16px;border-color:color-mix(in srgb,var(--primary) 16%,var(--border));box-shadow:0 14px 26px #02061721}.zone-dashboard-shell .home-accordion-summary{padding:11px 12px}.zone-dashboard-shell .home-accordion-content{padding:10px 12px 12px}.zone-dashboard-shell .home-action-grid{gap:10px}.zone-dashboard-shell .home-action-card{border-radius:14px;min-height:150px}.zone-dashboard-shell .home-action-card__subtitle{line-height:1.45}@media(max-width:1500px){.zone-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:860px){.zone-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.zone-summary-grid{grid-template-columns:minmax(0,1fr)}}.sidebar-link{background:transparent;border-color:transparent;color:var(--sidebar-text)}.sidebar-group-title{display:flex;align-items:center;gap:10px;width:100%;padding:4px 0;color:var(--sidebar-muted);font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.sidebar-group-title:after{content:"";flex:1 1 auto;height:1px;background:linear-gradient(90deg,color-mix(in srgb,currentColor 18%,transparent),transparent);opacity:.72}.sidebar-group--collapsible{gap:0;padding:0;overflow:hidden}.sidebar-group--collapsible.is-section-active{border-color:transparent!important}.sidebar-group-toggle{appearance:none;width:100%;border:0;border-radius:0;background:transparent;display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:auto;padding:0 8px 8px;cursor:pointer;color:var(--sidebar-text);transition:background-color .14s ease,color .14s ease}.sidebar-group-toggle:hover,.sidebar-group-toggle.is-active,.sidebar-group-toggle.is-expanded{background:transparent}.sidebar-group-toggle-icon{color:var(--sidebar-muted);transition:transform .16s ease,color .16s ease}.sidebar-group-toggle-icon.is-expanded{transform:rotate(90deg);color:var(--sidebar-text)}.sidebar-group-body{display:block;margin-top:0;padding:0;border-top:0;background:none}.sidebar-subnav{display:grid;gap:2px;width:100%}.sidebar-subnav--main{gap:4px}.sidebar-group-heading{padding:0 8px 8px}.sidebar-group--collapsible .sidebar-subnav .sidebar-link{position:relative;border:0;border-left:0;border-radius:10px;min-height:42px;padding:10px 36px 10px 12px;background:transparent;color:var(--sidebar-text);box-shadow:none}.sidebar-group--collapsible .sidebar-subnav .sidebar-link+.sidebar-link{box-shadow:inset 0 1px color-mix(in srgb,var(--primary) 12%,var(--sidebar-group-border))}.sidebar-group--collapsible .sidebar-subnav .sidebar-link:before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:999px;background:color-mix(in srgb,var(--primary) 72%,white);opacity:0;transform:scaleY(.4);transition:opacity .14s ease,transform .14s ease}.sidebar-group--collapsible .sidebar-subnav .sidebar-link:after{display:none}.sidebar-group--collapsible .sidebar-subnav .sidebar-link:hover{transform:none;border-color:transparent;background:color-mix(in srgb,var(--primary) 8%,transparent)}.sidebar-group--collapsible .sidebar-subnav .sidebar-link:hover:before,.sidebar-group--collapsible .sidebar-subnav .sidebar-link.is-active:before{opacity:1;transform:scaleY(1)}.sidebar-group--collapsible .sidebar-subnav .sidebar-link.is-active{background:color-mix(in srgb,var(--primary) 14%,transparent);border-color:transparent}.sidebar-group--collapsible .sidebar-subnav .sidebar-link-content{align-items:center;gap:10px}.sidebar-link-content{align-items:center;gap:12px}.sidebar-link-icon{width:26px;height:26px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;color:color-mix(in srgb,var(--primary) 72%,var(--sidebar-text));background:transparent;border:1px solid transparent;box-shadow:none;transition:background-color .14s ease,border-color .14s ease,color .14s ease}.sidebar-link-icon>svg{display:block}.sidebar-link-label{letter-spacing:-.01em}.sidebar-link:hover .sidebar-link-icon,.sidebar-link.is-active .sidebar-link-icon{color:var(--sidebar-text);border-color:color-mix(in srgb,var(--primary) 20%,transparent);background:color-mix(in srgb,var(--primary) 12%,transparent)}.sidebar-group--collapsible .sidebar-subnav .sidebar-link .sidebar-link-icon{width:24px;height:24px;border-radius:7px;background:transparent;border-color:transparent;box-shadow:none;color:color-mix(in srgb,var(--primary) 72%,var(--sidebar-text))}.sidebar-link:hover{border-color:color-mix(in srgb,var(--primary) 12%,transparent);background:color-mix(in srgb,var(--primary) 8%,transparent)}.sidebar-link.is-active{background:color-mix(in srgb,var(--primary) 14%,transparent);border-color:color-mix(in srgb,var(--primary) 28%,transparent);box-shadow:none}.sidebar-group{background:transparent!important;border-color:transparent!important;border-radius:0!important;padding:0!important;box-shadow:none!important}html.dark .sidebar-group{box-shadow:none!important}.sidebar-panel>.sidebar-group+.sidebar-group{margin-top:2px;padding-top:14px;border-top:1px solid color-mix(in srgb,var(--sidebar-group-border) 82%,transparent)}.sidebar-group .ui-button{width:100%;justify-content:flex-start;min-height:44px;border-radius:12px}.sidebar-group .ui-button--danger{background:color-mix(in srgb,var(--danger) 10%,transparent);border-color:color-mix(in srgb,var(--danger) 20%,transparent);color:color-mix(in srgb,var(--danger) 78%,var(--sidebar-text))}.sidebar-group .ui-button--danger:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 14%,transparent);border-color:color-mix(in srgb,var(--danger) 28%,transparent);box-shadow:none}.sidebar-version{border-top:1px solid color-mix(in srgb,var(--sidebar-group-border) 82%,transparent)}.sidebar-version__label{color:color-mix(in srgb,var(--sidebar-muted) 92%,var(--sidebar-text))}.sidebar-version__label:before{background:color-mix(in srgb,var(--primary) 76%,white);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 14%,transparent)}.table-wrap{overflow:auto;max-height:min(68vh,760px)}.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;padding:8px 10px;border-bottom:1px solid var(--border);background:var(--surface)}.table-toolbar-meta{display:inline-flex;align-items:center;gap:8px}.ui-table{border-collapse:separate;border-spacing:0}.ui-table th,.ui-table td{padding:11px 12px}.ui-table th{position:sticky;top:0;z-index:2;background:var(--surface-alt);color:var(--text-muted);box-shadow:inset 0 -1px 0 var(--border)}.ui-table td{background:var(--surface)}.ui-table tbody tr:nth-child(2n) td{background:color-mix(in srgb,var(--surface-alt) 52%,var(--surface))}.ui-table tbody tr:hover td{background:color-mix(in srgb,var(--primary) 6%,var(--surface))}.ui-table .ui-table-head.is-right,.ui-table .ui-table-cell.is-right{text-align:right}.ui-table .ui-table-head.is-center,.ui-table .ui-table-cell.is-center{text-align:center}.ui-table .ui-table-head.is-nowrap,.ui-table .ui-table-cell.is-nowrap{white-space:nowrap}.ui-table .ui-table-cell.is-numeric{font-variant-numeric:tabular-nums}.ui-table .ui-table-head.is-sticky-left,.ui-table .ui-table-cell.is-sticky-left{position:sticky;left:0;z-index:1}.ui-table .ui-table-head.is-sticky-right,.ui-table .ui-table-cell.is-sticky-right{position:sticky;right:0;z-index:1}.ui-table .ui-table-head.is-sticky-left,.ui-table .ui-table-head.is-sticky-right{z-index:4}.ui-table .ui-table-cell.is-sticky-left,.ui-table .ui-table-cell.is-sticky-right{box-shadow:inset -1px 0 color-mix(in srgb,var(--border) 72%,transparent)}.ui-table .ui-table-head.is-sticky-right,.ui-table .ui-table-cell.is-sticky-right{box-shadow:inset 1px 0 color-mix(in srgb,var(--border) 72%,transparent)}.ui-table-sort-button{width:100%;display:inline-flex;align-items:center;justify-content:space-between;gap:8px;border:0;margin:0;padding:0;background:transparent;color:inherit;font:inherit;font-weight:700;text-align:inherit}.ui-table-sort-indicator{color:var(--text-muted);font-size:.75rem;min-width:12px;text-align:center}.ui-table-sort-indicator.is-asc,.ui-table-sort-indicator.is-desc{color:var(--primary)}.ui-row-actions{display:inline-block}.ui-row-actions-trigger{list-style:none;cursor:pointer;border:1px solid var(--border);border-radius:10px;padding:6px 10px;font-size:.8rem;font-weight:700;color:var(--text-muted);background:var(--surface-alt);-webkit-user-select:none;user-select:none}.ui-row-actions-trigger::-webkit-details-marker{display:none}.ui-row-actions[open] .ui-row-actions-trigger{border-color:color-mix(in srgb,var(--primary) 40%,var(--border));color:var(--text)}.ui-row-actions-panel{margin-top:8px}.ui-row-actions-panel .inline-actions{justify-content:flex-end}.table-wrap.is-compact .ui-table th,.table-wrap.is-compact .ui-table td{padding:8px 10px;font-size:.84rem}.ui-toggle-track{background:var(--surface-alt)}.modal-panel,.sticky-footer{-webkit-backdrop-filter:none;backdrop-filter:none}.zone-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);gap:12px;align-items:stretch;margin-bottom:12px}.zone-detail-panel{height:clamp(420px,40vh,520px);display:flex;flex-direction:column}.zone-detail-scroll,.zone-detail-panel .zone-school-report-wrap{flex:1 1 auto;min-height:0}.zone-detail-scroll{overflow-y:auto}.zone-school-report-wrap{max-height:320px;overflow-x:hidden;overflow-y:auto}.zone-detail-panel .zone-school-report-wrap{max-height:none}.zone-school-report-table{width:100%;table-layout:fixed}.zone-school-report-th,.zone-school-report-td{overflow-wrap:anywhere}.zone-school-report-th:not(:first-child),.zone-school-report-td:not(:first-child){text-align:center}.zone-dashboard-shell .zone-school-report-row{transition:background-color .14s ease}.zone-dashboard-shell .zone-school-report-row.is-clickable{cursor:pointer}.zone-dashboard-shell .zone-school-report-row:hover{background:color-mix(in srgb,var(--primary) 8%,transparent)}.zone-dashboard-shell .zone-school-report-row.is-clickable:focus-visible{outline:none;box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--primary) 34%,var(--border))}@media(max-width:640px){.zone-school-report-wrap{max-height:none;overflow:visible}.zone-school-report-head{display:none}.zone-school-report-table,.zone-school-report-table tbody,.zone-school-report-row,.zone-school-report-empty-row{display:block;width:100%}.zone-school-report-row{border-top:1px solid var(--border);padding:8px 0}.zone-school-report-td{display:grid!important;grid-template-columns:96px minmax(0,1fr);gap:10px;width:100%;padding:8px 0!important;text-align:left!important}.zone-school-report-td:before{content:attr(data-label);font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.zone-school-report-empty{display:block;width:100%;padding:12px 0!important}.zone-school-report-empty:before{content:none}.principal-metric-grid,.principal-metric-tile__head{grid-template-columns:1fr}.principal-sparkline{justify-self:start}.principal-donut-pair{grid-template-columns:1fr}.principal-donut{width:124px;height:124px}.principal-donut__inner{width:78px;height:78px}.principal-insights-grid{grid-template-columns:1fr}.home-accordion-summary{align-items:flex-start;flex-wrap:wrap}.home-accordion-summary__meta{width:100%;justify-content:space-between}}@media(max-width:920px){.zone-detail-grid{grid-template-columns:1fr}.zone-detail-panel{height:auto}.zone-detail-scroll,.zone-detail-panel .zone-school-report-wrap{max-height:360px}}@media(min-width:768px){.sidebar{background:linear-gradient(180deg,var(--sidebar-panel-bg-start),var(--sidebar-panel-bg-end));border-right:1px solid var(--sidebar-panel-border)}.principal-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.principal-chart-card--wide{grid-column:span 2}.sidebar-panel{background:linear-gradient(180deg,var(--sidebar-panel-bg-start),var(--sidebar-panel-bg-end));border:0;box-shadow:none}}@media(min-width:1200px){.principal-metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}html[data-theme=light] .app-layout-root{--bg: color-mix(in srgb, var(--primary) 7%, #eef6ff);--surface: color-mix(in srgb, white 94%, var(--primary) 3%);--surface-alt: color-mix(in srgb, #edf5ff 90%, var(--primary) 6%);--text: #0f1f34;--text-muted: #5b708f;--border: color-mix(in srgb, var(--primary) 22%, #d5e3f3);--shadow: 0 24px 60px color-mix(in srgb, var(--primary) 10%, rgba(10, 24, 46, .12))}html[data-theme=dark] .app-layout-root{--bg: #081423;--surface: color-mix(in srgb, #101d32 88%, var(--primary) 12%);--surface-alt: color-mix(in srgb, #172743 88%, var(--primary) 10%);--text: #edf4ff;--text-muted: #aebdd1;--border: color-mix(in srgb, var(--primary) 24%, #2b4162);--shadow: 0 28px 68px rgba(2, 8, 20, .34)}.app-layout-root{min-height:100vh;position:relative;isolation:isolate;overflow-x:clip;background:radial-gradient(circle at 8% 4%,color-mix(in srgb,var(--primary) 17%,transparent),transparent 27%),radial-gradient(circle at 92% 12%,color-mix(in srgb,var(--accent) 13%,transparent),transparent 24%),radial-gradient(circle at 76% 92%,color-mix(in srgb,var(--primary) 9%,transparent),transparent 30%),linear-gradient(180deg,var(--login-bg-top),var(--login-bg-bottom))}html[data-theme=dark] .app-layout-root{background:radial-gradient(circle at 8% 4%,color-mix(in srgb,var(--primary) 18%,transparent),transparent 28%),radial-gradient(circle at 92% 12%,color-mix(in srgb,var(--accent) 10%,transparent),transparent 24%),radial-gradient(circle at 72% 100%,color-mix(in srgb,var(--primary) 9%,transparent),transparent 34%),linear-gradient(180deg,color-mix(in srgb,var(--primary) 13%,#10233d),#071321 72%)}.app-layout-root:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(color-mix(in srgb,var(--text-muted) 12%,transparent) 1px,transparent 1px),linear-gradient(90deg,color-mix(in srgb,var(--text-muted) 12%,transparent) 1px,transparent 1px);background-size:32px 32px;mask-image:linear-gradient(180deg,rgba(0,0,0,.62),transparent 88%);-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.62),transparent 88%)}.app-layout-root .app-shell,.app-layout-root .bottom-nav{position:relative;z-index:1}.app-layout-root .app-topbar{border-bottom:1px solid color-mix(in srgb,var(--primary) 26%,transparent);background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 86%,transparent),color-mix(in srgb,var(--surface-alt) 74%,transparent));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 18px 44px color-mix(in srgb,var(--primary) 10%,transparent)}html[data-theme=dark] .app-layout-root .app-topbar{background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 84%,transparent),color-mix(in srgb,#071321 24%,var(--surface) 76%))}.app-layout-root .topbar-brand,.app-layout-root .topbar-profile,.app-layout-root .topbar-icon-button,.app-layout-root .topbar-theme-dropdown .theme-dropdown__trigger--icon,.app-layout-root .topbar-search{border-color:color-mix(in srgb,var(--primary) 22%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 94%,transparent),color-mix(in srgb,var(--theme-hero-surface) 64%,var(--surface)));box-shadow:inset 0 1px color-mix(in srgb,white 22%,transparent),0 12px 28px color-mix(in srgb,var(--primary) 10%,transparent)}.app-layout-root .topbar-search.is-active,.app-layout-root .topbar-profile:hover,.app-layout-root .topbar-icon-button:hover,.app-layout-root .topbar-icon-button.is-active{border-color:color-mix(in srgb,var(--primary) 38%,var(--border));background:color-mix(in srgb,var(--primary) 10%,var(--surface))}.app-layout-root .theme-dropdown__panel,.login-screen .theme-dropdown__panel{color:var(--text);background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 98%,transparent),color-mix(in srgb,var(--surface-alt) 78%,var(--surface)))}.app-layout-root select option,.login-screen select option,.theme-dropdown__panel select option{color:var(--text);background:var(--surface)}html[data-theme=light] .app-layout-root select option,html[data-theme=light] .login-screen select option,html[data-theme=light] .theme-dropdown__panel select option{color:#0f1f34;background:#fff}html[data-theme=dark] .app-layout-root select option,html[data-theme=dark] .login-screen select option,html[data-theme=dark] .theme-dropdown__panel select option{color:#edf4ff;background:#12233c}.app-layout-root .page-shell{gap:18px}.app-layout-root .page-header{border:1px solid color-mix(in srgb,var(--primary) 20%,var(--border));border-radius:26px;padding:18px;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 94%,transparent),color-mix(in srgb,var(--theme-hero-surface) 48%,var(--surface)));box-shadow:0 24px 54px color-mix(in srgb,var(--primary) 9%,transparent)}.app-layout-root .page-title{font-family:Space Grotesk,Manrope,Segoe UI,sans-serif;font-size:clamp(1.32rem,1.08rem + .7vw,1.9rem);font-weight:800;letter-spacing:-.035em}.app-layout-root .page-subtitle{color:color-mix(in srgb,var(--text-muted) 92%,var(--text))}.app-layout-root .dashboard-page-shell{border:1px solid color-mix(in srgb,var(--primary) 14%,var(--border));border-radius:28px;padding:16px;background:radial-gradient(circle at 4% 0%,color-mix(in srgb,var(--primary) 9%,transparent),transparent 34%),color-mix(in srgb,var(--surface) 76%,transparent);box-shadow:0 28px 70px color-mix(in srgb,var(--primary) 9%,transparent)}.app-layout-root .ui-card,.app-layout-root .stat-card,.app-layout-root .home-action-card,.app-layout-root .list-row,.app-layout-root .table-wrap,.app-layout-root .modal-panel,.app-layout-root .sticky-footer,.app-layout-root .zone-dashboard-panel,.app-layout-root .zone-summary-card{border-color:color-mix(in srgb,var(--primary) 20%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 95%,transparent),color-mix(in srgb,var(--theme-hero-surface) 38%,var(--surface)));box-shadow:0 20px 45px color-mix(in srgb,var(--primary) 8%,transparent)}.app-layout-root .stat-card,.app-layout-root .home-action-card,.app-layout-root .list-row{border-radius:18px}.app-layout-root .ui-card{border-radius:22px}.app-layout-root .ui-card:before{display:block;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--primary) 38%,white),transparent);opacity:.72}.app-layout-root .ui-input,.app-layout-root .ui-select,.app-layout-root .ui-textarea,.app-layout-root input:not([type=checkbox]):not([type=radio]):not([type=file]),.app-layout-root select,.app-layout-root textarea{border-color:color-mix(in srgb,var(--primary) 20%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 88%,transparent),color-mix(in srgb,var(--surface-alt) 72%,var(--surface)))}.app-layout-root .ui-input:focus,.app-layout-root .ui-select:focus,.app-layout-root .ui-textarea:focus,.app-layout-root input:not([type=checkbox]):not([type=radio]):not([type=file]):focus,.app-layout-root select:focus,.app-layout-root textarea:focus{border-color:color-mix(in srgb,var(--primary) 46%,var(--border));box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 20%,transparent)}.app-layout-root .ui-table th,.app-layout-root .zone-school-report-head tr{background:color-mix(in srgb,var(--primary) 9%,var(--surface-alt))!important}.app-layout-root .ui-table td{background:color-mix(in srgb,var(--surface) 92%,transparent)}.app-layout-root .ui-table tbody tr:nth-child(2n) td{background:color-mix(in srgb,var(--surface-alt) 46%,var(--surface))}.app-layout-root .ui-table tbody tr:hover td{background:color-mix(in srgb,var(--primary) 8%,var(--surface))}.app-layout-root .bottom-nav{border-top-color:color-mix(in srgb,var(--primary) 18%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 92%,transparent),color-mix(in srgb,var(--surface-alt) 82%,transparent));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 -16px 42px color-mix(in srgb,var(--primary) 9%,transparent)}html[data-theme=light] .app-layout-root .sidebar-panel{--text: #17314d;--text-muted: #5d7694;--border: color-mix(in srgb, #7da4d3 22%, transparent);--surface: color-mix(in srgb, white 58%, transparent);--surface-alt: color-mix(in srgb, white 74%, transparent);--sidebar-text: #17314d;--sidebar-muted: #5d7694;--sidebar-panel-border: #bfd4ec;--sidebar-group-border: color-mix(in srgb, #7da4d3 26%, transparent);color:var(--sidebar-text);background:linear-gradient(180deg,#eef6ff,#d9eafe)!important;border-color:var(--sidebar-panel-border);box-shadow:0 18px 30px #668ab82e}html[data-theme=light] .app-layout-root .sidebar-panel:before{display:none}html[data-theme=light] .app-layout-root .sidebar-group-title{color:#17314d;text-shadow:none}html[data-theme=light] .app-layout-root .sidebar-panel>.sidebar-group+.sidebar-group,html[data-theme=light] .app-layout-root .sidebar-version{border-color:color-mix(in srgb,#7da4d3 26%,transparent)}html[data-theme=light] .app-layout-root .sidebar-group-title:after{background:linear-gradient(90deg,color-mix(in srgb,#7da4d3 34%,transparent),transparent)}html[data-theme=light] .app-layout-root .sidebar-link,html[data-theme=light] .app-layout-root .sidebar-group-toggle{color:#17314d;text-shadow:none}html[data-theme=light] .app-layout-root .sidebar-link:hover,html[data-theme=light] .app-layout-root .sidebar-link.is-active,html[data-theme=light] .app-layout-root .sidebar-group-toggle:hover,html[data-theme=light] .app-layout-root .sidebar-group-toggle.is-active,html[data-theme=light] .app-layout-root .sidebar-group-toggle.is-expanded{color:#0f2741}html[data-theme=light] .app-layout-root .sidebar-link.is-active{background:color-mix(in srgb,white 54%,transparent);border-color:color-mix(in srgb,#7da4d3 36%,transparent)}html[data-theme=light] .app-layout-root .sidebar-link:hover{background:color-mix(in srgb,white 34%,transparent)}html[data-theme=light] .app-layout-root .sidebar-link-icon,html[data-theme=light] .app-layout-root .sidebar-group--collapsible .sidebar-subnav .sidebar-link .sidebar-link-icon{color:color-mix(in srgb,var(--primary) 76%,#17314d)}html[data-theme=light] .app-layout-root .sidebar-link:hover .sidebar-link-icon,html[data-theme=light] .app-layout-root .sidebar-link.is-active .sidebar-link-icon{color:#0f2741;background:color-mix(in srgb,white 44%,transparent);border-color:color-mix(in srgb,#7da4d3 28%,transparent)}html[data-theme=light] .app-layout-root .sidebar-version__label{color:#35516f}html[data-theme=dark] .app-layout-root .sidebar-panel{--text: #f5fbff;--text-muted: color-mix(in srgb, white 84%, transparent);--border: color-mix(in srgb, white 18%, transparent);--surface: color-mix(in srgb, white 10%, transparent);--surface-alt: color-mix(in srgb, white 14%, transparent);--sidebar-text: #f5fbff;--sidebar-muted: color-mix(in srgb, white 84%, transparent);--sidebar-panel-border: color-mix(in srgb, white 16%, transparent);--sidebar-group-border: color-mix(in srgb, white 18%, transparent);color:var(--sidebar-text);background:linear-gradient(180deg,#08111d,#0b1727)!important;border-color:var(--sidebar-panel-border);box-shadow:0 20px 34px #01081461}html[data-theme=dark] .app-layout-root .sidebar-panel:before{display:none}html[data-theme=dark] .app-layout-root .sidebar-group-title{color:#f8fbff;text-shadow:0 1px 2px rgba(4,13,28,.24)}html[data-theme=dark] .app-layout-root .sidebar-panel>.sidebar-group+.sidebar-group,html[data-theme=dark] .app-layout-root .sidebar-version{border-color:color-mix(in srgb,white 22%,transparent)}html[data-theme=dark] .app-layout-root .sidebar-group-title:after{background:linear-gradient(90deg,color-mix(in srgb,white 28%,transparent),transparent)}html[data-theme=dark] .app-layout-root .sidebar-link,html[data-theme=dark] .app-layout-root .sidebar-group-toggle{color:color-mix(in srgb,white 92%,transparent);text-shadow:0 1px 2px rgba(4,13,28,.22)}html[data-theme=dark] .app-layout-root .sidebar-link:hover,html[data-theme=dark] .app-layout-root .sidebar-link.is-active,html[data-theme=dark] .app-layout-root .sidebar-group-toggle:hover,html[data-theme=dark] .app-layout-root .sidebar-group-toggle.is-active,html[data-theme=dark] .app-layout-root .sidebar-group-toggle.is-expanded{color:#fff}html[data-theme=dark] .app-layout-root .sidebar-link.is-active{background:color-mix(in srgb,var(--primary) 18%,transparent);border-color:color-mix(in srgb,var(--primary) 34%,transparent)}html[data-theme=dark] .app-layout-root .sidebar-link:hover{background:color-mix(in srgb,white 8%,transparent)}html[data-theme=dark] .app-layout-root .sidebar-link-icon,html[data-theme=dark] .app-layout-root .sidebar-group--collapsible .sidebar-subnav .sidebar-link .sidebar-link-icon{color:color-mix(in srgb,white 92%,transparent)}html[data-theme=dark] .app-layout-root .sidebar-link:hover .sidebar-link-icon,html[data-theme=dark] .app-layout-root .sidebar-link.is-active .sidebar-link-icon{color:#fff;background:color-mix(in srgb,white 13%,transparent);border-color:color-mix(in srgb,white 18%,transparent)}html[data-theme=dark] .app-layout-root .sidebar-version__label{color:color-mix(in srgb,white 88%,transparent)}@media(min-width:768px){.app-layout-root .app-shell{grid-template-columns:minmax(280px,306px) minmax(0,1fr)}html[data-theme=light] .app-layout-root .sidebar{position:sticky;top:68px;align-self:start;height:calc(100vh - 68px);min-height:auto;border-right:1px solid #bfd4ec;background:#d7e8fb}html[data-theme=dark] .app-layout-root .sidebar{position:sticky;top:68px;align-self:start;height:calc(100vh - 68px);min-height:auto;border-right:1px solid color-mix(in srgb,white 12%,transparent);background:#040b14}.app-layout-root .sidebar-panel{position:relative;top:auto;height:100%;max-height:100%;padding:14px 14px 20px}.app-layout-root .app-content{width:min(100%,1540px);padding:18px 28px 32px}}@media(max-width:767px){.app-layout-root .app-content{padding:14px 12px 96px}.app-layout-root .page-header{border-radius:22px;padding:14px}.app-layout-root .sidebar-panel{width:min(88vw,340px)}}.theme-dropdown{position:relative}.theme-dropdown__trigger{display:inline-flex;align-items:center;gap:10px;min-height:40px;padding:8px 12px;border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));border-radius:14px;background:color-mix(in srgb,var(--surface) 90%,transparent);color:var(--text);box-shadow:0 10px 22px color-mix(in srgb,var(--primary) 9%,transparent);transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background-color .14s ease}.theme-dropdown__trigger:hover:not(:disabled),.theme-dropdown__trigger.is-open{transform:translateY(-1px);border-color:color-mix(in srgb,var(--primary) 28%,var(--border));box-shadow:0 14px 28px color-mix(in srgb,var(--primary) 12%,transparent)}.theme-dropdown__trigger--icon{min-width:40px;min-height:40px;padding:7px;justify-content:center;border-radius:14px}.theme-dropdown__swatch{width:18px;height:18px;border-radius:50%;flex:0 0 auto;border:2px solid rgba(255,255,255,.75);box-shadow:0 3px 10px #0f172a24}.theme-dropdown__trigger--icon .theme-dropdown__swatch{width:16px;height:16px}.theme-dropdown__trigger-copy{min-width:0;display:grid;gap:1px;text-align:left}.theme-dropdown__trigger-copy strong,.theme-dropdown__trigger-copy small{display:block;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-dropdown__trigger-copy strong{font-size:.85rem;line-height:1.2}.theme-dropdown__trigger-copy small{color:var(--text-muted);font-size:.72rem;line-height:1.2}.theme-dropdown__trigger-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);transition:transform .14s ease,color .14s ease}.theme-dropdown__trigger.is-open .theme-dropdown__trigger-icon{transform:rotate(90deg);color:var(--text)}.theme-dropdown__trigger--icon .theme-dropdown__trigger-icon{transform:none;color:var(--text)}.theme-dropdown__trigger-icon.is-static{transform:none!important}.theme-dropdown__panel{position:absolute;top:calc(100% + 10px);z-index:80;width:min(92vw,260px);display:grid;gap:12px;padding:12px;border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));border-radius:18px;background:color-mix(in srgb,var(--surface) 96%,transparent);box-shadow:0 18px 40px #020c1c2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.theme-dropdown__panel--right{right:0}.theme-dropdown__panel--left{left:0}.theme-dropdown__title{color:var(--text);font-size:.92rem;font-weight:800;line-height:1.2}.theme-dropdown__field{display:grid;gap:6px}.theme-dropdown__label{color:var(--text-muted);font-size:.72rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}@media(max-width:640px){.theme-dropdown__trigger{min-height:38px;padding:7px 10px}.theme-dropdown__panel{width:min(92vw,240px)}}.login-screen{min-height:100vh;position:relative;overflow:hidden;padding:24px;display:grid;align-content:center;justify-items:center;background:radial-gradient(circle at 8% 10%,color-mix(in srgb,var(--primary) 18%,transparent),transparent 28%),radial-gradient(circle at 92% 18%,color-mix(in srgb,var(--accent) 14%,transparent),transparent 24%),linear-gradient(180deg,var(--login-bg-top),var(--login-bg-bottom))}.login-screen__mesh{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(color-mix(in srgb,var(--text-muted) 10%,transparent) 1px,transparent 1px),linear-gradient(90deg,color-mix(in srgb,var(--text-muted) 10%,transparent) 1px,transparent 1px);background-size:32px 32px;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.45),transparent 88%);mask-image:linear-gradient(180deg,rgba(0,0,0,.45),transparent 88%)}.login-screen__theme-wrap{position:absolute;top:24px;right:24px;z-index:2;width:auto;display:block}.login-screen__theme-panel{width:auto}.login-screen__theme-panel .theme-dropdown__trigger--icon{min-width:46px;min-height:46px;border-radius:16px;border-color:color-mix(in srgb,var(--primary) 20%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 94%,transparent),color-mix(in srgb,var(--theme-hero-surface) 84%,var(--surface)));box-shadow:0 18px 36px color-mix(in srgb,var(--primary) 12%,transparent);color:var(--theme-primary-soft-text)}.login-screen__theme-panel .theme-dropdown__trigger--icon:hover:not(:disabled),.login-screen__theme-panel .theme-dropdown__trigger--icon.is-open{border-color:color-mix(in srgb,var(--primary) 32%,var(--border));box-shadow:0 20px 40px color-mix(in srgb,var(--primary) 14%,transparent)}.login-screen__theme-panel .theme-dropdown__panel{width:min(88vw,220px);border-radius:18px;border-color:color-mix(in srgb,var(--surface) 72%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 96%,transparent),color-mix(in srgb,var(--surface) 88%,transparent));box-shadow:0 24px 48px color-mix(in srgb,var(--primary) 12%,rgba(15,23,42,.24))}.login-shell{position:relative;z-index:1;width:min(1040px,100%);display:grid;grid-template-columns:minmax(320px,.88fr) minmax(420px,1.12fr);border-radius:34px;overflow:hidden;border:1px solid color-mix(in srgb,var(--surface) 64%,var(--border));background:color-mix(in srgb,var(--surface) 96%,white 4%);box-shadow:0 34px 90px color-mix(in srgb,var(--primary) 16%,rgba(15,23,42,.24));-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.login-shell:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,color-mix(in srgb,var(--primary) 16%,transparent),transparent 34%),linear-gradient(180deg,color-mix(in srgb,white 10%,transparent),transparent 22%);opacity:.72}.login-brand-panel,.login-card{position:relative;min-height:600px}.login-brand-panel{display:flex;flex-direction:column;justify-content:space-between;padding:52px 44px 34px;color:#f5fbff;background:radial-gradient(circle at 16% 18%,color-mix(in srgb,white 16%,transparent),transparent 18%),radial-gradient(circle at 88% 84%,color-mix(in srgb,white 10%,transparent),transparent 22%),linear-gradient(180deg,color-mix(in srgb,var(--primary) 86%,#184a8f),color-mix(in srgb,var(--accent) 32%,var(--primary)))}.login-brand-panel:before{content:"";position:absolute;inset:auto -54px 42px auto;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,white 18%,transparent),transparent 68%);pointer-events:none}.login-brand-panel__inner,.login-card__body{position:relative;z-index:1}.login-brand-panel__copy{display:grid;gap:28px}.login-brand-panel__welcome{margin:0;font-size:1.9rem;font-weight:500;line-height:1.08;color:color-mix(in srgb,white 96%,transparent);letter-spacing:-.03em}.login-brand-panel__identity{display:grid;gap:18px;justify-items:start}.login-brand-panel__logo-card{width:108px;height:108px;display:grid;place-items:center;border-radius:999px;background:color-mix(in srgb,white 96%,transparent);box-shadow:inset 0 1px #ffffffb8,0 18px 36px #09274e2e}.login-brand-panel__logo{width:56px;height:56px;display:block}.login-brand-panel__identity-copy{display:grid;gap:8px}.login-brand-panel__title{margin:0;color:#fff;font-family:Space Grotesk,Manrope,Segoe UI,sans-serif;font-size:clamp(2.2rem,1.8rem + 1vw,3.1rem);line-height:.95;letter-spacing:-.05em;text-wrap:balance}.login-brand-panel__eyebrow{margin:0;color:color-mix(in srgb,white 74%,transparent);font-size:.88rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.login-brand-panel__lead{margin:0;max-width:29rem;color:color-mix(in srgb,white 78%,transparent);font-size:.98rem;line-height:1.72}.login-brand-panel__footer{display:flex;flex-wrap:wrap;gap:12px 18px;align-items:center;color:color-mix(in srgb,white 74%,transparent);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.login-brand-panel__footer span{display:inline-flex;align-items:center;gap:18px}.login-brand-panel__footer span:not(:last-child):after{content:"";width:1px;height:11px;background:color-mix(in srgb,white 32%,transparent)}.login-card{background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 98%,white 2%),color-mix(in srgb,var(--theme-hero-surface) 42%,var(--surface)))}.login-card:before{content:"";position:absolute;left:-42px;top:26px;bottom:26px;width:92px;background:radial-gradient(circle at 100% 32px,color-mix(in srgb,var(--surface) 98%,white 2%) 33px,transparent 34px) center top / 100% 84px repeat-y;pointer-events:none}.login-card__body{height:100%;padding:58px 58px 54px 92px;display:grid;align-content:center;gap:28px}.login-card__header{display:grid;gap:12px}.login-card__eyebrow{margin:0;color:color-mix(in srgb,var(--primary) 80%,var(--text-muted));font-size:.84rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.login-card__title{margin:0;color:var(--login-strong);font-family:Space Grotesk,Manrope,Segoe UI,sans-serif;font-size:clamp(2rem,1.76rem + .5vw,2.5rem);line-height:.98;letter-spacing:-.04em;text-wrap:balance}.login-card__subtitle{margin:0;max-width:26rem;color:var(--login-muted);font-size:.94rem;line-height:1.7}.login-form{display:grid;gap:22px;max-width:420px}.login-form__field{gap:10px}.login-form__field .ui-field-label{color:color-mix(in srgb,var(--text) 84%,var(--text-muted));font-size:.85rem;font-weight:700;letter-spacing:.02em}.login-form__input{min-height:0;padding:12px 0 14px;border:0;border-bottom:2px solid color-mix(in srgb,var(--primary) 22%,var(--border));border-radius:0;background:transparent;box-shadow:none}.login-form__input::placeholder{color:color-mix(in srgb,var(--text-muted) 88%,transparent)}.login-form__input:focus{border-color:color-mix(in srgb,var(--primary) 56%,var(--border));box-shadow:0 10px 18px color-mix(in srgb,var(--primary) 8%,transparent);background:transparent}.login-form__password-row{position:relative}.login-form__input--password{padding-right:86px}.login-form__toggle{position:absolute;top:50%;right:0;transform:translateY(-50%);min-width:70px;min-height:34px;border-radius:999px;border-color:color-mix(in srgb,var(--primary) 16%,var(--border));background:color-mix(in srgb,var(--theme-hero-surface) 72%,var(--surface));color:color-mix(in srgb,var(--primary) 80%,var(--text-muted));box-shadow:none}.login-form__toggle:hover:not(:disabled),.login-form__toggle:active:not(:disabled){transform:translateY(-50%);box-shadow:none}.login-form__error{padding:12px 14px;border-radius:16px;border:1px solid color-mix(in srgb,var(--danger) 24%,var(--border));background:color-mix(in srgb,var(--danger) 10%,transparent);color:color-mix(in srgb,var(--danger) 84%,white 8%);font-size:.88rem;font-weight:600}.login-form__submit{width:min(198px,100%);min-height:52px;border-radius:999px;justify-content:center;font-size:.92rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 20px 36px color-mix(in srgb,var(--primary) 18%,transparent)}.login-card__meta{display:flex;align-items:center;justify-content:flex-end;padding-top:10px;border-top:1px solid color-mix(in srgb,var(--primary) 12%,var(--border))}.login-card__version{color:color-mix(in srgb,var(--text-muted) 92%,var(--text));font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}@media(max-width:1039px){.login-shell{width:min(940px,100%);grid-template-columns:minmax(280px,.82fr) minmax(380px,1.18fr)}.login-brand-panel{padding:42px 34px 28px}.login-card__body{padding:48px 42px 44px 72px}}@media(max-width:899px){.login-screen{padding:18px;align-content:start}.login-screen__theme-wrap{top:18px;right:18px}.login-shell{margin-top:54px;grid-template-columns:1fr;border-radius:28px}.login-brand-panel,.login-card{min-height:0}.login-brand-panel{gap:28px;padding:34px 24px 24px}.login-card:before{display:none}.login-card__body{padding:28px 24px 30px}.login-form{max-width:none}}@media(max-width:640px){.login-screen{padding:14px}.login-screen__theme-wrap{top:14px;right:14px}.login-shell{margin-top:50px;border-radius:24px}.login-brand-panel{padding:28px 18px 20px}.login-brand-panel__welcome{font-size:1.55rem}.login-brand-panel__logo-card{width:88px;height:88px}.login-brand-panel__logo{width:48px;height:48px}.login-brand-panel__title{font-size:clamp(1.95rem,1.6rem + 2.4vw,2.4rem)}.login-brand-panel__lead,.login-card__subtitle{font-size:.9rem;line-height:1.58}.login-card__body{padding:24px 18px;gap:22px}.login-form{gap:18px}.login-form__submit{width:100%}.login-card__meta{justify-content:flex-start}}
