@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-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.9px;color:#6b6f88;padding:16px 10px 7px;font-weight:600}.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-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-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-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}.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;transition:background .14s,color .14s,border-color .14s}.icon-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--primary-soft)}.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}.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){.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;padding:17px 22px;border-bottom:1px solid var(--border)}.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}}.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}.stat .ico-badge{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:18px}.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}table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}.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}.tbl tbody td{padding:13px 22px;border-bottom:1px solid var(--border);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr{transition:background .1s}.tbl tbody tr:hover{background:var(--surface-2)}.cell-name{display:flex;align-items:center;gap:11px;font-weight:600}.cell-name .avatar{width:32px;height:32px;font-size:12px}.cell-sub{color:var(--text-faint);font-size:12px;font-weight:400}@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%}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}.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;padding:9px 16px;border-radius:10px;border:1px solid transparent;font-weight:600;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}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--sidebar-active-to));color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{filter:brightness(1.06);box-shadow:0 8px 22px #4f46e56b}.btn-ghost{background:var(--surface);color:var(--text);border-color:var(--border);box-shadow:var(--shadow-sm)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-sm{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}.field{margin-bottom:14px}.field label{display:block;font-size:12.5px;font-weight:600;color:var(--text-soft);margin-bottom:6px}.input,.select,.textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);transition:border-color .16s ease,box-shadow .16s ease;outline:none}.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong)}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.textarea{resize:vertical;min-height:84px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.search{position:relative;flex:1;max-width:320px}.search input{width:100%;padding:9px 12px 9px 36px;border:1px solid var(--border);border-radius:9px;background:var(--surface);outline:none}.search input:focus{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}.modal{background:var(--surface);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:pop .18s ease}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-head h3{font-size:17px;font-weight:700}.modal-body{padding:22px 24px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border)}.x-btn{background:none;border:none;font-size:22px;color:var(--text-faint);line-height:1;width:36px;height:36px;display:grid;place-items:center;border-radius:9px;transition:background .16s ease,color .16s ease}.x-btn:hover{background:var(--surface-2);color:var(--text)}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}.empty{text-align:center;padding:56px 20px;color:var(--text-faint)}.empty .ei{display:inline-grid;place-items:center;width:64px;height:64px;margin:0 auto 14px;border-radius:50%;background:var(--surface-2);color:var(--text-faint)}.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-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;background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:4px;gap:3px;box-shadow:var(--shadow-sm)}.pill-tabs button{border:none;background:none;padding:7px 15px;border-radius:8px;font-weight:600;font-size:13px;color:var(--text-soft);transition:background .16s ease,color .16s ease}.pill-tabs button:hover:not(.active){background:var(--surface-2);color:var(--text)}.pill-tabs button.active{background:linear-gradient(135deg,var(--primary),var(--sidebar-active-to));color:#fff;box-shadow:var(--shadow-primary)}.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 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-late{background:var(--amber);color:#fff}.attendance-toggle button.on-excused{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}@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)}.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}.input.invalid,.select.invalid,.textarea.invalid{border-color:var(--red)}.input.invalid:focus,.select.invalid:focus,.textarea.invalid:focus{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}}@media (prefers-reduced-motion: reduce){.btn{transition:none}.btn:active{transform:none}.tbl tbody tr,.card{transition:none}.modal,.modal-overlay{animation:none}}
