@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-app:#0b0f19;--bg-surface:#111827;--bg-hover:#ffffff08;--border-light:#ffffff14;--border-focus:#ffffff26;--accent:#4f46e5;--accent-hover:#4338ca;--accent-faint:#4f46e51a;--accent-light:#818cf8;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--text-main:#f8fafc;--text-muted:#94a3b8;--text-dim:#64748b;font-family:Inter,system-ui,sans-serif}html,body,#root{height:100%}body{background:var(--bg-app);color:var(--text-main);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4{color:var(--text-main);font-weight:600}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1rem}p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--bg-app);border-right:1px solid var(--border-light);flex-direction:column;flex-shrink:0;width:250px;display:flex}.sidebar-header{letter-spacing:.02em;border-bottom:1px solid var(--border-light);align-items:center;gap:.5rem;padding:1.25rem 1.5rem;font-size:1.1rem;font-weight:700;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1rem 0;display:flex}.nav-item{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.5rem 1.5rem;font-size:.9rem;font-weight:500;transition:background-color .2s,color .2s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-main)}.nav-item.active{background:var(--accent-faint);color:var(--accent);border-right:2px solid var(--accent)}.sidebar-footer{border-top:1px solid var(--border-light);flex-direction:column;gap:.5rem;padding:1rem 1.5rem;display:flex}.user-profile{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.main-content{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--border-light);background:var(--bg-app);align-items:center;height:60px;padding:0 2rem;display:flex}.page-container{width:100%;max-width:1400px;margin:0 auto;padding:2rem}.card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:8px;padding:1.5rem;box-shadow:0 1px 2px #0003}.section-title{color:var(--text-main);border-bottom:1px solid var(--border-light);margin-bottom:1rem;padding-bottom:.75rem;font-size:1rem;font-weight:600}.btn{cursor:pointer;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-outline{color:var(--text-main);border-color:var(--border-light);background:0 0}.btn-outline:hover{background:var(--bg-hover);border-color:var(--border-focus)}.btn-danger-outline{color:var(--danger);background:0 0;border-color:#ef44444d}.btn-danger-outline:hover{border-color:var(--danger);background:#ef44441a}.input-group{flex-direction:column;gap:.35rem;display:flex}.input-group label{color:var(--text-muted);font-size:.75rem;font-weight:500}input,select{background:var(--bg-app);border:1px solid var(--border-light);color:var(--text-main);border-radius:6px;outline:none;width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.85rem;transition:border-color .2s}input:focus,select:focus{border-color:var(--accent)}select option{background:var(--bg-surface)}.table-wrapper{border:1px solid var(--border-light);border-radius:6px;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.data-table th{background:var(--bg-app);color:var(--text-muted);border-bottom:1px solid var(--border-light);white-space:nowrap;padding:.75rem 1rem;font-weight:500}.data-table td{border-bottom:1px solid var(--border-light);color:var(--text-main);vertical-align:middle;padding:.75rem 1rem}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background-color .2s}.data-table tbody tr:hover{background:var(--bg-hover)}.tt-grid-wrapper{border:1px solid var(--border-light);background:var(--bg-app);border-radius:6px;overflow-x:auto}.tt-grid{border-collapse:collapse;width:100%;min-width:800px;font-size:.75rem}.tt-grid th{background:var(--bg-surface);color:var(--text-muted);text-align:center;border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light);padding:.75rem 1rem;font-weight:500}.tt-grid td{border:1px solid var(--border-light);vertical-align:top;min-width:120px;padding:.5rem}.tt-cell{background:var(--bg-surface);border:1px solid var(--border-light);text-align:left;border-radius:4px;margin-bottom:.5rem;padding:.5rem}.tt-cell:last-child{margin-bottom:0}.tt-cell.theory{border-left:3px solid var(--accent)}.tt-cell.lab{border-left:3px solid var(--success)}.tt-cell .subj{color:var(--text-main);margin-bottom:.25rem;font-size:.8rem;font-weight:600}.tt-cell .meta{color:var(--text-dim);font-size:.68rem}.tt-grid th:first-child{text-align:center}.tt-grid td:first-child{color:var(--text-dim);text-align:center;white-space:nowrap;font-size:.75rem;font-weight:600}.badge{border-radius:4px;justify-content:center;align-items:center;padding:.15rem .5rem;font-size:.7rem;font-weight:500;display:inline-flex}.badge-success{color:var(--success);background:#10b9811a;border:1px solid #10b98133}.badge-warning{color:var(--warning);background:#f59e0b1a;border:1px solid #f59e0b33}.badge-danger{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.badge-accent{background:var(--accent-faint);color:#818cf8;border:1px solid #4f46e533}.toast{z-index:9999;border-radius:6px;padding:1rem 1.25rem;font-size:.85rem;font-weight:500;animation:.25s fadeInUp;position:fixed;bottom:2rem;right:2rem;box-shadow:0 4px 12px #00000080}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:var(--bg-surface);border-left:4px solid var(--success);color:var(--text-main)}.toast-error{background:var(--bg-surface);border-left:4px solid var(--danger);color:var(--text-main)}.toast-warning{background:var(--bg-surface);border-left:4px solid var(--warning);color:var(--text-main)}.flex-col{flex-direction:column;gap:1rem;display:flex}.flex-row{align-items:center;gap:1rem;display:flex}.grid-2{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:1.25rem;display:grid}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.spinner{border:2px solid var(--border-focus);border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.login-wrapper{background:var(--bg-app);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:8px;width:100%;max-width:380px;padding:2.5rem 2rem;box-shadow:0 4px 12px #0000004d}.tabs-header{border-bottom:1px solid var(--border-light);gap:1.5rem;margin-bottom:1.5rem;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.5rem 0;font-size:.85rem;font-weight:500;transition:all .2s}.tab-btn:hover{color:var(--text-main)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.stat-card{flex-direction:column;padding:1.25rem;display:flex}.stat-card .value{color:var(--text-main);font-size:1.75rem;font-weight:600}.stat-card .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem;font-size:.75rem}
