:root{--bg:#fff;--bg-alt:#f5f7fb;--surface:#fff;--surface-2:#f8fafc;--border:#e2e8f0;--border-strong:#cbd5e1;--fg:#1a1a1a;--fg-muted:#64748b;--fg-inverted:#fff;--accent:#6366f1;--accent-hover:#4f46e5;--accent-fg:#fff;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--method-deductive:#3b82f6;--method-inductive:#8b5cf6;--method-error_based:#ef4444;--method-dialogic:#10b981;--method-contextual:#f59e0b;--method-ai_adaptive:#6366f1;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.5rem;--space-6:2rem;--space-8:3rem;--radius-sm:4px;--radius-md:8px;--radius-lg:16px;--shadow-card:0 1px 2px #0f172a0a, 0 8px 24px #0f172a0f;--shadow-elevated:0 4px 12px #0f172a14, 0 24px 48px #0f172a1a;--font-sans:system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono:ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace}[data-theme=dark]{--bg:#0f0f10;--bg-alt:#16161a;--surface:#1c1c20;--surface-2:#232328;--border:#2a2a30;--border-strong:#3a3a42;--fg:#ececec;--fg-muted:#94a3b8;--fg-inverted:#0f0f10;--accent:#818cf8;--accent-hover:#a5b4fc;--accent-fg:#1e1b4b;--shadow-card:0 1px 2px #0006, 0 8px 24px #00000073;--shadow-elevated:0 4px 12px #00000080, 0 24px 48px #0000008c}*{box-sizing:border-box}html,body,#root{background:var(--bg);height:100%;color:var(--fg);font-family:var(--font-sans);margin:0;padding:0}#root{overflow-y:auto}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}button:disabled{cursor:not-allowed;opacity:.55}input,textarea,select{color:var(--fg);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-family:inherit;font-size:1rem}input:focus,textarea:focus,select:focus{outline:2px solid var(--accent);outline-offset:1px}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);border:1px solid #0000;font-size:1rem;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.btn-primary{background:var(--accent);color:var(--accent-fg)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{color:var(--fg);border-color:var(--border-strong);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--surface-2)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.08)}.landing-page{max-width:40rem;min-height:100%;padding:var(--space-8) var(--space-5);text-align:center;align-items:center;gap:var(--space-6);flex-direction:column;margin:0 auto;display:flex}.landing-brand{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.landing-logo{border-radius:var(--radius-lg)}.landing-title{letter-spacing:-.02em;margin:0;font-size:2.25rem;font-weight:700}.landing-subtitle{color:var(--fg-muted);margin:0;font-size:1.125rem}.landing-intro{color:var(--fg-muted);max-width:36rem;font-size:1rem}.landing-intro p{margin:0;line-height:1.55}.landing-lang{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.landing-lang-label{color:var(--fg-muted);text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:.875rem}.landing-lang-options{gap:var(--space-2);display:flex}.landing-lang-btn{min-width:3rem;padding:var(--space-2) var(--space-3);border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--surface);color:var(--fg);font-size:.9rem;font-weight:500}.landing-lang-btn:hover{background:var(--surface-2)}.landing-lang-btn.is-active{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.landing-cta{background:var(--accent);color:var(--accent-fg);border-radius:var(--radius-md);padding:var(--space-3) var(--space-6);box-shadow:var(--shadow-card);border:none;font-size:1.125rem;font-weight:500}.landing-cta:hover:not(:disabled){background:var(--accent-hover)}.landing-secondary{margin-top:var(--space-4);text-align:center}.landing-secondary-link{color:var(--fg-muted);text-underline-offset:3px;font-size:.95rem;text-decoration:underline}.landing-secondary-link:hover{color:var(--accent)}.onboarding-page{max-width:38rem;padding:var(--space-6) var(--space-5);gap:var(--space-5);flex-direction:column;margin:0 auto;display:flex}.onboarding-header-row{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);flex-wrap:wrap;display:flex}.onboarding-header h1{letter-spacing:-.01em;margin:0;font-size:1.75rem;font-weight:700}.onboarding-skip-top{padding:var(--space-2) var(--space-4);flex-shrink:0;font-size:.9rem}.onboarding-intro{color:var(--fg-muted);margin:0;line-height:1.5}.onboarding-form{gap:var(--space-4);flex-direction:column;display:flex}.form-row{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:.95rem;font-weight:500}.form-required{color:var(--danger);margin-left:var(--space-1)}.form-optional{color:var(--fg-muted);font-size:.85em;font-weight:400}.form-hint{color:var(--fg-muted);font-size:.85rem}.form-actions{gap:var(--space-3);margin-top:var(--space-4);justify-content:flex-end;display:flex}.assessment-page{max-width:42rem;padding:var(--space-6) var(--space-5);gap:var(--space-5);flex-direction:column;margin:0 auto;display:flex}.assessment-page h1{margin:0 0 var(--space-2) 0;font-size:1.75rem}.assessment-progress{gap:var(--space-2);flex-direction:column;display:flex}.assessment-progress-caption{color:var(--fg-muted);margin:0;font-size:.85rem}.assessment-progress-bar{background:var(--surface-2);border-radius:999px;height:.5rem;overflow:hidden}.assessment-progress-fill{background:var(--accent);height:100%;transition:width .25s}.question-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-card);gap:var(--space-4);flex-direction:column;display:flex}.question-text{margin:0;font-size:1.25rem;font-weight:600;line-height:1.4}.question-answers{gap:var(--space-2);flex-direction:column;display:flex}.answer-option{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--fg);text-align:left;width:100%;font-size:1rem;transition:background .15s,border-color .15s;display:flex}.answer-option:hover:not(:disabled){background:var(--surface-2);border-color:var(--accent)}.answer-option.is-selected{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, var(--surface))}.answer-bullet{color:var(--accent);font-size:1rem;line-height:1.4}.answer-text{flex:1;line-height:1.4}.profile-dominant{align-items:center;gap:var(--space-2);margin:0;font-size:1.05rem;display:flex}.muted{color:var(--fg-muted)}.error-text{color:var(--danger)}.dashboard-page{max-width:76rem;padding:var(--space-6) var(--space-5);gap:var(--space-5);flex-direction:column;margin:0 auto;display:flex}.dashboard-header h1{margin:0;font-size:1.75rem}.dashboard-grid{gap:var(--space-4);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}@media (width<=720px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-card);gap:var(--space-3);flex-direction:column;display:flex}.dashboard-card-wide{grid-column:1/-1}.dashboard-card-title{color:var(--fg-muted);text-transform:uppercase;letter-spacing:.04em;margin:0;font-size:1rem;font-weight:600}.quick-start-btn{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:linear-gradient(135deg, var(--accent), var(--accent-hover));color:var(--accent-fg);border-radius:var(--radius-lg);text-align:left;box-shadow:var(--shadow-card);border:none;width:100%;font-size:1rem;display:flex}.quick-start-title{flex:1;font-size:1.25rem;font-weight:600;display:block}.quick-start-subtitle{opacity:.85;flex:1;font-size:.875rem;display:block}.quick-start-btn .method-badge{margin-left:auto}.metric-tile{flex:1;align-items:center;display:flex}.metric-grid{gap:var(--space-3);grid-template-columns:repeat(3,minmax(0,1fr));width:100%;display:grid}.metric-grid-5{gap:var(--space-3);grid-template-columns:repeat(5,minmax(0,1fr));width:100%;display:grid}@media (width<=720px){.metric-grid-5{grid-template-columns:repeat(2,minmax(0,1fr))}}.metric-cell{gap:var(--space-1);flex-direction:column;display:flex}.metric-label{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);font-size:.75rem}.metric-value{font-size:1.5rem;font-weight:700}.tile{background:var(--surface-2);border-radius:var(--radius-md);padding:var(--space-4);justify-content:center;align-items:center;min-height:120px;display:flex}.chart-tile{width:100%}.step-eval-insights{gap:var(--space-3);flex-direction:column;display:flex}.step-eval-metrics{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.step-eval-metric{background:var(--surface-2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);gap:var(--space-1);flex-direction:column;align-items:flex-start;display:flex}.step-eval-metric-value{color:var(--accent);font-size:1.4rem;font-weight:700;line-height:1.1}.step-eval-metric-label{color:var(--fg-muted);font-size:.85rem;line-height:1.3}.step-eval-stickiest{margin:0;font-size:.95rem}.tool-list{gap:var(--space-3);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.tool-card{background:var(--surface-2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);gap:var(--space-2);flex-direction:column;display:flex}.tool-name{font-size:1rem;font-weight:600}.tool-why{color:var(--fg-muted);margin:0;font-size:.9rem;line-height:1.4}.tool-methods{gap:var(--space-2);flex-wrap:wrap;display:flex}.session-page{max-width:60rem;padding:var(--space-5);gap:var(--space-4);flex-direction:column;margin:0 auto;display:flex}.session-header{gap:var(--space-3);flex-direction:column;display:flex}.session-header-row{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.session-header-chips{align-items:center;gap:var(--space-2);display:flex}.provider-chip{padding:var(--space-1) var(--space-3);background:var(--surface-2);color:var(--fg-muted);border:1px solid var(--border);border-radius:999px;font-size:.8rem;font-weight:500}.session-header h1{margin:0;font-size:1.5rem}.cycle-progress{gap:var(--space-2);flex-direction:column;display:flex}.cycle-caption{color:var(--fg-muted);margin:0;font-size:.85rem}.cycle-steps{gap:var(--space-1);grid-template-columns:repeat(7,minmax(0,1fr));margin:0;padding:0;list-style:none;display:grid}.cycle-step{align-items:center;gap:var(--space-1);padding:var(--space-2);border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--fg-muted);flex-direction:column;font-size:.75rem;transition:background .15s,border-color .15s;display:flex}.cycle-step.is-complete{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, var(--surface));color:var(--fg)}.cycle-step.is-current{border-color:var(--accent);background:var(--accent);color:var(--accent-fg);transition:background .25s,color .25s,border-color .25s}@keyframes cycle-pulse{0%{box-shadow:0 0 0 0 var(--accent);transform:scale(1)}40%{transform:scale(1.06);box-shadow:0 0 0 6px #0000}to{transform:scale(1);box-shadow:0 0 #0000}}.cycle-step.is-just-advanced{animation:.8s ease-out cycle-pulse}@media (prefers-reduced-motion:reduce){.cycle-step.is-just-advanced{animation:none}.cycle-step.is-current{transition:none}}.qr-viewfinder{pointer-events:none;position:absolute;inset:0}.qr-viewfinder-cutout{aspect-ratio:1;border-radius:12px;width:60%;max-width:240px;max-height:240px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.qr-viewfinder-corner{border:0 solid #fffffff2;width:32px;height:32px;position:absolute}.qr-viewfinder-corner.is-tl{border-top-width:4px;border-left-width:4px;border-top-left-radius:12px;top:0;left:0}.qr-viewfinder-corner.is-tr{border-top-width:4px;border-right-width:4px;border-top-right-radius:12px;top:0;right:0}.qr-viewfinder-corner.is-bl{border-bottom-width:4px;border-left-width:4px;border-bottom-left-radius:12px;bottom:0;left:0}.qr-viewfinder-corner.is-br{border-bottom-width:4px;border-right-width:4px;border-bottom-right-radius:12px;bottom:0;right:0}.qr-viewfinder-scanline{background:linear-gradient(90deg, transparent, rgba(var(--accent-rgb,99, 102, 241), .95), transparent);height:2px;animation:1.8s ease-in-out infinite qr-scanline;position:absolute;top:12%;left:8%;right:8%}@keyframes qr-scanline{0%,to{opacity:.4;top:12%}50%{opacity:1;top:78%}}.qr-success-checkmark{color:var(--success,#2e7d32);font-size:3rem;animation:.32s ease-out qr-success-pop;display:inline-block}@keyframes qr-success-pop{0%{opacity:0;transform:scale(0)}60%{opacity:1;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.qr-viewfinder-scanline{opacity:.6;animation:none;top:50%}.qr-success-checkmark{animation:none}}.cycle-evaluation-reason{margin:var(--space-1) 0 var(--space-3) 0;color:var(--fg-muted);font-size:.85rem;font-style:italic;line-height:1.4}.cycle-step-index{font-size:.85rem;font-weight:600}.cycle-step-label{white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}@media (width<=720px){.cycle-steps{grid-template-columns:repeat(4,minmax(0,1fr))}.cycle-step-label{display:none}}.session-chat{gap:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-card);flex-direction:column;display:flex}.chat-messages{gap:var(--space-2);max-height:50vh;padding-right:var(--space-2);flex-direction:column;display:flex;overflow-y:auto}.chat-message{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--surface-2);max-width:90%}.chat-message.is-user{background:var(--accent);color:var(--accent-fg);align-self:flex-end}.chat-message.is-assistant{background:var(--surface-2);align-self:flex-start}.chat-message.is-system{background:color-mix(in srgb, var(--accent) 8%, var(--surface));color:var(--fg-muted);align-self:stretch;font-size:.9rem}.chat-message-content{white-space:pre-wrap;margin:0;font-family:inherit;font-size:1rem;line-height:1.5}.chat-input-row{gap:var(--space-3);align-items:flex-end;display:flex}.chat-input-row textarea{resize:vertical;flex:1;min-height:3rem}.method-switch-banner{gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-md);background:color-mix(in srgb, var(--warning) 18%, var(--surface));border:1px solid var(--warning);flex-direction:column;display:flex}.method-switch-banner-head{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.method-switch-banner-body{color:var(--fg);margin:0}.method-switch-actions{gap:var(--space-3);justify-content:flex-end;display:flex}.modal-overlay{z-index:1000;padding:var(--space-4);background:#0f172a73;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-elevated);gap:var(--space-4);flex-direction:column;width:100%;max-width:32rem;display:flex}.modal-title{margin:0;font-size:1.25rem;font-weight:600}.rating-form{gap:var(--space-4);flex-direction:column;display:flex}.rating-value{margin-left:var(--space-2);color:var(--fg-muted);font-weight:400}.rating-row{gap:var(--space-2);flex-direction:column;display:flex}.rating-row-label{align-items:baseline;gap:var(--space-2);display:flex}.rating-buttons{gap:var(--space-2);grid-template-columns:repeat(5,minmax(0,1fr));display:grid}.rating-button{border:1px solid var(--border-strong);color:var(--fg);border-radius:var(--radius-md);padding:var(--space-3) var(--space-2);cursor:pointer;background:0 0;min-height:44px;font-size:1.1rem;font-weight:600;transition:background .12s,color .12s,border-color .12s}.rating-button:hover:not(:disabled){background:var(--surface-2)}.rating-button.is-active{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.rating-button:disabled{opacity:.5;cursor:not-allowed}.settings-page{max-width:48rem;padding:var(--space-6) var(--space-5);gap:var(--space-5);flex-direction:column;margin:0 auto;display:flex}.settings-page h1{margin:0;font-size:1.75rem}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-card);gap:var(--space-3);flex-direction:column;display:flex}.settings-section-title{color:var(--fg-muted);text-transform:uppercase;letter-spacing:.04em;margin:0;font-size:1rem;font-weight:600}.storage-mode-fieldset{gap:var(--space-3);border:0;flex-direction:column;margin:0;padding:0;display:flex}.storage-mode-option{align-items:flex-start;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex}.storage-mode-option:has(input:checked){border-color:var(--accent);background:var(--surface-2,var(--surface))}.storage-mode-option>input{margin-top:.25rem}.storage-mode-option>span{gap:var(--space-1);flex-direction:column;display:flex}.storage-mode-warning{color:var(--fg-muted);border-left:3px solid var(--warning,var(--accent));padding-left:var(--space-3);margin:0;font-size:.85rem}.storage-mode-counts{gap:var(--space-1) var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));margin:0;padding:0;font-size:.875rem;list-style:none;display:grid}.storage-mode-counts li{justify-content:space-between;gap:var(--space-2);display:flex}.storage-mode-table{color:var(--fg-muted)}.storage-mode-count{font-variant-numeric:tabular-nums;font-weight:500}.api-key-row{gap:var(--space-2);border-top:1px solid var(--border);padding-top:var(--space-3);flex-direction:column;display:flex}.api-key-row:first-of-type{border-top:none;padding-top:0}.api-key-row-head{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.api-key-row-input{gap:var(--space-2);align-items:center;display:flex}.api-key-row-input input{flex:1;min-width:0}.api-key-status{padding:var(--space-1) var(--space-3);background:var(--surface-2);color:var(--fg-muted);border-radius:999px;font-size:.85rem}.api-key-status.is-set{background:color-mix(in srgb, var(--success) 18%, var(--surface));color:var(--success)}.api-key-active-badge{text-transform:uppercase;letter-spacing:.06em;padding:var(--space-1) var(--space-2);background:var(--accent);color:var(--accent-fg);border-radius:999px;font-size:.75rem;font-weight:600}.api-key-row.is-active-provider{border-left:3px solid var(--accent);padding-left:var(--space-3)}.api-key-warning{color:var(--warning);background:color-mix(in srgb, var(--warning) 12%, var(--surface));border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);margin:0;font-size:.85rem}.commit-table-wrap{overflow-x:auto}.commit-table{border-collapse:collapse;width:100%;font-size:.95rem}.commit-table th,.commit-table td{text-align:left;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border)}.commit-table th{color:var(--fg-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}.commit-table tr:last-child td{border-bottom:none}.app-nav{align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-5);background:var(--surface);border-bottom:1px solid var(--border);z-index:50;display:flex;position:sticky;top:0}.nav-brand{align-items:center;gap:var(--space-2);color:var(--fg);font-weight:600;text-decoration:none;display:inline-flex}.nav-brand img{border-radius:var(--radius-sm)}.nav-brand-name{display:inline-block}@media (width<=600px){.nav-brand-name{display:none}}.nav-links{gap:var(--space-1);margin-left:auto;display:flex}.nav-link{color:var(--fg-muted);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;text-decoration:none}.nav-link:hover{background:var(--surface-2);color:var(--fg)}.nav-link.is-active{color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, var(--surface))}.nav-online-indicator{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);color:var(--fg-muted);cursor:default;border-radius:999px;font-size:.85rem;display:inline-flex}.nav-online-dot{background:var(--accent);border-radius:999px;width:.55rem;height:.55rem;transition:background .2s,box-shadow .2s}.nav-online-indicator.is-online .nav-online-dot{background:#10b981;box-shadow:0 0 0 2px #10b98133}.nav-online-indicator.is-offline .nav-online-dot{background:var(--danger,#ef4444);box-shadow:0 0 0 2px color-mix(in srgb, var(--danger,#ef4444) 20%, transparent)}.nav-online-indicator.is-offline .nav-online-label{color:var(--danger,#ef4444)}.nav-theme-toggle{border:1px solid var(--border-strong);width:2.25rem;height:2.25rem;color:var(--fg);background:0 0;border-radius:999px;justify-content:center;align-items:center;font-size:1rem;display:inline-flex}.nav-theme-toggle:hover{background:var(--surface-2)}.curriculum-toolbar{align-items:flex-end;gap:var(--space-4);flex-wrap:wrap;display:flex}.curriculum-create-form{gap:var(--space-2);flex:1;align-items:center;min-width:0;display:flex}.curriculum-create-form input{flex:1;min-width:0}.curriculum-tree-head{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.topic-tree{margin:0;padding:0;list-style:none}.topic-children{padding-left:var(--space-5);margin:0;list-style:none}.topic-node{padding:var(--space-1) 0}.topic-row{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);background:var(--surface-2);display:flex}.topic-row:hover{background:color-mix(in srgb, var(--accent) 6%, var(--surface-2))}.topic-toggle{color:var(--fg-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;padding:0;display:inline-flex}.topic-toggle.is-leaf{cursor:default}.topic-title{flex:1;font-size:.95rem}.topic-actions{gap:var(--space-1);opacity:.6;display:flex}.topic-row:hover .topic-actions{opacity:1}.topic-action-btn{color:var(--fg-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:1px solid #0000;width:1.75rem;height:1.75rem;font-size:.9rem}.topic-action-btn:hover{background:var(--surface);border-color:var(--border);color:var(--fg)}.topic-action-btn.is-danger:hover{color:var(--danger);border-color:var(--danger)}.add-topic-form,.lesson-list-wrap{gap:var(--space-3);flex-direction:column;display:flex}.lesson-create-form{gap:var(--space-2);display:flex}.lesson-create-form input{flex:1;min-width:0}.lesson-list{gap:var(--space-2);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.lesson-row{gap:var(--space-2);background:var(--surface-2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);flex-direction:column;display:flex}.lesson-row.is-editing{background:var(--surface);border:1px solid var(--border-strong)}.lesson-row-head{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.lesson-title{font-size:1rem}.lesson-content{color:var(--fg-muted);white-space:pre-wrap;margin:0;font-size:.9rem}.lesson-row-actions{gap:var(--space-2);display:flex}.lesson-row.is-editing textarea{resize:vertical}.recent-sessions{gap:var(--space-2);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.recent-session-row{gap:var(--space-1);padding:var(--space-3) var(--space-4);background:var(--surface-2);border-radius:var(--radius-md);cursor:pointer;flex-direction:column;transition:background .15s;display:flex}.recent-session-row:hover{background:color-mix(in srgb, var(--accent) 6%, var(--surface-2))}.recent-session-row:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.recent-session-line{align-items:center;gap:var(--space-2);display:flex}.recent-session-date{color:var(--fg-muted);font-size:.85rem}.recent-session-stats{gap:var(--space-4);color:var(--fg-muted);flex-wrap:wrap;font-size:.85rem;display:flex}.method-badge{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--surface-2);color:var(--fg);border-radius:999px;font-size:.85rem;font-weight:500;display:inline-flex}.method-dot{background:var(--accent);border-radius:999px;width:.55rem;height:.55rem;display:inline-block}.install-prompt{left:var(--space-3);right:var(--space-3);bottom:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);align-items:center;gap:var(--space-3);z-index:100;display:flex;position:fixed}.install-prompt-text{gap:var(--space-1);flex-direction:column;flex:1;min-width:0;display:flex}.install-prompt-subtitle{font-size:.85rem}.install-prompt-actions{gap:var(--space-2);flex-shrink:0;display:flex}@media (width>=769px){.install-prompt{left:auto;right:var(--space-5);bottom:var(--space-5);max-width:28rem}}@media (width<=480px){.install-prompt{flex-direction:column;align-items:stretch}.install-prompt-actions{width:100%}.install-prompt-actions .btn{flex:1;min-height:44px}}.nav-hamburger{border:1px solid var(--border-strong);border-radius:var(--radius-sm);width:2.75rem;height:2.75rem;color:var(--fg);cursor:pointer;background:0 0;justify-content:center;align-items:center;margin-left:auto;font-size:1.25rem;display:none}.nav-hamburger:hover{background:var(--surface-2)}@media (width<=768px){.nav-hamburger{display:inline-flex}.nav-online-label{display:none}.nav-online-indicator{padding:var(--space-1)}.nav-links{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-card);padding:var(--space-2);flex-direction:column;gap:0;margin-left:0;display:none;position:absolute;top:100%;left:0;right:0}.nav-links.is-open{display:flex}.nav-link{padding:var(--space-3) var(--space-4);align-items:center;min-height:44px;font-size:1rem;display:flex}.app-nav.is-menu-open{box-shadow:none}.nav-theme-toggle{width:2.75rem;height:2.75rem;margin-left:var(--space-2)}.btn{min-height:44px;padding:var(--space-3) var(--space-5)}input[type=text],input[type=number],input[type=email],input[type=password],select,textarea{min-height:44px;font-size:16px}textarea{padding:var(--space-2) var(--space-3)}.form-actions{align-items:stretch;gap:var(--space-2);flex-direction:column}.form-actions .btn{width:100%}.onboarding-header-row{align-items:stretch;gap:var(--space-2);flex-direction:column}.onboarding-skip-top{width:100%;min-height:44px}.api-key-row-input,.model-override-row-input{align-items:stretch;gap:var(--space-2);flex-direction:column}.api-key-row-input input,.model-override-row-input input,.api-key-row-input .btn,.model-override-row-input .btn{width:100%}.landing-page{padding:var(--space-4) var(--space-4)}.landing-title{font-size:1.6rem;line-height:1.2}.landing-cta{width:100%;min-height:44px}.landing-lang-options{flex-wrap:wrap;justify-content:center}.landing-lang-btn{min-width:44px;min-height:44px}.answer-option{min-height:44px;padding:var(--space-3)}.assessment-page{padding:var(--space-4) var(--space-4)}.spaced-rec-card{align-items:stretch;gap:var(--space-2);flex-direction:column}.spaced-rec-actions{gap:var(--space-2);flex-direction:row}.spaced-rec-actions .btn{flex:1;min-height:44px}.dashboard-page{padding:var(--space-4) var(--space-3)}.dashboard-card{padding:var(--space-3) var(--space-3)}.dashboard-card-title{font-size:1rem}.commit-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.commit-table{min-width:32rem}.step-eval-metrics{grid-template-columns:1fr}.session-chat{min-height:calc(100vh - 14rem);padding:var(--space-3);gap:var(--space-2)}.chat-messages{flex:1;max-height:none}.chat-input-row{gap:var(--space-2);align-items:stretch}.chat-input-row textarea{min-height:3rem;font-size:16px}.chat-input-row .btn{min-width:4rem;min-height:44px}.cycle-steps{grid-template-columns:repeat(7,minmax(2.4rem,1fr))}.cycle-step-label{display:none}.modal-card{width:100%;max-height:92vh;overflow-y:auto}}@media (width<=360px){.app-nav{padding:var(--space-2) var(--space-3);gap:var(--space-2)}.dashboard-page,.assessment-page,.onboarding-page,.landing-page{padding-left:var(--space-3);padding-right:var(--space-3)}}.export-row{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border);flex-wrap:wrap;display:flex}.export-row:last-child{border-bottom:none}.export-row-label{flex:200px;font-weight:600}.export-row-actions{gap:var(--space-2);flex-wrap:wrap;display:flex}.export-preview{margin-top:var(--space-4);background:var(--surface-2,var(--surface));border:1px solid var(--border);border-radius:var(--radius-2);padding:var(--space-3)}.export-preview-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.export-preview-body{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-1);padding:var(--space-3);font-family:var(--font-mono,monospace);white-space:pre-wrap;max-height:300px;font-size:.85rem;overflow:auto}.chat-transition-card{border:2px dashed var(--accent,#6366f1);background:var(--surface-2,var(--surface));border-radius:var(--radius-2);padding:var(--space-3);margin:var(--space-3) auto;text-align:center;max-width:90%}.chat-transition-header{margin-bottom:var(--space-2)}.chat-transition-badge{background:var(--accent,#6366f1);color:#fff;border-radius:var(--radius-1);letter-spacing:.05em;text-transform:uppercase;padding:.2em .6em;font-size:.85rem;font-weight:600;display:inline-block}.chat-transition-summary{margin:var(--space-2) 0;color:var(--text);font-style:italic}.chat-transition-next{margin-top:var(--space-2);color:var(--text)}.cycle-counter-badge{background:var(--accent,#6366f1);color:#fff;border-radius:var(--radius-1);letter-spacing:.04em;padding:.25em .6em;font-size:.85rem;font-weight:600;display:inline-block}.rating-cycles-summary{background:var(--surface-2,var(--surface));border:1px solid var(--border);border-radius:var(--radius-1);padding:var(--space-3);margin-bottom:var(--space-3)}.rating-cycles-list{margin:var(--space-2) 0 0 var(--space-3);padding:0;font-size:.95rem;list-style:decimal}.rating-cycles-list li{margin:var(--space-1) 0}
