:root{--bg: oklch(15% .018 230);--surface: oklch(19% .018 230);--surface-2: oklch(22% .018 230);--fg: oklch(96% .005 230);--muted: oklch(68% .012 230);--border: oklch(28% .014 230);--accent: oklch(72% .18 145);--accent-soft: color-mix(in oklch, var(--accent) 12%, transparent);--accent-tint: color-mix(in oklch, var(--accent) 6%, transparent);--danger: oklch(68% .18 25);--warning: oklch(76% .15 75);--fg-soft: color-mix(in oklch, var(--fg) 5%, transparent);--font-display: "Iowan Old Style", Charter, Georgia, "Times New Roman", serif;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, monospace;--gap-xs: 8px;--gap-sm: 12px;--gap-md: 20px;--gap-lg: 32px;--gap-xl: 56px;--radius: 8px;--radius-lg: 14px;--gutter: 32px}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;min-width:320px;background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:15px;line-height:1.55;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body:has(.mobile-bottom-nav){padding-bottom:0}img,svg{display:block;max-width:100%}svg{width:1em;height:1em}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}p,h1,h2,h3,h4,ul{margin:0}strong{color:var(--fg)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px}:root{color-scheme:dark light;--bg: oklch(15% .018 230);--surface: oklch(19% .018 230);--surface-2: oklch(22% .018 230);--fg: oklch(96% .005 230);--muted: oklch(68% .012 230);--border: oklch(28% .014 230);--accent: oklch(72% .18 145);--danger: oklch(68% .18 25);--warning: oklch(76% .15 75);--ok: oklch(72% .18 145);--accent-soft: color-mix(in oklch, var(--accent) 12%, transparent);--accent-tint: color-mix(in oklch, var(--accent) 6%, transparent);--warn-tint: color-mix(in oklch, var(--warning) 14%, transparent);--danger-tint: color-mix(in oklch, var(--danger) 12%, transparent);--fg-soft: color-mix(in oklch, var(--fg) 5%, transparent);--font-display: "Iowan Old Style", Charter, Georgia, "Times New Roman", serif;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, monospace;--gap-xs: 8px;--gap-sm: 12px;--gap-md: 20px;--gap-lg: 32px;--gap-xl: 56px;--gap-2xl: 96px;--container: 1120px;--gutter: 32px;--radius: 10px;--radius-lg: 16px}:root[data-theme=light]{--bg: oklch(99% .003 200);--surface: oklch(100% 0 0);--surface-2: oklch(97% .004 220);--fg: oklch(18% .02 230);--muted: oklch(50% .015 230);--border: oklch(92% .006 230);--accent: oklch(62% .16 145);--fg-soft: color-mix(in oklch, var(--fg) 5%, transparent)}::selection{background:var(--accent-soft);color:var(--fg)}.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}.page-container{padding-block:var(--gap-xl)}.practice-container{padding-block:var(--gap-xl);max-width:1080px}.section{padding-block:clamp(56px,9vw,var(--gap-2xl))}.section+.section{border-top:1px solid var(--border)}.row,.row-between{display:flex;align-items:center;gap:var(--gap-md)}.row-between{justify-content:space-between;flex-wrap:wrap}.row.center{justify-content:center}.row.wrap{flex-wrap:wrap}.stack-xl{display:flex;flex-direction:column;gap:var(--gap-xl)}.grid-2,.grid-3,.grid-4,.grid-1-2,.grid-2-1{display:grid;gap:var(--gap-lg)}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-1-2{grid-template-columns:1fr 2fr;align-items:center}.grid-2-1{grid-template-columns:2fr 1fr;align-items:center}.layout{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--gap-md);align-items:start}.clean-list{list-style:none;padding:0;margin:0}h1,.h1{font-family:var(--font-display);font-size:clamp(32px,4vw,48px);line-height:1.08;letter-spacing:0}h2,.h2{font-family:var(--font-display);font-size:clamp(26px,3.4vw,40px);line-height:1.12;letter-spacing:0}h3,.h3{font-size:22px;font-weight:650;line-height:1.3;letter-spacing:0}.lead{color:var(--muted);font-size:18px;line-height:1.55;max-width:60ch}.vi,.vi-sub,.sub,.panel-sub,.hint,.meta{color:var(--muted)}.eyebrow,.panel-eyebrow,.section-h,.lbl,.lang-tag,.meta,.pill,.filter-pill,.module-tag,.tag,.cefr,.num,.field label{font-family:var(--font-mono)}.eyebrow,.panel-eyebrow,.section-h{color:var(--accent);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}.num{font-variant-numeric:tabular-nums}.logo,.brand,.brand-mark{display:inline-flex;align-items:baseline;color:var(--fg);font-family:var(--font-display);font-size:22px;font-weight:650;line-height:1;letter-spacing:0}.logo span,.brand span,.brand-mark span{color:var(--accent)}#theme-toggle{position:fixed;right:18px;bottom:18px;z-index:999;width:34px;height:34px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--fg);display:grid;place-items:center;box-shadow:0 1px 2px #0000002e;transition:border-color .15s,color .15s,background .15s}#theme-toggle:hover{color:var(--accent);border-color:var(--fg)}.topnav{position:sticky;top:0;z-index:20;background:color-mix(in oklch,var(--bg) 92%,transparent);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topnav-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--gap-md);padding-block:14px}.topnav nav{display:flex;align-items:center;gap:var(--gap-lg);flex-wrap:wrap}.topnav nav a,.nav-actions a{color:var(--muted);font-size:14px;transition:color .15s}.topnav nav a:hover,.topnav nav a.active,.nav-actions a:hover{color:var(--fg)}.nav-actions{display:flex;align-items:center;gap:var(--gap-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border-radius:var(--radius);border:1px solid transparent;padding:9px 16px;background:transparent;color:var(--fg);font-size:14px;font-weight:550;transition:border-color .15s,background .15s,color .15s,transform .05s}.btn svg{width:15px;height:15px;flex:none}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:var(--surface);border-color:var(--accent)}.btn-primary:hover{background:color-mix(in oklch,var(--accent) 88%,black)}.btn-secondary{background:transparent;border-color:var(--border)}.btn-secondary:hover{border-color:var(--fg)}.btn-ghost{background:transparent;color:var(--fg);border-color:transparent;padding-inline:8px}.btn-ghost:hover{color:var(--accent)}.btn-danger{background:transparent;color:var(--danger);border-color:color-mix(in oklch,var(--danger) 45%,var(--border))}.btn-block{width:100%}.btn-icon{width:36px;padding:0}.btn:disabled,input:disabled{opacity:.68;cursor:not-allowed}.pill,.filter-pill,.head-meta .tag{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:5px 10px;background:var(--fg-soft);color:var(--muted);font-size:11px;letter-spacing:.04em}.pill.accent,.filter-pill.active{background:var(--accent-tint);border-color:var(--accent-soft);color:var(--accent)}.filter-pill{background:var(--surface);font-size:13px;text-transform:none;cursor:pointer}.filter-pill svg{width:12px;height:12px}.hero{padding-block:clamp(72px,11vw,144px)}.hero .container{max-width:1120px}.hero h1{max-width:18ch;font-size:clamp(44px,6vw,76px);line-height:1.04}.hero-vi{margin:8px 0 var(--gap-md);max-width:52ch}.hero .lead{margin-bottom:var(--gap-lg)}.hero-cta{display:flex;flex-wrap:wrap;gap:var(--gap-sm);margin-top:var(--gap-lg)}.hero-meta{margin-top:var(--gap-lg)}.landing-intro>div{max-width:38ch}.landing-intro .lead{max-width:40ch}.browser-stage{background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;box-shadow:0 1px 0 var(--border),0 18px 40px -28px color-mix(in oklch,var(--fg) 18%,transparent)}.browser-bar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);background:color-mix(in oklch,var(--bg) 80%,var(--surface))}.browser-dots{display:flex;gap:6px}.browser-dots span{width:11px;height:11px;border-radius:999px;background:var(--border)}.browser-url{flex:1;min-width:0;padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--muted);font-family:var(--font-mono);font-size:12px}.browser-canvas{position:relative;padding:clamp(28px,4vw,56px);background:var(--bg);color:var(--fg);font-family:var(--font-display);font-size:clamp(18px,1.6vw,22px);line-height:1.55}.browser-canvas p{max-width:60ch;margin-bottom:1em}.selected-text{background:var(--accent-tint);border-bottom:2px solid var(--accent);padding-inline:2px}.floating-icon{position:absolute;top:80px;right:min(36vw,420px);width:42px;height:42px;border-radius:999px;background:var(--accent);color:var(--surface);display:grid;place-items:center}.floating-icon svg{width:20px;height:20px}.extension-popup{position:absolute;top:64px;right:clamp(20px,4vw,48px);width:clamp(260px,30vw,320px);background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px;font-family:var(--font-body);box-shadow:0 20px 50px -24px #000000a6}.pop-head{display:flex;justify-content:space-between;gap:10px;align-items:baseline;margin-bottom:12px}.pop-head .word{color:var(--fg);font-weight:700}.pop-head .ipa{color:var(--muted);font-family:var(--font-mono);font-size:11px}.pop-vi,.pop-meaning{font-size:13px;margin-bottom:10px}.pop-meaning{color:var(--muted)}.pop-tags{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}.pop-tags span{border-radius:999px;padding:3px 8px;background:var(--fg-soft);color:var(--muted);font-family:var(--font-mono);font-size:10px}.pop-saved{display:flex;align-items:center;gap:8px;color:var(--accent);font-family:var(--font-mono);font-size:11px}.section-title{max-width:36ch}.feature-mark,.module-mark{width:36px;height:36px;border:1px solid var(--border);border-radius:10px;display:grid;place-items:center;color:var(--accent);margin-bottom:var(--gap-md)}.feature-mark svg,.module-mark svg{width:18px;height:18px}.feature h3{margin-bottom:6px;font-family:var(--font-body);font-size:22px}.feature p{color:var(--muted);font-size:15px}.stats-eyebrow{margin-bottom:40px}.stat-proof .stat-num{font-family:var(--font-mono);font-size:clamp(42px,6vw,64px);color:var(--accent);line-height:1}.stat-proof span{font-size:.5em}.stat-proof p{color:var(--muted);margin-top:10px}.card,.panel,.stat-card,.module,.source-passage,.answer-card,.feedback-card,.passage-card,.recorder-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.card{padding:28px}.tutor-card .row-between{margin-bottom:16px}.tutor-card .meta strong{color:var(--accent)}.display-copy{font-family:var(--font-display);font-size:19px;line-height:1.5;margin-block:12px}.inline-feedback{border-left:2px solid var(--border);padding-left:14px;color:var(--muted);font-size:14px}.inline-feedback span{text-decoration:line-through;opacity:.72}.cta-strip{text-align:center}.cta-container{max-width:600px}.cta-container .lead{margin:12px auto var(--gap-lg)}.pagefoot{padding-block:var(--gap-xl);color:var(--muted);font-size:13px;border-top:1px solid var(--border)}.login-layout{min-height:100dvh;display:grid;grid-template-columns:1.1fr 1fr}.brand-panel{padding:clamp(32px,5vw,64px);background:radial-gradient(circle at 20% 20%,var(--accent-tint),transparent 32%),var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;justify-content:space-between}.brand-pitch{max-width:480px;margin-block:auto}.brand-pitch h1{font-size:clamp(42px,5vw,68px);margin-bottom:14px}.brand-pitch>p{color:var(--muted);font-size:18px;max-width:44ch}.brand-features{display:flex;flex-direction:column;gap:14px;margin-top:var(--gap-lg)}.brand-features .row{align-items:flex-start;gap:12px}.brand-features .ico,.ext-icon{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--border);border-radius:8px;color:var(--accent)}.brand-features strong,.brand-features span{display:block;font-size:14px}.brand-features span,.brand-foot{color:var(--muted);font-size:12px}.form-panel{display:grid;place-items:center;padding:var(--gap-xl) var(--gutter)}.form-card{width:min(440px,100%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}.form-tabs{display:grid;grid-template-columns:1fr;gap:4px;padding:4px;margin-bottom:22px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg)}.form-tabs button{border:0;border-radius:6px;padding:8px;background:var(--accent-tint);color:var(--accent)}.form-card h1{font-size:clamp(28px,4vw,36px);margin-bottom:4px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{color:var(--muted);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.input,input,select,textarea{width:100%;min-width:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--fg);padding:10px 12px}.input:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.field-row{display:flex;align-items:center;justify-content:space-between;gap:var(--gap-sm);margin-bottom:16px;font-size:13px}.check{display:inline-flex;align-items:center;gap:8px;color:var(--muted)}.check input{width:auto}.forgot,.ext-cta a,.key-status a{color:var(--accent);text-decoration:underline}.divider-or{display:flex;align-items:center;gap:12px;color:var(--muted);font-family:var(--font-mono);font-size:11px;margin:22px 0}.divider-or:before,.divider-or:after{content:"";flex:1;border-top:1px solid var(--border)}.ext-cta{display:flex;gap:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:14px;color:var(--muted);font-size:13px}.notice,.form-error{border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;margin:18px 0}.notice{background:var(--accent-tint)}.form-error{background:var(--danger-tint);border-color:color-mix(in oklch,var(--danger) 42%,var(--border))}.lang-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:999px;background:var(--fg-soft);color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em}.lang-toggle .en{color:var(--fg);font-weight:650}.app-shell{display:grid;grid-template-columns:240px minmax(0,1fr);min-height:100dvh}.app-content{min-width:0}.sidenav{position:sticky;top:0;height:100dvh;border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column}.loading-state,.empty-state,.error-state{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:16px;color:var(--muted)}.loading-state,.error-state{margin-bottom:var(--gap-md)}.empty-state h3{margin:0 0 6px;font-size:15px;color:var(--text)}.empty-state p{margin:0;line-height:1.5}.error-state{border-color:color-mix(in oklch,var(--danger) 50%,var(--border));color:var(--danger)}.command-trigger{border:1px solid var(--border);text-align:left;cursor:pointer}.command-backdrop{position:fixed;inset:0;z-index:100;display:grid;place-items:start center;padding:9vh 18px 18px;background:#0000007a}.command-dialog{width:min(620px,100%);border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 24px 80px #00000061;overflow:hidden}.command-search{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.command-search svg{width:18px;height:18px;color:var(--muted)}.command-search input{width:100%;border:0;outline:0;background:transparent;color:var(--text);font:inherit}.command-search kbd{color:var(--muted)}.command-list{max-height:min(420px,58vh);overflow:auto;padding:8px}.command-list button{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;width:100%;border:0;border-radius:8px;background:transparent;color:var(--text);padding:11px 12px;text-align:left;cursor:pointer}.command-list button:hover,.command-list button.active{background:var(--fg-soft)}.command-list svg{width:18px;height:18px;color:var(--accent)}.command-list small{display:block;margin-top:2px;color:var(--muted);font-family:var(--font-mono);font-size:11px}.command-empty{padding:24px;color:var(--muted);text-align:center}.status-banner.ok{border-color:color-mix(in oklch,var(--ok) 45%,var(--border))}.sidenav .brand{padding:0 12px;margin-bottom:28px}.sidenav nav{display:flex;flex-direction:column;gap:2px;flex:1}.sidenav nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--muted);font-size:14px;transition:background .15s,color .15s}.sidenav nav a:hover{background:var(--fg-soft);color:var(--fg)}.sidenav nav a.active{background:var(--accent-tint);color:var(--accent)}.sidenav nav svg{width:16px;height:16px;flex:none}.sidenav .badge{margin-left:auto;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--fg);font-family:var(--font-mono);font-size:11px;padding:1px 6px}.streak-card{margin-top:16px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.streak-card .num{color:var(--accent);font-family:var(--font-display);font-size:28px;font-weight:650;line-height:1}.streak-card .label{color:var(--muted);font-size:12px;margin-top:4px}.user-row{margin-top:16px;padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;font-size:13px}.avatar{width:32px;height:32px;border-radius:999px;background:var(--accent-tint);color:var(--accent);display:grid;place-items:center;font-family:var(--font-display);font-weight:650}.user-name{font-weight:650}.user-level{color:var(--muted);font-size:12px}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:var(--gap-md);padding:18px var(--gutter);border-bottom:1px solid var(--border);background:color-mix(in oklch,var(--bg) 92%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar h1{font-size:22px;line-height:1.1}.topbar .vi{font-size:13px;margin-top:2px}.topbar-actions{display:flex;align-items:center;gap:12px}.search-box{display:flex;align-items:center;gap:8px;min-width:260px;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--muted);font-family:var(--font-mono);font-size:12px}.search-box svg{width:14px;height:14px;flex:none}.search-box span{margin-left:auto;opacity:.55}.icon-btn{width:36px;height:36px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted);display:grid;place-items:center}.icon-btn:hover{color:var(--fg)}.app-main{max-width:1180px;padding:var(--gap-lg) var(--gutter) var(--gap-xl)}.greeting{display:flex;align-items:end;justify-content:space-between;gap:var(--gap-lg);flex-wrap:wrap;margin-bottom:var(--gap-lg)}.greeting h2{font-size:clamp(28px,3.4vw,38px)}.greeting p{color:var(--muted);margin-top:6px;max-width:56ch}.streak-pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;background:var(--accent-tint);color:var(--accent);font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;padding:8px 14px}.streak-pill svg{width:14px;height:14px}.plan-card{display:grid;grid-template-columns:1.4fr 1fr;overflow:hidden;margin-bottom:var(--gap-lg)}.plan-main{padding:28px 32px}.plan-main h3{font-family:var(--font-display);font-size:24px;margin-bottom:6px}.plan-stats{display:flex;gap:var(--gap-xl);flex-wrap:wrap;margin:20px 0 22px}.plan-stats .n{font-family:var(--font-display);font-size:38px;font-weight:650;line-height:1}.plan-stats .accent{color:var(--accent)}.plan-stats .n span{font-size:.5em;opacity:.65}.plan-stats .l{color:var(--muted);font-size:12px;margin-top:4px}.plan-actions{display:flex;gap:10px;flex-wrap:wrap}.plan-side{padding:28px;border-left:1px solid var(--border);background:linear-gradient(180deg,var(--accent-tint),transparent 80%),var(--bg);display:flex;flex-direction:column;justify-content:space-between}.plan-side h4{color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}.week-track{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:18px}.week-track .day{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--muted);font-family:var(--font-mono);font-size:10px;padding:8px 0}.week-track .dot{width:24px;height:24px;border-radius:6px;background:var(--border);display:grid;place-items:center}.week-track .dot svg{width:10px;height:10px;color:var(--surface);stroke-width:3}.week-track .done .dot{background:var(--accent)}.week-track .today .dot{background:var(--surface);border:2px solid var(--accent)}.module-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap-md);margin-bottom:var(--gap-lg)}.module{padding:22px;display:flex;flex-direction:column;transition:border-color .15s,transform .05s}.module:hover{border-color:var(--fg)}.module:active{transform:translateY(1px)}.module-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.module-mark{width:32px;height:32px;margin:0;border-radius:8px}.module-tag{border-radius:999px;padding:3px 8px;background:var(--accent-soft);color:var(--accent);font-size:10px;letter-spacing:.06em;text-transform:uppercase}.module h4{font-family:var(--font-display);font-size:18px;margin-bottom:4px}.module .vi{font-size:12px;margin-bottom:10px}.module p{color:var(--muted);font-size:13px;flex:1}.module-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--border);color:var(--muted);font-family:var(--font-mono);font-size:12px}.module-foot .arrow{color:var(--accent)}.lower-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--gap-md)}.panel{padding:22px;margin-bottom:var(--gap-md)}.panel-h{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px}.panel-h h2{font-size:18px}.panel-action{color:var(--accent);font-family:var(--font-mono);font-size:11px}.lookup-list{display:flex;flex-direction:column}.lookup-list li{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:14px 0;border-top:1px solid var(--border)}.lookup-list li:first-child{border-top:0;padding-top:0}.lookup-list .ico{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;display:grid;place-items:center;color:var(--muted);font-family:var(--font-mono);font-size:11px}.lookup-list strong{display:block;font-size:14px}.lookup-list span{color:var(--muted);font-size:12px}.lookup-list .meta-r{text-align:right;font-family:var(--font-mono);letter-spacing:.04em}.weak-list li{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;padding:12px 0;border-top:1px solid var(--border)}.weak-list li:first-child{border-top:0;padding-top:0}.weak-list .lbl{color:var(--fg);font-size:14px}.weak-list small{display:block;color:var(--muted);font-size:12px;margin-top:2px}.bar-wrap{display:flex;align-items:center;gap:8px}.bar{height:4px;background:var(--border);border-radius:999px;overflow:hidden}.weak-list .bar{width:80px}.bar span{display:block;height:100%;background:var(--accent)}.weak-list .n{min-width:30px;text-align:right;color:var(--muted)}.stage{max-width:760px;min-height:calc(100dvh - 60px);margin:0 auto;padding:var(--gap-xl) var(--gutter) var(--gap-2xl);display:flex;flex-direction:column}.progress-row{display:flex;align-items:center;gap:14px;margin-bottom:var(--gap-lg);color:var(--muted);font-family:var(--font-mono);font-size:12px}.progress-bar{flex:1;height:4px;border-radius:999px;background:var(--border);overflow:hidden}.progress-bar span{display:block;height:100%;background:var(--accent)}.card-types{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:var(--gap-md)}.card-types .tag{border-radius:999px;background:var(--fg-soft);color:var(--muted);font-size:10px;padding:3px 8px;text-transform:uppercase}.card-types .active{background:var(--accent-soft);color:var(--accent)}.flashcard{padding:clamp(28px,5vw,56px);flex:1;display:flex;flex-direction:column;box-shadow:0 1px 0 var(--border)}.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px}.card-q-prompt,.card-meta-r{color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em}.card-meta-r{text-align:right}.card-question{font-size:clamp(36px,5vw,56px);line-height:1.1;margin-bottom:18px}.ipa-inline{display:block;margin-top:12px;color:var(--muted);font-family:var(--font-mono);font-size:.4em}.card-context{max-width:60ch;color:var(--muted);font-size:14px;border-left:2px solid var(--border);padding-left:14px}.card-context em{color:var(--fg);font-style:normal;font-weight:550}.reveal-divider{display:flex;align-items:center;gap:14px;margin:28px 0;border:0;background:transparent;color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}.reveal-divider:before,.reveal-divider:after{content:"";flex:1;border-top:1px dashed var(--border)}.card-answer{border:1px solid var(--accent-soft);border-radius:var(--radius);background:var(--accent-tint);padding:22px 26px}.card-answer .lbl{color:var(--accent);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}.card-answer .text{font-family:var(--font-display);font-size:clamp(24px,3vw,30px)}.card-answer .example{color:var(--muted);border-top:1px solid var(--accent-soft);padding-top:14px;margin-top:14px}.rating-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:28px}.rating-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--fg);padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:4px;transition:border-color .15s,transform .05s}.rating-btn:hover{border-color:var(--fg)}.rating-btn.good{background:var(--accent-tint);border-color:var(--accent-soft)}.rating-btn.good .lbl{color:var(--accent)}.rating-btn .next{color:var(--muted);font-family:var(--font-mono);font-size:11px}.session-info{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-md);margin-top:28px;padding-top:24px;border-top:1px solid var(--border)}.session-info .cell{color:var(--muted);font-family:var(--font-mono);font-size:12px}.session-info .n{display:block;color:var(--fg);font-family:var(--font-display);font-size:22px;margin-top:4px}.session-info .accent{color:var(--accent)}.kbd-hints{position:fixed;left:50%;bottom:24px;transform:translate(-50%);display:flex;gap:14px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);padding:8px 14px;font-family:var(--font-mono);font-size:11px}.kbd-hints kbd{border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--fg);padding:2px 6px;font:inherit}.head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--gap-md);flex-wrap:wrap;margin-bottom:var(--gap-lg)}.head-row h1{font-size:clamp(28px,3.4vw,38px)}.task-meta{display:flex;gap:8px;flex-wrap:wrap}.config-row{display:flex;gap:10px;flex-wrap:wrap;align-items:end;margin-bottom:var(--gap-md);padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.config-field{display:flex;flex-direction:column;gap:4px}.config-field label{color:var(--muted);font-size:10px;letter-spacing:.06em;text-transform:uppercase}.config-field select{min-width:140px;padding:7px 10px}.config-spacer{flex:1}.generate-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:36px;border:0;border-radius:8px;background:var(--accent);color:var(--surface);padding:9px 16px;font-size:13px;font-weight:550}.generate-btn svg{width:14px;height:14px}.source-passage,.answer-card,.passage-card,.recorder-card{padding:24px 28px;margin-bottom:var(--gap-md)}.label-row{display:flex;align-items:center;justify-content:space-between;gap:var(--gap-sm);flex-wrap:wrap;margin-bottom:16px}.lang-tag{color:var(--accent);font-size:11px;letter-spacing:.04em}.source-passage .passage,.passage-card .passage{font-family:var(--font-display);font-size:clamp(20px,2.6vw,24px);line-height:1.45}.tip{color:var(--muted);font-size:13px;border-top:1px solid var(--border);padding-top:12px;margin-top:12px}.answer-textarea{min-height:120px;resize:vertical;font-size:16px;line-height:1.5}.answer-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:14px}.feedback-card{overflow:hidden;margin-bottom:var(--gap-md)}.feedback-head{display:grid;grid-template-columns:auto 1fr auto;gap:var(--gap-md);align-items:center;padding:22px 28px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--accent-tint),transparent 100%)}.score-ring{position:relative;width:78px;height:78px;display:grid;place-items:center}.score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.score-ring circle{fill:none;stroke-width:6}.score-ring .bg{stroke:var(--border)}.score-ring .fg{stroke:var(--accent);stroke-linecap:round}.score-ring .num{position:absolute;color:var(--fg);font-family:var(--font-display);font-size:22px;font-weight:650}.feedback-head .title{font-family:var(--font-display);font-size:22px;line-height:1.2}.feedback-head .subtitle{color:var(--muted);font-size:13px;margin-top:4px}.level-est{border:1px solid var(--accent-soft);border-radius:8px;background:var(--surface);color:var(--accent);font-family:var(--font-mono);font-size:12px;padding:6px 12px}.feedback-body{padding:var(--gap-md) 28px}.score-table{width:100%;border-collapse:collapse;margin-bottom:var(--gap-md)}.score-table th,.score-table td{border-bottom:1px solid var(--border);padding:8px 0;text-align:left;font-size:13px}.score-table th{color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;font-weight:500}.score-table td:last-child,.score-table th:last-child{text-align:right}.bar-row{display:flex;align-items:center;gap:8px}.bar-row .bar{flex:1;min-width:80px}.compare-block{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:16px;margin-bottom:12px}.compare-block.corrected{background:var(--accent-tint);border-color:var(--accent-soft)}.compare-block .lbl{display:block;color:var(--muted);font-size:11px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.compare-block.corrected .lbl{color:var(--accent)}.compare-block .text{font-family:var(--font-display);font-size:17px;line-height:1.45}.compare-block del{color:var(--muted);opacity:.75}.compare-block ins{color:var(--accent);text-decoration:none;font-weight:650}.section-h{margin:22px 0 12px}.error-list{display:flex;flex-direction:column;gap:12px}.error-list li{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:14px 16px}.error-list .head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}.error-list .tag{border-radius:4px;background:var(--warn-tint);color:#efa831;font-size:10px;padding:3px 8px;text-transform:uppercase}.error-list .wrong{color:var(--muted);text-decoration:line-through;font-size:13px}.error-list .right{font-weight:550}.error-list .arrow{color:var(--accent);font-family:var(--font-mono)}.error-list .explain{color:var(--muted);font-size:13px}.strengths{border:1px solid var(--accent-soft);border-radius:var(--radius);background:var(--accent-tint);padding:16px;margin:16px 0}.strengths h4{color:var(--accent);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}.strengths ul{padding-left:18px}.feedback-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;border-top:1px solid var(--border);background:var(--bg);padding:var(--gap-md) 28px}.tts-toggle{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}.tts-toggle input{width:auto}.speaking-passage .missed,.missed{background:var(--warn-tint);border-bottom:2px solid var(--warning);border-radius:2px;padding-inline:2px}.recorder-row{display:grid;grid-template-columns:auto minmax(150px,1fr) minmax(180px,320px) auto;gap:16px;align-items:center}.rec-btn{width:62px;height:62px;border:1px solid var(--accent-soft);border-radius:999px;display:grid;place-items:center;background:var(--accent-tint);color:var(--accent)}.rec-btn svg{width:26px;height:26px}.rec-info .state{font-size:15px}.rec-info .sub{color:var(--muted);font-size:12px}.waveform{display:flex;align-items:center;gap:3px;height:54px;padding:0 8px}.waveform span{flex:1;min-width:3px;border-radius:999px;background:var(--accent);opacity:.72}.privacy-note{display:inline-flex;align-items:center;gap:8px;margin-top:18px;border-radius:999px;background:var(--fg-soft);color:var(--muted);padding:6px 10px;font-family:var(--font-mono);font-size:11px}.privacy-note svg{width:14px;height:14px;color:var(--accent)}.transcript-block{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-md);margin-bottom:var(--gap-md)}.transcript-block>div{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:16px}.transcript-block .lbl{display:block;color:var(--muted);font-size:11px;margin-bottom:8px}.feedback-notes{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:16px}.feedback-notes strong:first-child{color:var(--accent);font-family:var(--font-mono);font-size:11px}.feedback-notes ul{padding-left:18px;margin-top:10px}.page-head{max-width:1180px;margin:0 auto;padding:var(--gap-xl) var(--gutter) var(--gap-lg)}.page-head .lead{margin-top:14px}.toolbar{max-width:1180px;margin:0 auto;padding:0 var(--gutter) var(--gap-md);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.lookup-search{flex:1;min-width:240px}.lookup-search input{border:0;background:transparent;padding:0}.lookup-search input:focus{outline:0}.log-table,.models-table{width:100%;border-collapse:collapse}.log-table th,.log-table td,.models-table th,.models-table td{border-bottom:1px solid var(--border);padding:14px;text-align:left;vertical-align:top}.log-table th,.models-table th{color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;font-weight:500}.log-table tbody tr:hover,.models-table tbody tr:hover{background:var(--fg-soft)}.type-tag{width:28px;height:28px;display:inline-grid;place-items:center;border:1px solid var(--border);border-radius:6px;color:var(--muted);font-family:var(--font-mono);font-size:11px}.type-tag.w{background:var(--accent-tint);color:var(--accent);border-color:var(--accent-soft)}.preview-text{display:block;max-width:40ch;font-family:var(--font-display);font-size:17px;line-height:1.3}.preview-text.long{font-family:var(--font-body);font-size:14px}.preview-vi{display:block;color:var(--muted);font-size:13px;margin-top:4px}.cefr{border-radius:4px;background:var(--fg-soft);color:var(--muted);font-size:10px;padding:2px 6px}.num-col,.meta-col{color:var(--muted);font-family:var(--font-mono);font-size:12px}.pagination{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;color:var(--muted);margin-top:var(--gap-lg);font-size:13px}.pages{display:flex;gap:4px;flex-wrap:wrap}.pages button{border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--fg);padding:6px 10px}.pages .active{background:var(--fg);color:var(--surface)}.lookup-head{max-width:1080px}.crumbs{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;margin-bottom:24px}.word-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--gap-lg);flex-wrap:wrap;margin-bottom:16px}.word-head .word{font-size:clamp(44px,7vw,76px);line-height:1}.ipa{color:var(--muted);font-family:var(--font-mono);font-size:18px;margin-top:12px}.head-actions,.head-meta{display:flex;gap:8px;flex-wrap:wrap}.translation-panel{background:linear-gradient(180deg,var(--accent-tint),transparent 60%),var(--surface);border-color:var(--accent-soft)}.vi-big{font-family:var(--font-display);font-size:clamp(24px,3vw,30px);line-height:1.3;margin-bottom:12px}.meaning-en{color:var(--muted)}.audio-row{display:flex;align-items:center;gap:12px;margin-top:12px}.play-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:999px;background:var(--bg);color:var(--fg);padding:8px 14px;font-family:var(--font-mono);font-size:13px}.play-btn svg{width:14px;height:14px;color:var(--accent)}.example-block{border-top:1px solid var(--border);padding:16px 0}.example-block:first-of-type{border-top:0;padding-top:0}.example-block .en{font-family:var(--font-display);font-size:17px;line-height:1.45}.example-block .vi{margin-top:6px;font-size:14px}.grammar-list{display:flex;flex-direction:column;gap:12px;padding:0;list-style:none}.grammar-list li{position:relative;padding-left:18px;font-size:14px}.grammar-list li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:999px;background:var(--accent)}.mistake-row{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;border-top:1px solid var(--border);padding:12px 0}.mistake-row:first-of-type{border-top:0}.mistake-row .wrong{color:var(--muted);text-decoration:line-through}.mistake-row .arrow{color:var(--accent);font-family:var(--font-mono)}.mistake-row .right strong{color:var(--accent)}.rail .panel{padding:22px}.rail h3{font-family:var(--font-display);font-size:16px;margin-bottom:12px}.card-types-list{display:flex;flex-direction:column;gap:10px}.card-types-list li{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:10px 12px}.card-types-list small{display:block;color:var(--muted);font-family:var(--font-mono);font-size:11px;margin-top:2px}.card-types-list .due{color:var(--accent);font-family:var(--font-mono);font-size:11px}.source-link{display:flex;align-items:flex-start;gap:12px;font-size:13px;margin-bottom:14px}.favicon{width:20px;height:20px;border-radius:4px;background:var(--fg-soft);color:var(--muted);display:grid;place-items:center;font-family:var(--font-mono);font-size:10px}.source-link a{color:var(--accent)}.context-quote{border-left:3px solid var(--accent);border-radius:4px;background:var(--bg);padding:14px 16px;font-family:var(--font-display);font-size:15px}.context-quote em{font-style:normal;background:var(--accent-tint);border-bottom:2px solid var(--accent)}.meta-row{display:flex;justify-content:space-between;gap:12px;border-top:1px solid var(--border);padding:8px 0;font-size:13px}.meta-row:first-of-type{border-top:0}.meta-row .k{color:var(--muted);font-family:var(--font-mono);font-size:12px}.stat-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--gap-md);margin-bottom:var(--gap-lg)}.stat-card{padding:22px}.stat-card .lbl,.metric .lbl{color:var(--muted);font-size:11px;letter-spacing:.08em;text-transform:uppercase}.stat-card .n{font-family:var(--font-display);font-size:clamp(28px,3.6vw,42px);line-height:1.05;margin-top:8px}.stat-card .accent,.metric .ok{color:var(--accent)}.metric .warn{color:var(--warning)}.weak-lead{margin:-18px 0 var(--gap-lg)}.cat-list li{display:grid;grid-template-columns:1.2fr 1fr 64px 70px;gap:12px;align-items:center;border-top:1px solid var(--border);padding:13px 0}.cat-list li:first-child{border-top:0}.cat-list .name{font-weight:650}.cat-list small{display:block;color:var(--muted);font-weight:400;font-size:12px}.cat-list .count{text-align:right;font-family:var(--font-mono)}.cat-list .drill{color:var(--accent);font-family:var(--font-mono);font-size:12px}.trend-chart{width:100%;height:180px;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border)}.trend-legend{display:flex;flex-wrap:wrap;gap:16px;color:var(--muted);font-size:12px;margin-top:12px}.trend-legend span{display:inline-flex;align-items:center;gap:6px}.trend-legend .dot{width:8px;height:8px;border-radius:999px;background:var(--accent)}.trend-legend .muted{background:var(--muted)}.suggestion{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;border-top:1px solid var(--border);padding:14px 0}.suggestion:first-of-type{border-top:0}.suggestion .ico{width:34px;height:34px;display:grid;place-items:center;color:var(--accent);border:1px solid var(--border);border-radius:8px}.suggestion h4{font-size:14px}.suggestion p{color:var(--muted);font-size:12px}.suggestion .arrow{color:var(--accent)}.word-list li{display:flex;justify-content:space-between;gap:10px;border-top:1px solid var(--border);padding:10px 0;color:var(--muted);font-size:13px}.word-list li:first-child{border-top:0}.word-list .badge{color:var(--accent);font-family:var(--font-mono)}.settings-layout{display:grid;grid-template-columns:230px minmax(0,820px);gap:var(--gap-xl);max-width:1180px;margin:0 auto;padding:var(--gap-xl) var(--gutter);align-items:start}.settings-sidenav{position:sticky;top:86px;display:flex;flex-direction:column;gap:2px}.settings-sidenav a{border-radius:8px;color:var(--muted);padding:9px 12px;font-size:14px}.settings-sidenav a.active,.settings-sidenav a:hover{background:var(--accent-tint);color:var(--accent)}.settings-head{padding:0 0 var(--gap-md);margin:0}.grid-2 .field{margin-bottom:0}.key-status{display:flex;align-items:center;gap:8px;border-radius:var(--radius);background:var(--accent-tint);color:var(--muted);padding:12px;margin-top:16px;font-size:13px}.key-status svg{color:var(--accent)}.slider-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.slider{padding:0;accent-color:var(--accent)}.slider-val{min-width:34px;font-family:var(--font-mono)}.toggle-row{display:flex;justify-content:space-between;gap:16px;align-items:center;border-top:1px solid var(--border);padding:14px 0}.toggle-row .body h4{font-size:14px;margin-bottom:2px}.toggle-row .body p{color:var(--muted);font-size:13px}.switch input{width:auto;accent-color:var(--accent)}.device-list{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.device-list li{display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;border-top:1px solid var(--border);padding:12px 0}.device-list .icon{width:30px;height:30px;display:grid;place-items:center;color:var(--accent)}.device-list h4{font-size:14px}.device-list p{color:var(--muted);font-size:12px}.status{border-radius:999px;padding:3px 8px;font-family:var(--font-mono);font-size:11px}.status.active{background:var(--accent-tint);color:var(--accent)}.status.revoked{background:var(--fg-soft);color:var(--muted)}.revoke{border:0;background:transparent;color:var(--danger);font-size:12px}.danger-row{border-top-color:var(--fg)}.admin-tag{border:1px solid var(--accent-soft);border-radius:999px;background:var(--accent-tint);color:var(--accent);font-family:var(--font-mono);font-size:12px;padding:6px 12px}.status-banner{display:grid;grid-template-columns:auto 1fr auto;gap:var(--gap-md);align-items:center;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);padding:22px;margin-bottom:var(--gap-md)}.status-banner.warn{background:linear-gradient(180deg,var(--warn-tint),transparent 80%),var(--surface);border-color:color-mix(in oklch,var(--warning) 28%,var(--border))}.status-dot{width:12px;height:12px;border-radius:999px;background:var(--warning)}.status-banner h2{font-size:22px}.status-banner p{color:var(--muted)}.refresh{color:var(--muted);font-size:12px;font-family:var(--font-mono);text-align:right}.refresh a{color:var(--accent);text-decoration:underline}.tabs{display:flex;gap:4px;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:var(--gap-md)}.tabs button{border:0;border-bottom:2px solid transparent;background:transparent;color:var(--muted);padding:10px 12px}.tabs .active{color:var(--accent);border-bottom-color:var(--accent)}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--gap-md);margin-bottom:var(--gap-md)}.alert-list{display:flex;flex-direction:column;gap:10px}.alert-list li{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);padding:12px}.alert-list .crit{border-color:color-mix(in oklch,var(--danger) 40%,var(--border))}.alert-sev{border-radius:999px;padding:4px 8px;font-family:var(--font-mono);font-size:10px;text-transform:uppercase}.alert-sev.crit{background:var(--danger-tint);color:var(--danger)}.alert-sev.warn{background:var(--warn-tint);color:var(--warning)}.alert-body h4{font-size:13px}.alert-body p{color:var(--muted);font-size:12px}.alert-actions{display:flex;gap:6px}.alert-actions button{border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--fg);padding:5px 8px;font-size:12px}.provider-list{display:flex;flex-direction:column}.provider-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;border-top:1px solid var(--border);padding:12px 0}.provider-row:first-child{border-top:0}.provider-row .ico{width:34px;height:34px;border:1px solid var(--border);border-radius:8px;display:grid;place-items:center;color:var(--accent);font-family:var(--font-mono);font-size:11px}.provider-row .name{font-weight:650;font-size:14px}.provider-row .sub{color:var(--muted);font-size:12px}.provider-status{color:var(--accent);font-family:var(--font-mono);font-size:11px;text-align:right}.provider-status.warn{color:var(--warning)}.models-table .key{color:var(--fg);font-family:var(--font-mono);font-size:12px}.purpose,.status-tag{border-radius:999px;padding:3px 8px;background:var(--fg-soft);color:var(--muted);font-family:var(--font-mono);font-size:10px}.status-tag{color:var(--accent);background:var(--accent-tint)}.status-tag.warn{color:var(--warning);background:var(--warn-tint)}.event-log{display:flex;flex-direction:column}.event-row{display:grid;grid-template-columns:76px 42px 1fr;gap:10px;border-top:1px solid var(--border);padding:9px 0;font-size:12px}.event-row:first-child{border-top:0}.event-row .ts,.event-row .sev{font-family:var(--font-mono);color:var(--muted)}.event-row .crit{color:var(--danger)}.event-row .warn{color:var(--warning)}.event-row .ok{color:var(--accent)}.mobile-bottom-nav,.more-sheet,.more-backdrop{display:none}@media(max-width:1020px){.module-grid,.stat-row,.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.layout,.lower-grid,.grid-3{grid-template-columns:1fr}}@media(max-width:920px){.grid-2,.grid-1-2,.grid-2-1,.plan-card{grid-template-columns:1fr}.plan-side{border-left:0;border-top:1px solid var(--border)}.login-layout{grid-template-columns:1fr}.brand-panel{min-height:auto;gap:var(--gap-xl)}.settings-layout{grid-template-columns:1fr}.settings-sidenav{position:static;flex-direction:row;overflow-x:auto}.settings-sidenav a{white-space:nowrap}.recorder-row{grid-template-columns:auto 1fr}.waveform{grid-column:1 / -1}}@media(max-width:820px){:root{--gutter: 18px}body:has(.mobile-bottom-nav){padding-bottom:calc(64px + env(safe-area-inset-bottom,0))}.topnav nav,.topbar .search-box,.topbar .lang-toggle,.sidenav{display:none}.topnav-inner{padding-block:10px}.logo,.brand,.brand-mark{font-size:19px}.app-shell{grid-template-columns:1fr}.topbar{padding-block:12px;gap:10px}.topbar h1{font-size:18px}.topbar .vi{font-size:11px}#theme-toggle{bottom:calc(72px + env(safe-area-inset-bottom,0));right:14px;width:32px;height:32px}.mobile-bottom-nav{display:block;position:fixed;left:0;right:0;bottom:0;z-index:50;border-top:1px solid var(--border);background:color-mix(in oklch,var(--bg) 88%,transparent);-webkit-backdrop-filter:blur(20px) saturate(140%);backdrop-filter:blur(20px) saturate(140%);padding-bottom:env(safe-area-inset-bottom,0)}.mobile-bottom-nav-inner{display:grid;grid-template-columns:repeat(5,1fr);max-width:480px;height:60px;margin:0 auto}.mobile-bottom-nav a,.mobile-bottom-nav button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:0;background:transparent;color:var(--muted);padding:8px 4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;position:relative}.mobile-bottom-nav svg{width:20px;height:20px}.mobile-bottom-nav .active{color:var(--accent)}.mobile-bottom-nav .active:before{content:"";position:absolute;left:28%;right:28%;top:0;height:2px;background:var(--accent);border-radius:0 0 2px 2px}.more-backdrop{position:fixed;inset:0;z-index:55;border:0;background:#00000073;opacity:0;pointer-events:none;transition:opacity .25s}.more-backdrop.open{display:block;opacity:1;pointer-events:auto}.more-sheet{display:block;position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--surface);border-top:1px solid var(--border);border-radius:18px 18px 0 0;padding:12px 16px calc(20px + env(safe-area-inset-bottom,0));transform:translateY(100%);transition:transform .25s ease;box-shadow:0 -10px 40px #00000059}.more-sheet.open{transform:translateY(0)}.more-handle{width:36px;height:4px;background:var(--border);border-radius:999px;margin:0 auto 14px}.more-sheet h4{color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}.more-list{list-style:none;margin:0;padding:0}.more-list a{display:flex;align-items:center;gap:14px;padding:12px 8px;border-radius:10px}.more-list a:hover{background:var(--fg-soft)}.more-list svg{width:18px;height:18px;color:var(--muted)}.more-list .active,.more-list .active svg{color:var(--accent)}.more-list .vi{margin-left:auto;font-family:var(--font-mono);font-size:12px}}@media(max-width:720px){.nav-actions .btn-ghost,.browser-bar .meta{display:none}.extension-popup{position:static;width:100%;margin-top:18px}.floating-icon{display:none}.topnav .container{flex-wrap:nowrap}.card-head,.feedback-head,.status-banner{grid-template-columns:1fr}.card-meta-r,.refresh{text-align:left}.rating-row{grid-template-columns:repeat(2,1fr)}.session-info,.transcript-block{grid-template-columns:1fr}.log-table thead{display:none}.log-table,.log-table tbody,.log-table tr,.log-table td{display:block;width:100%}.log-table tr{border-bottom:1px solid var(--border);padding:16px 0}.log-table td{border:0;padding:4px 0}.cat-list li{grid-template-columns:1fr;gap:8px}.cat-list .count{text-align:left}.device-list li,.provider-row,.alert-list li{grid-template-columns:1fr}.provider-status{text-align:left}.models-table{display:block;overflow-x:auto;white-space:nowrap}.event-row{grid-template-columns:1fr;gap:4px}}@media(max-width:640px){.section{padding-block:54px}.hero h1{font-size:42px}.plan-stats,.stat-row,.metric-grid,.module-grid{grid-template-columns:1fr;display:grid;gap:var(--gap-md)}.lookup-list li{grid-template-columns:auto 1fr}.lookup-list .meta-r{grid-column:2;text-align:left}.recorder-row{grid-template-columns:1fr}.rec-btn{margin:0 auto}.waveform{grid-column:auto}.feedback-foot,.answer-actions,.head-row{align-items:stretch}.feedback-foot .row,.answer-actions .btn{width:100%}.feedback-foot .row .btn{flex:1}.kbd-hints{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}}
