@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-root: #07070f;--bg-surface: #0d0d1a;--bg-card: rgba(16, 16, 28, .85);--bg-sidebar: #090914;--bg-input: rgba(12, 12, 22, .9);--accent: #7c3aed;--accent-2: #6366f1;--accent-light: #a78bfa;--accent-gradient: linear-gradient(135deg, #7c3aed 0%, #4f46e5 100%);--accent-glow: 0 0 24px rgba(124, 58, 237, .35);--accent-glow-sm: 0 0 12px rgba(124, 58, 237, .25);--text-primary: #f1f0ff;--text-secondary: #94a3b8;--text-muted: #475569;--text-accent: #a78bfa;--border: rgba(99, 102, 241, .12);--border-hover: rgba(124, 58, 237, .35);--border-focus: rgba(124, 58, 237, .6);--success: #10b981;--success-bg: rgba(16, 185, 129, .1);--error: #f43f5e;--error-bg: rgba(244, 63, 94, .1);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--info: #38bdf8;--info-bg: rgba(56, 189, 248, .1);--sidebar-w: 280px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 4px 20px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-root);color:var(--text-primary);line-height:1.6;min-height:100vh}a{color:var(--accent-light);text-decoration:none;transition:color .15s}a:hover{color:var(--text-primary)}button{cursor:pointer;font-family:inherit}input,textarea{font-family:inherit}::selection{background:#7c3aed4d;color:var(--text-primary)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#7c3aed4d;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#7c3aed80}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes pulse-ring{0%{box-shadow:0 0 #7c3aed66}70%{box-shadow:0 0 0 8px #7c3aed00}to{box-shadow:0 0 #7c3aed00}}.auth-root{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--bg-root)}@media (max-width: 768px){.auth-root{grid-template-columns:1fr}.auth-hero{display:none}}.auth-hero{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;overflow:hidden;background:radial-gradient(ellipse at 30% 50%,rgba(124,58,237,.18) 0%,transparent 60%),radial-gradient(ellipse at 70% 20%,rgba(99,102,241,.12) 0%,transparent 60%),var(--bg-surface);border-right:1px solid var(--border)}.auth-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,rgba(124,58,237,.08) 1px,transparent 0);background-size:40px 40px}.auth-hero-content{position:relative;z-index:1;max-width:380px;text-align:center}.auth-hero-logo{width:72px;height:72px;margin:0 auto 1.5rem;background:var(--accent-gradient);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:var(--accent-glow);animation:pulse-ring 2.5s infinite}.auth-hero h1{font-size:2.2rem;font-weight:800;background:linear-gradient(135deg,#fff 0%,var(--accent-light) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.75rem;letter-spacing:-.03em}.auth-hero p{color:var(--text-secondary);font-size:1rem;line-height:1.7}.auth-hero-features{margin-top:2rem;display:flex;flex-direction:column;gap:.75rem;text-align:left}.auth-hero-feature{display:flex;align-items:center;gap:.625rem;background:#7c3aed0f;border:1px solid var(--border);border-radius:var(--radius);padding:.625rem .875rem;font-size:.875rem;color:var(--text-secondary)}.auth-form-panel{display:flex;align-items:center;justify-content:center;padding:3rem 2rem}.auth-form-card{width:100%;max-width:420px;animation:fadeIn .4s ease}.auth-form-card h2{font-size:1.6rem;font-weight:700;color:var(--text-primary);margin-bottom:.375rem;letter-spacing:-.01em}.auth-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:2rem}.auth-footer{margin-top:1.5rem;text-align:center;color:var(--text-muted);font-size:.875rem}.auth-footer a{color:var(--accent-light);font-weight:500}.dashboard-root{display:flex;height:100vh;overflow:hidden;background:var(--bg-root)}.sidebar{width:var(--sidebar-w);flex-shrink:0;display:flex;flex-direction:column;height:100%;background:var(--bg-sidebar);border-right:1px solid var(--border);position:relative}.sidebar:after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(to bottom,transparent,rgba(124,58,237,.4) 30%,rgba(124,58,237,.4) 70%,transparent);pointer-events:none}.sidebar-header{padding:1.25rem 1rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:.625rem;margin-bottom:.875rem}.sidebar-brand-icon{width:34px;height:34px;background:var(--accent-gradient);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;box-shadow:var(--accent-glow-sm)}.sidebar-brand-name{font-size:1.05rem;font-weight:700;background:linear-gradient(90deg,#fff,var(--accent-light));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.01em}.sidebar-add-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;background:var(--accent-gradient);border:none;border-radius:var(--radius);color:#fff;font-size:.875rem;font-weight:600;transition:all .2s;box-shadow:var(--accent-glow-sm)}.sidebar-add-btn:hover{transform:translateY(-1px);box-shadow:var(--accent-glow)}.sidebar-add-btn:active{transform:translateY(0)}.sidebar-section-label{padding:.875rem 1rem .375rem;font-size:.68rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--text-muted);flex-shrink:0}.sidebar-list{flex:1;overflow-y:auto;padding:0 .5rem .5rem}.sidebar-empty{padding:2rem 1rem;text-align:center;color:var(--text-muted);font-size:.875rem;line-height:1.6}.sidebar-empty-icon{font-size:2rem;margin-bottom:.5rem;opacity:.35;display:block}.sidebar-item{position:relative;display:flex;align-items:center;gap:.625rem;padding:.625rem .75rem;border-radius:var(--radius);cursor:pointer;transition:all .18s;margin-bottom:2px;border:1px solid transparent;animation:slideInLeft .25s ease both}.sidebar-item:hover{background:#7c3aed14;border-color:var(--border-hover)}.sidebar-item.active{background:#7c3aed24;border-color:#7c3aed4d}.sidebar-item-icon{width:32px;height:32px;border-radius:8px;background:#7c3aed1f;display:flex;align-items:center;justify-content:center;font-size:.875rem;flex-shrink:0;transition:all .18s}.sidebar-item.active .sidebar-item-icon{background:#7c3aed47}.sidebar-item-info{flex:1;min-width:0}.sidebar-item-title{font-size:.85rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sidebar-item-stage{font-size:.7rem;color:var(--text-muted);margin-top:1px}.sidebar-item-delete{opacity:0;background:transparent;border:none;color:var(--text-muted);padding:4px;border-radius:6px;transition:all .15s;display:flex;align-items:center;flex-shrink:0;font-size:.8rem}.sidebar-item:hover .sidebar-item-delete{opacity:1}.sidebar-item-delete:hover{color:var(--error);background:var(--error-bg)}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border);flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:.625rem;padding:.5rem .625rem;border-radius:var(--radius);transition:background .18s;width:100%;background:transparent;border:none}.sidebar-user:hover{background:#ffffff0a}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;color:#fff}.sidebar-user-info{flex:1;min-width:0;text-align:left}.sidebar-user-email{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-label{font-size:.65rem;color:var(--text-muted)}.sidebar-signout-icon{font-size:.75rem;color:var(--text-muted);flex-shrink:0;transition:color .15s}.sidebar-user:hover .sidebar-signout-icon{color:var(--error)}.main-content{flex:1;overflow-y:auto;padding:2rem;background:radial-gradient(ellipse at 60% 0%,rgba(124,58,237,.06) 0%,transparent 50%),var(--bg-root)}.dashboard-welcome{max-width:560px;margin:5rem auto;text-align:center;animation:fadeIn .4s ease}.dashboard-welcome-icon{font-size:3.5rem;margin-bottom:1rem}.dashboard-welcome h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem;letter-spacing:-.02em}.dashboard-welcome p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.975rem}.learning-detail{max-width:1320px;margin:0 auto;animation:fadeIn .3s ease}.learning-detail-header{margin-bottom:2rem}.learning-detail-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.625rem}.learning-detail-title{font-size:1.6rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.learning-detail-description{color:var(--text-secondary);font-size:.925rem}.learning-detail-date{font-size:.8rem;color:var(--text-muted);margin-top:.5rem}.detail-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.25rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color .2s}.detail-section:hover{border-color:var(--border-hover)}.detail-section-title{font-size:.75rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.pdf-link{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--info-bg);border:1px solid rgba(56,189,248,.25);border-radius:var(--radius);color:var(--info);font-size:.875rem;font-weight:500;transition:all .2s}.pdf-link:hover{background:#38bdf82e;border-color:#38bdf873;color:var(--info);transform:translateY(-1px)}.study-plan-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.9fr);gap:1.25rem}.study-plan-column{min-width:0}.study-plan-empty-state{display:flex;align-items:center;justify-content:space-between;gap:.875rem;padding:1rem;border-radius:var(--radius);background:#ffffff08;color:var(--text-secondary)}.study-plan-empty-state-rich,.study-plan-generating-state{display:grid;gap:1.1rem;padding:1.25rem;border-radius:var(--radius-lg);background:radial-gradient(circle at top,rgba(124,58,237,.14),transparent 45%),#ffffff08;border:1px solid rgba(255,255,255,.08)}.study-plan-empty-copy,.study-plan-generating-copy{display:grid;gap:.45rem}.study-plan-empty-copy h3,.study-plan-generating-copy h3{margin:0;color:var(--text-primary);font-size:1.15rem}.study-plan-empty-copy p,.study-plan-generating-copy p{margin:0;color:var(--text-secondary);line-height:1.6}.study-plan-empty-kicker,.study-plan-generating-badge{display:inline-flex;align-items:center;gap:.45rem;width:fit-content;padding:.35rem .75rem;border-radius:999px;background:#7c3aed24;border:1px solid rgba(124,58,237,.24);color:var(--text-secondary);font-size:.78rem}.study-plan-empty-controls{display:grid;gap:.75rem}.study-plan-empty-field{display:grid;gap:.45rem}.study-plan-empty-field span{font-size:.8rem;color:var(--text-muted)}.study-plan-generating-state{grid-template-columns:minmax(0,1.2fr) minmax(240px,.8fr);align-items:center}.study-plan-generating-visual{position:relative;width:220px;height:220px;margin:0 auto}.study-plan-orbit,.study-plan-core{position:absolute;top:50%;right:50%;bottom:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%}.study-plan-orbit{border:1px solid rgba(255,255,255,.1);animation:studyPlanPulse 2.8s ease-in-out infinite}.study-plan-orbit-outer{width:220px;height:220px}.study-plan-orbit-middle{width:160px;height:160px;animation-delay:.2s}.study-plan-orbit-inner{width:104px;height:104px;animation-delay:.4s}.study-plan-core{width:68px;height:68px;background:var(--accent-gradient);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--accent-glow);animation:studyPlanFloat 1.8s ease-in-out infinite}.study-plan-generating-steps{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem}.study-plan-generating-step{min-height:72px;padding:.95rem 1rem;border-radius:var(--radius);background:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:var(--text-secondary);display:flex;align-items:center;line-height:1.5}.study-plan-summary-card,.study-chat-card,.study-plan-topic-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg)}.study-plan-summary-card{padding:1.15rem 1.2rem;margin-bottom:1rem}.study-plan-summary-head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.study-plan-summary-card h3{margin:.35rem 0 .5rem;font-size:1.1rem;color:var(--text-primary)}.study-plan-summary-card p{margin:0;color:var(--text-secondary);font-size:.92rem;line-height:1.5}.study-plan-summary-topline,.study-chat-helper{font-size:.78rem;color:var(--text-muted)}.study-plan-summary-topline{display:flex;justify-content:space-between;gap:1rem;margin-bottom:.25rem}.study-plan-difficulty-row{display:flex;align-items:center;gap:.6rem;margin:.35rem 0 .15rem}.select-shell{position:relative;display:inline-flex;align-items:center}.select-shell-icon{position:absolute;right:.9rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color .18s ease,transform .18s ease}.select-shell:hover .select-shell-icon,.select-shell:focus-within .select-shell-icon{color:var(--text-primary)}.select-shell:focus-within .select-shell-icon{transform:translateY(-50%) scale(1.05)}.study-plan-difficulty-shell{width:fit-content}.study-plan-difficulty-select{width:auto;min-width:190px;padding:.78rem 2.75rem .78rem 1rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;border-radius:14px;background:linear-gradient(180deg,#ffffff0f,#ffffff05),#0c0c16eb;border-color:#7c3aed38;box-shadow:inset 0 1px #ffffff0d,0 8px 24px #0206172e;cursor:pointer;font-weight:600;letter-spacing:.01em}.study-plan-difficulty-select:hover:not(:disabled){border-color:#7c3aed61;background:linear-gradient(180deg,#ffffff14,#ffffff08),#0e0e1cf5;transform:translateY(-1px)}.study-plan-difficulty-select:focus{border-color:#7c3aed8c;box-shadow:inset 0 1px #ffffff0d,0 0 0 4px #7c3aed24,0 12px 28px #02061738}.study-plan-difficulty-select:disabled{cursor:not-allowed;opacity:.7}.study-plan-difficulty-select option{background:#121222;color:var(--text-primary)}.study-plan-difficulty-helper{margin:0 0 .5rem!important;font-size:.8rem!important;color:var(--text-muted)!important}.study-plan-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-top:1rem}.study-plan-stat{padding:.8rem .9rem;border-radius:var(--radius);background:#ffffff0a;border:1px solid rgba(255,255,255,.08);display:grid;gap:.15rem}.study-plan-stat-value{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.study-plan-stat-label{font-size:.76rem;color:var(--text-muted)}.study-plan-rationale{margin-top:.75rem!important;color:var(--text-muted)!important}.study-plan-topics{display:grid;gap:.9rem}.study-plan-topic-card{padding:.95rem 1rem}.study-plan-topic-header{display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start}.study-plan-checkbox-row{display:flex;gap:.85rem;align-items:flex-start;color:var(--text-secondary);flex:1}.study-plan-checkbox-row input{margin-top:.2rem}.study-plan-checkbox-row.subtopic{margin-top:.6rem;margin-left:1.25rem;padding-left:.75rem;border-left:1px solid rgba(255,255,255,.08)}.study-plan-subtopics{display:grid;gap:.1rem;margin-top:.35rem}.study-plan-topic-title,.study-plan-subtopic-title{font-weight:600;color:var(--text-primary)}.study-plan-toggle{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .18s,border-color .18s,color .18s,transform .18s}.study-plan-toggle:hover{background:#ffffff14;border-color:var(--border-hover);color:var(--text-primary);transform:translateY(-1px)}.study-plan-topic-description,.study-plan-subtopic-description{margin-top:.2rem;font-size:.86rem;line-height:1.45}.study-plan-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem;justify-content:flex-end}.study-plan-actions-top{margin-top:0;flex-shrink:0}.study-chat-card{display:flex;flex-direction:column;min-height:560px;position:sticky;top:1.5rem}.study-chat-header{display:grid;gap:.35rem;padding:1rem 1rem .5rem}.study-chat-title{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-primary)}.study-chat-messages{flex:1;overflow-y:auto;padding:.5rem 1rem 0;display:grid;gap:.75rem}.study-chat-empty,.study-chat-message{border-radius:var(--radius);padding:.85rem .95rem}.study-chat-empty{background:#ffffff08;color:var(--text-muted);display:flex;gap:.6rem;align-items:center}.study-chat-message-user{background:#7c3aed24;border:1px solid rgba(124,58,237,.24)}.study-chat-message-assistant{background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.study-chat-role{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.3rem}.study-chat-content{color:var(--text-secondary);white-space:pre-wrap;line-height:1.55}.study-chat-composer{border-top:1px solid rgba(255,255,255,.08);padding:1rem}.study-chat-textarea{min-height:110px}.study-chat-composer-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:.75rem;flex-wrap:wrap}.study-chat-error{font-size:.8rem;color:var(--error)}.lesson-layout,.lesson-summary-layout{display:block}.lesson-main,.lesson-side{min-width:0}.lesson-coach-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#02061794;opacity:0;pointer-events:none;transition:opacity .22s ease;z-index:30}.lesson-coach-overlay-open{opacity:1;pointer-events:auto}.lesson-coach-drawer{position:fixed;top:0;right:0;bottom:0;width:clamp(380px,50vw,760px);max-width:94vw;transform:translate(100%);transition:transform .24s ease;z-index:31;padding:0;overflow:hidden;overscroll-behavior:contain;will-change:transform;display:flex;flex-direction:column}.lesson-coach-drawer-open{transform:translate(0)}.lesson-chat-card-drawer{height:100%;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box;border-radius:0;border-left:1px solid rgba(255,255,255,.08);border-right:none;background:linear-gradient(180deg,#121222fa,#080c18fa),#0b1020;box-shadow:-24px 0 56px #02061761;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.lesson-chat-card-drawer .study-chat-header{flex-shrink:0}.lesson-chat-card-drawer .study-chat-messages{flex:1 1 auto;min-height:0}.lesson-chat-card-drawer .study-chat-composer{flex-shrink:0;box-sizing:border-box;padding:.9rem 1rem calc(1rem + env(safe-area-inset-bottom,0px));background:linear-gradient(180deg,#121222f5,#080c18fa),#0b1020}.lesson-chat-card-drawer .study-chat-textarea{min-height:84px;max-height:22vh}.lesson-chat-card-drawer .study-chat-composer-footer{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end}.lesson-chat-card-drawer .study-chat-composer-footer>:first-child{min-width:0}.lesson-chat-drawer-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem}.lesson-drawer-close{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .18s,border-color .18s,color .18s}.lesson-drawer-close:hover{background:#ffffff14;border-color:var(--border-hover);color:var(--text-primary)}.lesson-header-card,.lesson-question-card,.lesson-complete-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg)}.lesson-header-card{padding:1.1rem 1.2rem;display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:1rem}.lesson-header-card h3,.lesson-question-card h3,.lesson-complete-card h4{margin:.35rem 0 .5rem;color:var(--text-primary)}.lesson-header-card p,.lesson-complete-card p{margin:0;color:var(--text-secondary);line-height:1.5}.lesson-complete-card{padding:1rem 1.1rem;display:flex;gap:.85rem;align-items:flex-start}.lesson-question-card{padding:1.1rem 1.2rem}.lesson-question-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:1rem}.lesson-question-kicker{font-size:.76rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.lesson-progress-chip{flex-shrink:0;padding:.35rem .7rem;border-radius:999px;background:#7c3aed1f;border:1px solid rgba(124,58,237,.2);color:var(--text-secondary);font-size:.78rem}.lesson-progress-group{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.lesson-weight-chip{flex-shrink:0;padding:.35rem .7rem;border-radius:999px;background:#38bdf81f;border:1px solid rgba(56,189,248,.2);color:var(--text-secondary);font-size:.78rem}.lesson-image-panel{margin-bottom:1rem;border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.lesson-image{width:100%;max-height:360px;object-fit:contain;background:#0b1020}.lesson-image-caption{display:flex;align-items:center;gap:.45rem;padding:.7rem .85rem;font-size:.8rem;color:var(--text-muted)}.lesson-question-prompt{margin:0 0 1rem;color:var(--text-primary);font-size:1.02rem;line-height:1.6}.lesson-choices{display:grid;gap:.75rem}.lesson-choice{display:flex;gap:.8rem;align-items:flex-start;padding:.9rem 1rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--text-secondary);transition:border-color .18s,background .18s,transform .18s}.lesson-choice:hover{border-color:var(--border-hover);transform:translateY(-1px)}.lesson-choice input{margin-top:.25rem}.lesson-choice-selected{border-color:#7c3aed59;background:#7c3aed1f}.lesson-choice-correct{border-color:#22c55e59;background:#22c55e24}.lesson-choice-incorrect{border-color:#ef444459;background:#ef44441f}.lesson-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.lesson-feedback{margin-top:1rem;padding:.95rem 1rem;border-radius:var(--radius);line-height:1.6}.lesson-feedback-correct{background:#22c55e1f;border:1px solid rgba(34,197,94,.2);color:var(--text-secondary)}.lesson-feedback-incorrect{background:#ef44441a;border:1px solid rgba(239,68,68,.18);color:var(--text-secondary)}.lesson-explanation-image{width:100%;max-height:280px;object-fit:contain;margin-top:.9rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.08);background:#0b1020}.lesson-next-row{margin-top:.9rem}.lesson-chat-card{min-height:620px}.lesson-generating-state{display:grid;gap:1rem}.lesson-generating-header{display:grid;gap:.45rem}.lesson-generating-badge{display:inline-flex;align-items:center;gap:.45rem;width:fit-content;padding:.35rem .7rem;border-radius:999px;background:#7c3aed24;border:1px solid rgba(124,58,237,.24);color:var(--text-secondary);font-size:.78rem}.lesson-generating-copy{color:var(--text-secondary);line-height:1.5}.lesson-generating-preview{display:grid;gap:.85rem}.lesson-generating-card{height:84px;border-radius:var(--radius-lg);background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.shimmer{position:relative;overflow:hidden}.shimmer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%);animation:shimmerMove 1.5s infinite}.lesson-summary-stack{display:grid;gap:1rem;margin-top:1rem}.lesson-summary-grid,.lesson-chart-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem}.lesson-chart-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.lesson-summary-card,.lesson-chart-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg)}.lesson-summary-card{padding:1rem}.lesson-summary-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.lesson-summary-label{margin-top:.2rem;font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.lesson-summary-label-with-info{display:inline-flex;align-items:center;gap:.35rem}.lesson-metric-info{position:relative;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;color:var(--text-muted);background:#ffffff0d;border:1px solid rgba(255,255,255,.08);cursor:help;padding:0;transition:color .18s ease,border-color .18s ease,background .18s ease}.lesson-metric-info:hover,.lesson-metric-info:focus-visible{color:var(--text-primary);border-color:#7c3aed59;background:#7c3aed24;outline:none}.lesson-metric-tooltip{position:absolute;left:50%;bottom:calc(100% + .55rem);transform:translate(-50%) translateY(6px);width:min(220px,50vw);padding:.55rem .65rem;border-radius:10px;background:#0f172afa;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);font-size:.74rem;line-height:1.45;text-transform:none;letter-spacing:normal;white-space:normal;box-shadow:0 14px 30px #02061752;opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease;z-index:5}.lesson-metric-tooltip:after{content:"";position:absolute;left:50%;top:100%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:rgba(15,23,42,.98) transparent transparent transparent}.lesson-metric-info:hover .lesson-metric-tooltip,.lesson-metric-info:focus-visible .lesson-metric-tooltip{opacity:1;transform:translate(-50%) translateY(0)}.lesson-chart-card{padding:1rem}.lesson-chart-card h4{margin:0 0 .85rem;color:var(--text-primary)}.lesson-radar-list,.lesson-stacked-list,.lesson-metric-list{display:grid;gap:.7rem}.lesson-radar-card{display:grid;gap:1rem;position:relative}.lesson-radar-svg{width:100%;max-width:280px;margin:0 auto;display:block}.lesson-radar-grid{fill:#ffffff05;stroke:#ffffff1f;stroke-width:1}.lesson-radar-axis{stroke:#ffffff1f;stroke-width:1}.lesson-radar-shape{fill:#7c3aed38;stroke:#7c3aede6;stroke-width:2}.lesson-radar-point{fill:#8b5cf6}.lesson-radar-point-active{fill:#c084fc}.lesson-radar-hit-area{fill:transparent;cursor:pointer}.lesson-radar-chart-tooltip{position:absolute;transform:translate(-50%,calc(-100% - 14px));min-width:170px;max-width:220px;padding:.65rem .75rem;border-radius:12px;background:#0f172afa;border:1px solid rgba(255,255,255,.1);box-shadow:0 14px 30px #02061757;display:grid;gap:.2rem;color:var(--text-secondary);font-size:.76rem;line-height:1.45;pointer-events:none;z-index:4}.lesson-radar-chart-tooltip strong{color:var(--text-primary);font-size:.82rem}.lesson-radar-legend{display:grid;gap:.55rem}.lesson-radar-legend-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:.55rem;align-items:center;font-size:.82rem;color:var(--text-secondary);width:100%;padding:.6rem .7rem;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);background:#ffffff08;text-align:left;cursor:pointer;transition:border-color .18s ease,background .18s ease,color .18s ease}.lesson-radar-legend-item:hover,.lesson-radar-legend-item:focus-visible,.lesson-radar-legend-item-active{border-color:#7c3aed59;background:#7c3aed1a;color:var(--text-primary);outline:none}.lesson-radar-dot{width:10px;height:10px;border-radius:50%;background:#8b5cf6}.lesson-radar-detail{padding:.95rem 1rem;border-radius:var(--radius);background:#ffffff08;border:1px solid rgba(255,255,255,.08)}.lesson-radar-detail-title{font-size:.92rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.lesson-radar-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.lesson-radar-detail-item{display:grid;gap:.2rem}.lesson-radar-detail-item span{font-size:.75rem;color:var(--text-muted)}.lesson-radar-detail-item strong{color:var(--text-primary)}.lesson-radar-row,.lesson-stacked-row,.lesson-metric-row,.lesson-friction-row{display:grid;gap:.45rem}.lesson-radar-row{grid-template-columns:minmax(0,1fr) minmax(120px,1.5fr) auto;align-items:center}.lesson-radar-label,.lesson-stacked-label{color:var(--text-secondary);font-size:.84rem}.lesson-radar-bar,.lesson-stacked-bar{display:flex;width:100%;height:10px;border-radius:999px;overflow:hidden;background:#ffffff14}.lesson-radar-fill,.lesson-stacked-fill{height:100%}.lesson-radar-fill{background:var(--accent-gradient)}.lesson-radar-score,.lesson-stacked-meta{font-size:.78rem;color:var(--text-muted)}.lesson-stacked-fill.lesson-stacked-first{background:linear-gradient(90deg,#22c55e,#34d399)}.lesson-stacked-fill.lesson-stacked-assisted{background:linear-gradient(90deg,#f59e0b,#f97316)}.lesson-metric-row,.lesson-friction-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;padding:.7rem .75rem;border-radius:var(--radius);background:#ffffff08}.lesson-friction-subtext{font-size:.78rem;color:var(--text-muted);margin-top:.2rem}.lesson-summary-empty{margin:0;color:var(--text-muted)}.lesson-study-tips{margin:0;padding-left:1rem;display:grid;gap:.55rem;color:var(--text-secondary);line-height:1.5}@keyframes shimmerMove{to{transform:translate(100%)}}@keyframes studyPlanPulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(.98)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.02)}}@keyframes studyPlanFloat{0%,to{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 6px))}}@media (max-width: 1120px){.study-plan-layout{grid-template-columns:1fr}.study-plan-summary-head{flex-direction:column}.study-plan-actions-top{width:100%;justify-content:flex-start}.study-plan-empty-state,.study-plan-generating-state,.study-plan-generating-steps,.study-plan-stats{grid-template-columns:1fr}.study-chat-card{min-height:420px;position:static}.lesson-header-card,.lesson-question-header{flex-direction:column}.lesson-summary-grid,.lesson-chart-grid,.lesson-radar-row{grid-template-columns:1fr}.study-plan-difficulty-row{align-items:flex-start;flex-direction:column}}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background:#7c3aed05;position:relative}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:#7c3aed0f;box-shadow:var(--accent-glow-sm)}.upload-zone input[type=file]{display:none}.upload-zone-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.5}.upload-zone h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem}.upload-zone p{font-size:.85rem;color:var(--text-muted)}.upload-progress-bar{width:100%;height:6px;background:#ffffff14;border-radius:99px;margin-top:1.25rem;overflow:hidden}.upload-progress-fill{height:100%;background:var(--accent-gradient);border-radius:99px;transition:width .2s ease}.upload-filename{font-size:.8rem;color:var(--text-muted);margin-top:.5rem;font-style:italic}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .18s;white-space:nowrap;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--accent-glow-sm)}.btn-primary:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--accent-glow)}.btn-primary:not(:disabled):active{transform:translateY(0)}.btn-ghost{background:#ffffff0d;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:not(:disabled):hover{background:#ffffff17;border-color:var(--border-hover);color:var(--text-primary)}.btn-danger{background:var(--error-bg);color:var(--error);border:1px solid rgba(244,63,94,.2)}.btn-danger:not(:disabled):hover{background:#f43f5e2e;border-color:#f43f5e66}.btn-sm{padding:.4rem .875rem;font-size:.8rem}.btn-lg{padding:.8rem 1.75rem;font-size:1rem;border-radius:var(--radius-lg)}.btn-full{width:100%}.input-group{margin-bottom:1.125rem}.input-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.375rem;letter-spacing:.01em}.input{width:100%;padding:.7rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.9rem;font-family:inherit;transition:all .18s;outline:none}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #7c3aed1f;background:#10101ef2}.input:hover:not(:focus){border-color:#6366f140}textarea.input{resize:vertical;min-height:90px}.password-wrapper{position:relative;display:flex;align-items:center}.password-input{padding-right:2.75rem}.password-toggle{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;color:var(--text-muted);padding:.25rem;border-radius:4px;transition:color .15s,background .15s;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.password-toggle:hover{color:var(--text-secondary);background:#ffffff0f}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .625rem;border-radius:99px;font-size:.68rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.badge-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.badge-gray{background:#47556940;color:#94a3b8}.badge-gray .badge-dot{background:#94a3b8}.badge-amber{background:#f59e0b1f;color:#fbbf24}.badge-amber .badge-dot{background:#fbbf24;animation:blink 1.2s infinite}.badge-blue{background:#2563eb1f;color:#60a5fa}.badge-blue .badge-dot{background:#60a5fa}.badge-purple{background:#7c3aed26;color:#a78bfa}.badge-purple .badge-dot{background:#a78bfa}.badge-cyan{background:#0891b21f;color:#22d3ee}.badge-cyan .badge-dot{background:#22d3ee;animation:blink 1s infinite}.badge-green{background:#10b9811f;color:#34d399}.badge-green .badge-dot{background:#34d399}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .15s ease}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.75rem;width:100%;max-width:480px;box-shadow:var(--shadow-lg);animation:scaleIn .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.modal-close{background:#ffffff0f;border:none;color:var(--text-secondary);width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .15s}.modal-close:hover{background:#ffffff1f;color:var(--text-primary)}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.15);border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.spinner-sm{width:14px;height:14px}.spinner-lg{width:28px;height:28px;border-width:3px}.msg{padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.5rem;animation:fadeIn .2s ease}.msg-error{background:var(--error-bg);border:1px solid rgba(244,63,94,.25);color:#fca5a5}.msg-success{background:var(--success-bg);border:1px solid rgba(16,185,129,.25);color:#6ee7b7}.skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius)}.divider{border:none;border-top:1px solid var(--border);margin:1.25rem 0}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--text-accent)}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}
