.react-calendar{width:350px;max-width:100%;background:#fff;border:1px solid #a0a096;font-family:Arial,Helvetica,sans-serif;line-height:1.125em}.react-calendar--doubleView{width:700px}.react-calendar--doubleView .react-calendar__viewContainer{display:flex;margin:-.5em}.react-calendar--doubleView .react-calendar__viewContainer>*{width:50%;margin:.5em}.react-calendar,.react-calendar *,.react-calendar *:before,.react-calendar *:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.react-calendar button{margin:0;border:0;outline:none}.react-calendar button:enabled:hover{cursor:pointer}.react-calendar__navigation{display:flex;height:44px;margin-bottom:1em}.react-calendar__navigation button{min-width:44px;background:none}.react-calendar__navigation button:disabled{background-color:#f0f0f0}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:#e6e6e6}.react-calendar__month-view__weekdays{text-align:center;text-transform:uppercase;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__weekdays__weekday{padding:.5em}.react-calendar__month-view__weekNumbers .react-calendar__tile{display:flex;align-items:center;justify-content:center;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__days__day--weekend{color:#d10000}.react-calendar__month-view__days__day--neighboringMonth,.react-calendar__decade-view__years__year--neighboringDecade,.react-calendar__century-view__decades__decade--neighboringCentury{color:#757575}.react-calendar__year-view .react-calendar__tile,.react-calendar__decade-view .react-calendar__tile,.react-calendar__century-view .react-calendar__tile{padding:2em .5em}.react-calendar__tile{max-width:100%;padding:10px 6.6667px;background:none;text-align:center;font:inherit;font-size:.833em}.react-calendar__tile:disabled{background-color:#f0f0f0;color:#ababab}.react-calendar__month-view__days__day--neighboringMonth:disabled,.react-calendar__decade-view__years__year--neighboringDecade:disabled,.react-calendar__century-view__decades__decade--neighboringCentury:disabled{color:#cdcdcd}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:#e6e6e6}.react-calendar__tile--now{background:#ffff76}.react-calendar__tile--now:enabled:hover,.react-calendar__tile--now:enabled:focus{background:#ffffa9}.react-calendar__tile--hasActive{background:#76baff}.react-calendar__tile--hasActive:enabled:hover,.react-calendar__tile--hasActive:enabled:focus{background:#a9d4ff}.react-calendar__tile--active{background:#006edc;color:#fff}.react-calendar__tile--active:enabled:hover,.react-calendar__tile--active:enabled:focus{background:#1087ff}.react-calendar--selectRange .react-calendar__tile--hover{background-color:#e6e6e6}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4f46e5;--primary-light: #818cf8;--primary-dark: #3730a3;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg: #f8fafc;--card: #ffffff;--text: #1e293b;--text-light: #64748b;--border: #e2e8f0;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}html,body{height:100%;overflow:hidden}.app-layout{display:flex;height:100vh;overflow:hidden;position:relative}.sidebar{width:220px;background:var(--primary-dark);color:#fff;padding:20px 0;display:flex;flex-direction:column;flex-shrink:0;transition:width .25s ease,opacity .25s ease}.sidebar.collapsed{width:0;opacity:0;overflow:hidden;padding:0}.sidebar-toggle-btn{position:fixed;top:12px;left:12px;z-index:50;width:36px;height:36px;border:none;border-radius:var(--radius);background:var(--primary-dark);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 2px 8px #00000026;transition:left .25s ease}.sidebar-toggle-btn:hover{background:var(--primary)}.sidebar-logo{padding:0 20px 20px;font-size:18px;font-weight:700;border-bottom:1px solid rgba(255,255,255,.15);margin-bottom:10px}.sidebar-nav{flex:1;overflow-y:auto}.sidebar-nav a{display:block;padding:10px 20px;color:#fffc;text-decoration:none;font-size:14px;transition:all .2s}.sidebar-nav a:hover,.sidebar-nav a.active{background:#ffffff1f;color:#fff}.main-content{flex:1;padding:24px;overflow-y:auto;min-width:0}.main-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;background:var(--bg);margin:-24px -24px 24px}.main-header h1{font-size:22px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);text-align:center}.stat-card .value{font-size:32px;font-weight:700;color:var(--primary)}.stat-card .label{font-size:13px;color:var(--text-light);margin-top:4px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-outline{background:transparent;color:var(--text-light);border:1px solid var(--border)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-sm{padding:4px 10px;font-size:13px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:14px}.form-control{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;outline:none;transition:border .2s}.form-control:focus{border-color:var(--primary)}textarea.form-control{min-height:100px;resize:vertical}select.form-control{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);font-size:14px}th{font-weight:600;color:var(--text-light);font-size:13px}.progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.progress-bar .fill{height:100%;background:var(--primary);transition:width .3s}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-info{background:#dbeafe;color:#1e40af}.badge-danger{background:#fee2e2;color:#991b1b}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%)}.login-card{background:#fff;border-radius:12px;padding:40px;width:380px;box-shadow:0 20px 60px #00000026}.login-card h2{text-align:center;margin-bottom:24px;color:var(--text)}.login-card .btn{width:100%;justify-content:center;padding:10px}.quiz-option{display:flex;align-items:center;gap:10px;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius);margin-bottom:8px;cursor:pointer;transition:all .2s}.quiz-option:hover{border-color:var(--primary-light)}.quiz-option.selected{border-color:var(--primary);background:#eef2ff}.quiz-option.correct{border-color:var(--success);background:#d1fae5}.quiz-option.wrong{border-color:var(--danger);background:#fee2e2}.quiz-option input{display:none}.media-container{width:100%;aspect-ratio:16/9;background:#000;border-radius:var(--radius);overflow:hidden;margin-bottom:16px}.media-container iframe{width:100%;height:100%;border:none}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-8{gap:8px}.gap-16{gap:16px}.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}.text-center{text-align:center}.text-muted{color:var(--text-light)}.error-msg{color:var(--danger);font-size:13px;margin-top:4px}.loading,.empty-state{text-align:center;padding:40px;color:var(--text-light)}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.dialog{background:#fff;border-radius:12px;padding:24px;width:480px;max-width:90vw;max-height:80vh;overflow-y:auto}.dialog h3{margin-bottom:16px}.reading-card{max-width:800px}@media (max-width: 768px){.reading-card{max-width:100%}}.reading-content p{margin-bottom:12px}.reading-content h1,.reading-content h2,.reading-content h3{margin:20px 0 10px}.reading-content blockquote{border-left:4px solid var(--primary-light);padding:8px 16px;margin:12px 0;background:#f8fafc;color:var(--text-light)}.reading-content ul,.reading-content ol{padding-left:24px;margin-bottom:12px}.reading-content li{margin-bottom:4px}@media (max-width: 1024px){.sidebar{width:200px}.main-content{padding:20px}.main-header{padding:14px 20px;margin-top:-20px;margin-left:-20px;margin-right:-20px}}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:200;width:260px;transform:translate(-100%);transition:transform .25s ease}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{transform:translate(-100%);width:260px}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:190;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.main-content{padding:16px 12px}.main-header{padding:12px;margin-top:-16px;margin-left:-12px;margin-right:-12px;flex-direction:column;align-items:flex-start;gap:8px}.main-header>.flex-between{flex-wrap:wrap;gap:8px}.main-header h1{font-size:18px}.sidebar-toggle-btn{left:12px!important}.login-card{width:calc(100vw - 32px);max-width:380px;padding:24px 20px}.dialog{width:calc(100vw - 24px);padding:20px}.stats-grid{grid-template-columns:repeat(2,1fr)}table{font-size:13px}th,td{padding:8px 6px;font-size:12px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.btn{padding:10px 14px;font-size:14px}.form-control{padding:10px 12px;font-size:16px}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.react-calendar{border:1px solid var(--border)!important;border-radius:var(--radius)!important;font-family:inherit!important;width:100%!important;max-width:100%!important;background:var(--card)!important;box-shadow:none!important;padding:8px!important}.react-calendar__navigation{margin-bottom:8px!important}.react-calendar__navigation button{color:var(--text)!important;font-weight:600!important;font-size:14px!important;min-width:32px!important;background:none!important}.react-calendar__navigation button:disabled{color:var(--text-light)!important}.react-calendar__month-view__weekdays{font-size:12px!important;color:var(--text-light)!important}.react-calendar__month-view__weekdays__weekday{text-decoration:none!important}.react-calendar__month-view__weekdays__weekday abbr{text-decoration:none!important;font-weight:600!important}.react-calendar__tile{font-size:13px!important;padding:8px 4px!important;border-radius:6px!important;color:var(--text)!important}.react-calendar__tile:enabled:hover{background:var(--primary-light)!important}.react-calendar__tile--active{background:var(--primary)!important;color:#fff!important}.react-calendar__tile--now{background:#eef2ff!important;font-weight:700!important}.react-calendar__month-view__days__day--weekend{color:var(--danger)!important}.react-calendar__month-view__days__day--neighboringMonth{color:var(--text-light)!important}.react-calendar__tile .task-dot{display:block;width:4px;height:4px;background:var(--primary);border-radius:50%;margin:2px auto 0}.dashboard-top-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.task-panel{display:flex;flex-direction:column;gap:8px;min-height:300px}.task-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.task-panel-header h3{font-size:15px}.task-card{padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);transition:box-shadow .2s;cursor:default}.task-card:hover{box-shadow:0 2px 8px #00000014}.task-card.pending{border-left:3px solid var(--warning)}.task-card.overdue{border-left:3px solid var(--danger);background:#fef2f2}.task-card.completed{border-left:3px solid var(--success);opacity:.7}.task-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.task-card-title{font-weight:600;font-size:14px}.task-card-meta{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:12px;color:var(--text-light)}.task-card-actions{display:flex;gap:6px;margin-top:8px}.task-type-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;font-size:11px;font-weight:700;flex-shrink:0}.task-type-icon.vocab{background:#dbeafe;color:#1e40af}.task-type-icon.reading{background:#d1fae5;color:#065f46}.task-type-icon.quiz{background:#fef3c7;color:#92400e}.task-type-icon.lesson{background:#eef2ff;color:#4f46e5}.task-type-icon.custom{background:var(--border);color:var(--text-light)}@media (max-width: 768px){.dashboard-top-row{grid-template-columns:1fr}.task-card{padding:10px 12px}}
