@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#080c18;--bg-card:#0f1628;--bg-surface:#141d35;--bg-raised:#1a2440;--text:#dce3f5;--text-muted:#5a6a8a;--text-dim:#3a4a6a;--accent:#00c8e8;--accent-hover:#00a8c8;--accent-dim:#00c8e814;--accent-subtle:#00c8e826;--success:#00d67a;--success-dim:#00d67a1a;--warning:#f5a623;--warning-dim:#f5a6231a;--danger:#f0485a;--danger-dim:#f0485a1a;--purple:#9b6dff;--purple-dim:#9b6dff1a;--border:#1c2744;--border-bright:#263356;--radius:3px;--radius-sm:2px;--radius-lg:4px;--font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--transition:.15s ease}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}a{color:var(--accent);transition:color var(--transition);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:none}h1{letter-spacing:-.01em;color:var(--text);font-size:1.35rem;font-weight:700}.text-muted{color:var(--text-muted);font-size:.875rem}.loading,.error{min-height:200px;color:var(--text-muted);font-size:.875rem;font-family:var(--font-mono);letter-spacing:.04em;justify-content:center;align-items:center;display:flex}.error{color:var(--danger)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.app-layout{flex-direction:column;min-height:100vh;display:flex}.topbar{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;gap:16px;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.topbar:before{content:"";background:var(--accent);opacity:.5;height:1px;position:absolute;top:0;left:0;right:0}.topbar-left{align-items:center;gap:24px;display:flex}.logo{font-family:var(--font-mono);color:var(--accent);letter-spacing:.2em;text-transform:uppercase;font-size:1rem;font-weight:700}.dept-tabs{gap:2px;display:flex}.dept-tab{border-radius:var(--radius);color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:var(--font-mono);letter-spacing:.08em;cursor:pointer;transition:all var(--transition);background:0 0;border:1px solid #0000;padding:5px 14px}.dept-tab:hover{border-color:var(--border-bright);color:var(--text)}.dept-tab.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.topbar-nav{gap:2px;display:flex}.topbar-nav a{border-radius:var(--radius);color:var(--text-muted);transition:all var(--transition);border:1px solid #0000;padding:7px 14px;font-size:.8rem;font-weight:500}.topbar-nav a:hover{color:var(--text);border-color:var(--border-bright);background:var(--bg-surface)}.topbar-nav a.active{color:var(--accent);background:var(--accent-dim);border-color:var(--accent)}.topbar-right{align-items:center;gap:16px;display:flex}.user-info{align-items:center;gap:8px;display:flex}.user-avatar{border:1px solid var(--border-bright);border-radius:50%;width:26px;height:26px}.user-name{color:var(--text-muted);font-size:.8rem;font-weight:500}.btn-logout{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;font-size:.75rem;font-family:var(--font-body);transition:all var(--transition);background:0 0;padding:5px 12px}.btn-logout:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-dim)}.main-content{width:100%;max-width:1280px;margin:0 auto;padding:28px 32px}.date-picker{align-items:center;gap:8px;display:flex}.date-mode-toggle{display:flex}.mode-btn{border:1px solid var(--border);color:var(--text-muted);font-size:.72rem;font-family:var(--font-mono);letter-spacing:.04em;cursor:pointer;transition:all var(--transition);background:0 0;padding:4px 12px}.mode-btn:first-child{border-radius:var(--radius) 0 0 var(--radius);border-right:none}.mode-btn:last-child{border-radius:0 var(--radius) var(--radius) 0}.mode-btn:hover{background:var(--bg-surface);color:var(--text)}.mode-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.week-nav{align-items:center;gap:6px;display:flex}.nav-btn{border:1px solid var(--border);border-radius:var(--radius);width:26px;height:26px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;justify-content:center;align-items:center;font-size:.9rem;line-height:1;display:flex}.nav-btn:hover{border-color:var(--accent);color:var(--accent)}.week-label{font-size:.75rem;font-weight:600;font-family:var(--font-mono);color:var(--text);white-space:nowrap;text-align:center;min-width:110px}.custom-range{align-items:center;gap:6px;display:flex}.custom-range input{border:1px solid var(--border);border-radius:var(--radius);font-size:.75rem;font-family:var(--font-mono);color:var(--text);background:var(--bg-surface);transition:border-color var(--transition);padding:4px 8px}.custom-range input:focus{border-color:var(--accent);outline:none}.range-sep{color:var(--text-dim);font-size:.75rem}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background-image:linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);opacity:.35;background-size:48px 48px;position:absolute;inset:0}.login-page:after{content:"";border:1px solid var(--accent);opacity:.06;width:480px;height:480px;position:absolute;top:-120px;left:-120px;transform:rotate(15deg)}.login-card{z-index:1;background:var(--bg-card);border:1px solid var(--border-bright);text-align:center;width:100%;max-width:420px;padding:52px 60px;position:relative}.login-card:before{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;top:0;left:0;right:0}.login-logo{font-family:var(--font-mono);color:var(--accent);letter-spacing:.3em;margin-bottom:6px;font-size:2.4rem;font-weight:700;display:block}.login-card h1{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:1rem;font-weight:500}.login-card p{color:var(--text-muted);margin-bottom:36px;font-size:.85rem;line-height:1.6}.login-divider{background:var(--border-bright);width:32px;height:1px;margin:0 auto 32px}.btn-discord{background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent);border-radius:var(--radius);font-size:.875rem;font-weight:600;font-family:var(--font-body);letter-spacing:.02em;transition:all var(--transition);cursor:pointer;align-items:center;gap:10px;padding:13px 32px;display:inline-flex}.btn-discord:hover{background:var(--accent);color:var(--bg);text-decoration:none}.login-footer{color:var(--text-dim);font-size:.72rem;font-family:var(--font-mono);letter-spacing:.04em;margin-top:32px}.stats-grid{gap:14px;margin-bottom:14px;display:grid}.stats-grid-3{grid-template-columns:repeat(3,1fr)}.stats-grid-4,.stats-grid:not(.stats-grid-3):not(.stats-grid-4){grid-template-columns:repeat(4,1fr)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition);flex-direction:column;gap:5px;padding:18px 20px;display:flex;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--border-bright)}.stat-card-hero{padding:20px 24px}.stat-card[style*=borderLeft]{padding-left:20px}.stat-card-header{justify-content:space-between;align-items:flex-start;display:flex}.stat-icon{opacity:.6;font-size:1rem}.stat-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.1em;font-size:.67rem;font-weight:600;font-family:var(--font-mono)}.stat-value{font-size:1.45rem;font-weight:700;font-family:var(--font-mono);color:var(--text);line-height:1.2}.stat-value-lg{font-size:1.8rem}.stat-subtitle{color:var(--text-muted);margin-top:2px;font-size:.72rem}.stat-delta{font-size:.72rem;font-weight:600;font-family:var(--font-mono);align-items:center;gap:3px;margin-top:2px;display:inline-flex}.stat-delta.positive{color:var(--success)}.stat-delta.negative{color:var(--danger)}.charts-grid{grid-template-columns:1fr 1fr;gap:16px;margin-top:20px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px}.chart-card h3{font-size:.67rem;font-weight:600;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:20px}.chart-card.full-width{grid-column:1/-1}.data-table{border-collapse:collapse;width:100%;margin-top:12px}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 14px}.data-table th{text-transform:uppercase;color:var(--text-muted);letter-spacing:.1em;font-size:.67rem;font-weight:600;font-family:var(--font-mono);background:var(--bg-surface)}.data-table td{color:var(--text);font-size:.85rem}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover{background:var(--bg-surface)}.status{border-radius:var(--radius-sm);font-size:.68rem;font-weight:700;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;display:inline-block}.status.active{background:var(--success-dim);color:var(--success);border:1px solid #00d67a33}.status.inactive{background:var(--danger-dim);color:var(--danger);border:1px solid #f0485a33}.search-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:400px;color:var(--text);font-size:.875rem;font-family:var(--font-body);transition:border-color var(--transition);margin-bottom:20px;padding:9px 14px}.search-input::placeholder{color:var(--text-dim)}.search-input:focus{border-color:var(--accent);background:var(--bg-surface);outline:none}.btn{border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer;font-size:.8rem;font-family:var(--font-body);background:var(--accent-dim);color:var(--accent);transition:all var(--transition);letter-spacing:.02em;padding:8px 16px;font-weight:600}.btn:hover{background:var(--accent);color:var(--bg)}.btn-sm{padding:5px 12px;font-size:.75rem}.btn-secondary{border-color:var(--border-bright);color:var(--text-muted);background:0 0}.btn-secondary:hover{background:var(--bg-surface);border-color:var(--text-muted);color:var(--text)}.btn-danger{background:var(--danger-dim);border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-link{color:var(--accent);cursor:pointer;font-size:.78rem;font-family:var(--font-body);transition:color var(--transition);background:0 0;border:none;margin-left:8px;padding:0}.btn-link:hover{color:var(--accent-hover);text-decoration:underline}.tabs{gap:4px;margin-top:16px;margin-bottom:20px;display:flex}.tab{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-size:.8rem;font-weight:500;font-family:var(--font-body);transition:all var(--transition);background:0 0;padding:7px 18px}.tab:hover{border-color:var(--border-bright);color:var(--text);background:var(--bg-surface)}.tab.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.leaderboard-table .rank{font-weight:700;font-family:var(--font-mono);color:var(--text-muted);width:40px;font-size:.8rem}.rank-1 .rank{color:#f5c842}.rank-2 .rank{color:#a0aec0}.rank-3 .rank{color:#c07d3a}.grade-section{margin-bottom:28px}.grade-section h2{text-transform:uppercase;color:var(--text-muted);letter-spacing:.12em;font-size:.67rem;font-weight:600;font-family:var(--font-mono);border-bottom:1px solid var(--border);margin-bottom:12px;padding-bottom:8px}.members-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.member-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);color:var(--text);align-items:center;gap:14px;padding:14px 16px;text-decoration:none;display:flex}.member-card:hover{border-color:var(--border-bright);background:var(--bg-surface);color:var(--text);text-decoration:none}.member-avatar{border-radius:var(--radius-sm);color:#fff;width:38px;height:38px;font-size:.8rem;font-weight:700;font-family:var(--font-mono);opacity:.85;flex-shrink:0;justify-content:center;align-items:center;display:flex}.member-info{flex:1;min-width:0}.member-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text);font-size:.875rem;font-weight:600;display:block;overflow:hidden}.member-alias{color:var(--text-muted);font-size:.72rem;font-family:var(--font-mono);margin-top:1px;display:block}.member-meta{text-align:right;flex-shrink:0}.member-hours{font-size:.85rem;font-weight:600;font-family:var(--font-mono);color:var(--accent);margin-bottom:3px;display:block}.member-detail h1{margin-bottom:20px}.detail-section{margin-top:28px}.detail-section h2{font-size:.75rem;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:12px;padding-bottom:8px}.detail-grid{flex-direction:column;gap:12px;display:flex}.detail-item{align-items:center;gap:12px;display:flex}.detail-item label{text-transform:uppercase;color:var(--text-muted);width:120px;font-size:.72rem;font-weight:600;font-family:var(--font-mono);letter-spacing:.06em;flex-shrink:0}.inline-edit{align-items:center;gap:8px;display:flex}.inline-edit input{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--bg-surface);font-size:.85rem;font-family:var(--font-body);transition:border-color var(--transition);padding:6px 10px}.inline-edit input:focus{border-color:var(--accent);outline:none}.target-progress{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-top:16px;padding:16px 20px}.target-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.target-label{font-size:.67rem;font-weight:600;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.target-value{font-size:.8rem;font-weight:600;font-family:var(--font-mono);color:var(--text)}.progress-bar{background:var(--border);border-radius:0;height:4px;overflow:hidden}.progress-fill{border-radius:0;height:100%;transition:width .5s}.target-pct{font-size:.75rem;font-weight:700;font-family:var(--font-mono);margin-top:6px;display:inline-block}.absence-form{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.absence-form input,.absence-form select{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.8rem;font-family:var(--font-body);background:var(--bg-surface);transition:border-color var(--transition);padding:7px 12px}.absence-form input:focus,.absence-form select:focus{border-color:var(--accent);outline:none}.absence-form select option{background:var(--bg-card)}.info-banner{background:var(--accent-dim);border-radius:var(--radius);color:var(--accent);font-size:.8rem;font-family:var(--font-mono);border:1px solid #00c8e833;margin-bottom:12px;padding:10px 14px}.add-member-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;padding:18px 20px}.add-member-panel h3{margin-bottom:4px;font-size:.875rem;font-weight:600}.add-member-panel p{margin-bottom:12px}.add-member-form{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.add-member-form>input:not(.search-input){border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.875rem;font-family:var(--font-body);background:var(--bg-surface);transition:border-color var(--transition);padding:9px 14px}.add-member-form>input:not(.search-input):focus{border-color:var(--accent);outline:none}.status-met{color:var(--success);font-size:.78rem;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em}.status-not-met{color:var(--danger);font-size:.78rem;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em}.bonus-cell{color:var(--success);font-family:var(--font-mono);letter-spacing:.02em;font-size:.78rem;font-weight:600}.calculated-badge{color:var(--accent);cursor:help;font-weight:700;font-family:var(--font-mono)}.dashboard h1,.members-page h1,.leaderboard-page h1{margin-bottom:20px}@media (width<=1200px){.stats-grid:not(.stats-grid-3):not(.stats-grid-4){grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.stats-grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.topbar{flex-wrap:wrap;gap:10px;height:auto;padding:12px 16px}.topbar-nav{order:3;width:100%}.stats-grid-3,.stats-grid-4{grid-template-columns:1fr}.stats-grid:not(.stats-grid-3):not(.stats-grid-4){grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.chart-card.full-width{grid-column:1}.members-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.main-content{padding:16px}.date-picker{flex-wrap:wrap}.login-card{margin:16px;padding:36px 28px}.login-logo{font-size:1.8rem}}@media (width<=480px){.stats-grid:not(.stats-grid-3):not(.stats-grid-4){grid-template-columns:1fr}.detail-item{flex-direction:column;align-items:flex-start;gap:4px}.detail-item label{width:auto}}.my-stats{padding:0}.my-stats>h1{margin-bottom:4px}.stats-grid-2{grid-template-columns:repeat(2,1fr)}.dept-grid{grid-template-columns:repeat(2,1fr);gap:20px;margin-top:20px;display:grid}.dept-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:16px;padding:20px;display:flex}.dept-card-header{justify-content:space-between;align-items:center;display:flex}.dept-card-header h2{color:var(--text);margin:0;font-size:1.1rem;font-weight:700}.dept-grade{color:var(--text-muted);background:var(--bg-surface);border-radius:var(--radius-sm);padding:2px 8px;font-size:.8rem}.dept-logs h3,.dept-activity h3,.leaderboard-mini h3{color:var(--text-muted);margin-bottom:8px;font-size:.85rem;font-weight:600}.leaderboard-mini .data-table{font-size:.85rem}.highlight-row{background:var(--accent-dim)}.leaderboard-gap td{text-align:center;color:var(--text-dim);border:none;padding:2px 0;font-size:.75rem}.dept-card .stat-card{margin-bottom:0}.dept-card .target-progress{margin:0}@media (width<=768px){.dept-grid,.stats-grid-2{grid-template-columns:1fr}}
