:root{--bg-0:#05070a;--bg-1:#0a0e0c;--bg-2:#0f1411;--surface-1:#131816;--surface-2:#1a201d;--surface-3:#232b27;--border-1:#ffffff0f;--border-2:#ffffff17;--border-3:#ffffff24;--border-mint:#00ffcc3d;--text-1:#f3f5f4;--text-2:#c5cbc8;--text-3:#8a938f;--text-4:#5d6661;--text-5:#3d4541;--mint-50:#e6fffa;--mint-100:#b6fae6;--mint-200:#6ff5cf;--mint-300:#00d4aa;--mint-400:#00e6b8;--mint-500:#0fc;--mint-600:#00b894;--mint-700:#00876d;--mint-glow:#00ffcc38;--mint-soft:#00ffcc14;--warn:#f4b860;--warn-soft:#f4b8601f;--danger:#f87171;--danger-soft:#f871711f;--info:#60a5fa;--info-soft:#60a5fa1f;--neutral-soft:#ffffff0f;--r-xs:6px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:22px;--r-pill:999px;--shadow-1:0 1px 0 #ffffff08 inset, 0 1px 2px #0006;--shadow-2:0 1px 0 #ffffff0a inset, 0 8px 24px -8px #0009;--shadow-glow:0 0 0 1px #00ffcc59, 0 12px 40px -10px #00ffcc59;--font-sans:"Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}html,body,#app{height:100%}body{font-family:var(--font-sans);background:radial-gradient(1400px 800px at 75% -10%, #00ffcc1f, transparent 55%), radial-gradient(1000px 700px at -10% 110%, #00ffcc14, transparent 55%), radial-gradient(600px 400px at 50% 50%, #00ffcc06, transparent 70%), var(--bg-1);color:var(--text-1);font-feature-settings:"ss01", "cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0}button{cursor:pointer;font-family:inherit}input,textarea,select{color:inherit;font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff0f padding-box padding-box;border:2px solid #0000;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#ffffff1f padding-box padding-box;border:2px solid #0000}.pulse-dot{background:var(--mint-400);border-radius:50%;width:7px;height:7px;display:inline-block;position:relative}.pulse-dot:after{content:"";background:var(--mint-400);opacity:.5;border-radius:50%;animation:1.6s ease-out infinite pulseDot;position:absolute;inset:-3px}@keyframes pulseDot{0%{opacity:.55;transform:scale(.8)}to{opacity:0;transform:scale(2.2)}}.app{grid-template-columns:248px 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--border-1);background:linear-gradient(#0f141199,#0a0e0c66);flex-direction:column;height:100vh;padding:18px 14px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;margin-bottom:6px;padding:6px 6px 18px;display:flex}.brand-mark{background:linear-gradient(160deg, var(--mint-400), var(--mint-600));color:#03130b;border-radius:9px;flex-shrink:0;place-items:center;width:32px;height:32px;display:grid;box-shadow:0 0 0 1px #0fc6,0 8px 28px -4px #00ffcc8c,inset 0 1px #ffffff4d}.brand-name{letter-spacing:-.02em;color:var(--mint-300);font-size:18px;font-weight:600}.ascend-brand .brand-name{font-family:var(--font-sans);letter-spacing:.18em;font-size:15px;font-weight:600}.nav-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);padding:14px 10px 6px;font-size:11px;font-weight:500}.nav-items{flex-direction:column;gap:2px;display:flex}.nav-item{color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:9px;align-items:center;gap:11px;width:100%;padding:9px 11px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:flex}.nav-item:hover{color:var(--text-1);background:#ffffff08}.nav-item.active{color:var(--mint-300);border-color:var(--border-mint);background:linear-gradient(#00ffcc1a,#00ffcc0a)}.nav-item.active .nav-icon{color:var(--mint-400)}.nav-icon{width:18px;height:18px;color:var(--text-3);flex-shrink:0;display:inline-flex}.sidebar-footer{border-top:1px solid var(--border-1);align-items:center;gap:10px;margin-top:auto;padding:12px 8px;display:flex}.avatar{border:1px solid var(--border-2);width:32px;height:32px;color:var(--mint-300);background:linear-gradient(160deg,#2a3a33,#16201c);border-radius:50%;flex-shrink:0;place-items:center;font-size:12px;font-weight:600;display:grid}.main{flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--border-1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#0a0e0c99;align-items:center;gap:16px;padding:18px 32px;display:flex;position:sticky;top:0}.topbar-title{align-items:baseline;gap:10px;display:flex}.topbar-title h1{letter-spacing:-.02em;color:var(--text-1);margin:0;font-size:22px;font-weight:600}.topbar-actions{align-items:center;gap:10px;margin-left:auto;display:flex}.search{background:var(--surface-1);border:1px solid var(--border-1);width:320px;color:var(--text-3);border-radius:10px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.search input{color:var(--text-1);background:0 0;border:0;outline:0;flex:1;font-size:13px}.search kbd{font-family:var(--font-mono);color:var(--text-4);border:1px solid var(--border-1);background:#ffffff0d;border-radius:5px;padding:2px 6px;font-size:11px}.page{width:100%;max-width:1440px;padding:32px 32px 64px}.card{border:1px solid var(--border-1);border-radius:var(--r-lg);box-shadow:var(--shadow-2);background:linear-gradient(#131816b3,#0f14118c)}.card-header{border-bottom:1px solid var(--border-1);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.card-header h3{color:var(--text-1);letter-spacing:-.01em;margin:0;font-size:15px;font-weight:600}.card-body{padding:22px}.btn{cursor:pointer;white-space:nowrap;letter-spacing:-.005em;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;height:38px;padding:0 16px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s,color .15s,transform 50ms;display:inline-flex}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--mint-500);color:#03261f;font-weight:600;box-shadow:0 0 0 1px #0fc6,0 10px 28px -6px #00ffcc8c,0 0 40px -8px #0fc6,inset 0 1px #ffffff59}.btn-primary:hover{background:#2bffd6}.btn-secondary{background:var(--surface-2);color:var(--text-1);border-color:var(--border-2)}.btn-secondary:hover{background:var(--surface-3);border-color:var(--border-3)}.btn-ghost{color:var(--text-2);background:0 0}.btn-ghost:hover{background:var(--surface-1);color:var(--text-1)}.btn-danger{color:#fca5a5;background:#f871711f;border-color:#f8717140}.btn-danger:hover{background:#f871712e}.btn-sm{border-radius:8px;height:30px;padding:0 12px;font-size:12.5px}.btn-lg{border-radius:11px;height:46px;padding:0 22px;font-size:14px}.btn-icon{width:38px;padding:0}.btn-sm.btn-icon{width:30px}.field{flex-direction:column;gap:7px;display:flex}.field-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);font-size:11.5px;font-weight:600}.input,.textarea,.select{background:var(--surface-1);border:1px solid var(--border-1);width:100%;color:var(--text-1);border-radius:10px;outline:0;padding:11px 13px;font-size:14px;transition:border-color .15s,background .15s,box-shadow .15s}.input:focus,.textarea:focus,.select:focus{border-color:var(--border-mint);background:var(--bg-2);box-shadow:0 0 0 3px #00ffcc1a}.input::placeholder,.textarea::placeholder{color:var(--text-4)}.badge{border-radius:var(--r-pill);letter-spacing:.01em;border:1px solid #0000;align-items:center;gap:6px;padding:3px 10px;font-size:11.5px;font-weight:500;display:inline-flex}.badge .dot{border-radius:50%;width:6px;height:6px}.badge-active{background:var(--mint-soft);color:var(--mint-300);border-color:var(--border-mint)}.badge-active .dot{background:var(--mint-400);box-shadow:0 0 0 3px #00ffcc2e}.table-wrap{overflow-x:auto}.table{border-collapse:separate;border-spacing:0;width:100%;font-size:13.5px}.table th{text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border-1);background:#ffffff04;padding:14px 18px;font-size:11.5px;font-weight:500}.table td{border-bottom:1px solid var(--border-1);color:var(--text-2);vertical-align:middle;padding:16px 18px}.table tbody tr{transition:background .12s}.table tbody tr:hover{background:#ffffff05}.table tbody tr:hover td{color:var(--text-1)}.table tbody tr:last-child td{border-bottom:0}.table .num{font-family:var(--font-mono);font-feature-settings:"tnum"}.table .right{text-align:right}.stat{border:1px solid var(--border-1);border-radius:var(--r-lg);background:linear-gradient(#131816b3,#0f14118c);padding:22px;position:relative;overflow:hidden}.stat:after{content:"";pointer-events:none;background:radial-gradient(120% 80% at 100% 0,#00ffcc0a,#0000 60%);position:absolute;inset:0}.stat-label{color:var(--text-3);letter-spacing:.01em;font-size:12px;font-weight:500}.stat-value{letter-spacing:-.025em;color:var(--text-1);font-feature-settings:"tnum";margin-top:10px;font-size:30px;font-weight:600}.stat-value .currency{color:var(--text-3);letter-spacing:0;margin-right:4px;font-size:16px;font-weight:500}.stat-delta{align-items:center;gap:6px;margin-top:12px;font-size:12px;display:inline-flex}.stat-delta.up{color:var(--mint-300)}.stat-delta.down{color:#fca5a5}.stat-delta.flat{color:var(--text-3)}.grid-stats{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.grid-2{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=1100px){.grid-stats{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{grid-template-columns:1fr}}.page-header{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px;display:flex}.page-header h1{letter-spacing:-.025em;margin:0;font-size:28px;font-weight:600}.page-header p{color:var(--text-3);margin:6px 0 0;font-size:14px}.page-header-actions{gap:10px;display:flex}.cust-row{align-items:center;gap:10px;display:flex}.cust-name{color:var(--text-1);font-weight:500}.cust-sub{color:var(--text-4);font-size:12px}.toast{background:var(--surface-2);border:1px solid var(--border-mint);color:var(--mint-200);z-index:100;border-radius:10px;align-items:center;gap:10px;padding:12px 18px;font-size:13px;animation:.25s toastIn;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 12px 40px -10px #0009,0 0 0 1px #00ffcc26}.toast.error{color:#fca5a5;border-color:#f871714d}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,20px)}}.muted{color:var(--text-3)}.num{font-family:var(--font-mono);font-feature-settings:"tnum"}a{color:var(--mint-300);text-decoration:none}a:hover{color:var(--mint-200)}@media (prefers-reduced-motion:reduce){*,:before,:after{animation-duration:.001ms!important;animation-iteration-count:1!important}}.kpi-strip{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.kpi{background:var(--surface-1);border:1px solid var(--border-1);border-radius:16px;padding:18px;position:relative;overflow:hidden}.kpi .top{justify-content:space-between;align-items:center;display:flex}.kpi .ico{width:34px;height:34px;color:var(--text-2);background:#ffffff0a;border-radius:10px;place-items:center;display:grid}.kpi .ico.mint{background:var(--mint-soft);color:var(--mint-300)}.kpi .ico.blue{color:#93c5fd;background:#60a5fa1f}.kpi .ico.violet{color:#c4b5fd;background:#a78bfa1f}.kpi .ico.amber{color:#fbd38d;background:#f4b8601f}.kpi .trend{align-items:center;gap:3px;font-size:12px;font-weight:500;display:inline-flex}.kpi .trend.up{color:var(--mint-300)}.kpi .trend.down{color:#fca5a5}.kpi .label{color:var(--text-4);margin-top:14px;font-size:12px}.kpi .value{letter-spacing:-.025em;color:var(--text-1);font-feature-settings:"tnum";margin-top:2px;font-size:26px;font-weight:600}.kpi .spark{opacity:.8;width:50%;height:38px;position:absolute;bottom:0;right:0}.mz-grid{grid-template-columns:1.6fr 1fr;align-items:start;gap:16px;display:grid}.mz-col{flex-direction:column;gap:16px;display:flex}@media (width<=1100px){.mz-grid{grid-template-columns:1fr}}.kpi-tile{border:1px solid var(--border-1);background:#ffffff05;border-radius:11px;padding:12px 14px}.kpi-tile-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);font-size:11px}.kpi-tile-value{color:var(--text-1);letter-spacing:-.02em;font-feature-settings:"tnum";margin-top:4px;font-size:20px;font-weight:600}.quota-bar{background:#ffffff0d;border-radius:999px;height:4px;margin-top:6px;overflow:hidden}.quota-fill{background:linear-gradient(90deg, var(--mint-500), var(--mint-300));border-radius:999px;height:100%;box-shadow:0 0 10px #0fc6}.dp-bars{align-items:flex-end;gap:10px;height:150px;padding-top:10px;display:flex}.dp-bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:8px;height:100%;display:flex}.dp-bar{background:linear-gradient(180deg, var(--mint-400), var(--mint-600));border-radius:6px 6px 0 0;width:100%;max-width:40px;min-height:6px;position:relative}.dp-bar.peak{box-shadow:0 0 16px var(--mint-glow)}.dp-bar .cap{text-align:center;font-family:var(--font-mono);color:var(--text-3);font-size:11px;position:absolute;top:-20px;left:0;right:0}.dp-label{font-family:var(--font-mono);color:var(--text-4);font-size:11px}.cls-row{border-bottom:1px solid var(--border-1);grid-template-columns:56px 4px 1fr auto;align-items:center;gap:14px;padding:12px 0;display:grid}.cls-row:last-child{border-bottom:0}.cls-time{font-family:var(--font-mono);color:var(--text-1);text-align:right;font-size:12.5px;line-height:1.3}.cls-time .e{color:var(--text-4);font-size:10.5px;display:block}.cls-spine{border-radius:2px;width:4px;height:38px}.cls-name{color:var(--text-1);font-size:13.5px;font-weight:500}.cls-meta{color:var(--text-4);align-items:center;gap:6px;margin-top:2px;font-size:11.5px;display:flex}.cls-meta .dot{background:var(--text-5);border-radius:50%;width:3px;height:3px}.cls-status{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:4px 9px;font-size:10px}.cls-status.live{background:var(--mint-soft);color:var(--mint-300);border:1px solid var(--border-mint);align-items:center;gap:5px;display:inline-flex}.cls-status.next{color:#93c5fd;background:#60a5fa1f;border:1px solid #60a5fa38}.cls-status.done{background:var(--surface-2);color:var(--text-4);border:1px solid var(--border-2)}.cls-status.upcoming{background:var(--surface-1);color:var(--text-4);border:1px solid var(--border-1)}.lb-row{border-bottom:1px solid var(--border-1);grid-template-columns:36px 1fr auto;align-items:center;gap:12px;padding:11px 0;display:grid}.lb-row:last-child{border-bottom:0}.lb-av{border:1px solid var(--border-2);width:36px;height:36px;color:var(--mint-300);background:linear-gradient(160deg,#1e2924,#0f1411);border-radius:50%;place-items:center;font-size:12px;font-weight:600;display:grid}.lb-name{color:var(--text-1);font-size:13.5px;font-weight:500}.lb-meta{color:var(--text-4);align-items:center;gap:6px;margin-top:2px;font-size:11.5px;display:flex}.lb-meta .dot{background:var(--text-5);border-radius:50%;width:3px;height:3px}.course-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=1100px){.course-grid{grid-template-columns:1fr}}.course-card{background:var(--surface-1);border:1px solid var(--border-1);cursor:pointer;border-radius:16px;transition:border-color .12s,transform 50ms;overflow:hidden}.course-card:hover{border-color:var(--border-2)}.course-card .top{align-items:flex-end;height:70px;padding:14px;display:flex;position:relative}.course-card .top:after{content:"";opacity:.14;position:absolute;inset:0}.course-card .code{font-family:var(--font-mono);letter-spacing:.08em;z-index:1;border-radius:6px;padding:3px 8px;font-size:10.5px;position:relative}.course-card .body{padding:16px}.course-card .nm{color:var(--text-1);letter-spacing:-.01em;font-size:15px;font-weight:600}.course-card .tch{color:var(--text-4);margin-top:3px;font-size:12px}.course-card .c-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px;display:grid}.course-card .c-stat .v{font-family:var(--font-mono);color:var(--text-1);font-size:15px;font-weight:600}.course-card .c-stat .l{color:var(--text-4);white-space:nowrap;margin-top:1px;font-size:10px}.course-card .prog{background:#ffffff0d;border-radius:999px;height:5px;margin-top:14px;overflow:hidden}.course-card .prog i{border-radius:999px;height:100%;display:block}.tt-wrap{overflow-x:auto}.tt-grid{grid-template-columns:70px repeat(6,1fr);gap:8px;min-width:760px;display:grid}.tt-head{font-family:var(--font-mono);color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;text-align:center;padding:8px 0;font-size:11px}.tt-slot-label{font-family:var(--font-mono);color:var(--text-4);justify-content:flex-end;align-items:center;padding-right:8px;font-size:11px;display:flex}.tt-cell{border:1px solid var(--border-1);background:#ffffff04;border-radius:10px;flex-direction:column;gap:3px;min-height:58px;padding:8px;display:flex}.tt-cell.empty{border-style:dashed;border-color:var(--border-1);background:0 0}.tt-cell .c-code{font-family:var(--font-mono);opacity:.9;font-size:10px}.tt-cell .c-nm{color:var(--text-1);font-size:11px;font-weight:500;line-height:1.25}.tt-cell .c-room{color:var(--text-4);margin-top:auto;font-size:10px}.att-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.seg-toggle{background:var(--surface-1);border:1px solid var(--border-1);border-radius:9px;gap:2px;padding:3px;display:inline-flex}.seg-toggle button{color:var(--text-4);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:5px 12px;font-family:inherit;font-size:12px}.seg-toggle button.active{background:var(--mint-soft);color:var(--mint-300)}.att-row{border-bottom:1px solid var(--border-1);grid-template-columns:40px 1fr auto;align-items:center;gap:14px;padding:12px 0;display:grid}.att-row:last-child{border-bottom:0}.att-av{border:1px solid var(--border-2);width:40px;height:40px;color:var(--mint-300);background:linear-gradient(160deg,#1e2924,#0f1411);border-radius:50%;place-items:center;font-size:12px;font-weight:600;display:grid}.att-toggle{background:var(--surface-1);border:1px solid var(--border-1);border-radius:10px;gap:4px;padding:3px;display:inline-flex}.att-toggle button{color:var(--text-4);cursor:pointer;background:0 0;border:0;border-radius:7px;padding:6px 14px;font-family:inherit;font-size:12px}.att-toggle button.present.on{background:var(--mint-soft);color:var(--mint-300)}.att-toggle button.absent.on{color:#fca5a5;background:#f8717124}.att-toggle button.late.on{color:#fbd38d;background:#f4b86024}.fee-pill{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:3px 8px;font-size:10px}.fee-pill.paid{background:var(--mint-soft);color:var(--mint-300);border:1px solid var(--border-mint)}.fee-pill.overdue{color:#fca5a5;background:#f871711f;border:1px solid #f8717138}.fee-pill.partial{color:#fbd38d;background:#f4b8601f;border:1px solid #f4b86038}.status-chip{align-items:center;gap:6px;font-size:12px;display:inline-flex}.status-chip .pip{border-radius:50%;width:7px;height:7px}.status-chip.active .pip{background:var(--mint-400);box-shadow:0 0 0 3px #00ffcc2e}.status-chip.at-risk .pip{background:#fbbf6b}.res-stat-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}@media (width<=1100px){.res-stat-row{grid-template-columns:repeat(2,1fr)}}.report-grid{grid-template-columns:1.4fr 1fr;gap:16px;display:grid}@media (width<=1100px){.report-grid{grid-template-columns:1fr}}.settings-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=900px){.settings-grid{grid-template-columns:1fr}}.avail-switch{background:var(--surface-3);cursor:pointer;border:0;border-radius:999px;flex-shrink:0;width:38px;height:22px;display:inline-block;position:relative}.avail-switch:after{content:"";background:var(--text-3);border-radius:50%;width:16px;height:16px;transition:all .15s;position:absolute;top:3px;left:3px}.avail-switch.on{background:var(--mint-500)}.avail-switch.on:after{background:#03130b;left:19px}.setting-row{border-bottom:1px solid var(--border-1);justify-content:space-between;align-items:center;padding:14px 0;display:flex}.setting-row:last-child{border-bottom:0}.setting-row .lbl{color:var(--text-1);font-size:13.5px}.setting-row .val{color:var(--text-2);font-size:13px;font-family:var(--font-mono)}.auth-shell{flex-direction:column;justify-content:center;align-items:center;gap:18px;min-height:100vh;padding:40px 20px;display:flex}.auth-card{border:1px solid var(--border-2);background:linear-gradient(#131816eb,#0f1411cc);border-radius:22px;width:100%;max-width:410px;padding:34px 30px;box-shadow:0 30px 80px -20px #000000b3,0 0 0 1px #00ffcc0f}.auth-brand{align-items:center;gap:12px;margin-bottom:26px;display:flex}.auth-brand .brand-mark{width:38px;height:38px}.auth-name{letter-spacing:.16em;color:var(--mint-300);font-size:17px;font-weight:600}.auth-tag{color:var(--text-4);margin-top:2px;font-size:11.5px}.auth-title{letter-spacing:-.02em;color:var(--text-1);margin:0;font-size:24px;font-weight:600}.auth-sub{color:var(--text-3);margin:6px 0 22px;font-size:13.5px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-error{color:#fca5a5;font-size:12px}.auth-remember{color:var(--text-3);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.auth-remember input{accent-color:var(--mint-500);width:15px;height:15px}.auth-foot{color:var(--text-5);letter-spacing:.04em;font-size:11.5px}.sidebar-footer .logout-btn{width:30px;height:30px;color:var(--text-4);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;flex-shrink:0;place-items:center;margin-left:auto;display:grid}.sidebar-footer .logout-btn:hover{color:#fca5a5;background:#f8717114;border-color:#f871712e}.student-app{background:var(--bg-1);border-left:1px solid var(--border-1);border-right:1px solid var(--border-1);width:100%;max-width:460px;height:100dvh;margin:0 auto;position:relative;overflow:hidden}.m-screen{background:var(--bg-1);color:var(--text-1);font-family:var(--font-sans);letter-spacing:-.005em;flex-direction:column;height:100%;display:flex;overflow:hidden}.m-scroll{flex:1;padding:4px 16px 28px;overflow:hidden auto}.m-scroll::-webkit-scrollbar{display:none}.m-appbar{background:var(--bg-1);z-index:2;justify-content:space-between;align-items:center;gap:12px;padding:18px 16px 12px;display:flex;position:relative}.m-appbar h1{letter-spacing:-.025em;color:var(--text-1);margin:0;font-size:22px;font-weight:600}.m-appbar .sub{color:var(--text-4);margin-top:2px;font-size:12px}.m-icon-btn{background:var(--surface-1);border:1px solid var(--border-1);width:36px;height:36px;color:var(--text-2);cursor:pointer;border-radius:12px;place-items:center;display:grid;position:relative}.m-icon-btn .dot-badge{background:var(--mint-400);width:7px;height:7px;box-shadow:0 0 8px var(--mint-400);border-radius:50%;position:absolute;top:8px;right:8px}.m-tabbar{border-top:1px solid var(--border-1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:3;background:#0a0e0ceb;grid-template-columns:repeat(5,1fr);padding:6px 0 10px;display:grid;position:relative}.m-tabbar .tab{color:var(--text-4);cursor:pointer;background:0 0;border:0;flex-direction:column;align-items:center;gap:4px;padding:6px 4px 4px;font-family:inherit;font-size:10.5px;display:flex;position:relative}.m-tabbar .tab .icon{place-items:center;height:22px;display:grid}.m-tabbar .tab.active{color:var(--mint-300)}.m-tabbar .tab.active:before{content:"";background:var(--mint-400);width:28px;height:2px;box-shadow:0 0 12px var(--mint-400);border-radius:2px;position:absolute;top:-7px;left:50%;transform:translate(-50%)}.m-settings-group{background:var(--surface-1);border:1px solid var(--border-1);border-radius:14px;margin-bottom:14px;overflow:hidden}.m-settings-row{border-bottom:1px solid var(--border-1);align-items:center;gap:12px;padding:14px;display:flex}.m-settings-row:last-child{border-bottom:0}.m-settings-row .ico{width:30px;height:30px;color:var(--text-2);background:#ffffff0a;border-radius:9px;flex-shrink:0;place-items:center;display:grid}.m-settings-row .ico.mint{background:var(--mint-soft);color:var(--mint-300)}.m-settings-row .body{flex:1;min-width:0}.m-settings-row .body .l{color:var(--text-1);font-size:14px;font-weight:500}.m-settings-row .body .s{color:var(--text-4);margin-top:2px;font-size:11.5px}.m-settings-row .chev{color:var(--text-4);display:inline-flex}.m-settings-row .switch{background:var(--surface-3);border-radius:999px;flex-shrink:0;width:38px;height:22px;position:relative}.m-settings-row .switch:after{content:"";background:var(--text-3);border-radius:50%;width:16px;height:16px;transition:all .15s;position:absolute;top:3px;left:3px}.m-settings-row .switch.on{background:var(--mint-500)}.m-settings-row .switch.on:after{background:#03130b;left:19px}.m-signout{color:#fca5a5;cursor:pointer;background:#f871710d;border:1px solid #f871712e;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:14px;padding:14px;font-family:inherit;font-size:14px;font-weight:500;display:flex}.m-app-footer{text-align:center;font-family:var(--font-mono);letter-spacing:.1em;color:var(--text-4);margin-top:6px;font-size:10px}.mb-crumb{color:var(--mint-300);font-family:var(--font-mono);letter-spacing:.12em;align-items:center;gap:8px;font-size:11px;display:inline-flex}.mb-sec{justify-content:space-between;align-items:baseline;margin:22px 0 12px;display:flex}.mb-sec h3{letter-spacing:-.01em;color:var(--text-1);margin:0;font-size:16px;font-weight:600}.mb-sec .link{color:var(--mint-300);cursor:pointer;font-size:12px}.mb-date-row{scrollbar-width:none;gap:8px;margin:0 -16px;padding:0 16px 4px;display:flex;overflow-x:auto}.mb-date-row::-webkit-scrollbar{display:none}.mb-date{background:var(--surface-1);border:1px solid var(--border-1);text-align:center;cursor:pointer;border-radius:14px;flex:0 0 52px;padding:12px 0}.mb-date.active{background:var(--mint-soft);border-color:var(--border-mint)}.mb-date .dow{color:var(--text-4);text-transform:uppercase;letter-spacing:.06em;font-size:10.5px}.mb-date.active .dow{color:var(--mint-300)}.mb-date .dnum{color:var(--text-1);font-size:18px;font-weight:600;font-family:var(--font-mono);margin-top:3px}.mb-date.active .dnum{color:var(--mint-300)}.mb-prof-hero{align-items:center;gap:16px;padding:6px 0 18px;display:flex}.mb-prof-av{background:linear-gradient(160deg, var(--mint-400), var(--mint-600));color:#03130b;border-radius:20px;place-items:center;width:64px;height:64px;font-size:24px;font-weight:700;display:grid}.mb-prof-hero h2{letter-spacing:-.02em;color:var(--text-1);margin:0;font-size:20px;font-weight:600}.mb-prof-hero .sub{color:var(--text-4);margin-top:3px;font-size:12.5px}.mo-empty{text-align:center;padding:60px 20px}.mo-empty .t{color:var(--text-1);font-size:15px;font-weight:600}.mo-empty .s{color:var(--text-4);margin-top:4px;font-size:12.5px}.es-hero{background:linear-gradient(#00ffcc0f,#0000);padding:20px 16px 16px}.es-hero .greet{color:var(--text-4);font-size:13px}.es-hero h1{letter-spacing:-.02em;color:var(--text-1);margin:2px 0 0;font-size:24px;font-weight:600}.es-progress-card{border:1px solid var(--border-mint);background:linear-gradient(150deg,#00ffcc1a,#0f141199 65%);border-radius:18px;align-items:center;gap:16px;padding:18px;display:flex}.es-ring{flex-shrink:0;width:76px;height:76px;position:relative}.es-ring svg{transform:rotate(-90deg)}.es-ring .c{place-items:center;display:grid;position:absolute;inset:0}.es-ring .c .v{color:var(--mint-300);font-feature-settings:"tnum";font-size:20px;font-weight:600}.es-ring .c .l{color:var(--text-4);font-size:8.5px;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.es-prog-stats{flex:1}.es-prog-stats .r{justify-content:space-between;padding:5px 0;font-size:12.5px;display:flex}.es-prog-stats .r .l{color:var(--text-4)}.es-prog-stats .r .v{color:var(--text-1);font-family:var(--font-mono);font-weight:500}.es-next{background:var(--surface-1);border:1px solid var(--border-mint);border-radius:16px;padding:16px;position:relative;overflow:hidden}.es-next .spine{width:4px;position:absolute;top:0;bottom:0;left:0}.es-next .eyebrow{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--mint-300);font-size:10px}.es-next h3{color:var(--text-1);letter-spacing:-.01em;margin:6px 0 2px;font-size:17px;font-weight:600}.es-next .sub{color:var(--text-4);font-size:12.5px}.es-next .live-tag{font-family:var(--font-mono);color:var(--mint-300);background:var(--mint-soft);border:1px solid var(--border-mint);border-radius:999px;align-items:center;gap:5px;padding:4px 9px;font-size:10px;display:inline-flex;position:absolute;top:16px;right:16px}.es-next .join{background:var(--mint-500);color:#03130b;cursor:pointer;border:0;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:14px;padding:13px;font-family:inherit;font-size:14px;font-weight:600;display:flex}.es-cls{border-bottom:1px solid var(--border-1);align-items:center;gap:12px;padding:13px 0;display:flex}.es-cls:last-child{border-bottom:0}.es-cls .t{font-family:var(--font-mono);color:var(--text-2);text-align:center;flex-shrink:0;width:46px;font-size:12px;line-height:1.3}.es-cls .t .e{color:var(--text-4);font-size:9.5px;display:block}.es-cls .spine{border-radius:2px;flex-shrink:0;width:4px;height:38px}.es-cls .nm{color:var(--text-1);font-size:13.5px;font-weight:500}.es-cls .mt{color:var(--text-4);margin-top:2px;font-size:11px}.es-course{background:var(--surface-1);border:1px solid var(--border-1);border-radius:16px;margin-bottom:10px;padding:16px}.es-course .h{align-items:center;gap:12px;display:flex}.es-course .ic{border-radius:12px;flex-shrink:0;place-items:center;width:42px;height:42px;display:grid}.es-course .nm{color:var(--text-1);font-size:14.5px;font-weight:600}.es-course .tch{color:var(--text-4);margin-top:2px;font-size:11.5px}.es-course .prog{background:#ffffff0d;border-radius:999px;height:6px;margin-top:14px;overflow:hidden}.es-course .prog i{border-radius:999px;height:100%;display:block}.es-course .pm{color:var(--text-4);justify-content:space-between;margin-top:7px;font-size:11px;display:flex}.es-grade-row{border-bottom:1px solid var(--border-1);align-items:center;gap:12px;padding:13px 0;display:flex}.es-grade-row:last-child{border-bottom:0}.es-grade-score{width:44px;height:44px;font-family:var(--font-mono);border-radius:12px;flex-shrink:0;place-items:center;font-size:15px;font-weight:600;display:grid}.es-grade-row .nm{color:var(--text-1);font-size:13.5px;font-weight:500}.es-grade-row .mt{color:var(--text-4);margin-top:2px;font-size:11px}.es-fee-card{background:linear-gradient(150deg,#f4b8601a,#0f141180 65%);border:1px solid #f4b86038;border-radius:18px;padding:18px}.es-fee-card.clear{border-color:var(--border-mint);background:linear-gradient(150deg,#00ffcc14,#0f141180 65%)}
