:root{--bg: #f6f8fb;--card: #ffffff;--surface: #f8fafc;--text: #1a2332;--muted: #5c6b7f;--primary: #3b6ff5;--primary-hover: #2952c4;--primary-soft: #e8efff;--border: #e2e8f0;--success: #16a34a;--danger: #dc2626;--warning: #d97706;--radius: 14px;--radius-sm: 10px;--shadow: 0 8px 30px rgba(26, 35, 50, .06);--shadow-lg: 0 12px 40px rgba(26, 35, 50, .1);--touch: 44px;--space-xs: 8px;--space-sm: 12px;--space-md: 16px;--space-lg: 24px;--container: min(1080px, 100% - 32px);--font: Inter, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.55;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--primary);text-decoration:none;font-weight:500}a:hover{color:var(--primary-hover)}.container{width:var(--container);margin:0 auto;padding:var(--space-md) 0 calc(var(--space-lg) + env(safe-area-inset-bottom,0px))}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--space-md)}.card-flat{box-shadow:none;background:var(--surface)}.grid{display:grid;gap:var(--space-md)}.grid-2{grid-template-columns:1fr}@media(min-width:640px){.grid-2{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}.topbar{background:var(--card);border-bottom:1px solid var(--border);padding:var(--space-sm) 0;position:sticky;top:0;z-index:100}.topbar-inner{width:var(--container);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.brand{font-weight:700;font-size:1.05rem;letter-spacing:-.02em}.nav-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:var(--touch);min-height:var(--touch);padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer}.nav-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#2a313859;z-index:110;border:none;padding:0;cursor:pointer}.nav-overlay.open{display:block}.nav-links{display:flex;gap:var(--space-xs);flex-wrap:wrap;align-items:center}.nav-links a,.nav-links button{color:var(--text);font-weight:600;min-height:var(--touch);padding:0 var(--space-sm);border-radius:var(--radius-sm);display:inline-flex;align-items:center}.nav-links a.nav-active,.nav-links a:hover{color:var(--primary);background:var(--primary-soft)}.nav-user{font-size:.9rem;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-links-main,.nav-links-foot{display:contents}.nav-profile-card{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:8px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);text-decoration:none;color:inherit;grid-column:1 / -1}.nav-profile-card:hover{border-color:var(--primary);background:var(--primary-soft)}.nav-profile-avatar{flex-shrink:0;width:40px;height:40px;border-radius:999px;background:var(--primary-soft);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-weight:700}.nav-profile-text{min-width:0;display:flex;flex-direction:column;gap:1px}.nav-profile-name{font-weight:700;font-size:.95rem}.nav-profile-sub{font-size:.8rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-profile-action{font-size:.78rem;color:var(--primary);margin-top:2px}.nav-user-name{font-size:.9rem;font-weight:600;color:var(--muted);padding:0 var(--space-sm)}body.nav-open{overflow:hidden}.back-link{display:inline-flex;align-items:center;min-height:var(--touch);font-size:.9rem;font-weight:600;margin-bottom:var(--space-xs)}.field-hint{margin:6px 0 0;font-size:.85rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.input-with-actions{position:relative}.input-with-actions .input{width:100%;padding-right:48px}.input-with-actions .input-actions{position:absolute;right:6px;top:50%;transform:translateY(-50%);display:flex;gap:2px}.input-with-actions .input-actions .icon-btn:only-child~.input,.input-with-actions:has(.icon-btn:only-child) .input{padding-right:44px}.input-with-actions:has(.icon-btn+.icon-btn) .input{padding-right:80px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;min-width:var(--touch);min-height:var(--touch);padding:0;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:var(--radius-sm)}.icon-btn:hover{color:var(--primary);background:var(--primary-soft)}@media(max-width:767px){.nav-toggle{display:inline-flex}.nav-links{position:fixed;top:0;right:0;width:min(300px,88vw);height:100dvh;flex-direction:column;align-items:stretch;justify-content:space-between;gap:4px;padding:calc(var(--space-lg) + env(safe-area-inset-top,0px)) var(--space-md) var(--space-lg);background:var(--card);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);transform:translate(105%);transition:transform .2s ease;z-index:120;overflow-y:auto}.nav-links-main,.nav-links-foot{display:flex;flex-direction:column;gap:4px;width:100%}.nav-links-foot{margin-top:auto;padding-top:var(--space-md);border-top:1px solid var(--border)}.nav-user-name{max-width:none;padding:var(--space-sm) var(--space-md)}.nav-links.open{transform:translate(0)}.nav-links a,.nav-links button{width:100%;justify-content:flex-start;padding:0 var(--space-md)}.nav-user{max-width:none;padding:var(--space-sm) var(--space-md)}}@media(min-width:768px){.nav-toggle{display:none}}.btn{border:none;border-radius:var(--radius-sm);padding:0 var(--space-md);min-height:var(--touch);font-weight:600;font-size:.95rem;cursor:pointer;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);transition:background .15s ease;touch-action:manipulation}.btn:hover{background:var(--primary-hover)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.secondary{background:var(--primary-soft);color:var(--primary)}.btn.secondary:hover{background:#d6e4ff}.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn.ghost:hover{background:var(--surface);color:var(--text)}.input,.select,.textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 var(--space-sm);min-height:var(--touch);font:inherit;background:#fff;touch-action:manipulation}.textarea{padding:var(--space-sm);min-height:96px}.label{display:block;margin-bottom:6px;font-size:.9rem;color:var(--muted)}.muted{color:var(--muted)}strong{color:var(--text);font-weight:650}.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:.8rem;font-weight:600}.chat-layout{display:grid;grid-template-columns:1fr;gap:16px}@media(min-width:900px){.chat-layout{grid-template-columns:280px 1fr}}.chat-messages{min-height:420px;max-height:60vh;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:12px;padding-right:4px;overscroll-behavior:contain}.lesson-group{border:1px solid var(--border);border-radius:12px;background:#fff;flex-shrink:0}.lesson-group-header{width:100%;display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;padding:12px 14px;min-height:var(--touch);border:none;background:var(--surface);cursor:pointer;text-align:left;font:inherit;color:inherit;touch-action:manipulation}.lesson-group-header:hover{background:#f1f5f9}.lesson-group-chevron{flex:0 0 auto;font-size:.75rem;color:var(--muted, #64748b)}.lesson-group-title{flex:1 1 auto;font-weight:600;min-width:0}.lesson-group-badge{flex:0 0 auto;padding:2px 8px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:.75rem;font-weight:600}.lesson-group-meta{flex:1 1 100%;display:flex;gap:12px;font-size:.8rem;color:var(--muted, #64748b);padding-left:1.25rem}.lesson-group-body{display:flex;flex-direction:column;gap:12px;padding:12px 14px;border-top:1px solid var(--border);max-height:min(52vh,520px);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.lesson-group.collapsed .lesson-group-body{display:none}.msg{max-width:85%;padding:12px 14px;border-radius:12px;white-space:pre-wrap}.msg.user{align-self:flex-end;background:var(--primary);color:#fff}.msg.assistant{align-self:flex-start;background:#f1f5f9;border:1px solid var(--border)}.msg.thinking{align-self:flex-start;background:#fff7ed;border:1px dashed #fdba74;color:#9a3412;font-size:.9rem}.voice-permission-banner{margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid #93c5fd;border-radius:var(--radius);background:#eff6ff;font-size:.92rem}.voice-permission-banner p{margin:0 0 var(--space-sm)}.voice-perm-hint{margin:var(--space-sm) 0 0!important;font-size:.85rem}.voice-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm)}.voice-mode-toggle{display:flex;flex-wrap:wrap;gap:6px}.voice-mode-toggle .btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.voice-auto-speak{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--muted);cursor:pointer}.btn-voice{min-width:var(--touch);font-size:1.25rem;line-height:1;padding:.5rem .75rem}.btn-voice.recording{background:#dc2626;border-color:#dc2626;color:#fff;animation:voice-pulse 1s ease-in-out infinite}.msg.assistant{display:flex;align-items:flex-start;gap:8px}.btn-msg-speak{flex-shrink:0;margin-left:auto;padding:2px 8px;border:1px solid var(--border);border-radius:6px;background:#fff;cursor:pointer;font-size:1rem;line-height:1.4}.btn-msg-speak:hover:not(:disabled){background:#eff6ff;border-color:#93c5fd}.btn-msg-speak:disabled{opacity:.5;cursor:not-allowed}@keyframes voice-pulse{50%{opacity:.75}}.chat-input-row{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-sm)}@media(min-width:640px){.chat-input-row{flex-direction:row;align-items:flex-end}}.chat-input-row .textarea{min-height:var(--touch);resize:vertical}.chat-input-row .btn{width:100%}@media(min-width:640px){.chat-input-row .btn{width:auto;flex-shrink:0}}body.student-chat-page{overflow:hidden}.topbar-compact{padding:4px 0}.chat-topbar-back{font-weight:700;font-size:.95rem;min-height:var(--touch);display:inline-flex;align-items:center;color:var(--primary)}body.student-chat-page .container-chat{width:100%;max-width:none;margin:0;padding:0;height:100dvh;max-height:100dvh;overflow:hidden;display:flex;flex-direction:column}@media(min-width:768px){body.student-chat-page .container-chat{width:100%;max-width:none;margin:0;padding:0;height:100dvh;max-height:100dvh}}.ds-chat{flex:1;min-height:0;display:flex;position:relative;overflow:hidden;background:var(--bg)}.ds-chat-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;border:none;background:#0f172a59;cursor:pointer}.ds-chat-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:50;width:min(300px,88vw);background:var(--card);border-right:1px solid var(--border);transform:translate(-105%);transition:transform .22s ease;display:flex;flex-direction:column;overflow:hidden}.ds-chat-sidebar.open{transform:translate(0)}@media(min-width:900px){.ds-chat-overlay{display:none}.ds-chat-sidebar{position:relative;z-index:1;flex:0 0 280px;width:280px;transform:none}}.ds-chat-sidebar-inner{display:flex;flex-direction:column;min-height:0;height:100%}.ds-chat-sidebar-head{flex-shrink:0;padding:14px 16px 10px;border-bottom:1px solid var(--border)}.ds-chat-sidebar-title{margin:0;font-size:.95rem;font-weight:700;line-height:1.3}.ds-chat-sidebar-empty{padding:16px;margin:0;font-size:.88rem}.ds-chat-topic-list{flex:1;min-height:0;overflow-y:auto;padding:8px 10px 16px;-webkit-overflow-scrolling:touch}.ds-chat-day-group+.ds-chat-day-group{margin-top:12px}.ds-chat-day-label{padding:4px 8px 6px;font-size:.72rem;font-weight:650;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.ds-chat-topic-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.ds-chat-topic-item{width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px;border:none;border-radius:10px;background:transparent;cursor:pointer;text-align:left;font:inherit;color:inherit;touch-action:manipulation}.ds-chat-topic-item:hover{background:#f1f5f9}.ds-chat-topic-item.active{background:var(--primary-soft);color:var(--primary)}.ds-chat-topic-name{width:100%;font-size:.88rem;font-weight:600;line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.ds-chat-topic-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:.72rem;color:var(--muted)}.ds-chat-topic-badge{padding:1px 6px;border-radius:999px;background:#e2e8f0;color:#475569;font-weight:600}.ds-chat-topic-item.active .ds-chat-topic-badge{background:#ffffffa6}.ds-chat-main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.ds-chat-topbar{flex-shrink:0;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--card)}.ds-chat-topbar-left,.ds-chat-topbar-right{display:flex;align-items:center;gap:6px}.ds-chat-topbar-right{position:relative;justify-content:flex-end}.ds-chat-topbar-center{min-width:0;text-align:center;padding:0 4px}.ds-chat-topic-title{margin:0;font-size:.95rem;font-weight:700;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ds-chat-style-label{margin:2px 0 0;font-size:.78rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ds-chat-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:var(--touch);height:var(--touch);padding:0;border:none;border-radius:10px;background:transparent;color:var(--text);cursor:pointer;touch-action:manipulation}.ds-chat-icon-btn:hover{background:#f1f5f9}.ds-chat-status-dot{width:8px;height:8px;border-radius:50%;background:#94a3b8;flex-shrink:0}.ds-chat-status-dot.online{background:#22c55e}.ds-chat-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:60;min-width:220px;padding:6px;border:1px solid var(--border);border-radius:12px;background:var(--card);box-shadow:var(--shadow)}.ds-chat-menu-section{padding-bottom:4px;margin-bottom:4px;border-bottom:1px solid var(--border)}.ds-chat-menu-label{padding:6px 10px 4px;font-size:.72rem;font-weight:650;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}.ds-chat-menu-user{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;text-decoration:none;color:inherit;touch-action:manipulation}.ds-chat-menu-user:hover{background:#f1f5f9}.ds-chat-menu-user-avatar{flex-shrink:0;width:36px;height:36px;border-radius:999px;background:var(--primary-soft);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem}.ds-chat-menu-user-text{min-width:0;display:flex;flex-direction:column;gap:1px}.ds-chat-menu-user-name{font-weight:700;font-size:.92rem;line-height:1.25}.ds-chat-menu-user-sub{font-size:.78rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ds-chat-menu-user-action{font-size:.78rem;color:var(--primary);margin-top:2px}.ds-chat-menu-divider{height:1px;margin:4px 6px;background:var(--border)}.ds-chat-menu-item{display:block;width:100%;padding:10px 12px;border:none;border-radius:8px;background:transparent;text-align:left;font:inherit;font-size:.9rem;color:inherit;cursor:pointer;text-decoration:none;touch-action:manipulation}.ds-chat-menu-item:hover,.ds-chat-menu-item.active{background:#f1f5f9}.ds-chat-body{flex:1;min-height:0;position:relative;display:flex;flex-direction:column;overflow:hidden}.ds-chat-messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:16px 16px 72px;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch}.ds-chat-empty{text-align:center;margin:24px 0}.ds-chat-system-msg{font-style:italic;text-align:center;font-size:.88rem}.ds-chat-bubble{max-width:min(720px,92%)}.ds-chat-scroll-fabs{position:absolute;right:16px;bottom:12px;z-index:5;display:flex;flex-direction:column;gap:8px;pointer-events:none}.ds-chat-scroll-fab{pointer-events:auto;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid var(--border);border-radius:999px;background:var(--card);color:var(--text);box-shadow:0 4px 14px #0f172a1f;cursor:pointer;touch-action:manipulation}.ds-chat-scroll-fab:hover{background:#f8fafc}.ds-chat-composer{flex-shrink:0;padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);background:var(--card)}.ds-chat-composer-error,.ds-chat-voice-banner{margin-bottom:8px}.ds-chat-voice-strip{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px}.ds-chat-input-wrap{display:flex;align-items:flex-end;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:16px;background:var(--surface)}.ds-chat-textarea{flex:1;min-width:0;min-height:24px;max-height:160px;padding:6px 4px;border:none;background:transparent;resize:none;font:inherit;font-size:.95rem;line-height:1.45;color:inherit;outline:none}.ds-chat-mic-btn{flex-shrink:0;width:36px;height:36px;border:none;border-radius:10px;background:#f1f5f9;cursor:pointer;font-size:1rem;touch-action:manipulation}.ds-chat-mic-btn.recording{background:#fee2e2;animation:pulse-rec 1.2s ease-in-out infinite}.ds-chat-send-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:10px;background:var(--primary);color:#fff;cursor:pointer;touch-action:manipulation}.ds-chat-send-btn:disabled{opacity:.45;cursor:not-allowed}.chat-page{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.chat-mobile-head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);background:var(--card)}.chat-mobile-title{margin:0;font-size:1.05rem;font-weight:700}.chat-mobile-sub{margin:2px 0 0;font-size:.82rem}.chat-status-pill{flex-shrink:0;padding:4px 10px;border-radius:999px;font-size:.78rem;font-weight:600;background:#f1f5f9;color:var(--muted)}.chat-status-pill.online{background:#dcfce7;color:#166534}.chat-page .chat-layout{flex:1;min-height:0;gap:0;overflow:hidden}.chat-sidebar{display:none}.chat-panel{display:flex;flex-direction:column;min-height:0;flex:1;overflow:hidden;border-radius:0;box-shadow:none;border:none;border-top:1px solid var(--border);padding:0}.chat-page .chat-messages{flex:1;min-height:0;max-height:none;overflow-y:auto;padding:var(--space-sm) var(--space-md);-webkit-overflow-scrolling:touch}.chat-page .lesson-group-body{max-height:none;overflow:visible}.chat-page .lesson-group-header{flex-wrap:nowrap;gap:6px;padding:10px 12px}.chat-page .lesson-group-title{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.92rem}.chat-page .lesson-group-meta{flex:0 0 auto;padding-left:0;margin-left:auto;font-size:.72rem;white-space:nowrap}.chat-panel-footer{flex-shrink:0;padding:var(--space-sm) var(--space-md) calc(var(--space-sm) + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);background:var(--card)}.chat-panel-footer .error{margin-bottom:var(--space-xs)}.chat-panel-footer .voice-permission-banner,.chat-panel-footer .voice-toolbar{margin-top:0;margin-bottom:var(--space-xs)}.chat-panel-footer .chat-input-row{margin-top:0}@media(min-width:900px){.chat-mobile-head{display:none}body.student-chat-page .container-chat{padding:var(--space-md) 0}.chat-page .chat-layout{gap:var(--space-md);grid-template-columns:240px 1fr;display:grid}.chat-sidebar{display:flex;flex-direction:column;gap:8px;align-self:start;position:sticky;top:0}.chat-sidebar-title{margin:8px 0 0;font-size:1.1rem}.chat-panel{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);min-height:calc(100dvh - 120px);max-height:calc(100dvh - 120px)}}.student-course-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}@media(min-width:640px){.student-course-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.student-course-card{display:block;padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);color:inherit;text-decoration:none;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease;touch-action:manipulation}.student-course-card:hover{border-color:var(--primary);box-shadow:0 6px 20px #0f172a14;transform:translateY(-1px)}.student-course-card:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.student-course-card-title{margin:0 0 6px;font-size:1.05rem;font-weight:700;line-height:1.3}.student-course-card-sub{margin:0 0 14px;font-size:.88rem;color:var(--muted);line-height:1.4}.student-course-card-stats{display:flex;flex-wrap:wrap;gap:10px 20px;margin-bottom:12px}.student-course-stat{display:flex;flex-direction:column;gap:2px}.student-course-stat-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.student-course-stat-value{font-size:1.15rem;font-weight:700;color:var(--text)}.student-course-card-plan{padding-top:10px;border-top:1px solid var(--border)}.student-course-plan-label{font-size:.75rem;font-weight:650;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin-bottom:6px}.student-course-plan-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.student-course-plan-list li{display:flex;flex-wrap:wrap;gap:6px 10px;font-size:.88rem;line-height:1.35}.student-course-plan-date{flex-shrink:0;font-weight:650;color:var(--primary)}.student-course-plan-topic{min-width:0;color:var(--text)}.student-course-card-empty-plan{margin:0;padding-top:10px;border-top:1px solid var(--border);font-size:.84rem}.student-course-pick-grid{display:grid;gap:10px;margin-top:12px}@media(min-width:640px){.student-course-pick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.student-course-pick-item{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);cursor:pointer;text-align:left;font:inherit;color:inherit;touch-action:manipulation}.student-course-pick-item:hover{border-color:var(--primary);background:var(--primary-soft)}.grades-section-title{margin:0 0 12px;font-size:1rem}.grades-subjects-grid{display:grid;gap:10px}@media(min-width:640px){.grades-subjects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:960px){.grades-subjects-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.grades-subject-card{display:flex;flex-direction:column;gap:6px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);text-decoration:none;color:inherit;position:relative;min-height:88px}.grades-subject-card:hover{border-color:var(--primary);background:var(--primary-soft)}.grades-subject-name{font-weight:600;padding-right:48px}.grades-subject-meta{font-size:.84rem}.grades-badge,.grades-day-mark{display:inline-flex;align-items:center;justify-content:center;min-width:2.4rem;padding:4px 10px;border-radius:8px;font-weight:700;font-size:1rem;line-height:1.2}.grades-subject-card .grades-badge{position:absolute;top:12px;right:12px}.grade-tone-high{background:#dcfce7;color:#166534}.grade-tone-mid{background:#fef9c3;color:#854d0e}.grade-tone-low{background:#fee2e2;color:#991b1b}.grade-tone-neutral{background:var(--border);color:inherit}.grades-diary{display:flex;flex-direction:column;gap:16px}.grades-day{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.grades-day-head{padding:10px 14px;background:var(--primary-soft);font-weight:600;text-transform:capitalize}.grades-day-list{list-style:none;margin:0;padding:0}.grades-day-row{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1.6fr) auto;gap:8px 12px;align-items:center;padding:12px 14px;border-top:1px solid var(--border)}.grades-day-subject{font-weight:600}.grades-day-topic{font-size:.88rem}.grades-day-mark{justify-self:end;font-size:1.05rem}@media(max-width:520px){.grades-day-row{grid-template-columns:1fr auto;grid-template-rows:auto auto}.grades-day-topic{grid-column:1 / -1}}.stat-value{font-size:1.6rem;font-weight:700}.stat-link{border:none;background:none;padding:0;margin:0;font:inherit;font-size:inherit;font-weight:inherit;color:var(--primary);cursor:pointer;text-decoration:underline;text-underline-offset:3px}.stat-link:hover{color:#2952c4}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:20px}.modal-card{width:min(720px,100%);max-height:min(80vh,720px);overflow:hidden;display:flex;flex-direction:column;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border)}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-body{overflow-y:auto;padding:16px 20px 20px;display:flex;flex-direction:column;gap:12px}.question-detail-item{border:1px solid var(--border);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.question-detail-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:.8rem;color:var(--muted)}.badge-grade-unanswered{background:#fef3c7;color:#92400e}.badge-grade-wrong{background:#fee2e2;color:#b91c1c}.badge-grade-partial{background:#ffedd5;color:#c2410c}.badge-grade-correct{background:#dcfce7;color:#166534}.tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tab{min-height:var(--touch);padding:0 16px;border-radius:999px;border:1px solid var(--border);background:#fff;cursor:pointer;font:inherit;font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;justify-content:center}.tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.error{color:var(--danger);margin-top:var(--space-xs)}.success{color:var(--success);margin-top:var(--space-xs)}.alert{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:var(--space-md);font-size:.95rem}.alert-body{flex:1}.alert-dismiss{min-width:var(--touch);min-height:var(--touch);margin:calc(var(--space-xs) * -1);border:none;background:transparent;color:inherit;font-size:1.25rem;cursor:pointer}.alert-error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.alert-success{background:#ecfdf5;border-color:#a7f3d0;color:#047857}.alert-info{background:var(--primary-soft);border-color:#bfdbfe;color:#1d4ed8}.page-header{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-sm)}.page-header-compact{padding:0;background:transparent;border:none;box-shadow:none;margin-bottom:var(--space-sm)}.page-header-compact .page-title{font-size:clamp(1.2rem,3.5vw,1.5rem)}.page-header-main{display:flex;flex-direction:column;gap:var(--space-xs)}.page-title{margin:0;font-size:clamp(1.35rem,4vw,1.75rem);font-weight:700;letter-spacing:-.02em;line-height:1.25}.page-subtitle,.page-meta{margin:0;font-size:.95rem}.page-header-actions{display:flex;flex-wrap:wrap;gap:var(--space-xs);align-items:center}@media(min-width:640px){.page-header{flex-direction:row;align-items:flex-start;justify-content:space-between}}.child-nav{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-sm)}.child-nav-back{font-size:.9rem;min-height:var(--touch);display:inline-flex;align-items:center}.child-nav-links{display:flex;gap:var(--space-xs);overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.child-nav-links::-webkit-scrollbar{display:none}.child-nav-link{flex:0 0 auto;min-height:var(--touch);padding:0 var(--space-md);border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;white-space:nowrap}.child-nav-link:hover,.child-nav-link.active{color:var(--primary);border-color:#93b4fd;background:var(--primary-soft)}.stat-card{padding:var(--space-md)}.stat-card-label{font-size:.85rem;margin-bottom:4px}.stat-card-hint{font-size:.8rem;margin-top:6px}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}@media(min-width:640px){.stat-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.password-field-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.password-field-row .input{flex:1 1 180px;min-width:0}.password-toggle{flex:0 0 auto;padding:8px 12px;font-size:.85rem}.course-plan-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px}.course-plan-head-main{flex:1 1 220px;min-width:0}.course-plan-head-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.course-table{display:flex;flex-direction:column;gap:4px}.course-row{display:grid;grid-template-columns:1fr 72px 130px 72px;gap:10px;align-items:center;padding:10px 12px;border-radius:10px;border:1px solid var(--border);font-size:.92rem}.course-head{background:#f8fafc;font-weight:600;color:var(--muted);border-style:dashed}.course-row-completed{background:#f0fdf4;border-color:#bbf7d0}.course-row-planned{background:var(--primary-soft)}.course-row-lab{opacity:.92}.course-topic{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-completed{background:#dcfce7;color:#166534}.badge-planned{background:#dbeafe;color:#1d4ed8}.badge-upcoming{background:#f1f5f9;color:var(--muted)}.badge-repeat{background:#fef3c7;color:#92400e}.badge-lab{background:#ede9fe;color:#5b21b6}.course-repeat-item{display:flex;flex-wrap:wrap;gap:8px;align-items:baseline;padding:10px 0;border-bottom:1px solid var(--border)}.course-repeat-item:last-child{border-bottom:none}@media(max-width:720px){.course-row{grid-template-columns:1fr;gap:4px}.course-head{display:none}}.admin-shell{display:block;min-height:calc(100dvh - 80px);padding:var(--space-md) 0}.admin-topbar{width:var(--container);margin:0 auto var(--space-md);display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.admin-sidebar{position:fixed;top:0;left:0;width:min(280px,88vw);height:100dvh;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);z-index:120;transform:translate(-105%);transition:transform .2s ease;border-radius:0;overflow-y:auto}.admin-sidebar.open{transform:translate(0)}.admin-sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#2a313859;z-index:115;border:none;padding:0}.admin-sidebar-overlay.open{display:block}.admin-main{width:var(--container);margin:0 auto}@media(min-width:960px){.admin-shell{display:grid;grid-template-columns:240px 1fr;gap:var(--space-lg);width:min(1280px,100% - 32px);margin:0 auto;padding:var(--space-lg) 0}.admin-topbar{display:none}.admin-sidebar{position:sticky;top:var(--space-md);height:auto;max-height:calc(100dvh - 48px);transform:none;border-radius:var(--radius)}.admin-sidebar-overlay{display:none!important}.admin-main{width:auto;margin:0}}.admin-brand{font-weight:800;font-size:1.1rem;color:var(--primary)}.admin-nav{display:flex;flex-direction:column;gap:4px}.admin-nav-link{padding:0 var(--space-sm);min-height:var(--touch);border-radius:var(--radius-sm);color:inherit;text-decoration:none;display:flex;align-items:center}.admin-nav-link:hover{background:var(--primary-soft)}.admin-nav-link.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.admin-sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid var(--border)}.admin-main h1{margin-top:0}.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px}.admin-stat{padding:16px}.admin-stat-value{font-size:1.5rem;font-weight:800}.admin-stat-label{font-size:.85rem;color:var(--muted);margin-top:4px}.admin-stat-hint{font-size:.75rem;margin-top:4px}.admin-table-wrap{overflow-x:auto;padding:12px}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th,.admin-table td{padding:10px 8px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}.admin-table th{font-size:.8rem;color:var(--muted);font-weight:600}.admin-subrow td{background:#f8fafc;font-size:.85rem}.admin-actions{white-space:nowrap}.admin-form-row{padding:16px}.admin-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin:12px 0}.btn-link{border:none;background:none;padding:0;font:inherit;color:var(--primary);cursor:pointer;text-align:left}.btn.small,.btn.ghost.small{padding:4px 8px;font-size:.8rem;min-height:auto}.badge.danger{background:#fef2f2;color:#b91c1c}.badge.ok{background:#ecfdf5;color:#047857}.badge.muted{background:#f1f5f9;color:#64748b}.admin-table .pos{color:#047857;font-weight:600}.admin-table .neg{color:#b91c1c;font-weight:600}.admin-details code{font-size:.75rem;word-break:break-all}.admin-quick-links ul{margin:0;padding-left:20px}.chat-history-view{display:flex;flex-direction:column;gap:12px;min-width:0}.chat-history-layout{margin-top:0;min-width:0}.chat-history-mobile-tabs{display:none}.chat-history-tab{flex:1;min-height:var(--touch);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);font:inherit;font-weight:600;color:var(--text);cursor:pointer;touch-action:manipulation}.chat-history-tab.active{background:var(--primary-soft);border-color:#93b4fd;color:var(--primary)}.chat-history-tab:disabled{opacity:.45;cursor:not-allowed}.chat-history-filters{padding:0;overflow:hidden}.chat-history-filters-toggle{display:none;width:100%;min-height:var(--touch);padding:12px var(--space-md);border:none;background:var(--card);font:inherit;font-weight:600;text-align:left;cursor:pointer;color:inherit;touch-action:manipulation}.chat-history-filters-chevron{float:right;color:var(--muted)}.chat-history-filters-body{padding:var(--space-md)}.chat-history-filter-grid{margin:0}.chat-history-filter-wide{grid-column:1 / -1}.chat-history-filter-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.chat-history-pane-title{margin:0 0 8px;font-size:1rem}.chat-history-sessions{display:flex;flex-direction:column;min-width:0}.chat-history-session-list{display:flex;flex-direction:column;gap:8px;margin-top:8px;min-width:0}.chat-history-session-item{width:100%;text-align:left;border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-sm);min-height:var(--touch);background:#fff;cursor:pointer;font:inherit;color:inherit;touch-action:manipulation}.chat-history-session-item:hover,.chat-history-session-item.active{border-color:var(--primary);background:var(--primary-soft)}.chat-history-session-title{font-weight:600;font-size:.92rem;word-break:break-word}.chat-history-session-meta{font-size:.8rem;color:var(--muted);margin-top:4px}.chat-history-session-preview{font-size:.82rem;color:var(--muted);margin-top:6px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.chat-history-messages{display:flex;flex-direction:column;min-width:0;min-height:0}.chat-history-empty{margin:0;padding:8px 0}.chat-history-back-mobile{display:none;align-self:flex-start}.chat-history-toolbar{display:flex;flex-direction:column;gap:10px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.chat-history-toolbar-main{display:flex;flex-direction:column;gap:4px;min-width:0}.chat-history-session-heading{word-break:break-word}.chat-history-session-sub{font-size:.88rem;word-break:break-word}.chat-history-nav{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.chat-history-nav-pos{font-size:.85rem;padding:0 4px}.chat-history-thread{flex:1;min-height:0;max-height:min(62vh,720px);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.chat-history-message{min-width:0}.chat-history-thread .msg{max-width:min(92%,640px);overflow-wrap:anywhere;word-break:break-word}.chat-history-time{font-size:.75rem;margin-bottom:4px}.msg.assistant_tools{align-self:flex-start;background:#f8fafc;border:1px dashed var(--border);color:var(--muted);font-size:.9rem;font-style:italic}.admin-filters{padding:12px;margin-bottom:8px}.chat-history-filters.admin-filters{padding:0}.admin-groups .admin-group{margin-bottom:8px;padding:8px 12px}.admin-groups summary{cursor:pointer;font-weight:600;padding:6px 0}@media(max-width:899px){.chat-history-layout{grid-template-columns:1fr!important;gap:12px}.chat-history-mobile-tabs{display:flex;gap:8px}.chat-history-pane-hidden-mobile{display:none!important}.chat-history-pane-title{display:none}.chat-history-filters-toggle{display:block}.chat-history-filters-body{display:none;padding-top:0}.chat-history-filters-body.open{display:block}.chat-history-filter-grid{grid-template-columns:1fr}.chat-history-filter-actions .btn{flex:1 1 calc(50% - 4px);min-width:0}.chat-history-sessions:not(.chat-history-pane-hidden-mobile){max-height:none}.chat-history-messages:not(.chat-history-pane-hidden-mobile){min-height:calc(100dvh - 220px)}.chat-history-back-mobile{display:inline-flex}.chat-history-thread{max-height:calc(100dvh - 320px);min-height:240px}.chat-history-nav{width:100%}.chat-history-nav .btn.ghost{flex:1 1 auto;min-width:0;padding-left:8px;padding-right:8px;font-size:.85rem}}@media(min-width:900px){.chat-history-layout{align-items:stretch}.chat-history-filters-body{display:block!important}.chat-history-toolbar{flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:flex-start}.chat-history-toolbar-main{flex:1 1 220px}.chat-history-nav{flex:1 1 280px;justify-content:flex-end}.chat-history-sessions{position:sticky;top:calc(var(--space-md) + 56px);max-height:calc(100dvh - 120px);overflow-y:auto}.chat-history-messages{min-height:420px}}@media(max-width:480px){.chat-history-filter-actions .btn{flex:1 1 100%}.chat-history-thread .msg{max-width:100%}}.mod-stats-filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-top:12px}.mod-stats-filters label{display:flex;flex-direction:column;gap:4px;min-width:140px}.mod-chart{display:flex;flex-direction:column;gap:12px}.mod-chart-bars{display:flex;align-items:flex-end;gap:4px;overflow-x:auto;padding-bottom:4px;min-height:120px}.mod-chart-col{flex:1 1 12px;min-width:18px;max-width:36px;display:flex;flex-direction:column;align-items:center;gap:6px}.mod-chart-stack{width:100%;display:flex;flex-direction:column-reverse;justify-content:flex-start;border-radius:4px 4px 0 0;overflow:hidden;background:#f1f5f9;min-height:2px}.mod-chart-seg{width:100%;min-height:2px}.mod-chart-label{font-size:.65rem;color:var(--muted);writing-mode:horizontal-tb;text-align:center}.mod-chart-legend{display:flex;flex-wrap:wrap;gap:12px;font-size:.85rem;color:var(--muted)}.mod-chart-legend-item{display:inline-flex;align-items:center;gap:6px}.mod-chart-dot{width:10px;height:10px;border-radius:2px;display:inline-block}.billing-rules{background:var(--primary-soft, #eff6ff)}.billing-section-title{margin:0 0 6px;font-size:1.05rem}.billing-section-hint{margin:0 0 var(--space-md);font-size:.9rem}.billing-balance-card{display:flex;flex-direction:column;gap:var(--space-md)}.billing-balance-head{padding-bottom:var(--space-md);border-bottom:1px solid var(--border)}.billing-balance-label{display:block;font-size:.9rem;color:var(--muted);margin-bottom:4px}.billing-balance-amount{font-size:clamp(1.75rem,6vw,2.25rem);font-weight:700;letter-spacing:-.02em;line-height:1.15}.billing-topup{display:flex;flex-direction:column;gap:var(--space-sm)}.billing-preset-row{display:flex;flex-wrap:wrap;gap:8px}.billing-preset{flex:1 1 calc(50% - 4px);min-height:var(--touch);padding:0 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);font:inherit;font-weight:600;font-size:.95rem;color:var(--text);cursor:pointer}@media(min-width:480px){.billing-preset{flex:1 1 auto}}.billing-preset.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}.billing-amount-input-wrap{position:relative}.billing-amount-input{padding-right:36px}.billing-amount-suffix{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:600;pointer-events:none}.billing-topup-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.billing-topup-actions .btn{width:100%}.billing-children-list{display:flex;flex-direction:column;gap:10px}.billing-child-row{padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.billing-child-foot{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;font-size:.9rem}.billing-child-select{max-width:320px;margin-bottom:var(--space-md)}.product-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md);align-items:stretch}@media(min-width:560px){.product-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.product-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}.product-card{display:flex;flex-direction:column;min-height:100%;padding:var(--space-md);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.product-card-body{flex:1 1 auto}.product-card-title{margin:0 0 8px;font-size:1.05rem}.product-card-desc{margin:0;font-size:.9rem;line-height:1.45}.product-card-price-block{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border)}.product-card-discount{margin:0 0 8px;font-size:.85rem}.product-card-price{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 8px;margin-bottom:12px}.product-card-price-old{text-decoration:line-through;font-size:.95rem}.product-card-price-main{font-size:1.35rem;font-weight:700}.product-card-price-period{font-size:.9rem}.product-card-btn{width:100%}.page-title-inline{margin:0 0 var(--space-sm);font-size:clamp(1.2rem,3.5vw,1.5rem);font-weight:700}.collapsible-section{padding:0;overflow:hidden}.collapsible-section-toggle{width:100%;display:flex;flex-wrap:wrap;align-items:center;gap:8px;min-height:var(--touch);padding:var(--space-md);border:none;background:transparent;font:inherit;text-align:left;cursor:pointer;color:inherit}.collapsible-section-chevron{flex:0 0 auto;color:var(--muted);font-size:.85rem}.collapsible-section-title{flex:1 1 auto;font-weight:700;font-size:1.05rem}.collapsible-section-hint{flex:1 1 100%;padding-left:1.25rem;font-size:.85rem}.collapsible-section-body{padding:0 var(--space-md) var(--space-md);border-top:1px solid var(--border)}.collapsible-pre{margin:var(--space-md) 0 0;white-space:pre-wrap;font-family:inherit;font-size:.9rem;line-height:1.45}@media(max-width:640px){.page-header-actions{width:100%;flex-direction:column;align-items:stretch}.page-header-actions .select,.page-header-actions .btn{width:100%}}
