@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&display=swap";.landing-page{--ink: var(--sidebar);--ink-2: color-mix(in srgb, var(--sidebar) 85%, #000);--primary-2: var(--sidebar-active-to);--brand-grad: var(--grad-primary);--hero-grad: var(--grad-hero);--accent-light: color-mix(in srgb, var(--accent) 72%, #fff);--indigo-soft: var(--primary-soft);--paper: var(--bg);--tint: var(--primary-soft);--muted: var(--text-soft);--faint: var(--text-faint);--line: var(--border);--line-strong: var(--border-strong);--on-dark: #ffffff;--on-dark-muted: rgba(255, 255, 255, .78);--line-dark: rgba(255, 255, 255, .16);min-height:100vh;background:var(--paper);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.55}.landing-page *,.landing-page *:before,.landing-page *:after{box-sizing:border-box}.landing-page a{color:inherit}.landing-display{font-weight:800;letter-spacing:-.025em}.landing-page :focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:6px}.landing-wrap{width:100%;max-width:1180px;margin:0 auto;padding-left:clamp(20px,5vw,40px);padding-right:clamp(20px,5vw,40px)}.landing-kicker{margin:0 0 16px;color:var(--primary);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.landing-kicker.on-dark{color:var(--accent-light)}.landing-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;padding:0 22px;border:1px solid var(--line-strong);border-radius:12px;background:var(--surface);color:var(--text);font-size:15px;font-weight:700;text-decoration:none;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease,filter .15s ease}.landing-btn:hover{transform:translateY(-1px)}.landing-btn.primary{border:none;background:var(--brand-grad);color:#fff;box-shadow:0 6px 18px color-mix(in srgb,var(--primary) 32%,transparent)}.landing-btn.primary:hover{filter:brightness(1.06);box-shadow:0 10px 26px color-mix(in srgb,var(--primary) 42%,transparent)}.landing-btn.light{border:none;background:#fff;color:var(--primary);box-shadow:0 8px 22px #14103c47}.landing-btn.light:hover{background:#f6f5ff}.landing-btn.ghost-dark{background:#ffffff0f;border-color:var(--line-dark);color:var(--on-dark)}.landing-btn.ghost-dark:hover{border-color:#ffffff73;background:#ffffff1f}.landing-nav{position:sticky;top:0;z-index:40;background:var(--ink);border-bottom:1px solid var(--line-dark)}.landing-nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:66px}.landing-page a.landing-brand{display:inline-flex;align-items:center;gap:10px;color:#fff;font-family:Space Grotesk,Segoe UI,system-ui,sans-serif;font-weight:700;font-size:19px;letter-spacing:-.01em;text-decoration:none}.lb-accent{color:var(--accent-light);font-weight:700}.landing-mark{display:grid;place-items:center;width:33px;height:33px;border-radius:9px;background:var(--grad-brand);color:#fff;font-family:Space Grotesk,system-ui,sans-serif;font-weight:700;font-size:18px;box-shadow:0 4px 16px color-mix(in srgb,var(--sidebar-active-to) 55%,transparent),inset 0 0 0 1px #ffffff47}.landing-nav-links{display:flex;align-items:center;gap:26px}.landing-nav-links a{color:var(--on-dark-muted);font-size:14px;font-weight:600;text-decoration:none;transition:color .15s ease}.landing-nav-links a:hover{color:var(--on-dark)}.landing-nav-links .landing-btn{min-height:40px;padding:0 16px;font-size:14px}.landing-hero{position:relative;overflow:hidden;background:var(--hero-grad);color:var(--on-dark)}.landing-hero:before{content:"";position:absolute;width:620px;height:620px;border-radius:50%;background:#ffffff14;top:-260px;right:-160px;pointer-events:none}.landing-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:26px 26px;pointer-events:none}.landing-hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,.88fr) minmax(490px,1.12fr);gap:clamp(36px,5vw,68px);align-items:center;padding-top:clamp(48px,7vw,92px);padding-bottom:clamp(48px,7vw,92px)}.landing-hero h1{margin:0;color:#fff;font-size:clamp(40px,5.2vw,64px);line-height:1.04}.landing-hero h1 em{font-style:normal;color:var(--accent-light)}.landing-lede{max-width:520px;margin:22px 0 0;color:var(--on-dark-muted);font-size:clamp(17px,1.6vw,20px);line-height:1.6}.landing-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}.landing-reassure{display:flex;flex-wrap:wrap;gap:12px;margin:30px 0 0;padding:0;list-style:none}.landing-reassure li{display:inline-flex;align-items:center;padding:9px 16px;border-radius:999px;background:#ffffff1f;border:1px solid rgba(255,255,255,.28);color:#fff;font-size:14.5px;font-weight:700;letter-spacing:.01em}@media (prefers-reduced-motion: no-preference){.landing-anim{opacity:0;transform:translateY(14px);animation:landing-rise .6s cubic-bezier(.16,1,.3,1) forwards}.landing-anim.d1{animation-delay:.05s}.landing-anim.d2{animation-delay:.12s}.landing-anim.d3{animation-delay:.19s}.landing-anim.d4{animation-delay:.26s}.landing-anim.visual{animation-delay:.16s;animation-duration:.7s}}@keyframes landing-rise{to{opacity:1;transform:translateY(0)}}.landing-visual{min-width:0}.preview-shell{display:grid;grid-template-columns:142px minmax(0,1fr);overflow:hidden;border:1px solid rgba(255,255,255,.14);border-radius:18px;background:var(--surface);box-shadow:0 40px 90px #14103c80}.preview-rail{display:flex;flex-direction:column;gap:4px;padding:16px 12px;background:var(--ink)}.preview-brand{display:flex;align-items:center;gap:9px;padding:2px 4px 12px;color:#fff;font-weight:800;font-size:12.5px;white-space:nowrap}.preview-brandmark{display:grid;place-items:center;width:24px;height:24px;border-radius:7px;background:var(--grad-brand);color:#fff;font-size:13px;font-weight:800;box-shadow:0 3px 10px #6d6df080}.preview-navi{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:9px;color:#b9bcd0;font-size:12px;font-weight:500}.preview-navi svg{width:15px;height:15px;opacity:.85;flex:none}.preview-navi.active{background:var(--brand-grad);color:#fff;box-shadow:0 6px 16px color-mix(in srgb,var(--primary) 45%,transparent)}.preview-body{padding:20px;background:var(--paper)}.preview-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px}.preview-topbar strong{display:block;font-size:16px;letter-spacing:-.4px;color:var(--text)}.preview-topbar small{color:var(--muted);font-size:11.5px}.preview-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:var(--green-soft);color:#1f6b3c;font-size:11px;font-weight:800;white-space:nowrap}.preview-dot{width:6px;height:6px;border-radius:50%;background:var(--green)}@media (prefers-reduced-motion: no-preference){.preview-dot{animation:landing-pulse 1.8s ease-in-out infinite}}@keyframes landing-pulse{0%,to{opacity:1}50%{opacity:.35}}.preview-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.preview-kpi{position:relative;overflow:hidden;padding:13px 14px;border:1px solid var(--line);border-radius:13px;background:var(--surface);box-shadow:0 1px 2px #1417280d}.preview-kpi:after{content:"";position:absolute;top:0;right:0;width:80px;height:80px;background:radial-gradient(circle at top right,color-mix(in srgb,var(--primary) 12%,transparent),transparent 70%);pointer-events:none}.preview-kpi .k-label{font-size:11px;font-weight:500;color:var(--muted)}.preview-kpi .k-value{margin-top:5px;font-size:23px;font-weight:800;letter-spacing:-.6px;color:var(--text);font-variant-numeric:tabular-nums}.preview-kpi .k-badge{position:absolute;top:11px;right:11px;display:grid;place-items:center;width:28px;height:28px;border-radius:9px}.preview-kpi .k-badge svg{width:15px;height:15px}.k-badge.green{background:var(--green-soft);color:var(--green)}.k-badge.indigo{background:var(--indigo-soft);color:var(--primary)}.k-badge.amber{background:var(--amber-soft);color:var(--amber)}.preview-chart{margin-bottom:12px;padding:14px 16px 16px;border:1px solid var(--line);border-radius:13px;background:var(--surface);box-shadow:0 1px 2px #1417280d}.pc-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}.pc-head .pc-title{font-size:11.5px;font-weight:600;color:var(--muted)}.pc-head .pc-val{font-size:14px;font-weight:800;letter-spacing:-.3px;color:var(--text)}.pc-bars{display:flex;align-items:flex-end;gap:8px;height:58px}.pc-bars i{flex:1;border-radius:5px 5px 2px 2px;background:linear-gradient(180deg,color-mix(in srgb,var(--primary) 72%,#fff),var(--primary))}.pc-bars i.peak{background:linear-gradient(180deg,color-mix(in srgb,var(--sidebar-active-to) 72%,#fff),var(--sidebar-active-to))}.preview-rows{display:grid;gap:8px}.preview-rowi{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:11px;background:var(--surface)}.preview-rowi .r-ic{display:grid;place-items:center;width:26px;height:26px;border-radius:8px;background:var(--indigo-soft);color:var(--primary);flex:none}.preview-rowi .r-ic svg{width:14px;height:14px}.preview-rowi strong{font-size:12px;color:var(--text)}.preview-rowi small{flex:1;color:var(--muted);font-size:11.5px}.preview-rowi em{font-style:normal;font-size:10.5px;color:var(--faint)}.landing-onelogin{border-top:1px solid var(--line-dark);background:var(--ink-2);color:var(--on-dark)}.onelogin-inner{padding-top:clamp(44px,5vw,64px);padding-bottom:clamp(44px,5vw,64px);text-align:center}.onelogin-title{max-width:660px;margin:0 auto;color:#fff;font-size:clamp(24px,3vw,34px);font-weight:800;letter-spacing:-.02em;line-height:1.12}.onelogin-core{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin:30px auto 0;max-width:820px}.onelogin-chip{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border-radius:13px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#fff;font-size:15px;font-weight:700}.onelogin-chip svg{color:var(--accent-light);flex:none}.onelogin-more{max-width:640px;margin:22px auto 0;color:var(--on-dark-muted);font-size:14.5px;line-height:1.6}.landing-section{padding-top:clamp(56px,6vw,84px);padding-bottom:clamp(56px,6vw,84px)}.landing-section.tint{background:var(--tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.landing-head{max-width:720px}.landing-head.center{margin:0 auto;text-align:center}.landing-head h2{margin:0;font-size:clamp(28px,3.4vw,42px);line-height:1.1;color:var(--text)}.landing-head p{margin:16px 0 0;color:var(--muted);font-size:18px;line-height:1.6}.landing-card-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:44px}.landing-card{display:flex;flex-direction:column;padding:24px;border:1px solid var(--line);border-radius:var(--radius, 16px);background:var(--surface);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.landing-card{border-radius:16px}.landing-card:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 18px 40px #1417281a}.landing-card-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;background:var(--indigo-soft);color:var(--primary);margin-bottom:16px}.landing-card h3{margin:0 0 12px;font-size:17px;color:var(--text)}.landing-card ul{margin:0;padding:0;list-style:none;display:grid;gap:8px}.landing-card li{position:relative;padding-left:18px;color:var(--muted);font-size:14.5px;line-height:1.45}.landing-card li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.landing-split{display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);gap:clamp(36px,5vw,72px);align-items:center}.landing-feature-list{display:grid;gap:22px;margin:36px 0 0;padding:0;list-style:none}.landing-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:30px 48px;margin-top:48px}.landing-feature{display:grid;grid-template-columns:44px minmax(0,1fr);gap:16px;align-items:start}.landing-feature-ic{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--indigo-soft);color:var(--primary)}.landing-feature h4{margin:2px 0 5px;font-size:16px;color:var(--text)}.landing-feature p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.55}.landing-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.landing-metrics-row{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:32px}.landing-metric{padding:26px 22px;border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:0 1px 2px #1417280d}.landing-metric strong{display:block;font-size:clamp(30px,4vw,40px);font-weight:800;letter-spacing:-1px;line-height:1;color:var(--primary);font-variant-numeric:tabular-nums}.landing-metric span{display:block;margin-top:10px;color:var(--muted);font-size:14px;line-height:1.4}.landing-roles{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:44px}.landing-role{padding:22px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}.landing-role-ic{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--brand-grad);color:#fff;margin-bottom:14px;box-shadow:0 6px 16px color-mix(in srgb,var(--primary) 30%,transparent)}.landing-role h4{margin:0 0 6px;font-size:15px;color:var(--text)}.landing-role p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}.landing-price-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:48px;align-items:start}.landing-price{display:flex;flex-direction:column;padding:28px;border:1px solid var(--line);border-radius:18px;background:var(--surface)}.landing-price.featured{position:relative;border:2px solid var(--primary);box-shadow:0 22px 50px color-mix(in srgb,var(--primary) 18%,transparent);transform:translateY(-12px)}.landing-price-badge{position:absolute;top:-13px;left:28px;padding:5px 12px;border-radius:999px;background:var(--brand-grad);color:#fff;font-size:12px;font-weight:800;letter-spacing:.02em}.landing-price-name{font-size:15px;font-weight:800;color:var(--text)}.landing-price-cap{margin:4px 0 18px;color:var(--muted);font-size:13.5px}.landing-price-amount{display:flex;align-items:baseline;gap:6px;min-height:40px;margin-bottom:4px}.landing-price-amount strong{font-size:40px;font-weight:800;letter-spacing:-1.5px;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}.landing-price-amount span{color:var(--muted);font-size:14px;font-weight:600}.landing-price-bill{min-height:32px;margin:0 0 22px;color:var(--muted);font-size:13px}.landing-price .landing-btn{width:100%;margin-bottom:22px}.landing-price ul{margin:0;padding:0;list-style:none;display:grid;gap:11px}.landing-price li{display:grid;grid-template-columns:18px minmax(0,1fr);gap:9px;color:var(--text);font-size:14px;line-height:1.45}.landing-price li svg{margin-top:3px;color:var(--green)}.landing-price-note{display:flex;align-items:center;justify-content:center;gap:8px;margin:26px auto 0;max-width:640px;text-align:center;color:var(--muted);font-size:13.5px}.landing-price-note svg{color:var(--accent);flex:none}.landing-cta{position:relative;overflow:hidden;background:var(--ink);color:var(--on-dark);text-align:center}.landing-cta:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 130% at 50% -30%,color-mix(in srgb,var(--sidebar-active-to) 50%,transparent),transparent 60%);pointer-events:none}.landing-cta>*{position:relative;z-index:1}.landing-cta h2{max-width:760px;margin:0 auto;color:#fff;font-size:clamp(30px,4vw,48px);line-height:1.08}.landing-cta p{max-width:560px;margin:18px auto 0;color:var(--on-dark-muted);font-size:18px}.landing-cta .landing-actions{justify-content:center}.landing-footer{background:var(--ink-2);color:var(--on-dark-muted);border-top:1px solid var(--line-dark)}.landing-footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:28px;padding-top:40px;padding-bottom:28px}.landing-footer-brand{max-width:280px}.landing-footer-brand .landing-brand{margin-bottom:12px}.landing-footer-brand p{margin:0;font-size:14px;line-height:1.55}.landing-footer-cols{display:flex;flex-wrap:wrap;gap:48px}.landing-footer-col h5{margin:0 0 14px;color:var(--on-dark);font-size:13px;font-weight:700;letter-spacing:.04em}.landing-footer-col a{display:block;margin-bottom:9px;color:var(--on-dark-muted);font-size:14px;text-decoration:none;transition:color .15s ease}.landing-footer-col a:hover{color:var(--on-dark)}.landing-footer-bar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;padding-top:22px;padding-bottom:30px;border-top:1px solid var(--line-dark);font-size:13px}.landing-carousel{position:relative;display:grid;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:10px;margin-top:48px}.carousel-viewport{overflow:hidden;border-radius:20px}.carousel-track{display:flex;transition:transform .5s cubic-bezier(.16,1,.3,1)}.shot{flex:0 0 100%;min-width:0;margin:0;padding:0 4px}.shot-frame{overflow:hidden;border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:0 26px 60px #14172829}.shot-bar{display:flex;align-items:center;gap:7px;padding:12px 16px;background:var(--ink);border-bottom:1px solid rgba(255,255,255,.08)}.shot-bar i{width:10px;height:10px;border-radius:50%;background:#ffffff47}.shot-bar i:first-child{background:#ff5f57}.shot-bar i:nth-child(2){background:#febc2e}.shot-bar i:nth-child(3){background:#28c840}.shot-url{margin-left:10px;padding:3px 12px;border-radius:999px;background:#ffffff14;color:#fff9;font-size:11px;font-weight:600}.shot-body{aspect-ratio:16 / 10;background:var(--paper)}.shot-body img{display:block;width:100%;height:100%;object-fit:cover}.mock{display:flex;flex-direction:column;gap:14px;width:100%;height:100%;padding:clamp(16px,2.4vw,26px);background:var(--paper);text-align:left}.mock-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.mock-head strong{display:block;font-size:clamp(15px,1.9vw,20px);letter-spacing:-.3px;color:var(--text)}.mock-head small{color:var(--muted);font-size:clamp(11px,1.3vw,13px)}.mock-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;background:var(--green-soft);color:#1f6b3c;font-size:11px;font-weight:800;white-space:nowrap}.mock-pill-dot{width:6px;height:6px;border-radius:50%;background:var(--green)}.mock-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(8px,1vw,12px)}.mock-kpi{padding:clamp(10px,1.4vw,16px);border:1px solid var(--line);border-radius:12px;background:var(--surface)}.mock-kpi span{display:block;color:var(--muted);font-size:clamp(10px,1.2vw,12px);font-weight:600}.mock-kpi strong{display:block;margin-top:6px;font-size:clamp(18px,2.6vw,28px);font-weight:800;letter-spacing:-.6px;color:var(--text);font-variant-numeric:tabular-nums}.mock-kpi strong.warn,.mock-tile strong.warn{color:var(--amber)}.mock-needs{border:1px solid var(--line);border-radius:14px;background:var(--surface);overflow:hidden}.mock-needs-head{padding:11px 16px;border-bottom:1px solid var(--line);color:var(--muted);font-size:clamp(11px,1.3vw,13px);font-weight:800;letter-spacing:.02em;text-transform:uppercase}.mock-list,.mock-table{display:grid;gap:8px}.mock-li{display:flex;align-items:center;gap:12px;padding:clamp(8px,1.1vw,12px) 16px}.mock-needs .mock-li{border-top:1px solid var(--line)}.mock-needs .mock-li:first-of-type{border-top:none}.mock-list .mock-li{border:1px solid var(--line);border-radius:11px;background:var(--surface)}.mock-li strong,.mock-tr strong{flex:1;min-width:0;font-size:clamp(12px,1.45vw,15px);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mock-avatar{display:grid;place-items:center;width:clamp(26px,3vw,34px);height:clamp(26px,3vw,34px);border-radius:50%;background:var(--grad-brand);color:#fff;font-size:clamp(10px,1.2vw,12px);font-weight:800;flex:none}.mock-avatar.sm{width:clamp(22px,2.5vw,28px);height:clamp(22px,2.5vw,28px)}.mock-avatar.ghost{background:transparent}.mock-dot{width:8px;height:8px;border-radius:50%;flex:none}.mock-dot.red{background:var(--red)}.mock-dot.amber{background:var(--amber)}.mock-link{color:var(--primary);font-size:clamp(11px,1.3vw,13px);font-weight:700;white-space:nowrap}.mock-badge{padding:4px 11px;border-radius:999px;font-size:clamp(10px,1.2vw,12px);font-weight:800;text-transform:capitalize;white-space:nowrap}.mock-badge.present{background:var(--green-soft);color:#1f6b3c}.mock-badge.late{background:var(--amber-soft);color:var(--amber)}.mock-badge.absent{background:var(--red-soft);color:var(--red)}.mock-stats{display:flex;gap:10px}.mock-stat{flex:1;padding:clamp(9px,1.2vw,14px);border:1px solid var(--line);border-radius:12px;background:var(--surface);color:var(--muted);font-size:clamp(11px,1.3vw,13px);font-weight:600}.mock-stat b{display:block;font-size:clamp(17px,2.4vw,24px);font-weight:800;font-variant-numeric:tabular-nums}.mock-stat.green b{color:var(--green)}.mock-stat.amber b{color:var(--amber)}.mock-stat.red b{color:var(--red)}.mock-tiles{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(8px,1vw,12px)}.mock-tile{padding:clamp(10px,1.4vw,16px);border:1px solid var(--line);border-radius:12px;background:var(--surface)}.mock-tile span{color:var(--muted);font-size:clamp(10px,1.2vw,12px);font-weight:600}.mock-tile strong{display:block;margin-top:5px;font-size:clamp(17px,2.4vw,26px);font-weight:800;letter-spacing:-.5px;color:var(--text);font-variant-numeric:tabular-nums}.mock-tr{display:flex;align-items:center;gap:12px;padding:clamp(7px,1vw,11px) 14px;border:1px solid var(--line);border-radius:11px;background:var(--surface)}.mock-tr.label{background:transparent;border:none;padding-bottom:0}.mock-tr.label strong,.mock-tr.label em,.mock-tr.label .mock-grade-h{color:var(--muted);font-size:clamp(10px,1.2vw,12px);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-style:normal}.mock-tr em{font-style:normal;font-size:clamp(12px,1.4vw,14px);font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.mock-marks{display:flex;align-items:center;gap:8px;width:clamp(90px,14vw,150px)}.mock-bar{height:6px;border-radius:3px;background:var(--primary);flex:none}.mock-grade,.mock-grade-h{width:46px;text-align:center;flex:none}.mock-grade{padding:4px 0;border-radius:7px;background:var(--indigo-soft);color:var(--primary);font-size:clamp(11px,1.3vw,13px);font-weight:800}.shot figcaption{margin:18px auto 0;max-width:560px;text-align:center;color:var(--muted);font-size:15px;line-height:1.55}.carousel-arrow{display:grid;place-items:center;width:44px;height:44px;border:1px solid var(--line-strong);border-radius:50%;background:var(--surface);color:var(--text);cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease}.carousel-arrow:hover{border-color:var(--primary);color:var(--primary);transform:scale(1.05)}.carousel-dots{grid-column:2;display:flex;justify-content:center;gap:9px;margin-top:22px}.carousel-dots button{width:9px;height:9px;padding:0;border:none;border-radius:50%;background:var(--line-strong);cursor:pointer;transition:background .2s ease,transform .2s ease}.carousel-dots button.active{background:var(--primary);transform:scale(1.25)}.landing-promise{background:var(--brand-grad);color:#fff}.landing-promise-inner{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:28px;padding-top:clamp(34px,4vw,48px);padding-bottom:clamp(34px,4vw,48px);text-align:center}.promise-item strong{display:block;font-size:clamp(20px,2.4vw,26px);font-weight:800;letter-spacing:-.01em}.promise-item span{display:block;margin-top:8px;color:#ffffffd9;font-size:14.5px;line-height:1.5}.landing-about{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:clamp(36px,5vw,64px);align-items:center}.landing-about-copy h2{margin:0;font-size:clamp(26px,3.2vw,40px);line-height:1.12;color:var(--text)}.landing-about-copy p{margin:18px 0 0;color:var(--muted);font-size:16.5px;line-height:1.65}.landing-about-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:0;padding:0;list-style:none}.landing-about-stats li{padding:22px;border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:0 1px 2px #1417280d}.landing-about-stats strong{display:block;font-size:clamp(28px,3.4vw,36px);font-weight:800;letter-spacing:-1px;line-height:1;color:var(--primary);font-variant-numeric:tabular-nums}.landing-about-stats span{display:block;margin-top:9px;color:var(--muted);font-size:13.5px;line-height:1.4}.landing-contact-copy{max-width:640px}.landing-contact-copy h2{margin:0;font-size:clamp(26px,3.2vw,40px);line-height:1.12;color:var(--text)}.landing-contact-copy p{margin:16px 0 0;color:var(--muted);font-size:17px;line-height:1.6}.landing-contact-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:40px}.contact-card{display:flex;flex-direction:column;padding:24px;border:1px solid var(--line);border-radius:16px;background:var(--surface);text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.contact-card:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 18px 40px #1417281a}.contact-ic{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--indigo-soft);color:var(--primary);margin-bottom:16px}.contact-label{color:var(--muted);font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.contact-card strong{margin-top:6px;font-size:19px;font-weight:800;letter-spacing:-.01em;color:var(--text)}.contact-card small{margin-top:6px;color:var(--muted);font-size:13.5px}@media (max-width: 1000px){.landing-hero-inner,.landing-split,.landing-about{grid-template-columns:1fr}.landing-card-grid,.landing-roles,.landing-metrics-row{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-contact-cards{grid-template-columns:1fr;max-width:460px}.landing-price-grid{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}.landing-price.featured{order:-1;transform:none}}@media (max-width: 640px){.landing-nav-links a:not(.landing-btn){display:none}.preview-shell{grid-template-columns:1fr}.preview-rail{display:none}.preview-kpis,.landing-card-grid,.landing-roles,.landing-metrics,.landing-feature,.landing-feature-grid{grid-template-columns:1fr}.landing-metrics-row{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-promise-inner,.landing-about-stats{grid-template-columns:1fr}.landing-promise-inner{gap:22px}}.domain-test-page{display:grid;min-height:100vh;place-items:center;padding:32px;background:#f4f6fb;color:#161a2b}.domain-test-shell{width:min(680px,100%);padding:clamp(28px,5vw,52px);border:1px solid var(--line, #e8ebf3);border-radius:16px;background:#fff;box-shadow:0 24px 70px #1417281f}.domain-test-shell h1{margin:0;font-size:clamp(36px,6vw,64px);line-height:1}.domain-test-shell p{max-width:560px;margin:20px 0 0;color:#586079;font-size:18px;line-height:1.6}.domain-test-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.domain-test-links a{display:inline-flex;min-height:42px;align-items:center;justify-content:center;padding:0 16px;border:1px solid rgba(21,32,29,.16);border-radius:10px;color:#161a2b;font-weight:800;text-decoration:none}.domain-test-links a:first-child{border:none;background:var(--grad-primary);color:#fff}:root{--bg: #f4f6fb;--surface: #ffffff;--surface-2: #f6f8fc;--border: #e8ebf3;--border-strong: #d8dce8;--text: #161a2b;--text-soft: #586079;--text-faint: #969db3;--primary: #4f46e5;--primary-dark: #4036cc;--primary-soft: #ecebfd;--primary-glow: rgba(79, 70, 229, .16);--accent: #f59e0b;--accent-soft: #fdf2dd;--green: #16a34a;--green-soft: #e7f6ed;--amber: #d97706;--amber-soft: #fcf2e2;--red: #dc2626;--red-soft: #fdeaea;--blue: #2563eb;--blue-soft: #e8f0fe;--gray-soft: #eef0f6;--sidebar: #171a2e;--sidebar-active-from: #4f46e5;--sidebar-active-to: #7c4dda;--grad-primary: linear-gradient(135deg, #4f46e5, #7c4dda);--grad-brand: linear-gradient(135deg, #6d6df0, #9b59f6);--grad-avatar: linear-gradient(135deg, #6d6df0, #b65fd6);--grad-hero: linear-gradient(150deg, #4a3fc0 0%, #6d4fd4 45%, #a857d8 100%);--grad-banner: linear-gradient(120deg, #4f46e5 0%, #7c4dda 55%, #a855c7 100%);--chart-1: #5b5bd6;--chart-axis: #9499ab;--chart-grid: #e8ebf3;--shadow-sm: 0 1px 2px rgba(20, 23, 40, .05), 0 1px 1px rgba(20, 23, 40, .03);--shadow: 0 2px 4px rgba(20, 23, 40, .04), 0 10px 28px rgba(20, 23, 40, .07);--shadow-lg: 0 10px 28px rgba(20, 23, 40, .1), 0 28px 60px rgba(20, 23, 40, .16);--shadow-primary: 0 6px 18px rgba(79, 70, 229, .32);--radius: 16px;--radius-sm: 10px;--sidebar-w: 244px}[data-theme=dark]{--bg: #0e1020;--surface: #181b2e;--surface-2: #1f2336;--border: #2c3046;--border-strong: #3a3f5a;--text: #eef0f7;--text-soft: #a9b0c7;--text-faint: #7c83a0;--primary: #7c74ff;--primary-dark: #6a61f2;--primary-soft: #262652;--primary-glow: rgba(124, 116, 255, .22);--accent: #fbbf24;--accent-soft: #3a2f15;--green: #34d399;--green-soft: #123226;--amber: #fbbf24;--amber-soft: #392c12;--red: #f87171;--red-soft: #3a1d1d;--blue: #60a5fa;--blue-soft: #16294a;--gray-soft: #262a3e;--sidebar: #0a0c18;--grad-primary: linear-gradient(135deg, #7c74ff, #7c4dda);--chart-1: #7c74ff;--chart-axis: #7c83a0;--chart-grid: #2c3046;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .55);--shadow-primary: 0 6px 18px rgba(0, 0, 0, .5)}:root{--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--font-xs: 12px;--font-sm: 13px;--font-base: 14px;--font-md: 15px;--font-lg: 18px;--font-xl: 22px;--font-2xl: 28px;--ease-out: cubic-bezier(.2, .7, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--dur-1: .12s;--dur-2: .2s;--dur-3: .3s}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-size:14px;line-height:1.5;letter-spacing:-.005em;transition:background .2s,color .2s}h1,h2,h3,h4{letter-spacing:-.02em}.main *::-webkit-scrollbar{width:10px;height:10px}.main *::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px;border:3px solid var(--bg)}.main *::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}a{color:inherit;text-decoration:none}.skip-link{position:fixed;left:12px;top:-60px;z-index:1000;background:var(--primary);color:#fff;padding:10px 16px;border-radius:10px;font-weight:600;font-size:13px;box-shadow:var(--shadow-lg);transition:top .18s ease}.skip-link:focus{top:12px;outline:none}button{font-family:inherit;cursor:pointer;touch-action:manipulation}input,select,textarea{font-family:inherit;font-size:14px}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--sidebar);color:#c7cadb;display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;height:100vh;padding:22px 16px;z-index:50;transition:transform .26s cubic-bezier(.4,0,.2,1)}.sidebar-scrim{display:none}.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 22px;flex-shrink:0}.brand-mark{width:36px;height:36px;border-radius:10px;background:var(--grad-brand);display:grid;place-items:center;font-weight:800;color:#fff;font-size:18px;box-shadow:0 4px 14px #6d6df080}.brand-name{font-weight:700;color:#fff;font-size:16px;letter-spacing:-.2px}.brand-sub{font-size:11px;color:#7b7f98;letter-spacing:.3px}.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px;flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.18) transparent}.nav::-webkit-scrollbar{width:6px}.nav::-webkit-scrollbar-thumb{background:#ffffff29;border-radius:999px}.nav::-webkit-scrollbar-thumb:hover{background:#ffffff47}.nav-group{display:flex;flex-direction:column;gap:2px}.nav-section{width:100%;border:0;background:transparent;color:#8f93aa;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 10px;border-radius:10px;font:inherit;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .16s ease,color .16s ease}.nav-section:hover{background:#ffffff0d;color:#fff}.nav-section.active{color:#fff}.nav-section-meta{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.nav-section svg{transition:transform .2s var(--ease-out)}.nav-section[aria-expanded=true] svg{transform:rotate(180deg)}.nav-items-wrap{display:grid;grid-template-rows:0fr;opacity:0;overflow:hidden;transition:grid-template-rows .22s var(--ease-out),opacity .18s var(--ease-out)}.nav-items-wrap.is-open{grid-template-rows:1fr;opacity:1}.nav-items{display:flex;flex-direction:column;gap:2px;padding:0 0 8px;min-height:0;transform:translateY(-4px);transition:transform .22s var(--ease-out)}.nav-items-wrap.is-open .nav-items{transform:translateY(0)}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:#b9bcd0;font-weight:500;font-size:13.5px;transition:background .16s ease,color .16s ease,transform .16s ease}.nav-root-item{margin-bottom:6px}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item:active{transform:scale(.985)}.nav-item.active{background:linear-gradient(135deg,var(--sidebar-active-from),var(--sidebar-active-to));color:#fff;box-shadow:0 8px 20px #4f46e573}.nav-action-item{width:100%;border:0;background:transparent;font:inherit;cursor:pointer;text-align:left}.nav-static-item{cursor:default}.nav-static-item:hover{background:transparent;color:#b9bcd0}.nav-item .ico{width:20px;height:20px;display:grid;place-items:center;flex-shrink:0;opacity:.85}.nav-item.active .ico{opacity:1}.nav-item .ico svg{width:18px;height:18px}.sidebar-account{margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}.profile-menu{margin-bottom:8px;padding:8px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0a}.profile-menu-header,.profile-button{display:flex;align-items:center;gap:10px;min-width:0}.profile-menu-header{padding:4px 3px 8px}.profile-button{width:100%;border:0;border-radius:12px;padding:8px;background:#ffffff0d;color:#fff;cursor:pointer;font:inherit;text-align:left;transition:background .16s ease}.profile-button:hover{background:#ffffff14}.profile-button[aria-expanded=true] svg{transform:rotate(180deg)}.profile-button-copy{min-width:0;flex:1}.profile-menu-header .nm,.profile-button .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-menu-header .avatar,.profile-button .avatar{width:30px;height:30px;font-size:11px;flex:0 0 auto}.profile-page{display:grid;gap:var(--space-5);max-width:980px}.profile-form{display:grid;gap:var(--space-4)}.form-footer{display:flex;justify-content:flex-end}.sidebar-foot{margin-top:8px;border-top:1px solid rgba(255,255,255,.07);padding-top:14px;flex-shrink:0}.user-chip{display:flex;align-items:center;gap:10px;padding:6px 4px}.avatar{width:34px;height:34px;border-radius:50%;background:var(--grad-avatar);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0;box-shadow:inset 0 0 0 1px #ffffff29}.user-chip .nm{color:#fff;font-weight:600;font-size:13px;line-height:1.2}.user-chip .rl{color:#7b7f98;font-size:11.5px;text-transform:capitalize}.logout-btn{width:100%;margin-top:10px;background:#ffffff0f;color:#c7cadb;border:none;padding:9px;border-radius:9px;font-weight:600;font-size:13px;transition:background .14s}.logout-btn:hover{background:#ff50502e;color:#ff9a9a}.main{flex:1;margin-left:var(--sidebar-w);min-width:0}.topbar{height:64px;background:color-mix(in srgb,var(--surface) 82%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 32px;position:sticky;top:0;z-index:20}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}.topbar-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:40px;height:40px;border-radius:11px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);display:grid;place-items:center;font-size:18px;box-shadow:var(--shadow-sm);transition:background .14s,color .14s,border-color .14s,box-shadow .14s}.icon-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-strong)}.hamburger{display:none}.topbar h1{font-size:20px;font-weight:700;letter-spacing:-.4px}.topbar .sub{font-size:12.5px;color:var(--text-faint);margin-top:1px}.page{padding:28px 32px 56px;max-width:1280px;margin:0 auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-pad{padding:20px 22px}.onb-task{display:flex;align-items:center;gap:14px;width:100%;text-align:left;padding:16px 18px;cursor:pointer;transition:border-color .16s ease,box-shadow .16s ease,transform .12s ease}.onb-task:hover{border-color:var(--border-strong);box-shadow:0 6px 20px var(--primary-glow)}.onb-task:active{transform:translateY(1px)}@media (prefers-reduced-motion: reduce){.nav-items-wrap,.nav-items,.nav-section svg{transition:none}.onb-task{transition:none}.onb-task:active{transform:none}}.tt-add-cell{width:100%;min-height:56px;border:1px dashed var(--border-strong);border-radius:9px;background:transparent;color:var(--text-faint);cursor:pointer;font-size:18px;transition:border-color .15s ease,color .15s ease,background .15s ease}.tt-add-cell:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}@media (prefers-reduced-motion: reduce){.tt-add-cell{transition:none}}.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}.card-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:17px 22px;border-bottom:1px solid var(--border)}.card-head>div:first-child{min-width:0}.card-head>div:last-child{flex-wrap:wrap;justify-content:flex-end}.card-head h3{font-size:15px;font-weight:700}.card-head .muted{font-size:12.5px;color:var(--text-faint)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:22px}@media (max-width: 760px){.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}}@media (max-width: 420px){.stat-grid{grid-template-columns:1fr!important}}.teacher-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px;margin-bottom:var(--space-5)}.teacher-action-card{position:relative;display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:10px 12px;min-height:146px;padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:inherit;text-decoration:none;box-shadow:var(--shadow-sm);transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.teacher-action-card:hover{border-color:color-mix(in oklab,var(--primary) 35%,var(--border));box-shadow:var(--shadow-md);transform:translateY(-1px)}.teacher-action-copy{display:flex;flex-direction:column;min-width:0}.teacher-action-title{color:var(--text-muted);font-size:var(--font-sm);font-weight:700}.teacher-action-value{margin-top:8px;color:var(--text);font-size:24px;line-height:1.1;font-weight:800}.teacher-action-detail{margin-top:8px;color:var(--text-soft);font-size:var(--font-sm);line-height:1.35}.teacher-action-cta{grid-column:1 / -1;align-self:end;display:inline-flex;align-items:center;gap:4px;color:var(--primary);font-size:var(--font-sm);font-weight:800}.teacher-action-card.tone-red .teacher-action-cta{color:var(--red)}.teacher-action-card.tone-amber .teacher-action-cta{color:var(--amber)}.search .si{display:inline-flex}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}.stat:after{content:"";position:absolute;top:0;right:0;width:120px;height:120px;background:radial-gradient(circle at top right,var(--primary-glow),transparent 70%);pointer-events:none}.stat:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--border-strong)}.stat .label{font-size:12.5px;color:var(--text-soft);font-weight:500}.stat .value{font-size:27px;font-weight:800;letter-spacing:-.8px;margin-top:7px;font-variant-numeric:tabular-nums}.stat .foot{font-size:12px;color:var(--text-faint);margin-top:4px}.metric-grid{margin-bottom:var(--space-4)}.metric-card{min-height:104px}.metric-card.tone-green{border-color:color-mix(in srgb,var(--green) 24%,var(--border))}.metric-card.tone-amber{border-color:color-mix(in srgb,var(--amber) 24%,var(--border))}.metric-card.tone-red{border-color:color-mix(in srgb,var(--red) 24%,var(--border))}.metric-card.tone-blue{border-color:color-mix(in srgb,var(--blue) 24%,var(--border))}.stat .ico-badge{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:18px}.stat .ico-badge.tone-blue{background:var(--blue-soft);color:var(--blue)}.stat .ico-badge.tone-primary{background:var(--primary-soft);color:var(--primary)}.stat .ico-badge.tone-amber{background:var(--amber-soft);color:var(--amber)}.stat .ico-badge.tone-red{background:var(--red-soft);color:var(--red)}.grid-2{display:grid;grid-template-columns:1.5fr 1fr;gap:18px}.grid-cols{display:grid;gap:18px}@media (max-width: 1000px){.grid-2{grid-template-columns:1fr}}.table-wrap{overflow-x:auto;overscroll-behavior-x:contain;scrollbar-gutter:stable}table.tbl{width:100%;border-collapse:collapse;font-size:13.5px;line-height:1.45}table.tbl:not(.tbl-stack){min-width:720px}table.tbl.grid-table{min-width:max-content}.grid-table-wrap{border-top:1px solid var(--border)}table.tbl.tbl-stack{min-width:680px}.tbl thead th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-faint);font-weight:600;padding:12px 22px;border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap;position:sticky;top:0;z-index:1}.tbl tbody td{padding:12px 22px;border-bottom:1px solid var(--border);vertical-align:middle;max-width:340px}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr{transition:background .1s}.tbl tbody tr:hover{background:var(--surface-2)}.data-table .row-actions-head,.data-table .row-actions{width:1%;white-space:nowrap;text-align:right}.data-table .select-col{width:36px;max-width:36px}.data-table .strong-link,.strong-text{font-weight:700}.data-table .clickable-row{cursor:pointer}.data-table .clickable-row:focus-within,.data-table .clickable-row:hover{background:var(--surface-2)}.row-actions{position:relative}.inline-number-input{max-width:84px}.compact-input{width:160px;height:30px}.full-cell-input{width:100%;min-width:150px}.table-link-button{border:0;background:transparent;padding:0;font:inherit;color:var(--text);cursor:pointer}.setup-empty{text-align:center;padding:32px 0}.setup-empty-icon{color:var(--text-faint);margin-bottom:12px}.setup-empty h3{margin:0 0 6px}.setup-empty p{color:var(--text-soft);font-size:13.5px;max-width:380px;margin:0 auto 16px;line-height:1.5}.timetable-table{table-layout:fixed}.timetable-period-col{width:120px}.timetable-time-cell{font-variant-numeric:tabular-nums;color:var(--text-soft);font-size:12.5px}.timetable-period-name{font-weight:700;color:var(--text);font-size:13px}.timetable-kind-row{text-align:center;text-transform:capitalize;color:var(--text-soft);background:var(--surface-2);font-weight:600;font-size:12.5px}.timetable-grid-cell{padding:6px}.timetable-slot-card{background:var(--primary-soft);border-radius:8px;padding:8px 10px;min-height:56px}.timetable-slot-title{font-weight:700;font-size:13px}.timetable-slot-meta{font-size:11.5px;color:var(--text-soft)}.timetable-slot-actions{margin-top:6px;display:flex;gap:6px}.btn-xxs{padding:2px 8px;font-size:11px;min-height:22px}.timetable-panel{margin-bottom:14px}.timetable-panel-note{margin-top:10px;color:var(--text-faint);font-size:12px}.bulk-bar{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-4)}.bulk-bar>span{font-size:var(--font-sm);font-weight:700}.link-primary{color:var(--primary)}.text-action{border:none;background:transparent;color:var(--primary);padding:0;font:inherit;font-weight:650}.text-action:hover,.text-action:focus-visible{text-decoration:underline}.inline-badges{display:inline-flex;gap:6px;align-items:center;flex-wrap:wrap}.number-cell{font-variant-numeric:tabular-nums}.muted-cell{color:var(--text-soft)}.text-capitalize{text-transform:capitalize}.truncate-cell{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.progress-cell{display:flex;align-items:center;gap:var(--space-2);min-width:150px}.progress-cell .progress{flex:1}.progress-value{min-width:34px;font-size:var(--font-xs)}.table-caption{padding:10px 14px;font-size:var(--font-xs);color:var(--text-faint);border-bottom:1px solid var(--border)}.compact-error-list{display:flex;flex-direction:column;gap:2px;font-size:var(--font-xs)}.danger-text{color:var(--red)}.success-text{color:var(--green)}.warning-text{color:var(--amber)}.info-text{color:var(--blue)}.greeting-kicker{font-size:var(--font-sm);opacity:.85;position:relative}.greeting-title{font-size:var(--font-2xl);font-weight:800;position:relative}.greeting-subtitle{opacity:.9;margin-top:var(--space-2);position:relative;font-size:var(--font-md)}.section-card-lg{margin-bottom:var(--space-5)}.child-card-button{text-align:left;cursor:pointer;border:1px solid var(--border);background:var(--surface)}.progress-row{margin:14px 0;display:flex}.card-action-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:var(--space-2)}.download-inline{font-size:var(--font-xs);font-weight:600;color:var(--text-soft);cursor:pointer;white-space:nowrap}.download-inline.disabled{cursor:default}.gap-md{gap:var(--space-3)}.block-bottom-sm{margin-bottom:var(--space-3)}.block-bottom-md{margin-bottom:var(--space-4)}.text-sm{font-size:var(--font-sm)}.text-md{font-size:var(--font-md)}.text-xs{font-size:var(--font-xs)}.text-lg{font-size:var(--font-lg)}.text-xl{font-size:var(--font-xl)}.text-strong{font-weight:700}.text-heavy{font-weight:800}.text-muted{color:var(--text-soft)}.text-faint{color:var(--text-faint)}.text-danger{color:var(--red)}.text-success{color:var(--green)}.copy-relaxed{line-height:1.5}.center-panel{text-align:center}.hidden-input{display:none}.file-trigger{cursor:pointer}.form-grid-map{display:grid;grid-template-columns:minmax(120px,180px) 1fr;gap:8px 14px;align-items:center}.form-map-label{font-size:var(--font-sm);text-transform:capitalize}.required-mark{color:var(--red)}.card-action-bar{display:flex;align-items:center;gap:var(--space-3)}.wizard-steps{display:flex;gap:6px;margin-bottom:var(--space-4);font-size:12px;color:var(--text-faint)}.wizard-step-active{color:var(--primary);font-weight:700}.wizard-row-list{display:flex;flex-direction:column;gap:6px;margin-top:6px}.selectable-card-row{display:flex;align-items:center;gap:var(--space-3);padding:9px 12px;text-align:left;cursor:pointer}.selectable-card-row.is-selected{border-color:var(--primary);outline:1px solid var(--primary)}.empty-inline-message{color:var(--text-soft);font-size:var(--font-sm);padding:6px 2px}.payment-context-row{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.payment-balance{margin-left:auto;text-align:right}.amount-positive{color:var(--green)}.amount-warning{color:var(--amber)}.amount-danger{color:var(--red)}.invoice-amount-col{text-align:right;min-width:80px}.receipt-panel{text-align:center;padding:12px 0 8px}.receipt-check{color:var(--green);margin-bottom:10px}.receipt-check-mark{font-size:40px;line-height:1}.receipt-amount{font-weight:800;font-size:22px}.receipt-summary{margin-top:14px;display:inline-flex;gap:18px;padding:10px 18px;border-radius:var(--radius);background:var(--surface-2)}.action-card-row,.action-card-shell{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.action-card-row{flex:1;display:flex;align-items:center;gap:var(--space-3);padding:11px 12px;color:inherit;text-decoration:none;transition:background .12s}.action-card-row:hover{background:var(--surface-2)}.action-row-wrap{display:flex;align-items:stretch;gap:6px}.action-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--primary)}.action-dot.severity-critical{background:var(--red)}.action-dot.severity-warning{background:var(--amber)}.action-dot.severity-info{background:var(--primary)}.action-icon{color:var(--text-soft);display:flex;flex-shrink:0}.action-count{font-variant-numeric:tabular-nums;font-weight:700;font-size:15px}.action-count.severity-critical{color:var(--red)}.action-count.severity-warning{color:var(--amber)}.action-count.severity-info{color:var(--primary)}.action-label{font-size:var(--font-xs);font-weight:600;color:var(--primary);white-space:nowrap}.action-card-head{display:flex;align-items:center;gap:var(--space-3);padding:11px 12px}.action-resolve-body{padding:0 12px 12px}.resolve-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2)}.compact-reject-input{height:32px;width:150px}.caught-up{text-align:center;padding:18px 0;color:var(--text-soft);font-size:var(--font-sm)}.caught-up-icon{color:var(--green);margin-bottom:4px}.snooze-button{flex-shrink:0}.setup-hero{margin-bottom:16px}.setup-hero-row{display:flex;align-items:center;gap:22px;flex-wrap:wrap}.setup-step-head{display:flex;align-items:center;gap:12px;margin-bottom:6px}.setup-stage-body{margin-top:14px}.checklist-flow{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.checklist-node{display:inline-flex;align-items:center;gap:8px}.badge-button{cursor:pointer;border:none}.transport-toolbar{flex-wrap:wrap}.demo-status{display:flex;align-items:center;gap:var(--space-2);border-left:3px solid var(--amber);padding-left:var(--space-3);color:var(--text-soft);font-size:var(--font-sm)}.map-shell{padding:14px}.map-loading{height:460px;display:grid;place-items:center}.fleet-count{color:var(--text-faint);font-size:var(--font-sm)}.fleet-row-main{flex:1;min-width:0;text-align:left}.fleet-row-meta{text-align:right;white-space:nowrap}.center-loading{display:grid;place-items:center;padding:80px 0}.page-shell{max-width:920px;margin:0 auto}.page-shell-sm{max-width:640px;margin:0 auto}.task-hero{margin-bottom:16px;display:flex;gap:14px;align-items:flex-start}.task-icon-fixed{flex-shrink:0}.task-list{display:grid;gap:10px}.onb-task-body{flex:1}.task-status{font-size:var(--font-xs);color:var(--text-soft);flex-shrink:0}.task-status.is-done{color:var(--green)}.chevron-muted{color:var(--text-faint);font-size:18px}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3);margin-bottom:var(--space-4)}.mini-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;display:grid;gap:var(--space-2)}.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.choice-tile{display:flex;gap:9px;align-items:center;padding:8px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}.choice-tile.is-selected{background:var(--surface-2)}.choice-tile-start{align-items:flex-start;padding:9px 11px}.role-module-list{display:grid;gap:var(--space-4);margin-top:var(--space-3)}.role-module-title{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-faint);margin-bottom:8px}.permission-list{display:grid;gap:var(--space-2)}.permission-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(150px,210px);gap:var(--space-3);align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 11px}.permission-row.is-selected{background:var(--surface-2)}.permission-check{display:flex;gap:10px;align-items:flex-start}.check-offset{margin-top:2px}.access-preview{margin-top:6px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}.access-preview-title{font-weight:700;font-size:var(--font-sm);margin-bottom:8px}.action-subtitle{font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);font-weight:600;margin-bottom:6px}.self-edit-note{background:var(--surface-2);border-radius:var(--radius-sm);padding:10px 12px;font-size:var(--font-sm);color:var(--text-soft);margin-bottom:14px;display:flex;gap:var(--space-2);align-items:center}.selectable-card{cursor:pointer;border-radius:14px;border:1px solid transparent}.selectable-card.is-active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.exam-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-bottom:18px}.sticky-student-col{position:sticky;left:0;background:var(--surface-2)}.center-cell{text-align:center}.mark-input{width:64px;padding:6px 8px;text-align:center}.mark-input.readonly{background:var(--surface-2);color:var(--text-faint);cursor:not-allowed}.primary-mark{color:var(--primary)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.calendar-legend{display:flex;gap:14px;font-size:var(--font-xs);color:var(--text-faint)}.ring-center{display:flex;justify-content:center;margin-bottom:18px}.summary-stat-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}.summary-stat-box{flex:1;min-width:70px;text-align:center;background:var(--surface-2);border-radius:10px;padding:10px 4px}.modal-list{display:flex;flex-direction:column;gap:6px}.modal-list-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border)}.modal-note{flex:1;font-size:12px;color:var(--text-faint);text-align:right}.palette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding:12vh 16px 16px}.palette-panel{width:100%;max-width:600px;max-height:70vh;display:flex;flex-direction:column;background:var(--surface, #fff);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 60px #00000052;overflow:hidden}.palette-field{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.palette-input{flex:1;border:none;outline:none;background:transparent;font-size:16px;color:var(--text);padding:0}.palette-spinner{width:14px;height:14px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--primary);animation:spin .7s linear infinite;flex-shrink:0}.palette-list{overflow-y:auto;padding:8px;min-height:160px}.palette-group-label{font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;padding:10px 8px 5px}.palette-row{width:100%;border:none;background:transparent;display:flex;align-items:center;gap:10px;padding:9px 8px;border-radius:9px;cursor:pointer}.palette-row.is-active{background:var(--surface-2)}.palette-hint{text-align:center;color:var(--text-faint);font-size:var(--font-sm);padding:42px 28px}.palette-footer{display:flex;justify-content:flex-end;gap:14px;padding:9px 12px;border-top:1px solid var(--border);color:var(--text-faint);font-size:11.5px}.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:6px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-soft);font-size:11px;font-family:inherit}.kbd-small{min-width:17px;height:17px;padding:0 5px;font-size:10.5px}.palette-row-title{display:block;font-size:13.5px;font-weight:600;color:var(--text)}.palette-badge{font-size:11px;color:var(--text-soft);border:1px solid var(--border);border-radius:6px;padding:1px 6px;flex-shrink:0}.quick-link-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.quick-link-icon{background:var(--primary-soft);color:var(--primary)}.report-intro{color:var(--text-soft);font-size:var(--font-sm);margin-bottom:var(--space-4);max-width:660px}.report-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4)}.report-card-body{display:flex;flex-direction:column;height:100%}.report-card-title{font-size:var(--font-md);font-weight:700}.report-card-desc{font-size:var(--font-xs);color:var(--text-faint);margin:var(--space-2) 0 var(--space-3);line-height:1.5}.report-filter-row{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.report-filter-input{max-width:130px}.theme-switcher{position:fixed;right:18px;bottom:18px;z-index:2000;display:flex;flex-direction:column;align-items:flex-end;gap:10px;font-family:inherit}.theme-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius, 16px);box-shadow:var(--shadow-lg);padding:14px;width:232px;color:var(--text)}.theme-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-faint);margin-bottom:10px}.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.theme-option{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:10px;cursor:pointer;text-align:left;background:transparent;border:1px solid var(--border);color:var(--text);font:inherit;font-size:12.5px}.theme-option.is-active{background:var(--primary-soft);border-color:var(--primary)}.theme-swatch{width:18px;height:18px;border-radius:6px;flex-shrink:0;box-shadow:inset 0 0 0 1px #00000014}.theme-mode-row{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}.theme-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;cursor:pointer;background:var(--surface-2);border:1px solid var(--border);color:var(--text);font:inherit;font-size:13px}.theme-fab{width:46px;height:46px;border-radius:999px;cursor:pointer;border:none;background:var(--grad-primary, var(--primary));color:#fff;box-shadow:var(--shadow-primary);font-size:19px;display:grid;place-items:center}.copy-note{font-size:var(--font-sm);color:var(--text-soft);margin-bottom:14px;line-height:1.6}.copy-note-xs{font-size:var(--font-xs);color:var(--text-soft);margin-bottom:10px;line-height:1.5}.warning-note{margin-top:6px;font-size:var(--font-xs);color:var(--amber)}.section-rule{border:none;border-top:1px solid var(--border);margin:18px 0}.copy-control-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.field-130{max-width:130px}.field-150{max-width:150px}.field-160{max-width:160px}.field-170{max-width:170px}.field-200{max-width:200px}.field-260{max-width:260px}.side-card{align-self:start}.vehicle-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:14px}.vehicle-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary)}.vehicle-kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.vehicle-kpi{background:var(--surface-2);border-radius:12px;padding:12px}.map-relative{position:relative}.map-canvas{height:420px}.approval-detail{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}.approval-meta-grid{display:grid;grid-template-columns:minmax(110px,180px) minmax(0,1fr);gap:8px 14px}.announcement-grid{gap:var(--space-4)}.announcement-card-head{display:flex;justify-content:space-between;gap:12px}.announcement-actions{display:flex;gap:6px;flex-shrink:0}.choice-wrap{display:flex;flex-wrap:wrap;gap:14px}.choice-line{display:flex;align-items:center;gap:8px}.choice-line-sm{display:flex;align-items:center;gap:6px;font-size:var(--font-sm)}.template-toolbar{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.textarea-sm{min-height:70px}.today-empty{text-align:center;padding:48px 24px}.today-empty-icon{color:var(--green);margin-bottom:10px}.class-grid{grid-template-columns:1fr 1fr}.class-card{cursor:pointer}.class-card.is-active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.class-icon{width:42px;height:42px;border-radius:11px;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-weight:800;font-size:var(--font-md)}.settings-block{margin-bottom:var(--space-5)}.mono-input{font-family:var(--mono, monospace)}.line-panel{background:var(--surface-2);border-radius:var(--radius-sm);padding:var(--space-3);margin-bottom:var(--space-2)}.field-row-flush{margin-bottom:0}.field-row-end{margin-bottom:0;align-items:flex-end}.total-row{display:flex;justify-content:space-between;align-items:baseline;margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border);font-variant-numeric:tabular-nums}.button-bottom-align{margin-bottom:var(--space-2)}.icon-skeleton{width:18px;height:18px;border-radius:6px}.line-skeleton-md{width:45%;height:11px}.line-skeleton-sm{width:28%;height:9px}.center-text{text-align:center}.center-icon{margin-left:auto;margin-right:auto}.kanban-grid{display:grid;grid-template-columns:repeat(var(--kanban-columns, 4),minmax(210px,1fr));gap:var(--space-4);overflow-x:auto;padding-bottom:var(--space-2)}.kanban-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 2px}.kanban-card{padding:14px}.empty-dashed{font-size:var(--font-xs);color:var(--text-faint);text-align:center;padding:var(--space-5) 0;border:1px dashed var(--border);border-radius:var(--radius-sm)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.prewrap-copy{font-size:var(--font-sm);line-height:1.7;white-space:pre-wrap}.admit-note{font-size:var(--font-sm);color:var(--text-soft);margin-bottom:var(--space-5);line-height:1.6}.checkbox-line{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm)}.journal-line{display:flex;gap:var(--space-2);align-items:center}.journal-account{flex:2}.journal-amount{flex:1}.journal-description{flex:1.5}.journal-totals{margin-top:var(--space-3);display:flex;justify-content:flex-end;gap:var(--space-6);font-weight:700;font-variant-numeric:tabular-nums}.control-card{display:flex;gap:18px;flex-wrap:wrap;align-items:flex-end}.field-flush{margin:0}.field-flex{flex:1;min-width:220px}.slot-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.slot-time{min-width:96px;font-variant-numeric:tabular-nums;font-weight:600;color:var(--text-soft);font-size:var(--font-sm)}.summary-card-row{display:flex;align-items:center;gap:14px}.submission-row{border-bottom:1px solid var(--border);padding-bottom:8px}.chat-list{display:grid;gap:var(--space-2);padding:var(--space-3)}.chat-row{display:grid;grid-template-columns:42px minmax(0,1fr) auto;align-items:center;gap:var(--space-3);width:100%;text-align:left;padding:var(--space-3);border-radius:8px}.chat-row.is-active{background:var(--surface-2)}.text-ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-log{min-height:420px;max-height:560px;overflow:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);background:var(--bg)}.chat-shell-grid{display:grid;grid-template-columns:300px 1fr;gap:16px;min-height:420px}.chat-panel{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;max-height:560px}.chat-panel-scroll{overflow-y:auto}.chat-session-row{display:block;width:100%;text-align:left;padding:11px 13px;border:none;border-bottom:1px solid var(--border);background:transparent;cursor:pointer}.chat-session-row.is-active{background:var(--surface-2)}.chat-panel-column{display:flex;flex-direction:column}.chat-empty-center{flex:1;display:flex;align-items:center;justify-content:center}.chat-header{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border);flex-wrap:wrap}.chat-composer{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--border)}.chat-closed-note{padding:12px 14px;border-top:1px solid var(--border);color:var(--text-faint);font-size:var(--font-sm)}.chat-message{max-width:76%}.chat-message.self{align-self:flex-end}.chat-message.other{align-self:flex-start}.chat-bubble{padding:10px 12px;border-radius:8px;background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);white-space:pre-wrap}.chat-message.self .chat-bubble{background:var(--primary);color:#fff}.settings-form{max-width:620px}.settings-profile-grid{display:flex;gap:var(--space-5);align-items:flex-start}.logo-preview{width:84px;height:84px;object-fit:contain;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2)}.auto-stat-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.dashboard-chart{height:280px}.ops-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);padding:var(--space-5)}.announcement-list{padding:var(--space-2) 0}.announcement-row{padding:13px 22px;border-bottom:1px solid var(--border)}.portal-ring-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:var(--space-6)}.mini-stat-wrap{display:flex;gap:var(--space-3);flex-wrap:wrap}.mini-stat-card{flex:1;min-width:76px;text-align:center;padding:13px 6px;background:var(--surface-2);border-radius:12px}.timetable-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-3)}.timetable-day-card{background:var(--surface-2);border-radius:12px;padding:12px 12px 6px}.timetable-day-title{font-weight:700;font-size:var(--font-sm);margin-bottom:var(--space-2)}.clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.status-line{font-size:var(--font-sm);font-weight:600}.reference-panel{border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:var(--space-4);background:var(--bg-soft, transparent)}.reference-title{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-xs);font-weight:700;color:var(--text-soft);margin-bottom:10px}.reference-group{margin-bottom:8px}.chip-overflow{font-size:12px;color:var(--text-faint);align-self:center}.clamped-card-copy{color:var(--text-soft);margin:var(--space-2) 0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.detail-inline-panel{display:flex;gap:var(--space-5);align-items:center;flex-wrap:wrap}.detail-header-row{display:flex;gap:var(--space-4);justify-content:space-between;flex-wrap:wrap}.detail-header-title{margin:0}.detail-actions-row{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.info-row{margin-top:var(--space-3)}.card-section-title{margin-top:0}.card-pad.flush-bottom{padding-bottom:0}.modal-metric{font-size:var(--font-xl);font-weight:800}.push-right{margin-left:auto}.section-top{margin-top:var(--space-4)}.section-left-sm{margin-left:8px}.section-top-lg{margin-top:var(--space-5)}.mini-list-row{display:flex;justify-content:space-between;gap:var(--space-3);padding:6px 0;border-bottom:1px solid var(--border)}.reply-row{display:flex;gap:var(--space-2);width:100%}.message-stack{display:flex;flex-direction:column;gap:var(--space-3)}.message-bubble{align-self:flex-start;max-width:80%;background:var(--surface-2);border-radius:12px;padding:9px 12px}.message-bubble.mine{align-self:flex-end;background:var(--primary-soft)}.message-meta{font-size:11.5px;color:var(--text-faint);margin-bottom:2px}.message-body{font-size:var(--font-md);white-space:pre-wrap}.cell-name{display:flex;align-items:center;gap:11px;font-weight:600;min-width:0}.cell-name .avatar{width:32px;height:32px;font-size:12px}.cell-sub{color:var(--text-faint);font-size:12px;font-weight:400;overflow-wrap:anywhere}@media (max-width: 600px){table.tbl.tbl-stack,table.tbl.tbl-stack tbody,table.tbl.tbl-stack tr,table.tbl.tbl-stack td{display:block;width:100%;min-width:0}table.tbl.tbl-stack{min-width:0}table.tbl.tbl-stack thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}table.tbl.tbl-stack tr{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:6px 12px;margin-bottom:10px}table.tbl.tbl-stack tr:last-child{margin-bottom:0}table.tbl.tbl-stack tbody tr:hover{background:var(--surface-2)}table.tbl.tbl-stack td{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:7px 0;border:none;border-bottom:1px solid var(--border);text-align:right}table.tbl.tbl-stack td:last-child{border-bottom:none}table.tbl.tbl-stack td[data-label]:before{content:attr(data-label);flex:0 0 auto;margin-right:auto;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-faint);font-weight:600}table.tbl.tbl-stack td:not([data-label]),table.tbl.tbl-stack td[data-label=""]{justify-content:flex-end}table.tbl.tbl-stack td:first-child:not([data-label]){display:block;text-align:left}table.tbl.tbl-stack td:first-child:not([data-label]) .cell-sub{text-align:left}table.tbl.tbl-stack .cell-sub{text-align:right}}.stat-grid-auto{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap;line-height:1.25}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge.green{background:var(--green-soft);color:var(--green)}.badge.amber{background:var(--amber-soft);color:var(--amber)}.badge.red{background:var(--red-soft);color:var(--red)}.badge.blue{background:var(--blue-soft);color:var(--blue)}.badge.gray{background:var(--gray-soft);color:var(--text-soft)}.badge.no-dot:before{display:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:40px;padding:9px 15px;border-radius:10px;border:1px solid transparent;font-weight:650;font-size:13.5px;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,transform .12s ease,filter .16s ease;white-space:nowrap;text-decoration:none;cursor:pointer}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 1px 2px #14172814,0 6px 14px #4f46e52e}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);filter:none;box-shadow:0 2px 4px #1417281a,0 8px 18px #4f46e538}.btn-ghost{background:var(--surface);color:var(--text);border-color:var(--border);box-shadow:none}.btn-ghost:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-sm{min-height:32px;padding:6px 12px;font-size:12.5px;border-radius:8px}.btn-danger{background:var(--red);color:#fff;box-shadow:0 4px 12px #dc262647}.btn-danger:hover{filter:brightness(.94)}.btn-danger-ghost{background:transparent;color:var(--text-faint);border-color:transparent;padding:6px 9px}.btn-danger-ghost:hover{background:var(--red-soft);color:var(--red)}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;filter:none;transform:none}.btn:focus-visible,.icon-btn:focus-visible,.x-btn:focus-visible,.pill-tabs button:focus-visible,a:focus-visible,button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--primary-glow)}.field{margin-bottom:14px}.field label{display:block;font-size:12.5px;font-weight:600;color:var(--text-soft);margin-bottom:6px}.input,.textarea{width:100%;min-height:40px;padding:9px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);box-shadow:inset 0 1px #14172805;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease;outline:none}.select-trigger{width:100%;min-height:40px;padding:9px 10px 9px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);box-shadow:inset 0 1px #14172805;display:inline-flex;align-items:center;justify-content:space-between;gap:10px;font:inherit;font-size:14px;line-height:1.35;outline:none;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease}.select-trigger>span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select-trigger:hover{background:var(--surface-2);border-color:var(--border-strong)}.select-trigger:focus,.select-trigger[data-state=open]{background:var(--surface);border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.select-trigger.invalid{border-color:var(--red)}.select-trigger.invalid:focus,.select-trigger.invalid[data-state=open]{box-shadow:0 0 0 3px var(--red-soft)}.select-trigger:disabled,.select-trigger[data-disabled]{opacity:.55;cursor:not-allowed}.select-trigger-icon{color:var(--text-faint);flex:0 0 auto;display:inline-flex}.select-content{z-index:100;min-width:var(--radix-select-trigger-width);max-height:min(var(--radix-select-content-available-height),320px);overflow:hidden;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);box-shadow:var(--shadow-lg);animation:selectContentIn .12s var(--ease-out)}.menu-content{z-index:120;min-width:168px;overflow:hidden;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);box-shadow:var(--shadow-lg);padding:5px;animation:selectContentIn .12s var(--ease-out)}.menu-item{min-height:34px;border-radius:7px;padding:7px 10px;display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--text);outline:none;cursor:default;-webkit-user-select:none;user-select:none}.menu-item[data-highlighted]{background:var(--primary-soft);color:var(--primary)}.menu-item.danger{color:var(--red)}.menu-item.danger[data-highlighted]{background:var(--red-soft);color:var(--red)}.menu-item[data-disabled]{color:var(--text-faint);opacity:.55}.action-menu-trigger{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);display:inline-grid;place-items:center}.action-menu-trigger:hover,.action-menu-trigger[data-state=open]{background:var(--surface-2);border-color:var(--border-strong);color:var(--text)}.select-viewport{padding:5px}.select-item{position:relative;min-height:34px;border-radius:8px;padding:7px 32px 7px 10px;display:flex;align-items:center;font-size:13.5px;color:var(--text);outline:none;cursor:default;-webkit-user-select:none;user-select:none}.select-item[data-highlighted]{background:var(--primary-soft);color:var(--primary)}.select-item[data-state=checked]{font-weight:650}.select-item[data-disabled]{color:var(--text-faint);opacity:.55}.select-item-indicator{position:absolute;right:9px;display:inline-flex;color:var(--primary)}@keyframes selectContentIn{0%{opacity:0;transform:translateY(-3px) scale(.98)}}.input:hover,.textarea:hover{background-color:var(--surface-2);border-color:var(--border-strong)}.input:focus,.textarea:focus{background-color:var(--surface);border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.textarea{resize:vertical;min-height:84px}.password-field{position:relative}.password-input{padding-right:64px}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);min-height:26px;border:1px solid transparent;border-radius:7px;background:transparent;color:var(--text-faint);padding:2px 7px;font-weight:650;font-size:var(--font-xs)}.password-toggle:hover,.password-toggle:focus-visible{background:var(--surface-2);border-color:var(--border);color:var(--text)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.compact-date-field{width:min(170px,100%)}.check-row{display:flex;align-items:center;gap:var(--space-2);font-size:13.5px;color:var(--text)}.clickable-row{cursor:pointer}.check-row-tall{min-height:38px}.chip-picker{display:flex;flex-wrap:wrap;gap:var(--space-2);max-height:200px;margin-top:var(--space-1);overflow-y:auto}.chip-picker-item{cursor:pointer;border:1px solid var(--border);padding:5px 11px}.table-footer{display:flex;justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3)}.table-footer.split{justify-content:space-between;border-top:1px solid var(--border);color:var(--text-soft);font-size:var(--font-sm)}.table-section{margin-bottom:var(--space-5)}.section-card{margin-top:var(--space-4);margin-bottom:var(--space-4)}.page-back-link{display:inline-block;margin-bottom:var(--space-4)}.inline-top-link{display:inline-block;margin-top:var(--space-3)}.with-bottom-space{margin-bottom:var(--space-3)}.detail-subtitle{margin:0 0 var(--space-2);font-size:var(--font-sm)}.subtle-strip{padding:var(--space-2) 14px;font-size:var(--font-xs);color:var(--text-faint)}.tab-count-badge{margin-left:6px}.compact-panel{margin-bottom:var(--space-4);padding:var(--space-3) var(--space-4);font-size:var(--font-sm)}.meta-line{margin-top:var(--space-2)}.relation-field-wrap{margin-top:var(--space-1)}.relative-box{position:relative}.picker-popover{position:absolute;z-index:20;top:calc(100% + 4px);left:0;right:0;max-height:240px;overflow-y:auto;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md, 0 4px 16px rgba(0, 0, 0, .12))}.picker-empty{padding:var(--space-3);color:var(--text-faint);font-size:var(--font-sm)}.picker-option{display:block;width:100%;text-align:left;padding:var(--space-2) var(--space-3);background:transparent;border:none;cursor:pointer;font-size:var(--font-sm)}.picker-option:hover,.picker-option:focus-visible{background:var(--surface-2)}.tab-count-badge{margin-left:var(--space-2)}.align-start-grid{align-items:start}.stack-sm,.stack-md{display:flex;flex-direction:column}.stack-sm{gap:var(--space-2)}.stack-md{gap:var(--space-3)}.inline-alert-row{display:flex;align-items:flex-start;gap:10px}.min-w-0{min-width:0}.profile-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}.avatar-lg{width:56px;height:56px;font-size:20px}.profile-title{flex:1;min-width:0}.profile-title-main{font-size:20px;font-weight:800}.shrink-0{flex-shrink:0}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.detail-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);font-weight:600;margin-bottom:3px}.detail-value{font-size:14px;font-weight:500}.list-row{display:flex;align-items:center;gap:var(--space-3);padding:10px 0;border-bottom:1px solid var(--border)}.list-row.vertical{display:block;padding:12px 0}.body-copy{font-size:13.5px;margin-bottom:var(--space-2)}.modal-title-text{font-weight:800;font-size:18px}.payment-links{margin-top:4px}.payment-link{margin-right:10px}.compact-summary-table{margin-bottom:var(--space-2)}.compact-summary-table td{padding:var(--space-2) 0}.right-cell{text-align:right}.summary-stack{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) 0;border-top:1px solid var(--border)}.summary-row,.summary-total-row{display:flex;justify-content:space-between;gap:var(--space-3)}.summary-total-row{align-items:baseline;margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border)}.summary-label{color:var(--text-soft)}.summary-value{font-weight:600}.summary-total-value{font-weight:800;font-size:var(--font-lg)}.summary-panel{background:var(--surface-2);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);font-size:var(--font-sm)}.summary-panel-line{margin-top:var(--space-2)}.form-line-row{display:flex;gap:var(--space-2);align-items:center}.with-bottom-gap{margin-bottom:var(--space-2)}.form-total-text{margin-top:var(--space-4);text-align:right;font-weight:800;font-size:var(--font-lg)}.microcopy{font-size:var(--font-xs);color:var(--text-faint)}.flex-1{flex:1}.flex-2{flex:2}.compact-list{margin:0;padding-left:18px;font-size:13.5px;display:flex;flex-direction:column;gap:4px}.responsive-two-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4)}.responsive-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4)}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.panel-head.compact{gap:var(--space-2)}.panel-head.baseline{align-items:baseline}.panel-head.bordered{border-bottom:1px solid var(--border)}.clickable-inline{cursor:pointer}.demo-banner{display:flex;align-items:center;gap:10px;background:var(--blue-soft);color:var(--blue);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;font-weight:500;margin-bottom:16px}.load-more-row{display:flex;justify-content:center;padding:var(--space-4) 0}.load-more-row.compact{padding:var(--space-3)}.badge-offset{margin-left:var(--space-2)}.detail-badges{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4)}.detail-note-panel{background:var(--surface-2);border-radius:var(--radius-sm);padding:12px 14px;font-size:var(--font-sm);line-height:1.6;white-space:pre-wrap;margin-bottom:var(--space-4)}.modal-context-note{font-size:var(--font-sm);color:var(--text-soft);margin-bottom:var(--space-4);line-height:1.5}.modal-context-note.compact{margin-bottom:var(--space-3)}.search-wide{max-width:none}.inline-badges{display:flex;gap:6px;flex-wrap:wrap}.recipient-preview{font-size:var(--font-sm);color:var(--text-soft)}.recipient-preview strong{color:var(--text)}.nav-count{margin-left:auto;font-variant-numeric:tabular-nums}.palette-trigger{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 10px 0 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);color:var(--text-soft);cursor:pointer;font:inherit;font-size:13.5px}.campus-select{max-width:180px;height:40px}.route-loading{display:grid;place-items:center;padding:80px 0}.inline-token{display:inline-flex;align-items:center;gap:var(--space-1);cursor:pointer;border-radius:6px;transition:background var(--dur-1) var(--ease-out)}.inline-token.padded{padding:var(--space-1) var(--space-2);margin:calc(-1 * var(--space-1)) calc(-1 * var(--space-2))}.role-chip-row{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-1)}.chip-button{cursor:pointer;border:1px solid var(--border);padding:5px 11px}.chat-time{margin-top:4px}.chat-time.tiny{font-size:11px;color:var(--text-faint);margin-top:3px}.chat-time.self{text-align:right}.chat-time.other{text-align:left}.demo-note{padding:var(--space-2) 14px;font-size:var(--font-xs);color:var(--text-faint)}.map-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--surface-2);border-radius:12px}.demo-role-select{max-width:150px;height:32px;padding:2px 8px;font-size:12.5px}.reject-inline{display:flex;gap:6px;align-items:center}.link-plain{text-decoration:none}.unread-dot{width:8px;height:8px;display:inline-block;border-radius:999px;background:var(--blue)}.loading-block{display:grid;place-items:center;padding:48px 0}.compact-bottom{margin-bottom:4px}.compact-top{margin-top:4px}.soft-panel{background:var(--surface-2);border-radius:var(--radius-sm);padding:10px 12px}.answer-review-card{background:var(--surface);border-radius:var(--radius-sm);padding:8px 10px;font-size:13.5px}.top-gap-sm{margin-top:6px}.top-gap-md{margin-top:8px}.top-gap-lg{margin-top:12px}.marks-field{width:100px}.feedback-field{flex:1;min-width:160px}.form-actions-right{margin-top:12px;text-align:right}.no-margin{margin:0}.block-text{display:block}.route-card-list{display:grid;gap:var(--space-2);padding:0 16px 16px}.route-select-card{text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:8px;cursor:pointer}.route-select-card.selected{border-color:var(--primary);background:var(--primary-soft)}.route-select-head{display:flex;justify-content:space-between;gap:var(--space-2)}.route-select-meta{margin-top:4px}.feature-link-card{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);text-decoration:none;color:inherit}.feature-link-icon{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);flex-shrink:0}.feature-link-copy{flex:1;min-width:0}.kv-stack{margin-top:14px}.kv-row{display:flex;justify-content:space-between;gap:var(--space-3);font-size:var(--font-sm);margin-bottom:6px}.kv-row>span:first-child{color:var(--text-soft)}.kv-foot{margin-top:12px;padding-top:10px;border-top:1px solid var(--border);font-size:12.5px;color:var(--text-faint)}.empty-inline{margin-top:18px;color:var(--text-faint);font-size:var(--font-sm)}.form-inline-grid{display:flex;gap:var(--space-3);flex-wrap:wrap;align-items:flex-end}.field.field-inline,.field.field-inline-grow{margin:0}.field-inline-grow{flex:1 1 220px}.full-search{max-width:none}.compact-filter{max-width:150px}.wide-filter{max-width:190px}.inline-actions{display:inline-flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.top-action-panel{margin-bottom:14px}.arrow-separator{color:var(--text-faint);margin:0 2px}.helper-panel{color:var(--text-soft);font-size:var(--font-sm)}.helper-panel-action{margin-top:var(--space-2)}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.toolbar>.input,.toolbar>.select-trigger{flex:0 1 220px}.toolbar>.btn,.toolbar>a.btn{flex:0 0 auto}.filter-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-4)}.filter-controls{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;flex:1 1 520px;min-width:0}.filter-controls>.select-trigger{flex:0 1 210px}.filter-date-field{display:grid;gap:4px;flex:0 0 156px;min-width:148px}.filter-date-field span{color:var(--text-faint);font-size:11px;font-weight:700;letter-spacing:.02em}.filter-date-field .input{min-height:38px;padding-inline:10px}.filter-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);flex-wrap:wrap;margin-left:auto}.filter-count{display:inline-flex;align-items:center;justify-content:center;min-height:28px;min-width:70px;padding:4px 9px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:var(--font-xs);font-weight:700}.filter-count.is-empty{visibility:hidden}.homework-done-title{color:var(--text-faint);text-decoration:line-through}.search-input{position:relative;flex:1 1 300px;min-width:min(280px,100%);max-width:420px}.search-input>svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-faint);pointer-events:none;z-index:1}.search-input .input{padding-left:38px;padding-right:38px}.search-clear{position:absolute;right:7px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--text-faint);display:grid;place-items:center}.search-clear:hover,.search-clear:focus-visible{background:var(--surface-2);border-color:var(--border);color:var(--text)}.search{position:relative;flex:1 1 300px;min-width:240px;max-width:420px}.search input{width:100%;min-height:40px;padding:9px 12px 9px 38px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);box-shadow:inset 0 1px #14172805;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease;outline:none}.search input:hover{background:var(--surface-2);border-color:var(--border-strong)}.search input:focus{background:var(--surface);border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.search .si{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-faint)}.spacer{flex:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14172873;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;z-index:60;padding:20px;animation:fade .16s ease;overflow:hidden}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-width:min(640px,calc(100vw - 32px));max-height:90vh;overflow:hidden;animation:pop .18s ease;display:flex;flex-direction:column}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:20px 24px;border-bottom:1px solid var(--border);flex:0 0 auto}.modal-head h3{font-size:17px;font-weight:700;min-width:0;overflow-wrap:anywhere}.modal-body{padding:22px 24px;overflow-y:auto;min-height:0}.modal-foot{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:10px;padding:16px 24px;border-top:1px solid var(--border);flex:0 0 auto;background:var(--surface)}.x-btn{background:var(--surface);border:1px solid transparent;font-size:20px;color:var(--text-faint);line-height:1;width:34px;height:34px;display:grid;place-items:center;border-radius:9px;transition:background .16s ease,border-color .16s ease,color .16s ease}.x-btn:hover{background:var(--surface-2);border-color:var(--border);color:var(--text)}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}.empty{text-align:center;padding:48px 20px;color:var(--text-faint)}.empty .ei{display:inline-grid;place-items:center;width:58px;height:58px;margin:0 auto 14px;border-radius:14px;background:var(--surface-2);color:var(--text-faint);border:1px solid var(--border)}.empty .et{font-weight:600;color:var(--text-soft);margin-bottom:4px}.spinner{width:30px;height:30px;border:3px solid var(--primary-soft);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:60px auto}@keyframes spin{to{transform:rotate(360deg)}}.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);margin:26px 0 12px}.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-art{background:var(--grad-hero);position:relative;overflow:hidden;color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between}.login-art:before{content:"";position:absolute;width:460px;height:460px;border-radius:50%;background:#ffffff17;top:-160px;right:-120px}.login-art:after{content:"";position:absolute;width:320px;height:320px;border-radius:50%;background:#ffffff12;bottom:-120px;left:-80px}.login-art .la-top,.login-art .la-mid,.login-art .la-foot{position:relative;z-index:2}.login-foot-muted{opacity:.7;font-size:13px}.login-art .la-brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:18px}.login-art h2{font-size:38px;font-weight:800;line-height:1.12;letter-spacing:-1px;margin-bottom:16px}.login-art p{font-size:15px;opacity:.85;max-width:380px}.login-feats{display:flex;flex-direction:column;gap:12px;margin-top:26px}.login-feats div{display:flex;align-items:center;gap:10px;font-size:14px;opacity:.92}.login-form-side{display:grid;place-items:center;padding:40px}.login-card{width:100%;max-width:380px}.login-card h1{font-size:26px;font-weight:800;letter-spacing:-.6px}.login-card .lc-sub{color:var(--text-faint);margin:6px 0 26px}.login-card .btn-primary{width:100%;justify-content:center;padding:12px;margin-top:6px}.demo-creds{margin-top:24px;border:1px dashed var(--border);border-radius:11px;padding:14px 16px;background:var(--surface-2)}.demo-creds .dc-title{font-size:11.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-faint);font-weight:600;margin-bottom:9px}.demo-row{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;padding:4px 0}.demo-row button{background:var(--primary-soft);color:var(--primary);border:none;padding:3px 9px;border-radius:6px;font-weight:600;font-size:11.5px}.err-msg{background:var(--red-soft);color:var(--red);padding:9px 13px;border-radius:9px;font-size:13px;margin-bottom:14px;font-weight:500}@media (max-width: 880px){.login-wrap{grid-template-columns:1fr}.login-art{display:none}}.pill-tabs{display:inline-flex;max-width:100%;overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}.pill-tabs button{border:none;background:none;min-height:32px;padding:6px 13px;border-radius:7px;font-weight:650;font-size:13px;color:var(--text-soft);transition:background .16s ease,color .16s ease;white-space:nowrap}.pill-tabs button:hover:not(.active){background:var(--surface-2);color:var(--text)}.pill-tabs button.active{background:var(--primary-soft);color:var(--primary);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--primary) 22%,transparent)}.progress{height:7px;background:var(--gray-soft);border-radius:999px;overflow:hidden;min-width:90px}.progress>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--sidebar-active-to));transition:width .4s cubic-bezier(.2,.8,.2,1)}.kpi-row{display:flex;gap:8px;align-items:baseline}.attendance-toggle{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.attendance-toggle button{border:none;background:var(--surface);padding:6px 13px;font-weight:600;font-size:12.5px;color:var(--text-soft);border-right:1px solid var(--border)}.attendance-toggle .today-button{min-width:60px}.attendance-toggle button:last-child{border-right:none}.attendance-toggle button.on-present{background:var(--green);color:#fff}.attendance-toggle button.on-absent{background:var(--red);color:#fff}.attendance-toggle button.on-leave{background:var(--blue);color:#fff}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--border) 37%,var(--surface-2) 63%);background-size:400% 100%;animation:shimmer 1.3s ease infinite;border-radius:8px}.skeleton-top-sm{margin-top:8px}.skeleton-bottom-md{margin-bottom:var(--space-4)}.skeleton-bottom-lg{margin-bottom:22px}.skeleton-bottom-xl{margin-bottom:var(--space-6)}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}.skel-row{display:flex;align-items:center;gap:14px;padding:15px 22px;border-bottom:1px solid var(--border)}.skel-stat{height:104px}.toast-stack{position:fixed;top:18px;right:18px;z-index:200;display:flex;flex-direction:column;gap:10px;max-width:calc(100vw - 36px)}.toast{display:flex;align-items:flex-start;gap:11px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--primary);box-shadow:var(--shadow-lg);border-radius:12px;padding:13px 16px;min-width:280px;animation:toastIn .22s cubic-bezier(.2,.8,.2,1)}.toast.success{border-left-color:var(--green)}.toast.error{border-left-color:var(--red)}.toast.info{border-left-color:var(--blue)}.toast .t-ico{font-size:16px;line-height:1.3}.toast.success .t-ico{color:var(--green)}.toast.error .t-ico{color:var(--red)}.toast .t-body{flex:1;font-size:13.5px;font-weight:500;color:var(--text)}.toast .t-undo{background:none;border:none;color:var(--primary);font-weight:700;font-size:13px}@keyframes toastIn{0%{opacity:0;transform:translate(24px)}}.ring{position:relative;width:132px;height:132px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}.ring:before{content:"";position:absolute;top:13px;right:13px;bottom:13px;left:13px;border-radius:50%;background:var(--surface)}.ring-inner{position:relative;text-align:center}.ring-inner .rv{font-size:27px;font-weight:800;letter-spacing:-1px;line-height:1}.ring-inner .rl{font-size:11px;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.ring-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:22px;text-align:center}.ring-card .rc-title{font-weight:700;font-size:14px}.ring-card .rc-sub{font-size:12px;color:var(--text-faint)}.subj-bar{display:flex;align-items:center;gap:12px;padding:11px 0}.subj-bar .sb-name{width:130px;font-weight:600;font-size:13px;flex-shrink:0}.subj-bar .sb-track{flex:1;height:9px;background:var(--surface-2);border-radius:999px;overflow:hidden}.subj-bar .sb-fill{height:100%;border-radius:999px;transition:width .5s ease}.subj-bar .sb-val{width:52px;text-align:right;font-weight:700;font-size:13px}.greeting-banner{position:relative;overflow:hidden;border-radius:var(--radius);padding:26px 28px;color:#fff;background:var(--grad-banner);margin-bottom:22px}.greeting-banner:after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:#ffffff1a;top:-120px;right:-60px}.theme-toggle{display:flex;align-items:center;gap:8px;width:100%;margin-top:8px;background:#ffffff0f;color:#c7cadb;border:none;padding:9px;border-radius:9px;font-weight:600;font-size:13px;justify-content:center;transition:background .14s}.theme-toggle:hover{background:#ffffff1f}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.cal-dow{text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);padding-bottom:4px}.cal-cell{min-height:64px;border:1px solid var(--border);border-radius:10px;padding:7px 8px;display:flex;flex-direction:column;justify-content:space-between;background:var(--surface);transition:border-color .14s,background .14s}.cal-cell:hover{background:var(--surface-2)}.cal-num{font-size:12.5px;font-weight:600;color:var(--text-soft)}.cal-dot{align-self:flex-start;color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:999px}@media (max-width: 600px){.cal-cell{min-height:52px;padding:5px}.cal-dot{font-size:10px;padding:1px 5px}}@media (max-width: 860px){.sidebar{transform:translate(-100%);box-shadow:var(--shadow-lg)}.app-shell.nav-open .sidebar{transform:translate(0)}.app-shell.nav-open .sidebar-scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c1880;z-index:40}.main{margin-left:0}.hamburger{display:grid}.topbar{padding:0 16px}.page{padding:20px 16px 48px}.grid-2{grid-template-columns:1fr}.topbar h1{font-size:17px}.topbar .sub{display:none}}@media (max-width: 520px){.stat-grid{grid-template-columns:1fr 1fr}.field-row{grid-template-columns:1fr}}.timeline{display:flex;flex-direction:column}.tl-item{position:relative;display:flex;gap:14px;padding:0 0 18px}.tl-item:last-child{padding-bottom:0}.tl-item:before{content:"";position:absolute;left:15px;top:30px;bottom:-4px;width:2px;background:var(--border)}.tl-item:last-child:before{display:none}.tl-dot{position:relative;z-index:1;flex-shrink:0;width:32px;height:32px;border-radius:999px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border)}.tl-body{flex:1;min-width:0;padding-top:2px}.tl-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.setup-banner{display:flex;align-items:center;gap:10px;margin:16px 24px 0;padding:11px 16px;border-radius:var(--radius-sm);background:var(--amber-soft);color:var(--amber);border:1px solid color-mix(in srgb,var(--amber) 28%,transparent);font-size:13.5px;text-decoration:none}.setup-banner strong{font-weight:700}.setup-banner .sb-cta{margin-left:auto;display:inline-flex;align-items:center;gap:3px;font-weight:600;white-space:nowrap}@media (max-width: 720px){.setup-banner{margin:12px 14px 0}.setup-banner .sb-cta{display:none}}.bus-track-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(300px,1fr);gap:16px;align-items:start;margin-top:16px}@media (max-width: 980px){.bus-track-grid{grid-template-columns:1fr}}.fleet-map{width:100%;height:auto;display:block;border-radius:12px}.fm-bg{fill:var(--surface-2)}.fm-grid{stroke:var(--border);stroke-width:1;opacity:.5}.fm-marker{cursor:pointer}.fm-dot{stroke:var(--surface);stroke-width:2.5}.fm-green{fill:var(--green)}.fm-amber{fill:var(--amber)}.fm-ring{fill:none;stroke:var(--primary);stroke-width:2.5}.fm-pulse{opacity:.25;transform-origin:center;animation:fmPulse 1.8s ease-out infinite}@keyframes fmPulse{0%{transform:scale(.7);opacity:.35}70%{transform:scale(2.4);opacity:0}to{opacity:0}}@media (prefers-reduced-motion: reduce){.fm-pulse{animation:none}}.fm-label{fill:var(--text);font-size:18px;font-weight:700;paint-order:stroke;stroke:var(--surface);stroke-width:4px}.map-legend{display:flex;gap:16px;flex-wrap:wrap;align-items:center;padding:10px 4px 2px;font-size:12.5px;color:var(--text-soft)}.map-legend span{display:inline-flex;align-items:center;gap:6px}.map-legend i{width:10px;height:10px;border-radius:999px;display:inline-block}.map-legend .dot-green{background:var(--green)}.map-legend .dot-amber{background:var(--amber)}.fleet-list{display:flex;flex-direction:column;max-height:620px;overflow-y:auto}.fleet-row{display:flex;align-items:center;gap:11px;width:100%;padding:11px 16px;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;color:inherit;font:inherit}.fleet-row:hover{background:var(--surface-2)}.fleet-row.sel{background:var(--primary-soft)}.fleet-stat{width:9px;height:9px;border-radius:999px;flex-shrink:0}.fleet-stat.green{background:var(--green)}.fleet-stat.amber{background:var(--amber)}.fleet-stat.gray{background:var(--text-faint)}.fleet-map-leaflet{height:460px;width:100%;border-radius:12px;overflow:hidden;z-index:0}.fleet-map-leaflet .leaflet-control-attribution{font-size:10px}.lc-hint{font-size:12.5px;color:var(--text-faint);margin-top:6px}.lc-hint.ok{color:var(--green);font-weight:600}.lc-hint.bad{color:var(--red)}.icon-back{transform:rotate(180deg)}.link-btn{background:none;border:none;padding:0;color:var(--primary);font:inherit;font-weight:600;cursor:pointer;text-decoration:underline}.tenant-chip{display:flex;align-items:center;gap:7px;padding:7px 10px;margin-bottom:10px;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-soft);font-size:12.5px}.tenant-chip .tn{flex:1;min-width:0;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.setup-grid{display:grid;grid-template-columns:250px minmax(0,1fr);gap:16px;align-items:start}@media (max-width: 820px){.setup-grid{grid-template-columns:1fr}}.setup-rail{display:flex;flex-direction:column;gap:4px;position:sticky;top:8px}@media (max-width: 820px){.setup-rail{position:static;flex-direction:row;overflow-x:auto;padding-bottom:4px}}.setup-step{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);background:none;border:1px solid transparent;cursor:pointer;text-align:left;color:inherit;font:inherit;white-space:nowrap}.setup-step:hover{background:var(--surface-2)}.setup-step.active{background:var(--primary-soft);border-color:color-mix(in srgb,var(--primary) 30%,transparent)}.ss-num{width:26px;height:26px;flex-shrink:0;border-radius:999px;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--border);font-size:12.5px;font-weight:700;color:var(--text-soft)}.ss-num.done{background:var(--green);border-color:var(--green);color:#fff}.ss-body{display:flex;flex-direction:column;min-width:0}.ss-label{font-weight:600;font-size:13.5px}.ss-meta{font-size:11.5px;color:var(--text-faint)}.setup-step-ico{width:40px;height:40px;flex-shrink:0;border-radius:12px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary)}.field-err{color:var(--red);font-size:var(--font-xs);margin-top:6px}.field-hint{color:var(--text-faint);font-size:var(--font-xs);margin-top:6px}.section-block{margin-bottom:var(--space-5)}.section-heading{font-size:var(--font-sm);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);margin-bottom:var(--space-3)}.section-heading[data-has-desc=true]{margin-bottom:2px}.section-desc{font-size:var(--font-xs);color:var(--text-faint);margin-bottom:var(--space-3)}.section-stack{display:flex;flex-direction:column;gap:var(--space-3)}.input.invalid,.textarea.invalid,.select-trigger.invalid{border-color:var(--red)}.input.invalid:focus,.textarea.invalid:focus,.select-trigger.invalid:focus,.select-trigger.invalid[data-state=open]{box-shadow:0 0 0 3px var(--red-soft)}.btn{transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out),filter var(--dur-1) var(--ease-out)}.btn:active{transform:scale(.98)}.tbl tbody tr{transition:background var(--dur-1) var(--ease-out)}.card{transition:box-shadow var(--dur-2) var(--ease-out),border-color var(--dur-2) var(--ease-out)}.modal{animation:kitModalIn var(--dur-2) var(--ease-out)}@keyframes kitModalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}}.modal-overlay{animation:kitOverlayIn var(--dur-1) var(--ease-out)}@keyframes kitOverlayIn{0%{opacity:0}}.empty-centered{text-align:center}.error-icon{color:var(--red)}.empty-copy{color:var(--text-soft);max-width:420px;margin:0 auto}.retry-btn{margin-top:16px}.centered-fallback{display:grid;place-items:center;padding:48px 20px}.error-fallback-card{max-width:460px;text-align:center;padding:32px}.error-fallback-title,.confirm-title{font-size:17px;font-weight:700;margin-bottom:8px}.error-fallback-copy,.confirm-copy{color:var(--text-soft);line-height:1.55}.error-fallback-copy{margin-bottom:20px}.link-inherit{color:inherit}.tl-title{font-weight:600;font-size:14px}.tl-time{color:var(--text-faint);font-size:12.5px;white-space:nowrap}.tl-summary{font-size:13px;color:var(--text-soft);margin-top:2px}.tl-meta{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}.tl-actor{font-size:12px;color:var(--text-faint)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#14172873;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);transition:opacity .2s ease;display:flex;justify-content:flex-end}.drawer-panel{width:100%;height:100%;background:var(--surface);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transition:transform .2s ease}.drawer-head,.drawer-foot{display:flex;flex-shrink:0;padding:16px 24px}.drawer-head{align-items:center;justify-content:space-between;padding-top:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}.drawer-head h3{font-size:17px;font-weight:700}.drawer-body{padding:22px 24px;overflow-y:auto;flex:1}.drawer-foot{justify-content:flex-end;gap:10px;border-top:1px solid var(--border)}.confirm-modal{max-width:420px}.confirm-body{padding-top:24px}.pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap;padding:var(--space-3);border-top:1px solid var(--border)}.pagination-label,.pagination-page{font-size:var(--font-sm);color:var(--text-soft)}.pagination-actions,.card-head-actions{display:flex;align-items:center}.pagination-actions{gap:var(--space-1)}.pagination-page{margin-left:var(--space-2)}.card-head-actions{gap:var(--space-2)}.required-mark{color:var(--red);margin-left:3px}.quick-chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.quick-chip-label{font-size:12.5px;color:var(--text-faint);align-self:center;margin-right:4px}.detail-stack{display:grid;gap:10px}.detail-inline-group{display:flex;flex-wrap:wrap;gap:18px}.amount-row{display:flex;justify-content:space-between}.amount-row-label{color:var(--text-soft);font-weight:400}.amount-row-label.strong{font-weight:700}.amount-row-value{font-weight:600}.amount-row-value.strong{font-weight:800}.receipt-badges{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4)}.receipt-lines{display:flex;flex-direction:column;gap:var(--space-2);font-variant-numeric:tabular-nums}.text-center,.data-table [data-align=center]{text-align:center}.text-right,.data-table [data-align=right]{text-align:right}.nowrap{white-space:nowrap}@media (prefers-reduced-motion: reduce){.btn{transition:none}.btn:active{transform:none}.tbl tbody tr,.card{transition:none}.modal,.modal-overlay{animation:none}}
