.app{background:var(--page);min-height:100dvh;display:flex}.main{flex-direction:column;flex:1;min-width:0;display:flex}.content{width:100%;max-width:1280px;margin:0 auto;padding:30px 38px 56px}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:30;align-items:center;gap:20px;height:64px;padding:0 26px;display:flex;position:sticky;top:0}.tb-burger{border:1px solid var(--border-strong);background:var(--surface);width:42px;height:42px;color:var(--ink-2);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:none}.tb-burger:hover{background:var(--page);color:var(--navy)}.tb-divider{background:var(--border);width:1px;height:28px;margin:0 6px}.tb-search{flex:1;max-width:440px;position:relative}.tb-search svg{width:16px;height:16px;color:var(--ink-3);position:absolute;top:50%;left:13px;transform:translateY(-50%)}.tb-search input{border:1px solid var(--border-strong);background:var(--page);width:100%;color:var(--ink);transition:all .18s var(--ease);border-radius:8px;outline:none;padding:9px 14px 9px 37px;font-size:13.5px}.tb-search input:focus{border-color:var(--st-submitted);box-shadow:var(--sh-focus);background:#fff}.tb-right{align-items:center;gap:8px;margin-left:auto;display:flex}.icon-btn{cursor:pointer;width:38px;height:38px;color:var(--ink-2);transition:all .18s var(--ease);background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;display:flex;position:relative}.icon-btn:hover{background:var(--page);color:var(--ink)}.icon-btn svg{width:19px;height:19px}.icon-btn .badge{background:var(--gold);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.avatar{background:var(--st-open-soft);width:36px;height:36px;color:var(--navy);font-family:var(--font-display);cursor:pointer;border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.sidebar{background:linear-gradient(176deg, var(--navy), var(--navy-deep));width:248px;color:var(--ink-on-navy);flex-direction:column;flex-shrink:0;height:100dvh;display:flex;position:sticky;top:0}.sb-mobile-scrim{-webkit-backdrop-filter:blur(2px);z-index:80;opacity:0;pointer-events:none;transition:opacity .25s var(--ease);background:#101b3080;position:fixed;inset:0}.sb-mobile-scrim.open{opacity:1;pointer-events:auto}.sidebar.sb-mobile{z-index:81;width:min(280px,86vw);height:100dvh;transition:transform .28s var(--ease);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);display:none;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:16px 0 48px #101b3040}.sidebar.sb-mobile.open{transform:translate(0)}.sb-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:11px;padding:22px 22px 18px;display:flex}.sb-brand img{width:auto;height:42px}.sb-brand .wm b{font-family:var(--font-display);color:#fff;font-size:16px;font-weight:700;line-height:1;display:block}.sb-brand .wm span{letter-spacing:.15em;text-transform:uppercase;color:var(--gold-bright);margin-top:4px;font-size:8px;font-weight:600;display:block}.sb-nav{flex:1;padding:16px 14px;overflow-y:auto}.sb-sec{letter-spacing:.13em;text-transform:uppercase;color:var(--ink-on-navy-2);padding:14px 12px 7px;font-size:9.5px;font-weight:600}.sb-item{color:var(--ink-on-navy-2);cursor:pointer;transition:all .15s var(--ease);border-radius:8px;align-items:center;gap:12px;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;display:flex;position:relative}.sb-item svg{flex-shrink:0;width:18px;height:18px}.sb-item:hover{color:#fff;background:#ffffff12}.sb-item.active{color:#fff;background:#ffffff1a}.sb-item.active:before{content:"";background:var(--gold-bright);border-radius:0 3px 3px 0;width:3px;position:absolute;top:9px;bottom:9px;left:-14px}.sb-item .count{font-size:11px;font-family:var(--font-mono);color:#fff;background:#ffffff1f;border-radius:999px;margin-left:auto;padding:2px 8px}.sb-foot{border-top:1px solid #ffffff14;padding:14px 16px 16px}.sb-user{background:#ffffff0f;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:10px;padding:9px 11px;display:flex}.sb-user-info{flex:1;min-width:0}.sb-user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;line-height:1.2;overflow:hidden}.sb-user-role{letter-spacing:.08em;text-transform:uppercase;color:var(--gold-bright);margin-top:3px;font-size:10px;font-weight:700}.sb-signout{width:32px;height:32px;color:var(--ink-on-navy-2);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease);background:#ffffff14;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sb-signout:hover{color:#fff;background:#ffffff29}.page-head{grid-template-columns:1fr auto;align-items:end;gap:24px;margin-bottom:26px;display:grid}.page-head>div:first-child{min-width:0}.page-head .eyebrow{letter-spacing:.09em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:7px;font-size:11px;font-weight:700}.page-head h1{font-family:var(--font-display);letter-spacing:-.015em;color:var(--navy);margin:0;font-size:30px;font-weight:600;line-height:1.16}.page-head p{color:var(--ink-2);margin:7px 0 0;font-size:14px}.btn{font-family:var(--font-body);cursor:pointer;transition:all .17s var(--ease);white-space:nowrap;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:11px 17px;font-size:14px;font-weight:600;display:inline-flex}.btn svg{width:17px;height:17px}.btn:active{transform:scale(.98)}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:var(--navy-700);box-shadow:var(--sh-md)}.btn-primary:active{background:var(--navy-900)}.btn-green{background:var(--st-result);color:#fff}.btn-green:hover{filter:brightness(1.06);box-shadow:var(--sh-md)}.btn-gold{color:var(--gold-deep);border:1.5px solid var(--gold);background:#fff}.btn-gold:hover{background:var(--gold-soft)}.btn-ghost{color:var(--ink-2);border:1px solid var(--border-strong);background:0 0}.btn-ghost:hover{color:var(--ink);border-color:var(--ink-3);background:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(1.06);box-shadow:var(--sh-md)}.btn-danger-soft{background:var(--danger-soft);color:var(--danger);border:1px solid #f0c9c5}.btn-danger-soft:hover{background:#f8dedb}.btn-sm{padding:8px 13px;font-size:13px}.btn-block{width:100%}.btn:disabled,.btn-disabled{color:#a9b0bd;cursor:not-allowed;box-shadow:none;background:#eef0f3;border-color:#0000;transform:none}.pill{white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:7px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.pill .dot{border-radius:50%;width:7px;height:7px}.pill-open{background:var(--st-open-soft);color:var(--st-open);border-color:var(--st-open-line)}.pill-open .dot{background:var(--st-open)}.pill-submitted{background:var(--st-submitted-soft);color:var(--st-submitted);border-color:var(--st-submitted-line)}.pill-submitted .dot{background:var(--st-submitted)}.pill-eval{background:var(--st-eval-soft);color:var(--st-eval);border-color:var(--st-eval-line)}.pill-eval .dot{background:var(--st-eval-dot)}.pill-allotment{color:#4f46e5;background:#eef0ff;border-color:#dadcff}.pill-allotment .dot{background:#6366f1}.pill-result{background:var(--st-result-soft);color:var(--st-result);border-color:var(--st-result-line)}.pill-result .dot{background:var(--st-result)}.pill-expired{background:var(--st-expired-soft);color:var(--st-expired);border-color:var(--st-expired-line)}.pill-expired .dot{background:var(--st-expired)}.card{background:linear-gradient(180deg, var(--surface) 0%, #fdfbf3 100%);border:1px solid var(--border);border-radius:14px;box-shadow:0 1px 3px #101b300f,0 1px 2px #101b300a}.card-pad{padding:22px}.card-hover{transition:transform .35s cubic-bezier(.34, 1.4, .64, 1), box-shadow .3s var(--ease), border-color .25s var(--ease);position:relative;overflow:hidden}.card-hover:before{content:"";background:linear-gradient(90deg, var(--gold), var(--gold-bright), var(--gold));transform-origin:0;height:3px;transition:transform .4s var(--ease);pointer-events:none;z-index:1;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.card-hover:hover{border-color:var(--border-strong);transform:translateY(-4px);box-shadow:0 16px 36px #101b301a,0 4px 12px #101b300d}.card-hover:hover:before{transform:scaleX(1)}.chip{font-size:11.5px;font-weight:600;font-family:var(--font-mono);border-radius:6px;align-items:center;gap:6px;padding:5px 11px;display:inline-flex}.chip svg{width:13px;height:13px}.chip-clock{background:var(--st-eval-soft);color:var(--st-eval)}.chip-score{background:var(--gold-soft);color:var(--gold-deep)}.respill{color:var(--gold-deep);border:1.5px solid var(--gold);white-space:nowrap;cursor:pointer;transition:all .15s var(--ease);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:11.5px;font-weight:600;display:inline-flex}.respill:hover{background:var(--gold-soft)}.respill svg{width:13px;height:13px}.respill-off{color:var(--ink-3);border-color:var(--border-strong);cursor:not-allowed;background:var(--surface-2);border-style:solid}.respill-off:hover{background:var(--surface-2)}.statgrid{grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px;display:grid}.stat{background:linear-gradient(180deg, var(--surface) 0%, #fdfbf3 100%);border:1px solid var(--border);transition:transform .35s cubic-bezier(.34, 1.4, .64, 1), box-shadow .3s var(--ease), border-color .25s var(--ease);border-radius:14px;align-items:center;gap:16px;padding:20px 22px;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 3px #101b300f,0 1px 2px #101b300a}.stat:before{content:"";background:linear-gradient(90deg, var(--gold), var(--gold-bright), var(--gold));transform-origin:0;height:3px;transition:transform .4s var(--ease);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.stat:hover{border-color:var(--border-strong);transform:translateY(-3px);box-shadow:0 14px 32px #101b301a,0 4px 10px #101b300d}.stat:hover:before{transform:scaleX(1)}.stat .ic{border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;transition:transform .42s cubic-bezier(.34,1.56,.64,1);display:flex;box-shadow:inset 0 0 0 1px #ffffff73}.stat .ic svg{width:21px;height:21px}.stat:hover .ic{transform:scale(1.08)rotate(-5deg)}.stat .n{font-family:var(--font-mono);color:var(--ink);letter-spacing:-.015em;font-variant-numeric:tabular-nums;font-size:27px;font-weight:600;line-height:1}.stat .l{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-top:7px;font-size:11px;font-weight:600}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:22px;display:flex}.seg{background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;padding:3px;display:flex}.seg button{color:var(--ink-2);cursor:pointer;transition:all .15s var(--ease);background:0 0;border:none;border-radius:6px;align-items:center;gap:7px;padding:7px 14px;font-size:13px;font-weight:600;display:flex}.seg button svg{width:15px;height:15px}.seg button.on{background:var(--navy);color:#fff}.fc{border:1px solid var(--border-strong);color:var(--ink-2);cursor:pointer;transition:all .15s var(--ease);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:8px 13px;font-size:12.5px;font-weight:500;display:inline-flex}.fc svg{width:14px;height:14px}.fc:hover{border-color:var(--ink-3)}.fc.on{background:var(--navy);color:#fff;border-color:var(--navy)}.fc.on svg{color:var(--gold-bright)}.modhead{align-items:center;gap:12px;margin:30px 0 16px;display:flex}.modhead .mi{background:var(--st-open-soft);border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.modhead .mi svg{width:18px;height:18px;color:var(--navy)}.modhead h2{font-family:var(--font-display);color:var(--navy);white-space:nowrap;flex-shrink:0;margin:0;font-size:20px;font-weight:600}.modhead .mc{color:var(--ink-3);font-size:12px;font-family:var(--font-mono);margin-left:2px}.modhead .line{background:var(--border);flex:1;height:1px}.testgrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.hr{background:var(--border);border:none;height:1px;margin:0}.subj-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--sh-sm);cursor:pointer;border-radius:14px;padding:20px 22px;position:relative;overflow:hidden}.subj-card .subj-accent{background:linear-gradient(90deg, var(--green), #37c089);transform-origin:0;height:3px;transition:transform .26s var(--ease);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.subj-card:hover .subj-accent{transform:scaleX(1)}.subj-top{align-items:center;gap:13px;display:flex}.subj-ic{background:linear-gradient(155deg,#27b079,#178a5a);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex;box-shadow:0 5px 14px #1e9e6a47}.subj-avg{text-align:right;background:var(--green-soft);border:1px solid var(--green-line);border-radius:9px;flex-direction:column;align-items:flex-end;margin-left:auto;padding:7px 11px;display:flex}.subj-avg b{font-family:var(--font-mono);color:var(--green-700);font-size:18px;font-weight:600;line-height:1}.subj-avg span{letter-spacing:.05em;text-transform:uppercase;color:var(--green-700);opacity:.8;margin-top:3px;font-size:9px;font-weight:600}.subj-prog{margin:18px 0 4px}.subj-prog-head{color:var(--ink-2);justify-content:space-between;align-items:center;margin-bottom:7px;font-size:12px;display:flex}.subj-prog-head .subj-pct{font-family:var(--font-mono);color:var(--green-700);font-weight:600}.subj-bar{background:var(--page);border-radius:999px;height:7px;overflow:hidden}.subj-bar span{background:linear-gradient(90deg, #178a5a, var(--green));height:100%;transition:width .4s var(--ease);border-radius:999px;display:block}.subj-spark{align-items:flex-end;gap:12px;margin:14px 0 2px;display:flex}.subj-spark>div{flex:1}.subj-trend{font-family:var(--font-mono);color:var(--green-700);background:var(--green-soft);white-space:nowrap;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-flex}.subj-foot{border-top:1px solid var(--border);color:var(--navy);justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;font-size:13px;font-weight:600;display:flex}.subj-foot>span:first-child{white-space:nowrap}.subj-go{background:var(--green-soft);width:30px;height:30px;color:var(--green-700);transition:all .2s var(--ease);border-radius:8px;justify-content:center;align-items:center;display:flex}.subj-card:hover .subj-go{background:var(--green);color:#fff;transform:translate(2px)}.subj-card.locked{cursor:default;border-style:dashed;border-color:var(--st-expired-line);background:var(--surface-2)}.subj-card.locked .subj-accent{display:none}.subj-ic.locked{border:1px solid var(--border);box-shadow:none;background:#fff}.subj-lockchip{color:var(--ink-3);background:var(--page);border:1px solid var(--border);white-space:nowrap;border-radius:999px;align-items:center;gap:5px;margin-left:auto;padding:5px 11px;font-size:11px;font-weight:600;display:inline-flex}.subj-locked-body{height:101px;color:var(--ink-3);flex-direction:column;justify-content:center;align-items:center;gap:9px;margin:18px 0 2px;font-size:13px;font-weight:500;display:flex}.subj-go.locked{background:var(--page);color:var(--ink-3)}.subj-card.locked:hover .subj-go.locked{background:var(--page);color:var(--ink-3);transform:none}.subj-card.locked .subj-foot{border-top-style:dashed;border-top-color:var(--st-expired-line);font-weight:600}.empty{text-align:center;color:var(--ink-3);padding:46px 24px}.empty .ec{background:var(--page);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;margin:0 auto 14px;display:flex}.empty .ec svg{width:24px;height:24px;color:var(--ink-3)}.empty h3{font-family:var(--font-display);color:var(--ink-2);margin:0 0 6px;font-size:17px;font-weight:600}.empty p{max-width:340px;margin:0 auto;font-size:13.5px;line-height:1.55}.scrim{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:60;animation:fade .2s var(--ease);background:#101b3073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{box-shadow:var(--sh-xl);width:100%;max-width:560px;animation:rise .22s var(--ease);background:#fff;border-radius:16px;flex-direction:column;max-height:92vh;display:flex;overflow:hidden}.modal-lg{max-width:720px}.modal-head{justify-content:space-between;align-items:flex-start;padding:22px 24px 0;display:flex}.modal-head h2{font-family:var(--font-display);color:var(--navy);margin:0;font-size:21px;font-weight:600}.modal-head p{color:var(--ink-2);margin:5px 0 0;font-size:13px}.modal-body{padding:20px 24px;overflow-y:auto}.modal-foot{border-top:1px solid var(--border);background:var(--surface-2);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.scrim,.modal{animation:none}}.rbadge{white-space:nowrap;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.rbadge svg{width:13px;height:13px}.rbadge-student{background:var(--st-submitted-soft);color:var(--st-submitted);border-color:var(--st-submitted-line)}.rbadge-faculty{background:var(--gold-soft);color:var(--gold-deep);border-color:var(--st-eval-line)}.rbadge-admin{background:var(--st-open-soft);color:var(--st-open);border-color:var(--st-open-line)}.ubadge{white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:4px 11px;font-size:11.5px;font-weight:600;display:inline-flex}.ubadge .d{border-radius:50%;width:7px;height:7px}.ubadge-active{background:var(--st-result-soft);color:var(--st-result);border-color:var(--st-result-line)}.ubadge-active .d{background:var(--st-result)}.ubadge-suspended{background:var(--st-eval-soft);color:var(--st-eval);border-color:var(--st-eval-line)}.ubadge-suspended .d{background:var(--st-eval-dot)}.ubadge-blocked{background:var(--danger-soft);color:var(--danger);border-color:#f0c9c5}.ubadge-blocked .d{background:var(--danger)}.drawer-scrim{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:60;animation:fade .2s var(--ease);background:#101b3066;position:fixed;inset:0}.drawer{width:440px;max-width:92vw;height:100vh;box-shadow:var(--sh-xl);z-index:61;animation:slidein .26s var(--ease);background:#fff;flex-direction:column;display:flex;position:fixed;top:0;right:0}@keyframes slidein{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-head{background:linear-gradient(160deg, var(--navy), var(--navy-deep));color:#fff;padding:24px;position:relative}.drawer-head .close{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:flex;position:absolute;top:18px;right:18px}.drawer-head .close:hover{background:#fff3}.drawer-head .close svg{width:18px;height:18px}.drawer-av{width:60px;height:60px;font-family:var(--font-display);color:#fff;background:#ffffff1f;border:1px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;margin-bottom:14px;font-size:22px;font-weight:600;display:flex}.drawer-body{flex:1;padding:22px 24px;overflow-y:auto}.drawer-foot{border-top:1px solid var(--border);background:var(--surface-2);gap:10px;padding:16px 24px;display:flex}.kv{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:11px 0;font-size:13.5px;display:flex}.kv:last-child{border-bottom:none}.kv .k{color:var(--ink-3)}.kv .v{color:var(--ink);font-weight:600}@media (prefers-reduced-motion:reduce){.drawer,.drawer-scrim{animation:none}}.drop{border:2px dashed var(--st-submitted-line);background:var(--st-submitted-soft);text-align:center;cursor:pointer;transition:all .18s var(--ease);border-radius:12px;padding:30px}.drop:hover{border-color:var(--st-submitted);background:#e1ecfa}.drop .ic{width:48px;height:48px;box-shadow:var(--sh-sm);background:#fff;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 13px;display:flex}.drop .ic svg{width:23px;height:23px;color:var(--st-submitted)}.drop .t{color:var(--ink);font-size:15px;font-weight:600}.drop .t b{color:var(--st-submitted)}.drop .s{color:var(--ink-2);margin-top:6px;font-size:12.5px}.filerow{border:1px solid var(--border);background:#fff;border-radius:9px;align-items:center;gap:11px;margin-top:10px;padding:11px 13px;display:flex}.filerow .fi{background:var(--gold-soft);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.filerow .fi svg{width:17px;height:17px;color:var(--gold-deep)}.filerow .fn{color:var(--ink);font-size:13px;font-weight:600}.filerow .fm{color:var(--ink-3);font-size:11px;font-family:var(--font-mono);margin-top:2px}.filerow .rm{cursor:pointer;color:var(--ink-3);background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;width:30px;height:30px;margin-left:auto;display:flex}.filerow .rm:hover{background:var(--danger-soft);color:var(--danger)}.filerow .rm svg{width:16px;height:16px}.tl{align-items:flex-start;display:flex}.tl .step{text-align:center;flex:1;position:relative}.tl .node{z-index:2;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;margin:0 auto;display:flex;position:relative}.tl .node svg{width:16px;height:16px}.tl .line{z-index:1;width:100%;height:2px;position:absolute;top:16px;left:50%}.tl .step:last-child .line{display:none}.tl .done .node{background:var(--st-result);color:#fff}.tl .done .line{background:var(--st-result)}.tl .active .node{background:var(--st-eval-soft);border:2px solid var(--gold);color:var(--gold-deep)}.tl .active .line{background:var(--border-strong)}.tl .todo .node{border:2px solid var(--border-strong);color:var(--ink-3);background:#fff}.tl .todo .line{background:var(--border-strong)}.tl .nm{color:var(--ink);margin-top:10px;font-size:12.5px;font-weight:600}.tl .tm{color:var(--ink-3);font-size:10.5px;font-family:var(--font-mono);margin-top:3px}.tl .todo .nm{color:var(--ink-3)}.table{border-collapse:collapse;width:100%}.table th{text-align:left;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--border);background:var(--surface-2);padding:12px 16px;font-size:10.5px;font-weight:600}.table td{border-bottom:1px solid var(--border);color:var(--ink-2);padding:14px 16px;font-size:13.5px}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--surface-2)}.table .td-strong{color:var(--ink);font-weight:600}.table-wrap{width:100%;overflow-x:auto}.notif{border-bottom:1px solid var(--border);gap:12px;padding:13px 0;display:flex}.notif:last-child{border-bottom:none}.notif .ni{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.notif .ni svg{width:17px;height:17px}.notif .nt{color:var(--ink);font-size:13px;line-height:1.45}.notif .nt b{font-weight:600}.notif .nm{color:var(--ink-3);align-items:center;gap:6px;margin-top:3px;font-size:11px;display:flex}.notif .ch{letter-spacing:.04em;text-transform:uppercase;border-radius:4px;padding:1px 6px;font-size:9.5px;font-weight:600}.link{color:var(--st-submitted);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;font-weight:600;text-decoration:none}.link:hover{text-decoration:underline}.field{margin-bottom:16px}.field label{color:var(--ink);margin-bottom:7px;font-size:12px;font-weight:600;display:block}.field input,.field textarea,.field select{border:1px solid var(--border-strong);width:100%;font-size:14px;font-family:var(--font-body);color:var(--ink);transition:all .17s var(--ease);background:#fff;border-radius:8px;outline:none;padding:11px 13px}.field textarea{resize:vertical;min-height:90px;line-height:1.5}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--st-submitted);box-shadow:var(--sh-focus)}.field .hint{color:var(--ink-3);margin-top:6px;font-size:11.5px}.field .err{color:var(--danger);margin-top:6px;font-size:11.5px;font-weight:500}.field input.invalid,.field textarea.invalid,.field select.invalid{border-color:var(--danger)}.bars{align-items:flex-end;gap:14px;height:200px;padding-top:8px;display:flex}.bars .col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.bars .col .v{font-family:var(--font-mono);color:var(--ink-2);margin-bottom:6px;font-size:11px;font-weight:600}.bars .col .bar{border-radius:5px 5px 0 0;width:70%}.bars .col .lbl{color:var(--ink-3);margin-top:8px;font-size:11px;font-weight:600}.l-grid{align-items:start;gap:22px;display:grid}.l-grid.aside-340{grid-template-columns:minmax(0,1fr) 340px}.l-grid.aside-360{grid-template-columns:minmax(0,1fr) 360px}.l-grid.split-7-5{grid-template-columns:1.4fr 1fr}.l-grid.split-1-1{grid-template-columns:1fr 1fr}.l-grid.split-13-10{grid-template-columns:1.3fr 1fr}.l-grid.split-125-10{grid-template-columns:1.25fr 1fr}.l-grid.split-1-11{grid-template-columns:1fr 1.1fr}.l-grid.cols-3{grid-template-columns:repeat(3,1fr)}.l-grid.pair{gap:18px;display:grid}.dash-cards{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px;display:grid}@media (max-width:980px){.l-grid,.l-grid.aside-340,.l-grid.aside-360,.l-grid.split-7-5,.l-grid.split-1-1,.l-grid.split-13-10,.l-grid.split-125-10,.l-grid.split-1-11{grid-template-columns:1fr}.l-grid.cols-3{grid-template-columns:1fr 1fr}.l-grid>[style*=sticky]{position:static!important}}@media (max-width:640px){.l-grid.cols-3,.dash-cards{grid-template-columns:1fr}}@media (max-width:1080px){.statgrid{grid-template-columns:repeat(2,1fr)}.testgrid{grid-template-columns:1fr}.content{padding:26px 24px 48px}}@media (max-width:860px){.sidebar{display:none}.sidebar.sb-mobile{display:flex}.tb-burger{display:inline-flex}.topbar{gap:12px;padding:0 16px}.tb-search{max-width:none}.content{padding:22px 18px 48px}.page-head{grid-template-columns:1fr;align-items:start;gap:16px}.page-head h1{font-size:24px}.page-head p{font-size:13.5px}.modhead{margin:24px 0 14px}.modhead h2{font-size:18px}}@media (max-width:640px){.topbar{gap:10px;height:60px;padding:0 14px}.tb-search input{padding-left:37px;font-size:14px}.tb-search input::placeholder{opacity:0}.tb-logout-desktop,.tb-divider{display:none}.content{padding:18px 14px 40px}.statgrid{gap:12px}.testgrid{gap:14px}.page-head h1{font-size:22px}.modhead h2{font-size:16px}.modhead .mi{width:30px;height:30px}.modhead .mc{display:none}.scrim{align-items:stretch;padding:0}.modal{border-radius:0;max-width:100%;height:100dvh;max-height:100%}.modal-head{padding:calc(16px + env(safe-area-inset-top)) 18px 0}.modal-body{padding:16px 18px}.modal-foot{padding:12px 18px calc(12px + env(safe-area-inset-bottom));flex-direction:column-reverse;gap:8px}.modal-foot .btn{width:100%}.drawer{width:100%;max-width:100%}.drawer-head{padding:20px 18px}.drawer-body,.stat{padding:18px}.stat .ic{width:42px;height:42px}.stat .n{font-size:24px}.card-pad{padding:18px}.table th,.table td{padding:12px 14px}}@media (max-width:480px){.statgrid{grid-template-columns:1fr;gap:10px}.dash-cards{gap:14px}.page-head h1{font-size:20px;line-height:1.2}.page-head .eyebrow{font-size:10.5px}.stat{padding:16px}.topbar{padding:0 12px}.tb-burger{width:38px;height:38px}.icon-btn{width:36px;height:36px}.avatar{width:34px;height:34px;font-size:13px}.btn{min-height:44px;padding:10px 14px;font-size:13.5px}.toolbar{gap:8px}.seg button{padding:6px 10px;font-size:12.5px}.fc{padding:7px 11px;font-size:12px}}@media (max-width:360px){.content{padding:14px 12px 36px}.topbar{gap:8px;padding:0 10px}.page-head h1{font-size:18px}.card-pad{padding:16px}.stat .n{font-size:22px}.stat .ic{width:38px;height:38px}.modal-head h2{font-size:18px}.field input,.field textarea,.field select{padding:10px 12px}}@media (hover:none) and (pointer:coarse){.btn,.link,.sb-item,.sb-role button,.seg button,.fc,.respill,.chip,.pill{min-height:44px}.icon-btn,.tb-burger{min-width:44px;min-height:44px}}@media (max-width:820px){.auth-hero{display:none!important}}.pw-wrap{display:block;position:relative}.pw-wrap .pw-input{padding-right:46px}.pw-toggle{width:36px;height:36px;color:var(--ink-3);cursor:pointer;transition:color .15s var(--ease), background .15s var(--ease);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;display:inline-flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.pw-toggle:hover{color:var(--navy);background:var(--page)}.pw-toggle:active{transform:translateY(-50%)scale(.94)}.pw-toggle:focus-visible{outline:2px solid var(--st-submitted);outline-offset:1px;color:var(--navy)}.pw-toggle svg{width:17px;height:17px}.role-picker{grid-template-columns:1fr 1fr;gap:10px;display:grid}.role-card{text-align:left;border:1.5px solid var(--border-strong);cursor:pointer;font-family:var(--font-body);transition:all .18s var(--ease);background:#fff;border-radius:10px;align-items:center;gap:11px;padding:12px;display:flex;position:relative}.role-card:hover{border-color:var(--ink-3)}.role-card.on{border-color:var(--navy);background:var(--st-open-soft);box-shadow:inset 0 0 0 1px var(--navy)}.role-ic{background:var(--gold-soft);border:1px solid var(--st-eval-line);width:34px;height:34px;color:var(--gold-deep);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.role-card.on .role-ic{background:var(--navy);border-color:var(--navy);color:var(--gold-bright)}.role-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.role-title{color:var(--ink);font-size:13.5px;font-weight:600;line-height:1.2}.role-desc{color:var(--ink-3);font-size:11px;line-height:1.3}.role-check{color:#0000;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.role-card.on .role-check{background:var(--navy);color:#fff}@media (max-width:480px){.role-picker{grid-template-columns:1fr}}.card,.stat,.subj-card{contain:layout paint}.modhead{contain:layout}.sidebar,.topbar{contain:layout style}.form-row{gap:14px;display:grid}.form-row.row-2col{grid-template-columns:1fr 1fr}.form-row.row-3col{grid-template-columns:repeat(3,1fr)}@media (max-width:720px){.form-row.row-2col,.form-row.row-3col{grid-template-columns:1fr}}.table td,.kv .v,.drawer-body,.notif .nt,.empty p{overflow-wrap:anywhere;word-break:break-word}@media (max-width:480px){.tb-search{display:none}.topbar{justify-content:flex-end}.topbar .tb-burger{margin-right:auto}}@media (max-width:640px){.page-head{gap:12px}.page-head>div:first-child,.page-head>div:last-child{width:100%}.page-head .btn{flex:1;min-width:0}}@media (max-width:480px){.kv{flex-direction:column;align-items:flex-start;gap:4px;padding:10px 0}.kv .v{font-size:13px}}@media (max-width:640px){.table-wrap{overflow-x:visible}.table{display:block}.table thead{position:absolute;left:-9999px}.table tbody{display:block}.table tbody tr{border:1px solid var(--border);background:var(--surface);box-shadow:var(--sh-xs);border-radius:12px;margin-bottom:12px;padding:4px 14px 8px;display:block}.table tbody tr:hover{background:var(--surface)}.table tbody td{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;gap:12px;padding:9px 0;display:flex;text-align:left!important}.table tbody td:last-child{border-bottom:none}.table tbody td[data-label]:before{content:attr(data-label);letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);flex-shrink:0;font-size:10.5px;font-weight:600}.table tbody tr td[colspan]{text-align:center;display:block}.table tbody tr td[colspan]:before{display:none}}@media (max-width:480px){.bars{gap:8px;height:160px}.bars .col .v,.bars .col .lbl{font-size:10px}.bars .col .bar{width:80%}.auth-root>div:last-child{padding:18px!important}.auth-root .card{padding:22px 20px!important;padding-bottom:calc(22px + env(safe-area-inset-bottom))!important}}.btn:focus-visible,.link:focus-visible,.icon-btn:focus-visible,.fc:focus-visible,.seg button:focus-visible{outline:2px solid var(--st-submitted);outline-offset:2px}.main{overflow-x:hidden}.content{min-width:0}@keyframes portal-card-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.statgrid .stat{animation:.5s cubic-bezier(.22,.61,.36,1) backwards portal-card-enter}.statgrid .stat:first-child{animation-delay:0s}.statgrid .stat:nth-child(2){animation-delay:60ms}.statgrid .stat:nth-child(3){animation-delay:.12s}.statgrid .stat:nth-child(4){animation-delay:.18s}.dash-cards .card-hover{animation:.5s cubic-bezier(.22,.61,.36,1) backwards portal-card-enter}.dash-cards .card-hover:first-child{animation-delay:.24s}.dash-cards .card-hover:nth-child(2){animation-delay:.3s}.dash-cards .card-hover:nth-child(3){animation-delay:.36s}.dash-cards .card-hover:nth-child(4){animation-delay:.42s}.notif .ni{border-radius:10px;width:36px;height:36px;box-shadow:inset 0 0 0 1px #ffffff73}@media (prefers-reduced-motion:reduce){.statgrid .stat,.dash-cards .card-hover{animation:none}.stat:hover,.stat:hover .ic,.card-hover:hover{transform:none}.stat:before,.card-hover:before{display:none}}
