@font-face{font-family:"DM Serif Display";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/dm-serif-display-latin-ext-400-normal-F_7Nq69v.woff2) format("woff2"),url(/assets/dm-serif-display-latin-ext-400-normal-BqbNUkRK.woff) format("woff");unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"DM Serif Display";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/dm-serif-display-latin-400-normal-B8alCAS1.woff2) format("woff2"),url(/assets/dm-serif-display-latin-400-normal-CW1v3QHq.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk Variable;font-style:normal;font-display:swap;font-weight:300 700;src:url(/assets/space-grotesk-vietnamese-wght-normal-D_Q6m-an.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk Variable;font-style:normal;font-display:swap;font-weight:300 700;src:url(/assets/space-grotesk-latin-ext-wght-normal-OnFqUBEL.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk Variable;font-style:normal;font-display:swap;font-weight:300 700;src:url(/assets/space-grotesk-latin-wght-normal-5PZORFv8.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}html{scroll-behavior:smooth}:root{color-scheme:light;font-family:Space Grotesk,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #f5ede3;--paper: rgba(255, 249, 242, .76);--paper-strong: rgba(255, 248, 238, .92);--ink: #1f2131;--muted: #66606f;--line: rgba(31, 33, 49, .12);--shadow: 0 24px 80px rgba(31, 33, 49, .14);--cobalt: #2354f5;--mint: #2d8d74;--coral: #ef7a62;--amber: #f4b146;--white: #fffdf9;--motion-instant: 0ms;--motion-fast: .16s;--motion-medium: .24s;--motion-slow: .36s;--motion-route: .42s;--ease-standard: cubic-bezier(.4, 0, .2, 1);--ease-emphasis: cubic-bezier(.22, 1, .36, 1);--ease-decelerate: cubic-bezier(0, 0, .2, 1);--distance-lift-sm: 2px;--distance-route-y: 24px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(244,177,70,.18),transparent 30%),radial-gradient(circle at 85% 10%,rgba(35,84,245,.16),transparent 22%),linear-gradient(135deg,#f7f1e7,#efe3d6 48%,#efe7dc);color:var(--ink)}body.login-form-active,body.login-form-active #root{height:100dvh;overflow:hidden}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}#root{min-height:100vh}.app-frame{position:relative;min-height:100vh;display:grid;grid-template-columns:1fr;grid-template-rows:auto 1fr}.ambient{position:fixed;inset:auto;pointer-events:none;border-radius:999px;filter:blur(40px);opacity:.85;will-change:transform,filter}.ambient-one{width:320px;height:320px;background:#ef7a6226;top:-80px;right:10%;animation:floaty 14s ease-in-out infinite}.ambient-two{width:260px;height:260px;background:#2354f524;bottom:40px;left:18%;animation:floaty 18s ease-in-out infinite reverse}.side-rail{position:fixed;top:0;left:0;bottom:0;width:min(88vw,320px);z-index:50;padding:80px 24px 24px;background:linear-gradient(180deg,#1f2131f7,#171c2cf0);color:var(--white);display:flex;flex-direction:column;gap:28px;border-right:1px solid rgba(255,255,255,.08);transform:translate(-105%);transition:transform var(--motion-medium) var(--ease-standard);overflow-y:auto}.side-rail.open{transform:translate(0)}.side-rail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;background:#1f213166}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:center;padding:24px;background:#1f213170}.dialog-card{width:min(100%,560px);padding:28px;border-radius:28px;background:var(--paper-strong);border:1px solid rgba(31,33,49,.08);box-shadow:var(--shadow);display:grid;gap:16px}.dialog-card h2,.dialog-card p{margin:0}.dialog-detail{display:grid;gap:8px;padding:14px 16px;border-radius:18px;background:#ffffff9e;border:1px solid rgba(31,33,49,.08);word-break:break-word}.side-rail:after{content:"";position:absolute;inset:80px 24px auto;height:120px;border-radius:24px;background:linear-gradient(135deg,#f4b14624,#2354f51a);pointer-events:none;z-index:0}.brand-block{position:relative;z-index:1;padding:20px;border-radius:20px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.brand-block h1,.page-intro h1,.login-card h1{margin:0;font-family:"DM Serif Display",serif;font-weight:400;letter-spacing:.01em}.school-brand{position:relative;z-index:1;display:flex;gap:16px;align-items:center}.school-brand-mark-shell{width:116px;height:116px;flex:0 0 auto;display:grid;place-items:center;border-radius:28px;background:radial-gradient(circle at top left,rgba(244,177,70,.22),transparent 34%),radial-gradient(circle at 82% 12%,rgba(35,84,245,.16),transparent 24%),linear-gradient(135deg,#f7f1e7,#efe3d6 48%,#efe7dc);box-shadow:inset 0 0 0 1px #1f213114,0 14px 24px #1f21311f}.school-brand-mark{width:88%;height:88%;object-fit:contain;border-radius:14px}.school-brand-copy{display:grid;gap:4px;min-width:0}.school-brand-copy h1{font-size:clamp(1.25rem,2vw,1.9rem);line-height:1.02}.school-brand-local,.school-brand-meta{margin:0}.school-brand-local{font-size:.98rem;font-weight:700;letter-spacing:.01em}.school-brand-meta{max-width:520px;color:var(--muted)}.school-brand.is-inverted .school-brand-local,.school-brand.is-inverted .school-brand-meta{color:#ffffffc2}.school-brand.is-inverted .school-brand-mark-shell{box-shadow:inset 0 0 0 1px #ffffff2e,0 14px 24px #0815273d}.school-brand.is-compact{gap:12px}.school-brand.is-compact .school-brand-mark-shell{width:98px;height:98px}.school-brand.is-stacked{align-items:center;flex-direction:column;gap:14px;text-align:center}.school-brand.is-stacked .school-brand-mark-shell{width:72px;height:72px;border-radius:18px}.school-brand.is-stacked .school-brand-copy{width:100%;gap:4px}.school-brand.is-stacked .school-brand-copy h1{max-width:none;font-size:1.15rem;line-height:1.15}.school-brand.is-stacked .school-brand-local{font-size:.82rem}.school-brand.is-stacked .school-brand-meta{max-width:100%;font-size:.82rem;line-height:1.45;color:#ffffff8f}.brand-block p:last-child{margin-bottom:0;color:#ffffffb8}.eyebrow{margin:0 0 10px;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:#ffffff9e}.school-brand-copy>.eyebrow{width:fit-content;margin:0 auto 12px;padding:6px 10px;border-radius:999px;border:1px solid rgba(124,90,37,.14);background:#f4b1462e;color:#735326;font-size:.68rem;font-weight:700;letter-spacing:.14em}.school-brand.is-inverted .school-brand-copy>.eyebrow{border-color:#ffffff29;background:#ffffff14;color:#ffffffe0}.page-intro .eyebrow,.top-bar .eyebrow,.login-card .eyebrow,.hero-strip .eyebrow{color:var(--muted)}.nav-stack{position:relative;z-index:1;display:grid;gap:10px}.nav-link{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;transition:transform .18s ease,background .18s ease,border-color .18s ease}.nav-link:hover,.nav-link.is-active{transform:translate(6px);background:#f4b1461f;border-color:#f4b14647}.nav-link small{color:#ffffff9e}.rail-note{position:relative;z-index:1;margin-top:auto;padding:18px;border-radius:24px;background:#ffffff0a}.rail-note span,.rail-note p{color:#ffffffa8}.rail-note strong{display:block;margin-top:4px;font-size:1.05rem}.content-shell{position:relative;padding:20px}.global-navbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:12px;padding:10px 18px;background:#fff9f2f5;border-bottom:1px solid var(--line);min-height:56px}.global-navbar-center{flex:1;min-width:0}.global-navbar-center .eyebrow{margin:0;color:var(--ink);font-weight:700;font-size:.82rem;letter-spacing:.1em}.global-navbar-end{display:flex;align-items:center;gap:14px}.navbar-year-picker{display:grid;gap:4px}.navbar-year-picker label{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.navbar-year-picker select{min-width:180px;padding:9px 12px;border:1px solid rgba(31,33,49,.08);border-radius:14px;background:#fff9f2c7;color:var(--ink)}.toast-notification{position:fixed;top:18px;right:18px;z-index:9999;min-width:min(92vw,360px);padding:16px 18px;border-radius:18px;box-shadow:0 18px 42px #1f213133;color:var(--white);display:flex;align-items:flex-start;justify-content:space-between;gap:14px;animation:toast-slide-in .18s ease}.toast-notification.is-success{background:linear-gradient(135deg,var(--mint),#2f9f82)}.toast-notification.is-error{background:linear-gradient(135deg,var(--coral),#dc6651)}.toast-copy{display:grid;gap:4px}.toast-copy strong,.toast-copy span{display:block}.toast-dismiss{border:none;background:#ffffff29;color:var(--white);border-radius:999px;padding:8px 12px}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-10px) translate(8px)}to{opacity:1;transform:translateY(0) translate(0)}}.hamburger-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;background:transparent;cursor:pointer;border-radius:10px;transition:background .14s ease}.hamburger-toggle:hover{background:#1f213114}.hamburger-icon{display:flex;flex-direction:column;gap:5px;width:22px}.hamburger-icon span{display:block;height:2px;width:100%;background:var(--ink);border-radius:2px;transition:transform .22s ease,opacity .22s ease;transform-origin:center}.hamburger-icon.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger-icon.is-open span:nth-child(2){opacity:0}.hamburger-icon.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.top-bar{display:none}.top-bar h2{margin:0;font-size:clamp(1.7rem,3vw,2.6rem)}.top-bar-actions{display:flex;align-items:center;gap:12px}.role-pill,.chip,.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;font-size:.82rem;font-weight:600;letter-spacing:.03em}.role-pill{background:#1f213114;color:var(--ink)}.user-profile-wrapper{position:relative}.user-profile-trigger{display:flex;align-items:center;gap:10px;padding:8px 14px 8px 8px;border:1px solid rgba(31,33,49,.08);background:#fff9f2c7;cursor:pointer;border-radius:999px;box-shadow:0 10px 28px #1f213114;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.user-profile-trigger:hover{transform:translateY(-1px);box-shadow:0 14px 34px #1f21311f;background:#fffbf6f0}.user-avatar{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;background:linear-gradient(135deg,var(--cobalt),#4e77ff);color:var(--white);font-weight:700;font-size:.82rem;letter-spacing:.04em;overflow:hidden}.user-avatar-logo{object-fit:cover;background:#fff;-webkit-user-select:none;user-select:none}.user-profile-trigger-copy{display:grid;gap:1px;text-align:left}.user-profile-trigger-copy strong,.user-profile-trigger-copy small{display:block}.user-profile-trigger-copy strong{font-size:.86rem;line-height:1.05;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-profile-trigger-copy small{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.user-avatar-lg{width:48px;height:48px;font-size:.92rem}.user-profile-dropdown{position:absolute;top:calc(100% + 10px);right:0;z-index:100;min-width:280px;background:var(--white);border:1px solid var(--line);border-radius:18px;box-shadow:0 16px 48px #1f21312e;padding:0;animation:profile-reveal .16s ease}@keyframes profile-reveal{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.user-profile-header{display:flex;align-items:center;gap:14px;padding:18px 20px;border-bottom:1px solid var(--line)}.user-profile-header strong{display:block;font-size:.95rem}.user-profile-header .field-note{text-transform:capitalize}.user-profile-section{padding:12px 8px;border-bottom:1px solid var(--line)}.user-profile-section-label{display:block;padding:4px 12px 8px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.user-profile-detail{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:6px 12px;font-size:.85rem}.user-profile-detail .field-note{font-size:.76rem}.accent-swatches{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0 2px}.accent-swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .16s ease,box-shadow .2s ease,border-color .16s ease;box-shadow:0 2px 6px #1f21311f}.accent-swatch:hover{transform:scale(1.12)}.accent-swatch.is-active{border-color:var(--ink);box-shadow:0 0 0 2px #ffffffe6,0 4px 14px #1f213138}[data-theme=dark] .accent-swatch{box-shadow:0 2px 6px #0006}[data-theme=dark] .accent-swatch.is-active{border-color:#fff;box-shadow:0 0 0 2px #0009,0 4px 14px #00000080}.user-profile-nav{display:flex;flex-direction:column;gap:2px}.user-profile-nav-link{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-radius:10px;font-size:.88rem;font-weight:500;color:var(--ink);text-decoration:none;transition:background .14s ease}.user-profile-nav-link:hover{background:#1f21310f}.user-profile-nav-link.is-active{background:#2354f514;color:var(--cobalt)}.user-profile-nav-link small{font-size:.72rem;color:var(--muted);font-weight:400}.user-profile-footer{padding:10px 12px}.user-profile-footer .ghost-button{width:100%;text-align:center;font-size:.85rem}.notification-bell-wrapper{position:relative}.notification-bell-trigger{position:relative;width:50px;height:50px;padding:0;border:none;background:transparent;display:flex;align-items:center;justify-content:center;transition:transform .18s ease}.notification-bell-trigger:hover{transform:translateY(-1px)}.notification-bell-svg{display:none}.notification-orb{position:relative;width:50px;height:50px;border-radius:50%;overflow:hidden;background:radial-gradient(circle at 30% 24%,#ffffffe0,#ffffff29 48%,#ffffff0a 72%),#fffdf92e;will-change:transform;contain:layout paint}.notification-orb *,.notification-orb:after{animation-play-state:paused!important}.notification-orb:hover *,.notification-orb:hover:after,.notification-orb:focus-within *,.notification-orb:focus-within:after{animation-play-state:running!important}.notification-orb-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:1.75px solid #111111;box-shadow:inset 0 1px #ffffffb8,0 10px 24px #1f213114}.notification-orb-liquid{--notification-fill-level: 0%;position:absolute;left:0;right:0;bottom:0;height:var(--notification-fill-level);min-height:0;overflow:hidden;transition:height .42s cubic-bezier(.22,1,.36,1)}.notification-orb-liquid:after{content:"";position:absolute;inset:-8% auto -12% -28%;width:58%;background:linear-gradient(100deg,#fff0,#ffffff57,#fff0);transform:skew(-18deg);opacity:.56;animation:notification-sea-shine 4.4s ease-in-out infinite;pointer-events:none}.notification-orb-surface{--notification-fill-level: 0%;position:absolute;left:0;right:0;top:calc(100% - var(--notification-fill-level) - 12px);height:24px;overflow:hidden;z-index:1;transition:top .42s cubic-bezier(.22,1,.36,1);pointer-events:none}.notification-orb-surface-wave{position:absolute;left:-30%;width:160%;border-radius:48%;background-repeat:repeat-x}.notification-orb-surface-wave-back{top:7px;height:16px;background:radial-gradient(ellipse at 26px 13px,rgba(232,242,255,.34) 0 12px,transparent 13px),radial-gradient(ellipse at 74px 7px,rgba(214,230,255,.16) 0 9px,transparent 10px),radial-gradient(ellipse at 122px 13px,rgba(226,239,255,.3) 0 12px,transparent 13px),linear-gradient(180deg,#afd0ff94,#6da5ff57);background-size:148px 16px,148px 16px,148px 16px,100% 100%;background-position:0 0,0 0,0 0,0 0;opacity:.72;animation:notification-surface-wave-back 11s linear infinite}.notification-orb-surface-wave-front{top:0;height:20px;background:radial-gradient(ellipse at 24px 14px,rgba(238,246,255,.58) 0 12px,transparent 13px),radial-gradient(ellipse at 56px 8px,rgba(255,255,255,.24) 0 8px,transparent 9px),radial-gradient(ellipse at 96px 14px,rgba(236,245,255,.54) 0 12px,transparent 13px),radial-gradient(ellipse at 128px 6px,rgba(255,255,255,.2) 0 7px,transparent 8px),linear-gradient(180deg,#ffffff1f,#6da8ff1f 36%,#4882f9c7);background-size:152px 20px,152px 20px,152px 20px,152px 20px,100% 100%;background-position:0 0,0 0,0 0,0 0,0 0;opacity:.96;animation:notification-surface-wave-front 8s linear infinite}.notification-orb-surface-shine{position:absolute;top:2px;left:-30%;width:160%;height:10px;background:radial-gradient(ellipse at 34px 5px,rgba(255,255,255,.34) 0 10px,transparent 11px),radial-gradient(ellipse at 102px 3px,rgba(255,255,255,.18) 0 7px,transparent 8px),radial-gradient(ellipse at 154px 5px,rgba(255,255,255,.3) 0 10px,transparent 11px);background-size:170px 10px,170px 10px,170px 10px;background-position:0 0,0 0,0 0;background-repeat:repeat-x;mix-blend-mode:screen;opacity:.7;animation:notification-surface-shine 9s linear infinite}.notification-orb-depth{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#b6d5ffeb,#5891fff5 52%,#1b58dbfa),radial-gradient(circle at 20% 20%,rgba(255,255,255,.28),transparent 42%);background-size:130% 100%,100% 100%;animation:notification-sea-depth 16s linear infinite}.notification-orb-wave{position:absolute;left:-90%;width:280%;border-radius:50%;background-repeat:repeat-x;background-size:120px 100%}.notification-orb-wave-back{top:-13px;height:30px;background:radial-gradient(ellipse at 24px 24px,rgba(255,255,255,.34) 0 18px,transparent 19px),radial-gradient(ellipse at 84px 24px,rgba(255,255,255,.28) 0 18px,transparent 19px),#96c2ff85;opacity:.8;animation:notification-sea-wave-back 18s linear infinite}.notification-orb-wave-mid{top:-10px;height:28px;background:radial-gradient(ellipse at 30px 22px,rgba(255,255,255,.22) 0 16px,transparent 17px),radial-gradient(ellipse at 92px 22px,rgba(255,255,255,.18) 0 16px,transparent 17px),#649fff7a;opacity:.74;animation:notification-sea-wave-mid 13s linear infinite}.notification-orb-wave-front{top:-8px;height:24px;background:radial-gradient(ellipse at 26px 18px,rgba(255,255,255,.72) 0 14px,transparent 15px),radial-gradient(ellipse at 86px 18px,rgba(255,255,255,.62) 0 14px,transparent 15px),#427bf8a8;opacity:.96;animation:notification-sea-wave-front 9s linear infinite}.notification-orb-bell{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:2;color:#111;transform:translateY(-1px)}.notification-bell-icon{width:24px;height:24px;display:block;filter:drop-shadow(0 1px 0 rgba(255,255,255,.85)) drop-shadow(0 0 10px rgba(255,255,255,.35))}.notification-dot{position:absolute;top:2px;right:1px;width:8px;height:8px;background:var(--cobalt);border-radius:50%;box-shadow:0 0 0 2px #fff9f2f2;z-index:3}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:min(360px,calc(100vw - 24px));max-height:420px;background:linear-gradient(180deg,#fffcf7fa,#f8f3ecf5),radial-gradient(circle at top right,rgba(35,84,245,.08),transparent 34%);border:1px solid rgba(31,33,49,.1);border-radius:22px;box-shadow:0 24px 60px #1f21312e,inset 0 1px #ffffffc7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:100;overflow:hidden;animation:profile-reveal .16s ease}.notification-dropdown-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid rgba(31,33,49,.08);background:linear-gradient(180deg,#ffffff6b,#ffffff2e)}.notification-dropdown-header .ghost-button{padding:8px 12px;font-size:.78rem}.notification-dropdown-list{display:grid;gap:8px;overflow-y:auto;overscroll-behavior:contain;max-height:360px;padding:12px;background:linear-gradient(180deg,#ffffff29,#f3ece485)}.notification-item{width:100%;padding:14px 14px 13px;border:1px solid rgba(31,33,49,.08);border-radius:16px;background:#ffffff8f;text-align:left;cursor:pointer;transition:background .16s ease,border-color .16s ease,transform .16s ease,box-shadow .16s ease}.notification-item.is-unread{background:linear-gradient(180deg,#e8f0ffeb,#f3f8ffd1);border-color:#2354f52e;box-shadow:inset 3px 0 0 var(--cobalt),0 10px 22px #2354f514}.notification-item:hover{background:#ffffffe6;border-color:#1f213124;transform:translateY(-1px);box-shadow:0 10px 24px #1f213114}.notification-item-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.notification-item-title{display:block;font-size:.84rem}.notification-item-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#2354f51f;color:var(--cobalt);font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.notification-item strong{display:block;font-size:.82rem}.notification-item p{margin:6px 0 8px;font-size:.78rem;color:var(--muted);line-height:1.45}.notification-item small{font-size:.72rem;color:var(--muted)}@keyframes notification-sea-wave-back{0%{transform:translate(-20%) translateY(0)}to{transform:translate(0) translateY(0)}}@keyframes notification-sea-wave-mid{0%{transform:translate(-16%) translateY(0)}to{transform:translate(4%) translateY(0)}}@keyframes notification-sea-wave-front{0%{transform:translate(-24%) translateY(0)}to{transform:translate(6%) translateY(0)}}@keyframes notification-sea-depth{0%{transform:translate(-4%);filter:saturate(1)}to{transform:translate(4%);filter:saturate(1.04)}}@keyframes notification-surface-wave-back{0%{background-position:0 0,0 0,0 0,0 0}to{background-position:148px 0,148px 0,148px 0,0 0}}@keyframes notification-surface-wave-front{0%{background-position:0 0,0 0,0 0,0 0,0 0}to{background-position:152px 0,152px 0,152px 0,152px 0,0 0}}@keyframes notification-surface-shine{0%{background-position:0 0,0 0,0 0;opacity:.64}to{background-position:170px 0,170px 0,170px 0;opacity:.72}}.chip{background:#2354f514;color:var(--cobalt)}.chip-done{background:#2d8d741f;color:var(--mint)}.chip-pending{background:#1f21310f;color:var(--muted, #888)}.marks-subject-status{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.marks-actions-field{display:flex;align-items:flex-end}.page-shell{display:grid;--page-shell-gap: 22px;gap:var(--page-shell-gap);padding-bottom:32px}.academic-nav{display:flex;flex-wrap:wrap;gap:6px;position:sticky;top:0;z-index:20;padding:10px 14px;margin:0 -20px;background:#fff9f2f5;border-bottom:1px solid var(--line)}.academic-nav-link{display:inline-flex;align-items:center;padding:8px 16px;border-radius:999px;border:1px solid transparent;font-size:.85rem;font-weight:500;color:var(--muted);background:#1f21310d;text-decoration:none;transition:background .16s ease,color .16s ease,border-color .16s ease,box-shadow .16s ease;white-space:nowrap}.academic-nav-link:hover{background:#2354f514;color:var(--cobalt);border-color:#2354f52e}.academic-nav-link.is-active{background:linear-gradient(135deg,var(--cobalt),#4e77ff);color:var(--white);border-color:transparent;box-shadow:0 4px 14px #2354f547}.page-intro{display:flex;justify-content:space-between;gap:20px;padding:18px 8px 4px;align-items:end}.page-intro h1{font-size:clamp(2rem,4vw,3.8rem)}.page-copy{max-width:720px;margin:10px 0 0;color:var(--muted)}.page-actions{display:flex;gap:10px;flex-wrap:wrap}.hero-strip,.metric-grid,.stack-grid,.split-grid,.triptych-grid{display:grid;gap:18px}.hero-strip{grid-template-columns:1.5fr 1fr}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.stack-grid,.compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.split-grid{grid-template-columns:minmax(0,1.3fr) minmax(320px,.9fr)}.triptych-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.panel,.login-card,.hero-panel{background:var(--paper);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow)}.hero-panel{position:relative;overflow:hidden;padding:24px;min-height:220px}.hero-panel:after{content:"";position:absolute;inset:auto -20px -20px auto;width:180px;height:180px;border-radius:34px;background:linear-gradient(135deg,#ef7a6229,#2354f529),repeating-linear-gradient(0deg,rgba(255,255,255,.22),rgba(255,255,255,.22) 2px,transparent 2px,transparent 10px);transform:rotate(-8deg)}.hero-panel h3,.panel h2,.login-card h1{margin:0}.hero-panel p,.panel-head p,.panel-note,.helper-text,.field-note,.empty-state{color:var(--muted)}.panel{padding:20px;content-visibility:auto;contain-intrinsic-size:0 480px}.panel-head{display:flex;justify-content:space-between;align-items:start;gap:16px;margin-bottom:18px}.panel-body{display:grid;gap:16px}.metric-card{padding:18px;border-radius:24px;border:1px solid var(--line);box-shadow:var(--shadow);min-height:160px;display:grid;align-content:start;gap:8px}.metric-card p,.metric-card span{margin:0;color:var(--muted)}.metric-card strong{font-size:clamp(1.8rem,4vw,2.8rem);line-height:1}.tone-sand{background:#fff8f0e6}.tone-mint{background:#def5eec7}.tone-ink{background:#1f2131eb;color:var(--white)}.tone-ink p,.tone-ink span{color:#ffffffad}.tone-coral{background:#fce4ded1}.metric-sparkline{width:100%;height:24px;margin:6px 0 2px;opacity:.78;color:var(--cobalt)}.tone-sand .metric-sparkline{color:var(--amber)}.tone-mint .metric-sparkline{color:var(--mint)}.tone-ink .metric-sparkline{color:#ffffffb8}.tone-coral .metric-sparkline{color:var(--coral)}.ghost-button,.primary-button,.accent-button,.soft-button{border-radius:999px;border:1px solid transparent;padding:12px 16px;transition:transform .18s ease,background .18s ease}.ghost-button{background:#1f21310f;color:var(--ink)}.link-button{padding:0;border:none;background:transparent;color:#24345f;font-weight:700;text-align:left;text-decoration:underline;text-decoration-color:#24345f47;text-underline-offset:4px}.primary-button{background:var(--ink);color:var(--white);box-shadow:0 14px 36px #1f213138}.accent-button{background:linear-gradient(135deg,var(--cobalt),#4e77ff);color:var(--white);box-shadow:0 16px 36px #2354f542}.soft-button{background:#ef7a621f;color:var(--ink);border-color:#ef7a622e}.ghost-button:hover,.link-button:hover,.primary-button:hover,.accent-button:hover,.soft-button:hover{transform:translateY(-1px)}.menu-toggle{display:none;margin-bottom:8px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:var(--paper-strong)}.status-pill{min-width:94px;background:#1f213114}.status-active,.status-present{background:#2d8d7424;color:var(--mint)}.status-inactive,.status-absent{background:#ef7a6224;color:#b14e39}.status-leave,.status-pending{background:#f4b1462e;color:#9b6508}.status-passout,.status-passedout,.status-tooktc,.status-closed{background:#1f21311a;color:var(--ink)}.form-grid,.mini-grid,.field-stack,.badge-stack{display:grid;gap:14px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.field-span-2{grid-column:span 2}.mini-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.field-stack{grid-template-columns:1fr}.badge-stack{grid-template-columns:repeat(auto-fit,minmax(140px,max-content))}.field,.inline-field{display:grid;gap:8px}.inline-check{display:inline-flex;align-items:center;gap:10px}.field label,.inline-field label{font-size:.9rem;font-weight:600}.field input,.field select,.field textarea,.inline-field input,.inline-field select{width:100%;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#ffffffbd;color:var(--ink)}.table-action-stack{display:grid;gap:10px;min-width:220px}.table-note-input{width:100%;padding:10px 12px;border-radius:14px;border:1px solid var(--line);background:#ffffffbd;color:var(--ink)}.field textarea{min-height:110px;resize:vertical}.form-actions,.inline-actions,.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.message-banner{padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#ffffffb8}.message-banner.is-error{background:#fce4dee0;border-color:#ef7a6247}.message-banner.is-success{background:#def5eed1;border-color:#2d8d743d}.today-chip{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;padding:12px 16px;border-radius:999px;border:1px solid var(--line);background:#ffffffa8}.today-orb{width:52px;height:52px;display:inline-grid;place-items:center;border-radius:999px;background:linear-gradient(135deg,var(--cobalt),#4e77ff);color:var(--white);font-weight:700;box-shadow:0 14px 30px #2354f538}.table-wrap{overflow:auto;border-radius:20px;border:1px solid var(--line)}.student-roster-scroll .table-wrap{max-height:72vh;overflow:auto}.student-roster-scroll .data-table th{position:sticky;top:0;z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.data-table{width:100%;border-collapse:collapse;min-width:720px}.data-table th,.data-table td{padding:14px 16px;text-align:left;border-bottom:1px solid rgba(31,33,49,.08);vertical-align:top}.data-table th{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:#ffffff61}.data-table tbody tr:hover{background:#ffffff6b}.empty-state{padding:28px 0;text-align:center}.list-card{display:grid;gap:12px}.academic-subject-row{display:grid;grid-template-columns:minmax(0,1.7fr) repeat(2,minmax(120px,.7fr)) auto;gap:12px;align-items:end;padding:14px;border-radius:20px;border:1px solid var(--line);background:#ffffff70}.academic-row-action{min-width:110px}.status-draft{background:#f4b1462e;color:#9b6508}.status-published{background:#2d8d7424;color:var(--mint)}.list-row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px 0;border-bottom:1px dashed rgba(31,33,49,.12)}.list-row:last-child{border-bottom:none}.list-row strong,.detail-stack strong{display:block}.detail-stack,.attendance-grid{display:grid;gap:12px}.detail-stack{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.academic-history-status{display:grid;gap:6px}.academic-history-note{font-size:.74rem;color:var(--muted)}.status-admitted{background:#f4b1462e;color:#9b6508}.status-promoted{background:#2354f51f;color:var(--cobalt)}.detail-back-float{position:fixed;left:16px;top:96px;z-index:42;width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;border:2px solid rgba(17,17,17,.12);border-radius:999px;padding:0;background:#fffbf6d6;color:#111;box-shadow:0 14px 32px #1f21311f,inset 0 1px #ffffffb8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.detail-back-float:hover{transform:translate(-2px) scale(1.02)}.detail-back-float-icon{display:block;font-size:1.75rem;font-weight:900;line-height:1;transform:translate(-1px)}.attendance-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.attendance-row{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px 16px;border-radius:20px;border:1px solid var(--line);background:#ffffff94}.register-actions{justify-content:space-between}.assignment-summary{display:grid;gap:4px;min-width:240px}.user-directory-identity,.user-directory-teacher{display:grid;gap:4px}.user-directory-teacher{min-width:0}.access-compact{display:flex;flex-wrap:wrap;gap:4px;max-width:200px}.access-tag{display:inline-block;padding:2px 8px;font-size:.75rem;border-radius:10px;background:#1f21310f;white-space:nowrap}.access-tag-more,.access-tag-toggle{background:#2354f514;color:var(--cobalt);font-weight:500;cursor:pointer;border:none;font-family:inherit;font-size:.75rem;padding:2px 8px;border-radius:10px}.access-tag-more:hover,.access-tag-toggle:hover{background:#2354f524}.access-compact-expanded{max-width:none}.side-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0f10188c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.side-panel{position:fixed;top:0;left:0;bottom:0;width:min(560px,100vw);background:#fff9f2;border-right:1px solid rgba(31,33,49,.1);box-shadow:6px 0 28px #0000001a;display:flex;flex-direction:column;z-index:201;animation:side-panel-slide-in .22s ease}@keyframes side-panel-slide-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.side-panel-header{flex-shrink:0;padding:18px 28px;border-bottom:1px solid rgba(31,33,49,.12);background:#1f2131;color:#fff;display:flex;justify-content:space-between;align-items:center;min-height:56px}.side-panel-header .ghost-button{color:#ffffffb3}.side-panel-header .ghost-button:hover{color:#fff}.side-panel-header h2{margin:0;font-size:1.2rem}.side-panel>form{display:flex;flex-direction:column;flex:1;min-height:0}.side-panel-body{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:20px 28px;min-height:0}.side-panel-footer{flex-shrink:0;padding:16px 28px;border-top:1px solid rgba(31,33,49,.08);background:#fff9f2;display:flex;gap:10px}.is-danger-text{color:var(--coral)}.status-action-wrapper{position:relative}.status-action-trigger{display:inline-flex;align-items:center;gap:6px;padding:7px 12px 7px 14px;border-radius:18px;border:1px solid rgba(31,33,49,.12);font-size:.82rem;font-weight:500;cursor:pointer;background:#1f21310f;color:var(--ink);transition:background .15s ease,box-shadow .15s ease}.status-action-trigger:hover{background:#1f21311a;box-shadow:0 1px 4px #00000014}.status-action-trigger.status-active{background:#2d8d741a;border-color:#2d8d7438;color:var(--mint)}.status-action-trigger.status-active:hover{background:#2d8d7429}.status-action-trigger.status-inactive{background:#ef7a621a;border-color:#ef7a6238;color:var(--coral)}.status-action-trigger.status-inactive:hover{background:#ef7a6229}.status-action-caret{display:inline-flex;align-items:center;font-size:.65rem;opacity:.7;transition:transform .15s ease}.status-action-trigger:hover .status-action-caret{opacity:1}.status-action-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:140px;background:var(--paper);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);z-index:50;overflow:hidden;animation:profile-reveal .12s ease}.status-action-menu button{display:block;width:100%;padding:10px 14px;border:none;background:none;text-align:left;font-size:.85rem;cursor:pointer;color:var(--ink)}.status-action-menu button:hover{background:#1f21310a}.status-action-menu button.is-danger{color:var(--coral)}.status-action-menu button.is-danger:hover{background:#ef7a620f}.iam-action-bar{display:flex;align-items:center;gap:12px}.iam-filter-input{flex:1;max-width:400px;padding:10px 16px;border:1px solid var(--line);border-radius:14px;font-size:.88rem;font-family:inherit;background:var(--paper);transition:border-color .15s ease}.iam-filter-input:focus{outline:none;border-color:var(--cobalt)}.audit-filter-toggle{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line);border-radius:12px;background:var(--paper);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;color:var(--ink);transition:background .15s ease,border-color .15s ease}.audit-filter-toggle:hover{background:#1f21310a}.audit-filter-toggle.is-open{border-color:var(--cobalt);color:var(--cobalt)}.audit-filter-toggle.has-filters{border-color:var(--cobalt)}.audit-filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--cobalt);color:#fff;font-size:.7rem;font-weight:600}.audit-filter-panel{padding:14px 0 6px;border-top:1px solid rgba(31,33,49,.06);margin-top:8px;animation:reveal .2s ease}.check-list{display:grid;gap:10px;max-height:340px;overflow:auto}.check-item{display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:18px;border:1px solid var(--line);background:#ffffff94}.student-search-results{display:grid;gap:8px;margin-top:10px;max-height:240px;overflow-y:auto;padding:10px;border-radius:18px;border:1px solid var(--line);background:#ffffff8f}.student-search-option{width:100%;display:grid;gap:2px;padding:10px 12px;border:1px solid rgba(31,33,49,.08);border-radius:14px;background:#ffffffd1;text-align:left;color:var(--ink);transition:background .14s ease,border-color .14s ease,transform .14s ease}.student-search-option:hover,.student-search-option.is-selected{background:#e8f0ffeb;border-color:#2354f538;transform:translateY(-1px)}.student-search-empty{padding:10px 12px;color:var(--muted)}.segmented{display:inline-grid;grid-auto-flow:column;gap:6px;padding:6px;border-radius:999px;border:1px solid var(--line);background:#ffffff80}.segmented button{padding:10px 14px;border:none;border-radius:999px;background:transparent}.segmented button.is-active{background:var(--ink);color:var(--white)}.login-shell{min-height:100dvh;display:grid;place-items:center;padding:32px 16px;overflow-y:auto;padding:clamp(12px,2vh,24px) 24px;overflow:hidden}.login-panel{width:min(1140px,100%);display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.78fr);gap:clamp(18px,2vw,24px);padding:clamp(20px,2vw,28px);height:calc(100dvh - clamp(24px,4vh,48px));max-height:calc(100dvh - clamp(24px,4vh,48px));border-radius:34px;background:#fff9f2b8;border:1px solid rgba(31,33,49,.1);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);overflow:hidden}.login-panel-copy,.login-form-card{min-width:0;min-height:0}.login-panel-copy{display:grid;gap:clamp(12px,1.4vh,18px);align-content:center;padding:6px;overflow:hidden}.login-panel-story{display:grid;gap:6px;align-content:center}.login-panel-story h2{margin:0;font-family:"DM Serif Display",serif;max-width:10ch;font-size:clamp(2rem,3.6vw,3.35rem);line-height:.92;color:#24345f}.login-panel-story p:last-child{margin:0;max-width:560px;color:var(--muted);font-size:.98rem}.login-panel-story.is-school{justify-items:center;text-align:center;gap:14px}.login-panel-story.is-school h2{max-width:none}.login-panel-story.is-school p:last-child{margin-inline:auto}.login-school-logo{width:110px;height:110px;border-radius:22px;object-fit:cover;box-shadow:0 14px 40px -18px #1f213159,0 0 0 1px #1f21310f;background:#fff}.login-form-card .form-actions{justify-content:center}.sso-divider{display:flex;align-items:center;gap:12px;margin:18px 0 4px;color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em}.sso-divider:before,.sso-divider:after{content:"";flex:1;height:1px;background:#1f21311f}[data-theme=dark] .sso-divider:before,[data-theme=dark] .sso-divider:after{background:#ffffff1f}.sso-stack{display:grid;gap:10px;margin-top:6px}.sso-button{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 18px;border-radius:999px;border:1px solid rgba(31,33,49,.18);background:#fff;color:#1f2131;font-size:.96rem;font-weight:600;cursor:pointer;transition:border-color .16s ease,transform .16s ease,box-shadow .16s ease}.sso-button:hover:not(:disabled){border-color:#1f21315c;transform:translateY(-1px);box-shadow:0 6px 18px -10px #1f21314d}.sso-button:disabled{opacity:.6;cursor:not-allowed}.sso-button-icon{display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem}[data-theme=dark] .sso-button{background:#ffffff14;border-color:#ffffff2e;color:#fffffff2}[data-theme=dark] .sso-button:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff52}.sso-button-host{display:flex;justify-content:center}.login-card{padding:28px}.login-form-card{display:grid;align-content:center;gap:8px;align-self:stretch;background:#fffaf5c7}.login-form-card .page-copy{margin:0 0 4px}.login-form-card h1{font-size:clamp(2.3rem,3vw,3.2rem)}.login-form-card .field input{padding:12px 16px}.subtle-grid{display:grid;gap:14px}@keyframes floaty{0%,to{transform:translateY(0) translate(0)}50%{transform:translateY(-22px) translate(14px)}}@keyframes reveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1180px){.metric-grid,.triptych-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-strip,.stack-grid,.split-grid,.compact-grid{grid-template-columns:1fr}}@media (max-width: 960px){.content-shell{padding:14px}.form-grid,.mini-grid,.metric-grid,.triptych-grid{grid-template-columns:1fr}.login-panel{grid-template-columns:1fr;height:min(900px,calc(100dvh - 28px));overflow:auto}.field-span-2{grid-column:auto}.academic-subject-row{grid-template-columns:1fr}.saas-how-grid{grid-template-columns:1fr;max-width:400px;margin:8px auto 0}.saas-nav-links{display:none}.saas-stats{gap:24px}}@media (max-width: 680px){.top-bar,.page-intro,.list-row,.attendance-row{align-items:stretch;flex-direction:column}.panel,.hero-panel,.login-card,.login-panel{padding:18px;border-radius:24px}.school-brand{align-items:flex-start;flex-direction:column}.content-shell{padding:10px}.saas-hero-content h1{font-size:1.8rem}.saas-hero-actions{flex-direction:column;align-items:center}.saas-stats{flex-direction:column;gap:20px}.saas-footer-inner{flex-direction:column;text-align:center}.saas-orb{display:none}.saas-hero-content{padding-top:40px}}@media (max-height: 820px){.login-shell{padding:16px}.login-panel{height:calc(100dvh - 32px);padding:22px;gap:18px}.login-panel-copy{gap:14px}.login-panel-story h2{font-size:clamp(1.85rem,3vw,3rem)}.login-card{padding:22px}}@keyframes aurora-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes orb-float-1{0%,to{transform:translate(0) scale(1)}25%{transform:translate(40px,-30px) scale(1.05)}50%{transform:translate(-20px,-60px) scale(.95)}75%{transform:translate(30px,-20px) scale(1.02)}}@keyframes orb-float-2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-50px,20px) scale(1.08)}66%{transform:translate(30px,-40px) scale(.96)}}@keyframes orb-float-3{0%,to{transform:translate(0) scale(1)}40%{transform:translate(25px,35px) scale(1.04)}80%{transform:translate(-35px,-15px) scale(.97)}}@keyframes gradient-text-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes pulse-glow{0%,to{box-shadow:0 0 16px #2354f52e,0 16px 36px #2354f538}50%{box-shadow:0 0 28px #2354f552,0 16px 48px #2354f547}}.saas-landing{min-height:100vh;position:relative;overflow-x:hidden;color:var(--ink)}.saas-orb{position:fixed;border-radius:50%;pointer-events:none;z-index:0;will-change:transform}.saas-orb-1{width:380px;height:380px;top:-60px;right:-40px;background:#2354f51f;filter:blur(90px);animation:orb-float-1 20s ease-in-out infinite}.saas-orb-2{width:320px;height:320px;bottom:20%;left:-60px;background:#ef7a621a;filter:blur(80px);animation:orb-float-2 25s ease-in-out infinite}.saas-orb-3{width:260px;height:260px;top:40%;right:15%;background:#2d8d741a;filter:blur(70px);animation:orb-float-3 18s ease-in-out infinite}.saas-aurora{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse at 20% 20%,rgba(35,84,245,.1) 0%,transparent 50%),radial-gradient(ellipse at 80% 30%,rgba(239,122,98,.08) 0%,transparent 45%),radial-gradient(ellipse at 50% 80%,rgba(45,141,116,.07) 0%,transparent 50%),radial-gradient(ellipse at 70% 60%,rgba(244,177,70,.06) 0%,transparent 40%);background-size:200% 200%;animation:aurora-shift 12s ease-in-out infinite}.saas-gradient-text{background:linear-gradient(135deg,var(--cobalt),var(--coral),var(--mint),var(--cobalt));background-size:300% 300%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradient-text-shift 6s ease infinite}.saas-glass{background:#fff9f273;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.28);border-radius:20px}.saas-glow-btn{transition:box-shadow .28s ease,transform .18s ease}.saas-glow-btn:hover{box-shadow:0 0 20px #2354f559,0 0 60px #2354f51f,0 16px 36px #2354f538}.saas-nav{position:relative;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:20px 32px;max-width:1200px;margin:0 auto}.saas-logo{font-family:"DM Serif Display",serif;font-size:1.5rem;color:var(--ink)}.saas-nav-links{display:flex;gap:28px;align-items:center}.saas-nav-links a{font-size:.88rem;font-weight:500;color:var(--muted);text-decoration:none;transition:color .18s ease}.saas-nav-links a:hover{color:var(--ink)}.saas-nav-actions{display:flex;gap:10px;align-items:center}.saas-hero{position:relative;padding-bottom:80px;overflow:hidden}.saas-hero-content{position:relative;z-index:2;max-width:780px;margin:0 auto;padding:72px 32px 0;text-align:center}.saas-hero-badge{display:inline-block;padding:6px 18px;border-radius:999px;font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--cobalt);background:#2354f514;border:1px solid rgba(35,84,245,.14);margin-bottom:20px}.saas-hero-content h1{font-family:"DM Serif Display",serif;font-size:clamp(2.2rem,5.5vw,3.8rem);line-height:1.1;margin:0 0 20px}.saas-hero-content>p{font-size:1.12rem;color:var(--muted);max-width:560px;margin:0 auto 32px;line-height:1.6}.saas-hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.saas-sticky-cta{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;justify-content:space-between;align-items:center;padding:12px 32px;background:#fff9f2e0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(31,33,49,.08);transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .35s ease}.saas-sticky-cta-visible{transform:translateY(0);opacity:1;pointer-events:auto}.saas-sticky-cta-actions{display:flex;gap:10px;align-items:center}.saas-stats{position:relative;z-index:2;display:flex;justify-content:center;gap:48px;flex-wrap:wrap;max-width:900px;margin:0 auto;padding:48px 32px}.saas-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.saas-stat strong{font-family:"DM Serif Display",serif;font-size:2rem}.saas-stat span{font-size:.85rem;color:var(--muted)}.saas-section-title{font-family:"DM Serif Display",serif;font-size:clamp(1.6rem,3vw,2.2rem);text-align:center;margin:0 0 8px}.saas-section-subtitle{text-align:center;color:var(--muted);margin:0 0 36px;font-size:1rem}.saas-features{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:72px 32px}.saas-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.saas-feature-card{position:relative;padding:28px;transition:transform .28s ease,box-shadow .28s ease}.saas-feature-card:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:21px;background:transparent;z-index:-1;transition:background .35s ease;mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;-webkit-mask-composite:xor;padding:2px}.saas-feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #1f213114}.saas-feature-card:hover:before{background:linear-gradient(135deg,var(--cobalt),var(--coral),var(--mint))}.saas-feature-icon{display:block;font-size:1.8rem;margin-bottom:12px}.saas-feature-card strong{display:block;font-size:1rem;margin-bottom:6px}.saas-feature-card p{font-size:.88rem;color:var(--muted);margin:0;line-height:1.5}.saas-feature-grid .saas-reveal:nth-child(2){transition-delay:80ms}.saas-feature-grid .saas-reveal:nth-child(3){transition-delay:.16s}.saas-feature-grid .saas-reveal:nth-child(4){transition-delay:.24s}.saas-feature-grid .saas-reveal:nth-child(5){transition-delay:.32s}.saas-feature-grid .saas-reveal:nth-child(6){transition-delay:.4s}.saas-how{position:relative;z-index:2;max-width:1000px;margin:0 auto;padding:72px 32px}.saas-how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px}.saas-how-step{padding:32px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.saas-how-num{width:48px;height:48px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,var(--cobalt),#4e77ff);color:#fff;font-size:1.1rem;font-weight:700;box-shadow:0 8px 24px #2354f538;flex-shrink:0}.saas-how-step strong{font-size:1rem}.saas-how-step p{font-size:.88rem;color:var(--muted);margin:0;line-height:1.5}.saas-pricing{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:72px 32px;text-align:center}.saas-pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;text-align:left}.saas-pricing-card{position:relative;padding:28px;display:flex;flex-direction:column;transition:transform .28s ease,box-shadow .28s ease}.saas-pricing-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #1f213114}.saas-pricing-badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(135deg,var(--cobalt),#4e77ff);color:#fff;margin-bottom:12px;align-self:flex-start}.saas-pricing-card h3{font-size:1.2rem;margin:0 0 4px}.saas-price{font-family:"DM Serif Display",serif;font-size:2rem;margin:0 0 16px}.saas-price span{font-size:.85rem;font-family:Space Grotesk,sans-serif;color:var(--muted)}.saas-pricing-card ul{list-style:none;padding:0;margin:0 0 20px;flex:1}.saas-pricing-card ul li{padding:6px 0;font-size:.88rem;border-bottom:1px solid rgba(31,33,49,.06)}.saas-pricing-card ul li:before{content:"✓ ";color:var(--mint);font-weight:600}.saas-pricing-featured{border-color:var(--cobalt);box-shadow:0 4px 24px #2354f51f}.saas-pricing-current{outline:2px solid var(--cobalt);outline-offset:-2px}.saas-final-cta{position:relative;z-index:2;text-align:center;padding:80px 32px;max-width:700px;margin:0 auto}.saas-final-cta h2{font-family:"DM Serif Display",serif;font-size:clamp(1.8rem,4vw,2.6rem);margin:0 0 14px}.saas-final-cta p{color:var(--muted);margin:0 0 28px;font-size:1.05rem}.saas-footer{position:relative;z-index:2;padding:32px;border-top:1px solid var(--line);color:var(--muted);font-size:.85rem}.saas-footer-inner{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:24px}.saas-footer-inner p{margin:4px 0 0}.saas-footer-links{display:flex;gap:20px;align-items:center}.saas-footer-links a,.saas-footer-link-btn{color:var(--muted);text-decoration:none;font-size:.85rem;background:none;border:none;padding:0;cursor:pointer;font:inherit;transition:color .18s ease}.saas-footer-links a:hover,.saas-footer-link-btn:hover{color:var(--ink)}.saas-reveal{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1)}.saas-revealed{opacity:1;transform:translateY(0)}.billing-toggle{display:inline-flex;gap:4px;padding:4px;border-radius:999px;background:#1f21310f;margin:0 auto 32px}.billing-toggle button{padding:8px 20px;border-radius:999px;border:none;background:transparent;font-weight:600;font-size:.9rem;cursor:pointer;color:var(--muted);transition:background .18s ease,color .18s ease;display:inline-flex;align-items:center;gap:6px}.billing-toggle button.is-active{background:var(--ink);color:#fff}.billing-toggle-save{font-size:.7rem;padding:2px 8px;border-radius:999px;background:var(--mint);color:#fff}.platform-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:var(--bg)}.platform-sidebar{background:#1f2131f5;color:#fff;padding:24px 16px;display:flex;flex-direction:column;gap:24px;position:sticky;top:0;height:100vh}.platform-brand{display:flex;flex-direction:column;gap:4px;padding:0 12px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.platform-brand strong{font-family:"DM Serif Display",serif;font-size:1.4rem}.platform-brand .field-note{color:#ffffff80;font-size:.75rem}.platform-nav{display:flex;flex-direction:column;gap:4px;flex:1}.platform-nav-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:12px;color:#ffffffb3;text-decoration:none;font-size:.92rem;font-weight:500;transition:background .16s ease,color .16s ease;position:relative}.platform-nav-link:hover{background:#ffffff0f;color:#fff}.platform-nav-link.is-active{background:#2354f538;color:#fff}.platform-nav-icon{font-size:1.1rem;width:24px;text-align:center}.platform-nav-badge{margin-left:auto;background:var(--coral);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:999px}.platform-sidebar-footer{padding-top:16px;border-top:1px solid rgba(255,255,255,.08);font-size:.82rem;color:#ffffffb3}.platform-sidebar-footer .field-note{color:#ffffff80}.platform-sidebar-footer strong{display:block;color:#fff;margin-top:2px}.platform-main{padding:32px;overflow-y:auto}.platform-mobile-toggle{display:none;position:fixed;top:12px;left:12px;z-index:110;padding:8px 14px;border-radius:10px;background:#1f2131f5;color:#fff;border:none;font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:0 2px 12px #0003}.platform-mobile-overlay{display:none}@media (max-width: 768px){.platform-shell{grid-template-columns:1fr}.platform-sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;transform:translate(-100%);transition:transform .25s ease;z-index:105}.platform-sidebar.is-mobile-open{transform:translate(0)}.platform-mobile-toggle{display:block}.platform-mobile-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100}.platform-main{padding:64px 16px 16px}}.impersonation-banner{position:sticky;top:0;z-index:999;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:linear-gradient(90deg,#f4b146,#ef7a62);color:#1f2131;font-size:.88rem;font-weight:500;text-align:center;box-shadow:0 2px 12px #0000001f}.impersonation-banner .ghost-button{background:#1f21312e;color:#1f2131;font-weight:600}.read-only-banner{position:sticky;top:0;z-index:999;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:linear-gradient(90deg,#ef7a6226,#f4b14626);color:var(--ink);font-size:.88rem;border-bottom:2px solid var(--coral)}.read-only-banner .ghost-button{background:var(--cobalt);color:#fff;font-weight:600;text-decoration:none}.status-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.status-card{width:min(560px,100%);padding:40px 32px;background:var(--paper-strong);border-radius:24px;border:1px solid var(--line);box-shadow:var(--shadow);text-align:center}.status-badge{width:80px;height:80px;border-radius:999px;display:grid;place-items:center;color:#fff;margin:0 auto 16px;box-shadow:0 8px 24px #0000001f}.status-card h1{margin:0 0 24px;font-family:"DM Serif Display",serif;font-size:clamp(1.4rem,3vw,2rem)}.status-error{color:var(--coral);margin:0 0 16px}.status-components{display:grid;gap:8px;text-align:left;margin:24px 0}.status-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#fff6;border-radius:12px;border:1px solid var(--line)}.status-meta{font-size:.78rem;color:var(--muted);margin:16px 0 0}.splash-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#fef9f2d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:opacity .6s ease}.splash-overlay.splash-fading{opacity:0;pointer-events:none}.splash-content{display:flex;flex-direction:column;align-items:center;gap:18px;transition:transform 1s cubic-bezier(.4,0,.2,1),opacity .8s ease}.splash-content.splash-fly{transform:translate(calc(50vw - 60px),calc(-50vh + 40px)) scale(.45);opacity:.3}.splash-logo{width:100px;height:100px;border-radius:24px;object-fit:cover;transform:scale(0);opacity:0;transition:transform .6s cubic-bezier(.34,1.56,.64,1),opacity .4s ease;box-shadow:0 8px 32px #0000001f}.splash-logo-fallback{display:flex;align-items:center;justify-content:center;background:var(--cobalt);color:#fff;font-size:2.5rem;font-family:"DM Serif Display",serif}.splash-logo-enter{transform:scale(1);opacity:1}.splash-logo-fly{border-radius:50%}.splash-school-name{font-family:"DM Serif Display",serif;font-size:1.6rem;color:var(--ink);opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.splash-name-visible{opacity:1;transform:translateY(0)}.upgrade-prompt{display:flex;align-items:center;justify-content:center;min-height:400px;padding:40px}.upgrade-prompt-card{text-align:center;max-width:480px;padding:48px 32px;border-radius:24px;background:var(--paper-strong, rgba(255, 248, 238, .92));border:1px solid var(--line)}.upgrade-prompt-icon{margin-bottom:16px}.upgrade-prompt h2{font-family:"DM Serif Display",serif;font-size:1.4rem;margin:0 0 12px}.upgrade-prompt p{color:var(--muted, #666);margin:0 0 24px}.nav-link-locked{opacity:.5;pointer-events:none;position:relative}.nav-link-locked:after{content:"🔒";position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:.7rem}.saas-pricing-current{border-color:var(--mint);background:#2d8d740a}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;align-items:center;justify-content:center;background:#0f101880;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.onboarding-card{width:min(520px,90vw);max-height:90vh;overflow-y:auto;background:#fff9f2;border-radius:24px;padding:32px;box-shadow:0 20px 60px #00000026}.onboarding-header{text-align:center;margin-bottom:24px}.onboarding-header h2{font-family:"DM Serif Display",serif;font-size:1.5rem;margin:0 0 8px}.onboarding-progress{height:6px;border-radius:3px;background:#1f213114;margin:16px 0 6px}.onboarding-progress-bar{height:100%;border-radius:3px;background:var(--cobalt);transition:width .4s ease}.onboarding-steps{display:grid;gap:8px;margin-bottom:24px}.onboarding-step{display:flex;gap:12px;align-items:flex-start;padding:12px 16px;border-radius:14px;border:1px solid transparent;cursor:pointer;transition:background .15s ease}.onboarding-step:hover{background:#1f213108}.onboarding-step.is-active{background:#2354f50f;border-color:var(--cobalt)}.onboarding-step.is-done{opacity:.5}.onboarding-step.is-done .onboarding-step-icon{color:var(--mint)}.onboarding-step-icon{font-size:1.3rem;flex-shrink:0;margin-top:2px}.onboarding-step strong{display:block;font-size:.9rem}.onboarding-step p{font-size:.82rem;color:var(--muted, #666);margin:4px 0 0}.onboarding-dismiss{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 0 4px;font-size:.85rem;color:var(--muted);cursor:pointer}.onboarding-dismiss input{cursor:pointer}.onboarding-actions{display:flex;gap:12px;justify-content:center}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;background:#0f101866;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.search-modal{width:min(560px,90vw);background:#fff9f2;border-radius:18px;box-shadow:0 20px 60px #00000026;overflow:hidden}.search-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid rgba(31,33,49,.08)}.search-icon{color:var(--muted, #888);flex-shrink:0}.search-input{flex:1;border:none;background:none;font-size:1rem;font-family:inherit;outline:none;color:var(--ink)}.search-kbd{padding:2px 6px;font-size:.7rem;border-radius:4px;background:#1f21310f;color:var(--muted, #888);font-family:monospace}.search-results{max-height:320px;overflow-y:auto}.search-result-item{display:flex;gap:12px;align-items:center;width:100%;padding:12px 18px;border:none;background:none;text-align:left;font-family:inherit;font-size:.88rem;cursor:pointer;border-bottom:1px solid rgba(31,33,49,.04)}.search-result-item:hover{background:#2354f50a}.search-result-type{padding:2px 8px;border-radius:8px;font-size:.7rem;font-weight:600;text-transform:uppercase;background:#2354f514;color:var(--cobalt);flex-shrink:0}.search-hint{padding:14px 18px;text-align:center}.search-hint kbd{padding:1px 5px;border-radius:3px;background:#1f21310f;font-size:.75rem}.empty-state-rich{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;gap:8px}.empty-state-icon{font-size:2.5rem}.empty-state-rich h3{font-size:1.1rem;margin:0}.empty-state-rich p{color:var(--muted, #666);font-size:.88rem;margin:0;max-width:320px}.empty-state-action{margin-top:12px}.skeleton-line{background:linear-gradient(90deg,#1f21310f 25%,#1f21311f,#1f21310f 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:6px;margin-bottom:8px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-lines{padding:12px 0}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.skeleton-card{padding:20px;border-radius:14px;border:1px solid rgba(31,33,49,.06);display:grid;gap:10px}.skeleton-table{display:grid;gap:4px}.skeleton-row{display:flex;gap:12px;padding:10px 0}.calendar-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-weekday{padding:8px 4px;text-align:center;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.calendar-cell{min-height:54px;padding:6px;border-radius:10px;border:1px solid transparent;display:flex;flex-direction:column;align-items:center;gap:4px;transition:background .12s ease}.calendar-cell.is-empty{min-height:0}.calendar-cell.is-today{background:#2354f514;border-color:#2354f533}.calendar-cell.has-events{background:#ffffff80;border-color:var(--line)}.calendar-day{font-size:.82rem;font-weight:600}.calendar-event-dot{width:8px;height:8px;border-radius:999px}.calendar-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px;font-size:.78rem;color:var(--muted)}.calendar-legend span{display:inline-flex;align-items:center;gap:6px}.calendar-legend-dot{display:inline-block;width:10px;height:10px;border-radius:999px}.parent-child-header{display:flex;gap:16px;align-items:center}.parent-child-photo{width:72px;height:72px;border-radius:18px;object-fit:cover;border:2px solid var(--line)}.parent-child-photo-placeholder{width:72px;height:72px;border-radius:18px;background:#2354f514;color:var(--cobalt);display:grid;place-items:center;font-size:1.8rem;font-weight:700}.parent-child-info{display:grid;gap:4px;font-size:.88rem}.attendance-dots{display:flex;flex-wrap:wrap;gap:6px}.att-dot{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:.72rem;font-weight:600}.att-present{background:#2d8d7424;color:var(--mint)}.att-absent{background:#ef7a6224;color:#b14e39}.att-leave{background:#f4b1462e;color:#9b6508}[data-theme=dark]{color-scheme:dark;--bg: #141420;--paper: rgba(28, 28, 44, .88);--paper-strong: rgba(32, 32, 50, .94);--ink: #e8e6f0;--muted: #9a95a8;--line: rgba(255, 255, 255, .1);--shadow: 0 24px 80px rgba(0, 0, 0, .32);--white: #1a1a2e}[data-theme=dark] body{background:radial-gradient(circle at top left,rgba(244,177,70,.06),transparent 30%),radial-gradient(circle at 85% 10%,rgba(35,84,245,.06),transparent 22%),linear-gradient(135deg,#14131f,#1a1928 48%,#161524)}[data-theme=dark] .global-navbar{background:#161626f5}[data-theme=dark] .field input,[data-theme=dark] .field select,[data-theme=dark] .field textarea,[data-theme=dark] .inline-field input,[data-theme=dark] .inline-field select,[data-theme=dark] .table-note-input{background:#ffffff0f;border-color:#ffffff1a;color:var(--ink)}[data-theme=dark] .ghost-button{background:#ffffff14;color:var(--ink)}[data-theme=dark] .data-table th{background:#ffffff0a}[data-theme=dark] .data-table tbody tr:hover{background:#ffffff0d}[data-theme=dark] .data-table th,[data-theme=dark] .data-table td{border-bottom-color:#ffffff0f}[data-theme=dark] .tone-sand{background:#f4b1461a}[data-theme=dark] .tone-mint{background:#2d8d741f}[data-theme=dark] .tone-ink{background:#ffffff14;color:var(--ink)}[data-theme=dark] .tone-ink p,[data-theme=dark] .tone-ink span{color:var(--muted)}[data-theme=dark] .tone-coral{background:#ef7a621f}[data-theme=dark] .message-banner{background:#ffffff0f}[data-theme=dark] .message-banner.is-error{background:#ef7a621f;border-color:#ef7a6238}[data-theme=dark] .message-banner.is-success{background:#2d8d741f;border-color:#2d8d7433}[data-theme=dark] .today-chip{background:#ffffff0f}[data-theme=dark] .status-inactive,[data-theme=dark] .status-absent{color:#ef8a75}[data-theme=dark] .status-leave,[data-theme=dark] .status-pending{color:#e0a83c}[data-theme=dark] .link-button{color:#7fa0ff;text-decoration-color:#7fa0ff4d}[data-theme=dark] .dialog-card{background:var(--paper-strong)}[data-theme=dark] .dialog-detail,[data-theme=dark] .academic-subject-row{background:#ffffff0a}[data-theme=dark] .search-modal{background:#1e1e32}[data-theme=dark] .search-result-item:hover{background:#2354f514}[data-theme=dark] .skeleton-line{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}[data-theme=dark] .skeleton-card{border-color:#ffffff0f}[data-theme=dark] .side-panel{background:var(--paper-strong)}[data-theme=dark] .ambient-one{background:#ef7a620f}[data-theme=dark] .ambient-two{background:#2354f50f}[data-theme=dark] .calendar-cell.is-today{background:#2354f51f}[data-theme=dark] .calendar-cell.has-events{background:#ffffff0a}[data-theme=dark] .saas-aurora{background:radial-gradient(ellipse at 20% 20%,rgba(35,84,245,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 30%,rgba(239,122,98,.04) 0%,transparent 45%),radial-gradient(ellipse at 50% 80%,rgba(45,141,116,.04) 0%,transparent 50%),radial-gradient(ellipse at 70% 60%,rgba(244,177,70,.03) 0%,transparent 40%);background-size:200% 200%;animation:aurora-shift 12s ease-in-out infinite}[data-theme=dark] .saas-glass{background:#1c1c2c8c;border-color:#ffffff14}[data-theme=dark] .saas-orb-1{background:#2354f50f}[data-theme=dark] .saas-orb-2{background:#ef7a620d}[data-theme=dark] .saas-orb-3{background:#2d8d740d}[data-theme=dark] .saas-sticky-cta{background:#161626e0}[data-theme=dark] .saas-hero-badge{background:#2354f51f;border-color:#2354f533}[data-theme=dark] .saas-feature-card:hover{box-shadow:0 12px 40px #0003}[data-theme=dark] .saas-pricing-featured{border-color:var(--cobalt);background:#2354f50f}.theme-toggle{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#ffffff0f;cursor:pointer;font-size:.78rem;color:var(--muted);transition:background .18s ease}.theme-toggle:hover{background:#ffffff1f}.theme-toggle-icon{font-size:1rem;line-height:1}.shortcuts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:grid;place-items:center;background:#1f213170;padding:24px}.shortcuts-card{width:min(440px,90vw);background:var(--paper-strong);border-radius:20px;box-shadow:var(--shadow);overflow:hidden}[data-theme=dark] .shortcuts-card{background:#1e1e32}.shortcuts-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--line)}.shortcuts-header h3{margin:0;font-size:1rem}.shortcuts-list{padding:12px 20px 20px;display:grid;gap:6px}.shortcuts-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:.88rem}.shortcut-key{display:inline-flex;gap:4px;align-items:center}.shortcut-key span{padding:3px 8px;border-radius:6px;font-size:.76rem;font-family:monospace;background:#1f213114;border:1px solid var(--line)}[data-theme=dark] .shortcut-key span{background:#ffffff14}.help-tooltip-wrap{position:relative;display:inline-flex}.help-tooltip-trigger{width:20px;height:20px;display:inline-grid;place-items:center;border-radius:999px;border:1px solid var(--line);background:#1f21310a;font-size:.72rem;font-weight:700;color:var(--muted);cursor:pointer;padding:0;line-height:1}.help-tooltip-trigger:hover{background:#2354f514;color:var(--cobalt);border-color:#2354f533}.help-tooltip-bubble{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:max-content;max-width:260px;padding:10px 14px;border-radius:12px;background:var(--ink);color:#fff;font-size:.8rem;line-height:1.45;box-shadow:0 8px 24px #0000002e;z-index:100;pointer-events:auto}.help-tooltip-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--ink)}.undo-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:400;display:flex;align-items:center;gap:14px;padding:14px 20px;border-radius:16px;background:var(--ink);color:#fff;font-size:.88rem;box-shadow:0 12px 40px #00000038;animation:undo-slide-up .26s ease;overflow:hidden}@keyframes undo-slide-up{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.undo-toast-btn{padding:6px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:#ffffff1f;color:#fff;font-weight:600;font-size:.82rem;cursor:pointer;white-space:nowrap}.undo-toast-btn:hover{background:#ffffff38}.undo-toast-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff1a}.undo-toast-bar-fill{height:100%;background:var(--cobalt);transition:width .1s linear}.mobile-bottom-nav{display:none}@media (max-width: 680px){.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;display:flex;justify-content:space-around;align-items:stretch;background:var(--paper-strong);border-top:1px solid var(--line);padding:4px 0 env(safe-area-inset-bottom,4px);box-shadow:0 -4px 20px #0000000f}[data-theme=dark] .mobile-bottom-nav{background:#161626f5;box-shadow:0 -4px 20px #0000003d}.mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px 6px;font-size:.64rem;font-weight:600;color:var(--muted);text-decoration:none;flex:1;min-width:0}.mobile-bottom-nav a.is-active{color:var(--cobalt)}.mobile-nav-icon{font-size:1.15rem;line-height:1}.mobile-bottom-nav span:last-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.content-shell{padding-bottom:72px}.hamburger-toggle{display:none}.undo-toast{bottom:72px}}.content-shell{overflow:hidden}.workspace-aurora{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.4;background:radial-gradient(ellipse at 15% 20%,rgba(35,84,245,.1) 0%,transparent 50%),radial-gradient(ellipse at 85% 25%,rgba(239,122,98,.07) 0%,transparent 45%),radial-gradient(ellipse at 50% 90%,rgba(45,141,116,.07) 0%,transparent 55%),radial-gradient(ellipse at 75% 65%,rgba(244,177,70,.05) 0%,transparent 45%);background-size:200% 200%;animation:aurora-shift 24s ease-in-out infinite;will-change:background-position}.global-navbar{background:#fff9f2b8;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid rgba(255,255,255,.45);box-shadow:0 1px #1f21310a,0 8px 24px -18px #1f21312e}.nav-link{position:relative}.nav-link:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,var(--cobalt),var(--mint));box-shadow:0 0 12px var(--cobalt);opacity:0;transition:opacity var(--motion-fast) var(--ease-standard)}.nav-link.is-active{background:linear-gradient(135deg,#2354f52e,#2d8d741a);border-color:#2354f547;box-shadow:inset 0 0 0 1px #2354f529,0 0 24px -8px #2354f573}.nav-link.is-active:before{opacity:1}.nav-link:hover:before{opacity:.5}.page-shell{position:relative;z-index:1;min-width:0}.route-transition-shell{position:relative;min-width:0;display:grid;gap:var(--page-shell-gap)}.route-transition-frame{min-width:0;display:grid;gap:var(--page-shell-gap);transform-origin:top center;animation:route-frame-enter var(--motion-route) var(--ease-emphasis) both;will-change:opacity,transform}.route-transition-frame[data-route-direction=backward]{animation-name:route-frame-enter-backward}@supports (view-transition-name: none){.route-transition-frame{view-transition-name:main-content}.route-transition-frame,.route-transition-frame[data-route-direction=backward]{animation:none}::view-transition-old(main-content),::view-transition-new(main-content){animation-duration:var(--motion-route);animation-timing-function:var(--ease-emphasis)}::view-transition-old(main-content){animation-name:vt-main-exit}::view-transition-new(main-content){animation-name:vt-main-enter}::view-transition-old(root),::view-transition-new(root){animation-duration:var(--motion-fast);animation-timing-function:var(--ease-standard)}}@keyframes vt-main-exit{to{opacity:0;transform:translate3d(0,calc(var(--distance-route-y) * -.35),0) scale(.992)}}@keyframes vt-main-enter{0%{opacity:0;transform:translate3d(0,var(--distance-route-y),0) scale(.985)}}@keyframes route-frame-enter{0%{opacity:0;transform:translate3d(0,var(--distance-route-y),0) scale(.985)}55%{opacity:1}to{opacity:1;transform:translateZ(0) scale(1)}}@keyframes route-frame-enter-backward{0%{opacity:0;transform:translate3d(0,calc(var(--distance-route-y) * -.35),0) scale(.992)}55%{opacity:1}to{opacity:1;transform:translateZ(0) scale(1)}}.global-navbar-center{display:flex;align-items:center}.navbar-route-progress{position:absolute;left:18px;right:18px;bottom:0;height:2px;border-radius:999px;overflow:hidden;pointer-events:none;opacity:0;transition:opacity var(--motion-fast) var(--ease-standard)}.navbar-route-progress.is-visible{opacity:1}.navbar-route-progress-bar{position:absolute;inset:0 auto 0 -18%;width:38%;min-width:120px;border-radius:inherit;background:linear-gradient(90deg,#2354f500,#2354f5eb,#2d8d74b8);box-shadow:0 0 18px #2354f547;animation:navbar-route-progress var(--motion-route) var(--ease-emphasis) both}.navbar-title-stack{min-width:0;display:grid}.navbar-title-chip{display:inline-flex;align-items:center;gap:12px;width:fit-content;max-width:100%;padding:6px 14px 6px 8px;border-radius:999px;border:1px solid rgba(31,33,49,.08);background:linear-gradient(135deg,#ffffffd6,#ffffff94);box-shadow:0 18px 30px -24px #1f213138;animation:navbar-title-enter var(--motion-route) var(--ease-emphasis) both}.navbar-title-chip[data-route-direction=backward]{animation-name:navbar-title-enter-backward}.navbar-title-badge{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:62px;padding:7px 10px;border-radius:999px;background:linear-gradient(135deg,var(--cobalt),var(--mint));box-shadow:0 12px 20px -16px #2354f5b3;color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.navbar-title-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink);font-size:.92rem;letter-spacing:.01em}@keyframes navbar-title-enter{0%{opacity:0;transform:translate3d(0,10px,0) scale(.97)}to{opacity:1;transform:translateZ(0) scale(1)}}@keyframes navbar-title-enter-backward{0%{opacity:0;transform:translate3d(0,-7px,0) scale(.985)}to{opacity:1;transform:translateZ(0) scale(1)}}@keyframes navbar-route-progress{0%{transform:translate(0) scaleX(.82)}to{transform:translate(320%) scaleX(1.16)}}.nav-stack{position:relative;padding:4px}.nav-stack-indicator{position:absolute;left:4px;right:4px;top:0;z-index:0;border-radius:20px;background:linear-gradient(135deg,#2354f52e,#2d8d741f);border:1px solid rgba(35,84,245,.18);box-shadow:0 18px 32px -28px #2354f5cc,inset 0 1px #ffffff14;pointer-events:none;transition:transform var(--motion-route) var(--ease-emphasis),height var(--motion-medium) var(--ease-standard),opacity var(--motion-fast) var(--ease-standard)}.nav-link{z-index:1;color:#ffffffeb;transition:transform var(--motion-medium) var(--ease-emphasis),background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-medium) var(--ease-standard),color var(--motion-fast) var(--ease-standard)}.nav-link-copy{min-width:0;display:grid;gap:2px}.nav-link-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;transition:transform var(--motion-medium) var(--ease-emphasis)}.nav-link-badge{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff0f;color:#ffffffb8;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:transform var(--motion-medium) var(--ease-emphasis),background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard)}.nav-link:hover{transform:translate(4px);box-shadow:0 18px 30px -26px #081527b8}.nav-link:hover .nav-link-badge{border-color:#ffffff24;background:#ffffff1a}.nav-link.is-active{transform:none;background:#ffffff0d;border-color:transparent;box-shadow:inset 0 0 0 1px #ffffff0a}.nav-link.is-active .nav-link-label{transform:translate(4px)}.nav-link.is-active .nav-link-badge{transform:translate(-2px);background:#ffffff29;border-color:#ffffff29;color:#fff}@media (max-width: 680px){.mobile-bottom-nav{gap:6px;padding:6px 8px calc(env(safe-area-inset-bottom,4px) + 6px);background:#fff8eee6;backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);border-top:1px solid rgba(31,33,49,.08);box-shadow:0 -18px 30px -28px #1f21313d}.mobile-nav-link{position:relative;isolation:isolate;border-radius:18px;transition:color var(--motion-fast) var(--ease-standard),transform var(--motion-medium) var(--ease-emphasis)}.mobile-nav-link:before,.mobile-nav-link:after{content:"";position:absolute;pointer-events:none;transition:transform var(--motion-medium) var(--ease-emphasis),opacity var(--motion-fast) var(--ease-standard)}.mobile-nav-link:before{top:2px;right:2px;bottom:2px;left:2px;border-radius:16px;background:linear-gradient(135deg,#2354f529,#2d8d741f);box-shadow:0 16px 28px -22px #2354f575;opacity:0;transform:translateY(8px) scale(.9);z-index:0}.mobile-nav-link:after{left:50%;top:3px;width:28px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--cobalt),var(--mint));opacity:0;transform:translate(-50%) scaleX(.55);z-index:1}.mobile-nav-link.is-active{color:var(--ink);transform:translateY(-2px)}.mobile-nav-link.is-active:before{opacity:1;transform:translateY(0) scale(1)}.mobile-nav-link.is-active:after{opacity:1;transform:translate(-50%) scaleX(1)}.mobile-nav-icon,.mobile-nav-label{position:relative;z-index:2;transition:transform var(--motion-medium) var(--ease-emphasis),color var(--motion-fast) var(--ease-standard)}.mobile-nav-link.is-active .mobile-nav-icon{transform:translateY(-1px) scale(1.08)}.mobile-nav-label{max-width:100%}}.panel{position:relative;background:linear-gradient(180deg,#ffffffc7,#ffffff9e);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(31,33,49,.06);box-shadow:0 1px #fff9 inset,0 12px 32px -20px #1f21312e;transition:transform var(--motion-medium) var(--ease-emphasis),box-shadow var(--motion-slow) var(--ease-standard)}.panel:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;padding:1px;background:transparent;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;-webkit-mask-composite:xor;pointer-events:none;transition:background .32s ease}.panel:hover{transform:translateY(calc(-1 * var(--distance-lift-sm)));box-shadow:0 1px #fff9 inset,0 20px 48px -24px #1f213138}.panel:hover:before{background:linear-gradient(135deg,var(--cobalt),var(--coral),var(--mint))}.tone-sand{--tone-glow: rgba(244, 177, 70, .35)}.tone-mint{--tone-glow: rgba(45, 141, 116, .35)}.tone-ink{--tone-glow: rgba(35, 84, 245, .4)}.tone-coral{--tone-glow: rgba(239, 122, 98, .35)}.metric-card{position:relative;overflow:hidden;transition:transform var(--motion-medium) var(--ease-emphasis),box-shadow var(--motion-slow) var(--ease-standard)}.metric-card:after{content:"";position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--tone-glow, rgba(35, 84, 245, .3)),transparent 70%);filter:blur(20px);pointer-events:none;opacity:.6}.metric-card:hover{transform:translateY(calc(-1 * var(--distance-lift-sm)));box-shadow:0 18px 40px -22px var(--tone-glow, rgba(35, 84, 245, .3))}.accent-button{box-shadow:0 8px 20px -8px #2354f58c;transition:box-shadow .28s ease,transform .18s ease}.accent-button:hover{box-shadow:0 0 0 1px #2354f566,0 12px 28px -8px #2354f58c,0 0 32px -4px #2354f559}.ghost-button{transition:border-color .18s ease,background .18s ease,transform .18s ease}.ghost-button:hover{border-color:#2354f54d}.field input,.field select,.field textarea,.inline-field input,.inline-field select{transition:border-color .18s ease,box-shadow .22s ease,background .22s ease}.field input:focus,.field select:focus,.field textarea:focus,.inline-field input:focus,.inline-field select:focus{outline:none;border-color:transparent;box-shadow:0 0 0 1px var(--cobalt),0 0 0 4px #2354f51f,0 0 18px -4px #2354f559}.status-pill{position:relative;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.status-active,.status-present{box-shadow:0 0 0 1px #2d8d7440,0 0 12px -2px #2d8d7466}.status-inactive,.status-absent{box-shadow:0 0 0 1px #ef7a6240,0 0 12px -2px #ef7a6266}.status-leave,.status-pending{box-shadow:0 0 0 1px #f4b1464d,0 0 12px -2px #f4b14673}.status-passout,.status-passedout,.status-tooktc,.status-closed{box-shadow:0 0 0 1px #1f21312e,0 0 12px -2px #1f213140}.data-table{border-collapse:separate;border-spacing:0}.data-table th{position:sticky;top:0;z-index:2;background:linear-gradient(180deg,#fff9f2f2,#fff9f2d9);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(31,33,49,.08);box-shadow:0 1px #1f21310a}.data-table tbody tr:nth-child(2n) td{background:#1f213106}.data-table tbody tr{transition:transform .16s ease,box-shadow .2s ease,background .16s ease;animation:row-stagger-in var(--motion-medium) var(--ease-decelerate) both}.data-table tbody tr:hover{background:#2354f50a;box-shadow:inset 3px 0 0 var(--cobalt)}.data-table tbody tr:hover td{background:#2354f50a}.data-table tbody tr:nth-child(1){animation-delay:0ms}.data-table tbody tr:nth-child(2){animation-delay:18ms}.data-table tbody tr:nth-child(3){animation-delay:36ms}.data-table tbody tr:nth-child(4){animation-delay:54ms}.data-table tbody tr:nth-child(5){animation-delay:72ms}.data-table tbody tr:nth-child(6){animation-delay:90ms}.data-table tbody tr:nth-child(7){animation-delay:108ms}.data-table tbody tr:nth-child(8){animation-delay:126ms}.data-table tbody tr:nth-child(9){animation-delay:144ms}.data-table tbody tr:nth-child(10){animation-delay:162ms}.data-table tbody tr:nth-child(11){animation-delay:.18s}.data-table tbody tr:nth-child(12){animation-delay:198ms}.data-table tbody tr:nth-child(13){animation-delay:216ms}.data-table tbody tr:nth-child(14){animation-delay:234ms}.data-table tbody tr:nth-child(15){animation-delay:252ms}.data-table tbody tr:nth-child(16){animation-delay:.27s}.data-table tbody tr:nth-child(17){animation-delay:288ms}.data-table tbody tr:nth-child(18){animation-delay:306ms}.data-table tbody tr:nth-child(19){animation-delay:324ms}.data-table tbody tr:nth-child(n+20){animation-delay:342ms}.data-table tbody tr:only-child{animation:none}@keyframes row-stagger-in{0%{opacity:0;transform:translate3d(0,4px,0)}to{opacity:1;transform:translateZ(0)}}.skeleton-line{background:linear-gradient(90deg,#1f21310f,#2354f51a,#1f21310f);background-size:200% 100%}.empty-state-rich{position:relative;isolation:isolate}.empty-state-icon{position:relative}.empty-state-icon:before{content:"";position:absolute;top:50%;left:50%;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(35,84,245,.18),transparent 70%);filter:blur(20px);transform:translate(-50%,-50%);z-index:-1}.recharts-cartesian-grid line{stroke:#1f21310f}@media (prefers-reduced-motion: reduce){.panel,.panel:before,.metric-card,.metric-card strong,.data-table tbody tr,.accent-button,.ghost-button,.status-pill,.empty-state-icon,.page-shell,.route-transition-frame,.nav-stack-indicator,.navbar-route-progress-bar,.navbar-title-chip,.workspace-aurora,.workspace-orb,.nav-link,.nav-link:before,.mobile-nav-link,.mobile-nav-link:before,.mobile-nav-link:after,.mobile-nav-icon,.mobile-nav-label{animation:none!important;transition:none!important;transform:none!important}::view-transition-old(main-content),::view-transition-new(main-content),::view-transition-old(root),::view-transition-new(root){animation:none!important}}[data-theme=dark] .workspace-aurora{opacity:.22}[data-theme=dark] .workspace-orb-a{background:#2354f50d}[data-theme=dark] .workspace-orb-b{background:#ef7a620a}[data-theme=dark] .workspace-orb-c{background:#2d8d740a}[data-theme=dark] .global-navbar{background:#161626b8;border-bottom-color:#ffffff0f;box-shadow:0 1px #ffffff08,0 8px 24px -18px #0006}[data-theme=dark] .nav-link.is-active{background:linear-gradient(135deg,#2354f547,#2d8d7424);border-color:#2354f55c;box-shadow:inset 0 0 0 1px #2354f538,0 0 28px -8px #2354f58c}[data-theme=dark] .side-rail{background:linear-gradient(180deg,#121420fa,#0c0f1afa);border-right-color:#ffffff1f;box-shadow:8px 0 32px #00000080}[data-theme=dark] .side-rail-overlay{background:#0009}[data-theme=dark] .nav-link{background:#ffffff0f;border-color:#ffffff24;color:#ffffffeb}[data-theme=dark] .nav-link:hover{background:#ffffff1a;border-color:#ffffff38}[data-theme=dark] .nav-link small{color:#ffffffb8}[data-theme=dark] .nav-stack-indicator{background:linear-gradient(135deg,#2354f557,#2d8d7429);border-color:#7fa0ff33;box-shadow:0 18px 32px -28px #2354f5bf,inset 0 1px #ffffff14}[data-theme=dark] .navbar-title-chip{background:linear-gradient(135deg,#222538f0,#181a28d1);border-color:#ffffff14;box-shadow:0 18px 30px -24px #0000008c}[data-theme=dark] .navbar-title-label{color:#fffffff5}[data-theme=dark] .navbar-route-progress-bar{box-shadow:0 0 18px #7fa0ff73}[data-theme=dark] .rail-note{background:#ffffff0f;border:1px solid rgba(255,255,255,.1)}[data-theme=dark] .rail-note span,[data-theme=dark] .rail-note p{color:#ffffffc7}[data-theme=dark] .panel{background:linear-gradient(180deg,#28283c8c,#1c1c2c80);border-color:#ffffff0f;box-shadow:0 1px #ffffff0a inset,0 12px 32px -20px #00000080}[data-theme=dark] .panel:hover{box-shadow:0 1px #ffffff0a inset,0 20px 48px -24px #0009}[data-theme=dark] .tone-sand{--tone-glow: rgba(244, 177, 70, .22)}[data-theme=dark] .tone-mint{--tone-glow: rgba(45, 141, 116, .25)}[data-theme=dark] .tone-ink{--tone-glow: rgba(35, 84, 245, .3)}[data-theme=dark] .tone-coral{--tone-glow: rgba(239, 122, 98, .22)}[data-theme=dark] .accent-button{box-shadow:0 8px 20px -8px #2354f599}[data-theme=dark] .accent-button:hover{box-shadow:0 0 0 1px #2354f580,0 12px 28px -8px #2354f599,0 0 32px -4px #2354f573}[data-theme=dark] .ghost-button:hover{border-color:#7fa0ff66}@media (max-width: 680px){[data-theme=dark] .mobile-nav-link:before{background:linear-gradient(135deg,#2354f547,#2d8d7429)}[data-theme=dark] .mobile-nav-link.is-active{color:#fff}}[data-theme=dark] .field input:focus,[data-theme=dark] .field select:focus,[data-theme=dark] .field textarea:focus,[data-theme=dark] .inline-field input:focus,[data-theme=dark] .inline-field select:focus{box-shadow:0 0 0 1px var(--cobalt),0 0 0 4px #2354f52e,0 0 18px -4px #2354f580}[data-theme=dark] .data-table th{background:linear-gradient(180deg,#161626f2,#161626d9);border-bottom-color:#ffffff14}[data-theme=dark] .data-table tbody tr:nth-child(2n) td{background:#ffffff05}[data-theme=dark] .data-table tbody tr:hover,[data-theme=dark] .data-table tbody tr:hover td{background:#2354f51a}[data-theme=dark] .skeleton-line{background:linear-gradient(90deg,#ffffff0a,#2354f51a,#ffffff0a);background-size:200% 100%}[data-theme=dark] .empty-state-icon:before{background:radial-gradient(circle,rgba(35,84,245,.22),transparent 70%)}.panel{backdrop-filter:none;-webkit-backdrop-filter:none;background:linear-gradient(180deg,#ffffffeb,#ffffffd6);contain:layout paint}[data-theme=dark] .panel{background:linear-gradient(180deg,#28283ce0,#1c1c2cd1)}.metric-card{contain:layout paint}.global-navbar{backdrop-filter:blur(6px) saturate(120%);-webkit-backdrop-filter:blur(6px) saturate(120%);background:#fff9f2f0;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-medium) var(--ease-standard)}[data-theme=dark] .global-navbar{background:#161626f0}.workspace-orb{filter:blur(36px)}.data-table th,.status-pill{backdrop-filter:none;-webkit-backdrop-filter:none}.workspace-aurora{animation-duration:90s}@media (prefers-reduced-motion: reduce){.workspace-orb,.workspace-aurora,.saas-orb{animation:none!important}}[data-theme=dark] .recharts-cartesian-grid line{stroke:#ffffff0f}[data-school-type=play-school]{--bg: #FFF8F0;--paper: #FFF5EB;--paper-strong: #FFF2E5;--ink: #4A3728;--muted: #8B7355;--line: rgba(74, 55, 40, .1);--cobalt: #E88D67;--mint: #7EC8A0;--coral: #F4A5A5;--amber: #F4C76B;--shadow: 0 8px 24px -12px rgba(74, 55, 40, .15)}[data-school-type=play-school] .side-rail{background:linear-gradient(180deg,#4a3728f5,#3c2a1cf0)}[data-school-type=play-school] .side-rail:after{background:linear-gradient(135deg,#e88d672e,#7ec8a01f)}[data-school-type=play-school] .panel{background:linear-gradient(180deg,#fff8f0f2,#fff2e5e0);border-color:#e88d671f;border-radius:28px}[data-school-type=play-school] .panel:hover{box-shadow:0 20px 48px -24px #e88d6740}[data-school-type=play-school] .metric-card{border-radius:24px}[data-school-type=play-school] .accent-button{background:linear-gradient(135deg,#e88d67,#d4754f);box-shadow:0 8px 20px -8px #e88d678c}[data-school-type=play-school] .accent-button:hover{box-shadow:0 0 0 1px #e88d6766,0 12px 28px -8px #e88d678c}[data-school-type=play-school] .global-navbar{background:#fff8f0f0;border-bottom-color:#e88d671f}[data-school-type=play-school] .navbar-title-chip{background:linear-gradient(135deg,#fffaf5f5,#fff3e8d1);border-color:#e88d6724}[data-school-type=play-school] .navbar-title-badge{background:linear-gradient(135deg,#e88d67,#7ec8a0);box-shadow:0 12px 20px -16px #e88d679e}[data-school-type=play-school] .nav-link.is-active{background:linear-gradient(135deg,#e88d672e,#7ec8a01a);border-color:#e88d6747;box-shadow:inset 0 0 0 1px #e88d6729,0 0 24px -8px #e88d6773}[data-school-type=play-school] .nav-stack-indicator{background:linear-gradient(135deg,#e88d6738,#7ec8a024);border-color:#e88d672e;box-shadow:0 18px 32px -28px #e88d67b8,inset 0 1px #ffffff1a}[data-school-type=play-school] .nav-link.is-active:before{background:linear-gradient(180deg,#e88d67,#7ec8a0);box-shadow:0 0 12px #e88d67}[data-school-type=play-school] .workspace-orb-a{background:#e88d6714}[data-school-type=play-school] .workspace-orb-b{background:#7ec8a012}[data-school-type=play-school] .workspace-orb-c{background:#f4a5a50f}[data-school-type=play-school] .data-table th{background:linear-gradient(180deg,#fff8f0f2,#fff2e5d9)}[data-school-type=play-school][data-theme=dark]{--bg: #1A1410;--paper: #221C15;--paper-strong: #2A2318;--ink: #F5E6D3;--muted: #C4A882;--line: rgba(245, 230, 211, .1)}[data-school-type=play-school][data-theme=dark] .panel{background:linear-gradient(180deg,#2a2318e0,#221c15d1)}[data-school-type=play-school][data-theme=dark] .global-navbar{background:#1a1410f0}[data-school-type=play-school][data-theme=dark] .navbar-title-chip{background:linear-gradient(135deg,#34261df5,#241c16d1);border-color:#e88d672e}[data-school-type=play-school][data-theme=dark] .side-rail{background:linear-gradient(180deg,#1a1410fa,#120e0afa)}.student-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:18px}.student-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px 16px;border-radius:24px;background:#ffffffc7;border:1px solid rgba(31,33,49,.06);box-shadow:0 6px 18px -12px #1f21311f;cursor:pointer;transition:transform .18s ease,box-shadow .22s ease;text-decoration:none;color:inherit}.student-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px -16px #1f213133}.student-card-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;background:linear-gradient(135deg,var(--cobalt),var(--mint));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;font-weight:700}.student-card-name{font-weight:700;font-size:1rem;text-align:center}.student-card-detail{font-size:.82rem;color:var(--muted);text-align:center}[data-school-type=play-school] .student-card{background:#fff8f0e6;border-color:#e88d671f;border-radius:28px}[data-theme=dark] .student-card{background:#28283c8c;border-color:#ffffff0f}
