: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: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-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,250px);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:14px;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}.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:8px;position:relative;overflow:visible;border:1px solid color-mix(in srgb,var(--group-accent) 24%,var(--border));background:linear-gradient(165deg,color-mix(in srgb,var(--group-accent) 8%,var(--surface)),color-mix(in srgb,var(--surface-alt) 55%,var(--surface)));border-radius:14px;padding:12px;box-shadow:0 10px 24px color-mix(in srgb,var(--group-accent) 10%,transparent)}.sidebar-group:before{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--group-accent) 58%,white),transparent);pointer-events:none}.sidebar-link{width:100%;text-align:left;border:1px solid color-mix(in srgb,var(--item-accent) 14%,transparent);border-left-width:3px;background:color-mix(in srgb,var(--item-accent) 6%,transparent);padding:10px 10px 10px 9px;border-radius:10px;color:var(--text-muted);display:flex;align-items:center;justify-content:flex-start;gap:8px;min-height:44px;height:auto;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:flex-start;gap:8px;min-width:0;width:100%}.sidebar-link-label{display:block;min-width:0;white-space:normal;word-break:break-word;overflow-wrap:anywhere;line-height:1.25}.sidebar-link:hover{transform:translate(2px);border-color:color-mix(in srgb,var(--item-accent) 34%,var(--border));background:color-mix(in srgb,var(--item-accent) 12%,transparent);color:var(--text)}.sidebar-link.is-active{background:color-mix(in srgb,var(--item-accent) 18%,transparent);border-color:color-mix(in srgb,var(--item-accent) 42%,var(--border));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--item-accent) 24%,transparent);color:var(--text)}.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}.modal-panel--full{width:min(100%,980px);max-height:calc(100vh - 24px);overflow:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}.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;object-fit:cover;border-radius:14px;background:#0b1220;border:1px solid var(--border);display:block}.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}.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}.sidebar{position:static;inset:auto;z-index:auto;pointer-events:auto;padding:12px 0 12px 12px}.sidebar-scrim{display:none}.sidebar-panel{position:sticky;top:68px;left:auto;bottom:auto;width:auto;max-height:calc(100vh - 80px);padding:0;overflow-x:visible;overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable;display:flex;flex-direction:column;transform:none;transition:none;background: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}}: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}.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:#fff}html.dark .ui-button--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:#f0f1f7;border-radius:16px;padding:12px}html.dark .dashboard-page-shell{background:#111f34}.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:#fff;background-image:none;border-color:#97b3d5;box-shadow:0 8px 18px #2440631a}html.dark .dashboard-page-shell .principal-metric-tile{border-color:color-mix(in srgb,var(--primary) 24%,var(--border));background:linear-gradient(150deg,color-mix(in srgb,var(--primary) 7%,var(--surface)),color-mix(in srgb,var(--surface) 94%,transparent));box-shadow:var(--shadow)}.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{--chart-line-attendance: #7a52f4;--chart-line-coverage: #2bbcf3;--chart-grid: color-mix(in srgb, #9aa8c0 35%, transparent);--chart-axis: color-mix(in srgb, #8698b4 48%, transparent);--chart-label: color-mix(in srgb, #6f819f 88%, black 4%);--chart-tooltip-bg: rgba(255, 255, 255, .94);--chart-tooltip-border: color-mix(in srgb, #c2ccdb 72%, white 10%);--chart-tooltip-shadow: 0 10px 22px rgba(24, 41, 66, .14);--chart-hover-line: color-mix(in srgb, #7f8fa8 50%, transparent);display:grid;gap:8px}html.dark .principal-monthly-chart{--chart-line-attendance: #8d67ff;--chart-line-coverage: #35c9ff;--chart-grid: color-mix(in srgb, #6f86a8 30%, transparent);--chart-axis: color-mix(in srgb, #84a0c5 44%, transparent);--chart-label: color-mix(in srgb, #a8bcd9 84%, white 4%);--chart-tooltip-bg: rgba(15, 30, 54, .95);--chart-tooltip-border: color-mix(in srgb, #56709b 58%, transparent);--chart-tooltip-shadow: 0 14px 30px rgba(2, 8, 20, .42);--chart-hover-line: color-mix(in srgb, #89a3ca 48%, transparent)}.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}.sidebar-link{background:var(--sidebar-link-bg);border-color:color-mix(in srgb,var(--sidebar-group-border) 78%,transparent);color:var(--sidebar-text)}.sidebar-group-title{padding:4px 8px 8px;color:var(--sidebar-muted);font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.sidebar-link:hover{border-color:color-mix(in srgb,var(--primary) 36%,var(--sidebar-group-border));background:var(--sidebar-link-hover)}.sidebar-link.is-active{background:var(--sidebar-link-active);border-color:color-mix(in srgb,var(--primary) 48%,var(--sidebar-group-border));box-shadow:none}.sidebar-group{background:var(--sidebar-group-bg)!important;border-color:var(--sidebar-group-border)!important;box-shadow:0 8px 18px #1c33531c!important}html.dark .sidebar-group{box-shadow:0 10px 20px #02081457!important}.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:start;margin-bottom:12px}.zone-school-report-wrap{max-height:320px;overflow-x:hidden;overflow-y:auto}.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}@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}}@media(min-width:768px){.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:1px solid var(--sidebar-panel-border);box-shadow:0 14px 28px #172a4629}}@media(min-width:1200px){.principal-metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
