*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand:#00c2dc;--brand-dark:#009ab0;--brand-glow:#00c2dc2e;--green:#22c47a;--yellow:#f5a623;--red:#ef4444;--grey:#6b7a8f;--bg:#0d1117;--surface:#161b24;--surface2:#1e2535;--border:#252e40;--text:#dde6f0;--text-muted:#7a90a8;--header-h:60px;color:var(--text);background:var(--bg);font-family:Segoe UI,system-ui,Arial,sans-serif;font-size:14px}body{min-height:100vh}#root{flex-direction:column;min-height:100vh;display:flex}.login-wrap{background:radial-gradient(at 50% 30%,#0a2030 0%,#0d1117 70%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:18px;width:370px;padding:40px 44px;box-shadow:0 24px 64px #0000008c,0 0 0 1px #00c2dc14}.login-logo-img{width:200px;margin:0 auto 6px;display:block}.login-logo-text{color:var(--brand);letter-spacing:1px;margin-bottom:4px;font-size:26px;font-weight:800}.login-sub{color:var(--text-muted);margin-bottom:28px;font-size:13px}.login-card input,.login-card select{background:var(--surface2);width:100%;color:var(--text);border:1.5px solid var(--border);border-radius:8px;outline:none;margin-bottom:14px;padding:11px 14px;font-size:14px;transition:border-color .2s}.login-card input:focus,.login-card select:focus{border-color:var(--brand)}.login-card select option{background:var(--surface2)}.login-btn{background:linear-gradient(135deg, var(--brand), var(--brand-dark));color:#0d1117;cursor:pointer;letter-spacing:.3px;border:none;border-radius:8px;width:100%;padding:12px;font-size:15px;font-weight:700;transition:opacity .2s}.login-btn:hover{opacity:.88}.login-error{color:var(--red);margin-top:10px;font-size:13px}.login-tabs{border:1px solid var(--border);border-radius:10px;margin-bottom:20px;display:flex;overflow:hidden}.login-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex:1;padding:9px 0;font-size:13px;font-weight:600;transition:all .15s}.login-tab.active{background:var(--brand);color:#0d1117}.login-tab:hover:not(.active){background:var(--surface2);color:var(--text)}.header{z-index:100;background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 28px;display:flex;position:sticky;top:0;box-shadow:0 2px 12px #0006}.header-logo{height:36px;display:block}.header-logo-text{color:var(--brand);letter-spacing:1px;font-size:22px;font-weight:800}.header-left{align-items:center;gap:16px;display:flex}.header-left-info h1{color:var(--text);font-size:15px;font-weight:700}.header-left-info p{color:var(--text-muted);margin-top:2px;font-size:11px}.header-right{align-items:center;gap:12px;display:flex}.logout-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:20px;padding:6px 16px;font-size:13px;transition:all .2s}.logout-btn:hover{color:var(--text);border-color:var(--text-muted)}.refresh-btn{background:var(--brand-glow);color:var(--brand);cursor:pointer;border:1px solid #00c2dc4d;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600;transition:all .2s}.refresh-btn:hover{background:#00c2dc47}.founder-header-badge{color:var(--yellow);background:#f5a6231a;border:1px solid #f5a62340;border-radius:20px;margin-left:10px;padding:3px 12px;font-size:11px;font-weight:700}.founder-tag{color:var(--yellow);text-transform:uppercase;letter-spacing:.5px;vertical-align:middle;background:#f5a6231a;border:1px solid #f5a62340;border-radius:20px;margin-left:8px;padding:2px 8px;font-size:9px;font-weight:700}.founder-branch-switcher{align-items:center;gap:4px;display:flex}.branch-switch-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:20px;padding:5px 14px;font-size:13px;transition:all .15s}.branch-switch-btn.active{background:var(--brand);color:#0d1117;border-color:var(--brand);font-weight:700}.branch-switch-btn:hover:not(.active){border-color:var(--brand);color:var(--brand)}.week-bar{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 28px;display:flex}.week-bar span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.week-chip{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:20px;padding:5px 16px;font-size:13px;transition:all .15s}.week-chip:hover{border-color:var(--brand);color:var(--brand)}.week-chip.active{background:var(--brand);color:#0d1117;border-color:var(--brand);font-weight:700}.main{flex:1;padding:20px 28px}.center-msg{text-align:center;color:var(--text-muted);padding:60px 20px}.spinner{border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:36px;height:36px;margin:0 auto 16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.cards-grid{gap:20px;display:grid}.teacher-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:box-shadow .2s;overflow:hidden;box-shadow:0 2px 12px #0000004d}.teacher-card:hover{box-shadow:0 4px 20px #0006}.card-header{cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 20px;transition:background .15s;display:flex}.card-header:hover{background:var(--surface2)}.teacher-name{color:var(--brand);font-size:16px;font-weight:700}.mentor-badge{color:var(--brand);text-transform:uppercase;letter-spacing:.5px;background:#00c2dc26;border:1px solid #00c2dc40;border-radius:20px;margin-left:8px;padding:3px 10px;font-size:10px;font-weight:700}.card-header-right{align-items:center;gap:8px;display:flex}.tracker-btn{color:var(--brand);white-space:nowrap;background:#00c2dc1f;border:1px solid #00c2dc4d;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;text-decoration:none;transition:background .15s}.tracker-btn:hover{background:#00c2dc40}.issue-badge{white-space:nowrap;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.issue-badge.red{color:#f87171;background:#ef444426;border:1px solid #ef444440}.issue-badge.green{color:#4ade80;background:#22c47a1f;border:1px solid #22c47a33}.chevron{color:var(--text-muted);font-size:12px;transition:transform .2s}.chevron.open{transform:rotate(180deg)}.top-nav{background:var(--surface);border-bottom:2px solid var(--border);gap:4px;padding:0 28px;display:flex}.top-nav-btn{color:var(--text-muted);cursor:pointer;letter-spacing:.2px;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:14px 22px;font-size:14px;font-weight:700;transition:all .15s}.top-nav-btn:hover{color:var(--text)}.top-nav-btn.active{color:var(--brand);border-bottom-color:var(--brand)}.card-body{grid-template-columns:1fr 1fr;gap:0;display:grid}@media (width<=700px){.card-body{grid-template-columns:1fr}}.card-section{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:14px 20px}.card-section:nth-child(2n){border-right:none}.card-section:last-child,.card-section:nth-last-child(2):nth-child(odd){border-bottom:none}.card-section-full{padding:16px 20px}.section-title{text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);margin-bottom:10px;font-size:10px;font-weight:700}.metric-bar{align-items:center;gap:8px;margin-bottom:7px;display:flex}.metric-label{color:var(--text-muted);flex-shrink:0;width:150px;font-size:12px}.bar-track{background:var(--surface2);border-radius:10px;flex:1;height:9px;overflow:hidden}.bar-fill{border-radius:10px;height:100%;transition:width .4s}.metric-count{color:var(--text);white-space:nowrap;min-width:30px;font-size:12px}.task-row{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;gap:8px;padding:5px 0;display:flex}.task-row:last-child{border-bottom:none}.task-label{color:var(--text-muted);flex:1;font-size:12px}.task-val{white-space:nowrap;text-align:right;text-overflow:ellipsis;border-radius:4px;max-width:160px;padding:2px 8px;font-size:11px;font-weight:600;overflow:hidden}.task-val.done{color:#4ade80;background:#22c47a1f}.task-val.bad{color:#f87171;background:#ef44441f}.task-val.neutral{color:#f5a623;background:#f5a6231a}.task-val.na{color:var(--text-muted);background:#6b7a8f1a}.task-val.absent{color:#c084fc;background:#c026d31a}.task-val.noclass{color:var(--brand);background:#00c2dc14}.task-val.info{color:var(--brand);background:#00c2dc1a}.tracker-loading{color:var(--text-muted);font-size:12px;font-style:italic}.no-score{color:var(--text-muted);font-size:12px}.tracker-content{flex-wrap:wrap;align-items:flex-start;gap:24px;display:flex}.tracker-left{flex-shrink:0}.score-badge{border-radius:10px;align-items:baseline;gap:2px;padding:8px 16px;font-weight:800;display:inline-flex}.score-number{font-size:28px;line-height:1}.score-denom{opacity:.7;font-size:13px}.score-notes{color:var(--text-muted);max-width:180px;margin-top:6px;font-size:11px;font-style:italic}.tracker-right{flex:1;min-width:200px}.chapter-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.chapter-label{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:120px;font-size:11px;overflow:hidden}.chapter-bar-track{background:var(--surface2);border-radius:10px;flex:1;height:7px;overflow:hidden}.chapter-bar-fill{background:linear-gradient(90deg, var(--brand), var(--brand-dark));border-radius:10px;height:100%;transition:width .4s}.chapter-count{color:var(--text);text-align:right;white-space:nowrap;min-width:28px;font-size:11px}.assign-pending{color:var(--yellow);white-space:nowrap;background:#f5a6231a;border:1px solid #f5a62340;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600}.assign-badge{background:var(--yellow);color:#fff;cursor:default;border-radius:999px;justify-content:center;align-items:center;min-width:15px;height:15px;margin-left:3px;padding:0 3px;font-size:9px;font-weight:700;line-height:1;display:inline-flex}.card-footer{border-top:1px solid var(--border)}.flags-section{background:#ef444412;border-top:2px solid #ef44444d;padding:12px 20px}.flags-section .section-title{color:#f87171}.flag-item{color:#f87171;margin-bottom:4px;font-size:12px}.flag-item:before{content:"⚠ "}.points-section{background:#f5a6230f;border-top:1px solid #f5a62333;padding:12px 20px}.points-section .section-title{color:var(--yellow)}.point-item{color:var(--text-muted);margin-bottom:4px;font-size:12px}.point-item:before{content:"→ ";color:var(--yellow);font-weight:700}.student-connect{flex-direction:column;gap:14px;display:flex}.sc-selectors{flex-wrap:wrap;align-items:flex-end;gap:14px;display:flex}.sc-selector-group{flex-direction:column;gap:4px;display:flex}.sc-selector-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);font-size:9px;font-weight:700}.sc-select{background:var(--surface2);color:var(--text);border:1.5px solid var(--border);cursor:pointer;border-radius:8px;outline:none;min-width:140px;padding:7px 12px;font-size:13px;transition:border-color .2s}.sc-select:focus{border-color:var(--brand)}.sc-response-count{color:var(--text-muted);padding-bottom:7px;font-size:12px}.sc-status{color:var(--text-muted);padding:8px 0;font-size:12px;font-style:italic}.sc-error{color:var(--red);font-style:normal}.sc-tiles{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}@media (width<=500px){.sc-tiles{grid-template-columns:1fr}}.score-tile{background:var(--surface2);border:1.5px solid var(--border);text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:12px 14px;transition:border-color .3s;display:flex}.score-tile-emoji{font-size:20px}.score-tile-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:10px;font-weight:700}.score-tile-value{font-size:22px;font-weight:800;line-height:1.1}.score-tile-max{opacity:.6;font-size:13px;font-weight:600}.score-tile-pct{font-size:12px;font-weight:600}.score-tile-bar-track{background:var(--border);border-radius:10px;width:100%;height:6px;margin-top:2px;overflow:hidden}.score-tile-bar-fill{border-radius:10px;height:100%;transition:width .4s}.score-tile-na{color:var(--text-muted);font-size:12px}.sc-qualities{flex-direction:column;gap:6px;margin-top:4px;display:flex}.sc-qualities-title{color:var(--brand);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:700}.sc-quality-row{background:var(--surface2);border:1px solid var(--border);border-radius:7px;flex-wrap:wrap;align-items:center;gap:8px;padding:5px 8px;display:flex}.sc-quality-name{color:var(--text);flex:140px;font-size:12px;font-weight:600}.sc-quality-batches{flex-wrap:wrap;gap:4px;display:flex}.sc-quality-batch-chip{color:var(--brand);background:#00c2dc14;border:1px solid #00c2dc33;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600}.sc-quality-total{color:var(--text-muted);font-size:11px}.quality-tag{color:var(--brand);background:#00c2dc14;border:1px solid #00c2dc33;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.sc-q8{background:#f5a6230d;border:1px solid #f5a62333;border-radius:8px;padding:10px 14px}.sc-q8-label{color:var(--yellow);text-transform:uppercase;letter-spacing:.5px;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:8px;font-size:11px;font-weight:700;display:flex}.sc-q8-context{color:var(--text-muted);text-transform:none;letter-spacing:0;font-style:italic;font-weight:500}.sc-q8-item{color:var(--text-muted);border-bottom:1px dashed var(--border);padding:4px 0;font-size:12px;font-style:italic}.sc-q8-item:last-child{border-bottom:none}.sc-q8-empty{color:var(--text-muted);margin-top:6px;font-size:11px;font-style:italic}.sc-trend{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.sc-trend-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.sc-trend-title{color:var(--text);font-size:11px;font-weight:700}.sc-trend-legend{gap:12px;font-size:10px;font-weight:600;display:flex}.trend-chart{width:100%;display:block}.trend-empty{color:var(--text-muted);text-align:center;padding:20px 0;font-size:12px;font-style:italic}.hamburger-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text);border-radius:9px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:4px;padding:0;transition:background .15s,border-color .15s,color .15s;display:none}.hamburger-btn:hover{border-color:var(--brand);color:var(--brand)}.hamburger-btn.open{color:var(--brand);background:#00c2dc1f;border-color:#00c2dc66}.hamburger-bar{background:currentColor;border-radius:2px;width:16px;height:1.5px;transition:transform .2s,opacity .2s}.hamburger-btn.open .hamburger-bar:first-child{transform:translateY(5.5px)rotate(45deg)}.hamburger-btn.open .hamburger-bar:nth-child(2){opacity:0}.hamburger-btn.open .hamburger-bar:nth-child(3){transform:translateY(-5.5px)rotate(-45deg)}.mobile-page-tag{color:var(--brand);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;display:none;overflow:hidden}.mobile-nav-panel{background:var(--surface);border-bottom:1px solid var(--border);top:var(--header-h,60px);z-index:98;display:none;position:sticky;box-shadow:0 6px 18px #0008}.mobile-nav-panel.open{display:block}.mobile-nav-item{width:100%;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;border-left:3px solid #0000;justify-content:space-between;align-items:center;padding:13px 18px;font-size:14px;font-weight:600;transition:background .12s;display:flex}.mobile-nav-item:hover{background:var(--surface2)}.mobile-nav-item.active{color:var(--brand);border-left-color:var(--brand);background:#00c2dc14;font-weight:700}.mobile-nav-item .current-tag{color:var(--brand);opacity:.75;font-size:10px;font-weight:600}.mobile-nav-divider{border-top:1px solid var(--border);margin:6px 14px}.mobile-nav-extras{flex-direction:column;gap:10px;padding:10px 18px 14px;display:flex}.mobile-nav-extras-row{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:10px;font-size:12px;display:flex}.mobile-nav-extras-row .branch-switch-btn,.mobile-nav-extras-row .refresh-btn,.mobile-nav-extras-row .logout-btn{min-height:38px}.mobile-nav-scrim{z-index:95;background:#0d111780;animation:.15s ease-out scrimIn;display:none;position:fixed;inset:0}.mobile-nav-scrim.open{display:block}@keyframes scrimIn{0%{opacity:0}to{opacity:1}}.top-nav{top:var(--header-h,60px);z-index:99;position:sticky}.lb-mobile-list{flex-direction:column;gap:10px;display:flex}.lb-mobile-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;padding:12px 14px;transition:border-color .15s,background .15s}.lb-mobile-card:hover{border-color:var(--brand)}.lb-mobile-card.you{box-shadow:inset 3px 0 0 var(--brand);background:#00c2dc1a;border-color:#00c2dc66}.lb-card-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.lb-card-name-wrap{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.lb-card-name{color:var(--text);word-break:break-word;flex-wrap:wrap;align-items:center;gap:6px;font-size:14px;font-weight:700;display:flex}.lb-card-name.you{color:var(--brand)}.lb-card-sub{color:var(--text-muted);margin-top:2px;font-size:10.5px}.lb-card-rank{text-align:center;border-radius:8px;flex-shrink:0;min-width:34px;padding:4px 8px;font-size:13px;font-weight:900;display:inline-block}.lb-card-total{text-align:right;flex-shrink:0}.lb-card-total-num{font-size:22px;font-weight:900;line-height:1}.lb-card-total-den{color:var(--text-muted);margin-top:2px;font-size:9.5px}.lb-card-pillars{grid-template-columns:1fr 1fr 1fr;gap:6px;margin-top:10px;display:grid}.lb-pillar-tile{background:var(--surface2);text-align:center;border-radius:6px;padding:6px 8px}.lb-pillar-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:8.5px}.lb-pillar-value{color:var(--text);margin-top:2px;font-size:13px;font-weight:800;line-height:1.15}.lb-pillar-value-den{color:var(--text-muted);font-size:10px;font-weight:600}.lb-pillar-raw{color:var(--text-muted);margin-top:1px;font-size:9px}.lb-pillar-blank{color:var(--yellow)}.lb-card-footer{border-top:1px dashed var(--border);color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:10px;padding-top:8px;font-size:10.5px;display:flex}@media (width<=640px){:root{--header-h:52px;font-size:16px}body{-webkit-text-size-adjust:100%}.header{gap:8px;padding:10px 14px}.header-logo{height:30px}.header-logo-text{font-size:18px}.header-left{flex:1;gap:10px;min-width:0}.header-left-info h1{font-size:13px}.header-left-info p{font-size:10px}.header-right{gap:8px}.hamburger-btn{display:flex}.mobile-page-tag{display:block}.header .refresh-btn,.header .logout-btn,.header .founder-branch-switcher{display:none}.header .founder-header-badge{margin-left:0;padding:2px 8px;font-size:9px}.top-nav{display:none}.week-bar{gap:8px;padding:8px 14px}.week-chip{align-items:center;min-height:38px;padding:7px 12px;font-size:12px;display:inline-flex}.main{padding:14px 12px}.login-card{width:auto;max-width:92vw;padding:28px 22px}.login-card input,.login-card select{padding:12px 14px;font-size:16px}.login-btn{min-height:46px;padding:13px;font-size:16px}.login-tab{min-height:40px;padding:11px 0;font-size:13px}.login-logo-img{width:160px}.teacher-card .card-header{padding:12px 14px}.teacher-name{font-size:15px}.tracker-btn,.issue-badge{align-items:center;min-height:32px;padding:5px 10px;font-size:11px;display:inline-flex}.metric-label{flex:1;width:auto;font-size:12px}.card-section,.card-section-full{padding:12px 14px}.sc-selectors{gap:10px}.sc-select{width:100%;min-width:0;min-height:44px;padding:10px 12px;font-size:14px}.sc-selector-group{flex:calc(50% - 5px);min-width:0}.logout-btn,.refresh-btn,.branch-switch-btn{min-height:40px}}
