html,body,#root{height:100%}body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f8fafc;color:#111827}:root{--header-height: 64px}.container{max-width:1040px;padding:0 16px;margin:0 auto}.header{border-bottom:1px solid #e5e7eb;background:#fff;position:fixed;top:0;left:0;right:0;z-index:1000;box-shadow:0 1px #0000000a}.header-inner{display:flex;align-items:center;justify-content:space-between;padding:0 16px;min-height:var(--header-height)}.brand{font-weight:600;font-size:18px;text-decoration:none;color:inherit}.nav a,.nav button{font-size:14px;color:#374151;text-decoration:none;margin-left:16px;background:none;border:none;cursor:pointer}.nav a:hover,.nav button:hover{color:#111827}.main{min-height:calc(100vh - 120px);padding-top:var(--header-height)}.footer{border-top:1px solid #e5e7eb;background:#fff;padding:16px;font-size:14px;color:#6b7280}.grid{display:grid;gap:16px}@media (min-width: 640px){.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.card{border:1px solid #e5e7eb;background:#fff;border-radius:12px;overflow:hidden}.card:hover{box-shadow:0 4px 16px #0000000f}.card-cover{height:144px;background:#f3f4f6;background-size:cover;background-position:center}.card-body{padding:16px}.card-title{font-weight:600}.card-subtitle{font-size:12px;color:#6b7280;margin-bottom:4px}.card-desc{font-size:14px;color:#4b5563}.badge{font-size:12px;background:#dc2626;color:#fff;border-radius:9999px;padding:4px 8px}.form{max-width:440px;margin:0 auto;padding:48px 0}.label{display:block;font-size:14px;margin-bottom:4px}.input{width:100%;border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px;font-size:14px}.button{width:100%;border:none;border-radius:8px;padding:10px 12px;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.button:hover{background:#1d4ed8}.page{padding:32px 0}.page-title{font-size:24px;font-weight:600;margin-bottom:16px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.course-hero{border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:16px;margin-bottom:16px}.pill{display:inline-block;background:#eef2ff;color:#3730a3;font-size:12px;font-weight:600;border-radius:9999px;padding:4px 10px;margin-bottom:8px}.course-title{font-size:20px;font-weight:700;margin-bottom:8px}.calendar{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.calendar-row{display:flex;border-top:1px solid #f1f5f9}.calendar-row:first-child{border-top:none}.calendar-cell{flex:1;padding:12px}.calendar-cell--label{width:200px;background:#f8fafc;border-right:1px solid #f1f5f9}.layout-2col{display:grid;grid-template-columns:160px 1fr;gap:16px;margin-top:16px}.sidebar{display:flex;flex-direction:column;gap:6px}.sidebar .tab{width:auto;display:inline-block;text-align:left;padding:8px 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;font-weight:600;font-size:14px}.sidebar .tab:hover{box-shadow:0 2px 8px #0000000d}.sidebar .tab.active{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.section{border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:12px}.section-title{font-weight:700;margin-bottom:8px}.table{width:100%;border-collapse:collapse}.table th,.table td{border-bottom:1px solid #f1f5f9;text-align:left;padding:10px 8px;font-size:14px}.table th{color:#6b7280;font-weight:600;background:#f8fafc}.table tr:hover td{background:#fafafa}.link{color:#2563eb;text-decoration:none}.link:hover{text-decoration:underline}.muted{color:#6b7280}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-cell-day{border:1px solid #e5e7eb;background:#fff;border-radius:8px;min-height:56px;padding:4px;position:relative}.calendar-weekday{font-size:10px;color:#6b7280;text-align:center}.event{font-size:9px;margin-top:2px;padding:1px 4px;border-radius:6px}.event.lesson{background:#eef2ff;color:#3730a3}.event.hw{background:#fef3c7;color:#92400e}.calendar-legend{display:flex;gap:8px;font-size:10px;margin-top:4px}.calendar-legend .dot{width:6px;height:6px;border-radius:999px;display:inline-block;margin-right:4px}.calendar-legend .lesson{background:#6366f1}.calendar-legend .hw{background:#f59e0b}.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.filters .input,.filters .select{width:auto;min-width:140px}.controls{display:flex;gap:8px;align-items:center}.task-grid{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 1024px){.task-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.task-card{border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:12px}.task-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.task-number{font-weight:700}.task-subject{font-size:12px;color:#6b7280}.spoiler{margin-top:8px}.spoiler summary{cursor:pointer;font-weight:600}.spoiler-content{margin-top:6px;font-size:14px;color:#111827}.small{font-size:12px;color:#6b7280}.nav .logout-btn{background:#dc2626;color:#fff;border-radius:8px;padding:8px 12px;border:none;font-weight:600}.nav .logout-btn:hover{background:#b91c1c}.review-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px}.review-table{width:100%;border-collapse:collapse}.review-table th,.review-table td{border-bottom:1px solid #f1f5f9;padding:8px;text-align:left;font-size:14px}.review-table th{background:#f8fafc;color:#6b7280}.grade-form{display:flex;gap:8px;align-items:center}.grade-input{width:80px}.remaining{font-weight:600}.remaining-soon{color:#d97706}.remaining-overdue{color:#dc2626}@media (max-width: 768px){.container{padding:0 12px}.page{padding:16px 0}.header-inner{padding:0 12px}.layout-2col{grid-template-columns:1fr;gap:12px}.sidebar{flex-direction:row;overflow-x:auto;gap:6px;padding-bottom:4px}.sidebar .tab{white-space:nowrap;font-size:13px;padding:8px 10px}.course-hero{padding:12px}.course-title{font-size:18px}.pill{font-size:11px;padding:3px 8px}.calendar-grid{gap:2px}.calendar-cell-day{min-height:44px;padding:3px;border-radius:6px}.calendar-weekday{font-size:10px}.event{font-size:8px;margin-top:2px;padding:1px 3px}.calendar-legend{font-size:10px;gap:6px}.calendar-legend .dot{width:6px;height:6px}.task-card{padding:10px}.card-body{padding:12px}.card-cover{height:120px}.section{overflow-x:auto;-webkit-overflow-scrolling:touch}.table th,.table td{font-size:13px;padding:8px 6px}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
