.app{min-height:100vh;display:flex;flex-direction:column}.main{flex:1 0 auto}.footer{flex-shrink:0}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;--footer-height: 56px}.container{max-width:1040px;padding:0 16px;margin:0 auto}.header{border-bottom:1px solid #e5e7eb;background:#fff;width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}.header-inner{max-width:1040px;margin:0 auto;padding:0 16px;min-height:var(--header-height);display:flex;align-items:center;justify-content:space-between}.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:auto;padding-top:0;padding-bottom:0}.footer{border-top:1px solid #e5e7eb;background:#fff;width:100vw;margin-top:12px;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}.footer-inner{max-width:1040px;margin:0 auto;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:94%;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 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}.meeting-card{display:flex;gap:12px;align-items:flex-start;border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:12px;margin-top:8px}.meeting-card__icon{font-size:20px;line-height:20px}.meeting-card__body{flex:1}.meeting-card__title{font-weight:700;margin-bottom:6px}.meeting-card__row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.meeting-link{word-break:break-all;color:#2563eb;text-decoration:none}.meeting-link:hover{text-decoration:underline}.copy-btn{border:1px solid #e5e7eb;background:#fff;border-radius:8px;padding:6px 10px;cursor:pointer;font-weight:600;font-size:13px}.copy-btn:hover{background:#f9fafb}.copy-note{margin-top:6px;font-size:12px;color:#16a34a}.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:8px}.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;margin-bottom: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}.auth-wrap{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 160px)}.auth-card{width:100%;max-width:420px;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:24px;box-shadow:0 8px 24px #0000000f}.auth-head{text-align:center;margin-bottom:16px}.auth-logo{font-weight:800;letter-spacing:.5px;font-size:20px}.auth-title{font-size:20px;font-weight:700;margin-top:6px}.auth-subtitle{font-size:13px;color:#6b7280;margin-top:2px}.auth-form{margin-top:16px}.input-row{position:relative}.input-row--with-toggle{display:flex;gap:8px;align-items:center}.input-toggle{border:1px solid #e5e7eb;background:#fff;border-radius:8px;padding:8px 10px;cursor:pointer;font-size:12px;color:#374151}.input-toggle:hover{background:#f9fafb}.auth-error{margin-top:10px;background:#fef2f2;color:#991b1b;border:1px solid #fee2e2;border-radius:8px;padding:8px 12px;font-size:13px}.auth-submit{margin-top:16px;width:100%}.auth-hint{text-align:center;margin-top:10px;font-size:12px}.spinner{width:16px;height:16px;border:2px solid #ffffff;border-right-color:transparent;border-radius:50%;display:inline-block;animation:spin .8s linear infinite;vertical-align:-2px}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.container{padding:0 12px}.page{padding:16px 0 0}.header-inner{padding:0 12px}.footer-inner{padding: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:0;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}
