@import"https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&family=Instrument+Serif:ital@0;1&display=swap";:root{--bg: #FAFAF7;--bg-sunken: #F4F2EC;--surface: #FFFFFF;--surface-2: #FBFAF6;--tint-blue: #EEF1FF;--tint-blue-2: #E2E8FF;--tint-green: #E8F3EC;--tint-amber: #F8EFD8;--tint-coral: #F8E5DF;--border: #EBE8DF;--border-2: #DEDAD0;--ink: #15181E;--ink-2: #43474F;--ink-3: #767A82;--ink-4: #A8ABB2;--blue: #2E4BD9;--blue-deep: #1F35A6;--green: #1E8E5A;--amber: #B07B12;--coral: #BB4530;--font-sans: "Geist", ui-sans-serif, system-ui, sans-serif;--font-mono: "Geist Mono", ui-monospace, monospace;--font-serif: "Instrument Serif", "Times New Roman", serif;color:var(--ink);background:var(--bg);font-family:var(--font-sans)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea{font:inherit}button{color:inherit}.app-shell{min-height:100vh;display:grid;grid-template-columns:232px minmax(0,1fr);background:var(--bg)}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:16px;padding:24px 18px;border-right:1px solid var(--border);background:var(--surface-2)}.identity{display:flex;align-items:center;gap:12px;padding:6px 6px 16px}.avatar{width:38px;height:38px;border-radius:50%;flex:0 0 auto;overflow:hidden;background:var(--surface-2)}.avatar img{width:100%;height:100%;display:block;object-fit:cover;object-position:center 22%}.identity-copy{min-width:0}.identity-copy strong,.identity-copy span{display:block}.identity-copy strong{font-size:13.5px;letter-spacing:-.01em}.identity-copy span{margin-top:2px;color:var(--ink-3);font-size:11.5px}.side-nav{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;width:100%;min-height:36px;border:0;border-radius:8px;background:transparent;color:var(--ink-2);cursor:pointer;padding:8px 10px;text-align:left;font-size:13.5px}.nav-item svg{color:var(--ink-4)}.nav-item.is-active{background:var(--surface);box-shadow:inset 0 0 0 1px var(--border);color:var(--ink);font-weight:550}.nav-item.is-active svg{color:var(--blue)}.active-dot{width:4px;height:4px;margin-left:auto;border-radius:50%;background:var(--blue)}.next-card,.connection-card{border:1px solid var(--border);border-radius:12px;background:var(--surface)}.next-card{margin-top:auto;padding:14px}.next-card strong,.next-card span{display:block}.next-card strong{margin-top:6px;font-size:14px}.next-card span{margin-top:2px;color:var(--ink-3);font-size:11.5px}.days-row{display:flex;align-items:baseline;gap:5px;margin-top:12px}.days-row b{font:400 32px/1 var(--font-serif)}.connection-card{display:flex;align-items:center;gap:8px;padding:10px 12px;color:var(--ink-3);font-size:11.5px}.sign-out-button{display:flex;align-items:center;gap:8px;width:100%;min-height:36px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--ink-3);cursor:pointer;padding:9px 12px;font-size:11.5px;text-align:left}.sign-out-button span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sign-out-button svg{flex:0 0 auto;color:var(--ink-4)}.app-main{min-width:0;height:100vh;display:flex;flex-direction:column;overflow:hidden}.student-error-stack{position:fixed;top:16px;right:18px;z-index:80;width:min(430px,calc(100vw - 36px));max-height:calc(100vh - 32px);display:flex;flex-direction:column;gap:10px;overflow:auto;pointer-events:none}.student-error-card{display:grid;grid-template-columns:30px minmax(0,1fr) 28px;gap:10px;border:1px solid #F0E0C6;border-left:4px solid var(--amber);border-radius:12px;background:var(--surface);box-shadow:0 18px 44px -28px #15181e73;color:var(--ink);padding:12px 10px 12px 12px;pointer-events:auto}.student-error-card.severity-critical{border-color:#f0d2c6;border-left-color:var(--coral)}.student-error-card.severity-info{border-color:var(--tint-blue-2);border-left-color:var(--blue)}.student-error-icon{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;background:var(--tint-amber);color:var(--amber)}.student-error-card.severity-critical .student-error-icon{background:var(--tint-coral);color:var(--coral)}.student-error-card.severity-info .student-error-icon{background:var(--tint-blue);color:var(--blue)}.student-error-copy{min-width:0}.student-error-copy h2{margin:1px 0 4px;font-size:13.5px;font-weight:650;letter-spacing:0}.student-error-copy p{margin:0;color:var(--ink-2);font-size:12.5px;line-height:1.4}.student-error-copy strong{display:block;margin-top:7px;color:var(--ink);font:500 11.5px/1.35 var(--font-mono);letter-spacing:0}.student-error-copy code,.app-fatal code{white-space:nowrap;font:inherit}.student-error-dismiss{width:28px;height:28px;display:grid;place-items:center;border:0;border-radius:8px;background:transparent;color:var(--ink-3);cursor:pointer}.student-error-dismiss:hover{background:var(--surface-2);color:var(--ink)}.app-fatal{min-height:100vh;display:grid;place-items:center;padding:28px;background:var(--bg)}.app-fatal section{width:min(520px,100%);border:1px solid var(--border);border-left:4px solid var(--coral);border-radius:12px;background:var(--surface);padding:24px;box-shadow:0 20px 60px -38px #15181e80}.app-fatal h1{margin:8px 0 10px;font-size:24px;letter-spacing:0}.app-fatal p{color:var(--ink-2);line-height:1.5}.app-fatal strong{display:block;margin:14px 0 18px;font:500 12px/1.4 var(--font-mono)}.app-fatal button{min-height:38px;border:0;border-radius:10px;background:var(--ink);color:#fff;cursor:pointer;padding:9px 14px;font-weight:600}@media(max-width:760px){.student-error-stack{top:84px;right:12px;width:calc(100vw - 24px);max-height:calc(100vh - 100px)}.student-error-card{grid-template-columns:28px minmax(0,1fr) 28px}}.auth-screen{min-height:100vh;display:grid;grid-template-columns:minmax(420px,1.05fr) minmax(360px,1fr);background:var(--bg);color:var(--ink)}.auth-brand{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;background:#293b2d;color:#fbfaf4;padding:56px 64px}.auth-brand:after{content:"";position:absolute;inset:auto -18% -30% 22%;height:46%;border:1px solid rgba(251,250,244,.12);border-radius:50%;pointer-events:none}.auth-brand-topline{position:relative;z-index:1;display:flex;align-items:center;gap:10px;color:#fbfaf4a3;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0}.auth-brand-line{height:1px;flex:1;min-width:42px;background:#fbfaf438}.auth-brand-core{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;gap:24px}.auth-logo-frame{width:132px;height:132px;display:grid;place-items:center;border-radius:20px;background:#fbfaf4;box-shadow:0 22px 60px #09130c38}.auth-logo-frame img{width:108px;height:108px;display:block;object-fit:contain}.auth-brand h1{max-width:480px;margin:0;color:#fbfaf4;font:italic 400 54px/1.04 var(--font-serif);letter-spacing:0}.auth-brand p{position:relative;z-index:1;max-width:360px;margin:0;color:#fbfaf4a8;font-size:13px;line-height:1.5}.auth-form-panel{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:64px;background:var(--bg)}.auth-form{width:min(340px,100%);display:flex;flex-direction:column;gap:14px}.auth-form-heading{margin-bottom:8px}.auth-form-heading span,.auth-field>span,.auth-divider b{color:var(--ink-3);font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0}.auth-form-heading h2{margin:6px 0 0;color:var(--ink);font:italic 400 26px/1.12 var(--font-serif);letter-spacing:0}.auth-alert,.auth-message{border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--ink-2);padding:10px 12px;font-size:12.5px;line-height:1.35}.auth-message.is-error,.auth-alert{border-color:#e7bfb5;background:#fcf0ec;color:#8f2d1f}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field>span{display:flex;align-items:baseline;justify-content:space-between}.auth-input-wrap{display:flex;align-items:center;gap:10px;min-height:44px;border:1px solid var(--border-2);border-radius:10px;background:var(--surface);padding:0 13px;transition:border-color .12s ease,box-shadow .12s ease}.auth-input-wrap:focus-within{border-color:#293b2d;box-shadow:0 0 0 3px #293b2d1a}.auth-input-wrap svg{flex:0 0 auto;color:var(--ink-4)}.auth-input-wrap input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--ink);font-size:14px;padding:11px 0}.auth-input-wrap input::placeholder{color:var(--ink-4)}.auth-input-wrap input:disabled{cursor:not-allowed}.auth-inline-action{border:0;background:transparent;color:var(--ink-3);cursor:pointer;font-size:11.5px;padding:0}.auth-inline-action:disabled{cursor:not-allowed;opacity:.55}.auth-submit,.auth-google{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:10px;border:1px solid transparent;cursor:pointer;font-size:14px;font-weight:500}.auth-submit{margin-top:6px;background:#293b2d;color:#fff}.auth-submit:disabled,.auth-google:disabled{cursor:not-allowed;opacity:.62}.auth-divider{display:flex;align-items:center;gap:10px;margin:4px 0}.auth-divider span{height:1px;flex:1;background:var(--border)}.auth-google{background:var(--surface);color:var(--ink);border-color:var(--border-2)}.auth-google-mark{width:18px;height:18px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,#ea4335,#fbbc05 40%,#34a853 65%,#4285f4);color:#fff;font-size:10px;font-weight:700}.auth-invite{margin:4px 0 0;color:var(--ink-3);font-size:12.5px;text-align:center}.auth-invite a{color:#293b2d;font-weight:500;text-decoration:underline;text-underline-offset:3px}.auth-spin{animation:auth-spin .9s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}@media(max-width:860px){.auth-screen{grid-template-columns:1fr}.auth-brand,.auth-form-panel{min-height:auto}.auth-brand{gap:42px;padding:34px 28px 38px}.auth-brand h1{font-size:40px}.auth-logo-frame{width:104px;height:104px;border-radius:16px}.auth-logo-frame img{width:86px;height:86px}.auth-form-panel{align-items:flex-start;padding:38px 24px 46px}}@media(max-width:480px){.auth-brand{padding:28px 20px 34px}.auth-brand-topline{flex-wrap:wrap}.auth-brand-line{order:3;flex-basis:100%}.auth-brand h1{font-size:34px}.auth-form-panel{padding:32px 18px 42px}}.topbar{flex:0 0 auto;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;padding:28px 40px 22px;border-bottom:1px solid var(--border);background:var(--bg)}.topbar h1{margin:0;font-size:26px;font-weight:520;letter-spacing:-.02em}.topbar h1.topbar-summary{font-size:22px;line-height:1.38}.topbar h1 em,.vocab-page h1 em{font-family:var(--font-serif);font-style:italic;font-weight:400}.topbar-actions,.button-row,.pill-row,.header-left,.header-right{display:flex;align-items:center;gap:10px}.topbar-actions{flex:0 0 auto}.eyebrow{color:var(--ink-3);font:500 10.5px/1.2 var(--font-mono);letter-spacing:.1em;text-transform:uppercase}.btn{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:10px;cursor:pointer;padding:9px 15px;font-size:13.5px;font-weight:560;letter-spacing:-.005em;white-space:nowrap}.btn span{white-space:nowrap}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;flex-shrink:0}.btn-icon svg{display:block}.btn:disabled{cursor:not-allowed;opacity:.64}.btn-primary{background:var(--ink);color:#fff}.btn-blue{background:var(--blue);color:#fff}.btn-ghost{border-color:var(--border-2);background:transparent;color:var(--ink)}.btn-danger{background:var(--coral);color:#fff}.btn.wide{width:100%;min-height:46px}@keyframes btn-shine-sweep{0%{transform:translate(-120%)}to{transform:translate(120%)}}.btn-primary,.btn-blue,.flash-show-button,.setup-start-button{position:relative;overflow:hidden;transition:transform .16s ease,box-shadow .16s ease}.btn-primary:after,.btn-blue:after,.flash-show-button:after,.setup-start-button:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.32) 50%,transparent 70%);transform:translate(-120%);pointer-events:none}.btn-primary:hover:not(:disabled):after,.btn-blue:hover:not(:disabled):after,.flash-show-button:hover:after,.setup-start-button:hover:after{animation:btn-shine-sweep .7s cubic-bezier(.4,0,.3,1) forwards}.btn-primary:hover:not(:disabled),.flash-show-button:hover,.setup-start-button:hover{transform:translateY(-2px);box-shadow:0 1px #ffffff1a inset,var(--setup-btn-hover-shadow, 0 10px 22px -8px rgba(20,22,28,.45))}.btn-blue:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 1px #ffffff24 inset,0 18px 30px -12px #2e4bd98c}.pill{display:inline-flex;align-items:center;gap:6px;width:max-content;max-width:100%;border:1px solid var(--border-2);border-radius:999px;padding:3px 8px;color:var(--ink-2);background:transparent;font:500 10.5px/1.2 var(--font-mono);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}.pill-blue{border-color:var(--tint-blue-2);background:var(--tint-blue);color:var(--blue-deep)}.pill-green{border-color:#c9e5d2;background:var(--tint-green);color:var(--green)}.pill-amber{border-color:#ebd8a5;background:var(--tint-amber);color:var(--amber)}.pill-red{border-color:#f0d2c6;background:var(--tint-coral);color:var(--coral)}.search-button{min-width:320px;min-height:36px;display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--ink-3);cursor:pointer;padding:8px 12px;text-align:left;font-size:12.5px}.search-button kbd{margin-left:auto;border:1px solid var(--border);border-radius:4px;color:var(--ink-4);background:var(--surface-2);padding:1px 5px;font:500 10.5px/1 var(--font-mono)}.dashboard-grid{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1.6fr) minmax(320px,1fr);gap:28px;overflow:auto;padding:28px 40px 32px}.stack{display:flex;flex-direction:column;gap:22px;min-width:0}.hero-strip,.card{border:1px solid var(--border);border-radius:14px;background:var(--surface)}.hero-strip{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:20px 24px}.hero-strip h2{margin:0;font:italic 32px/1.1 var(--font-serif);letter-spacing:-.01em}.hero-strip p{margin:7px 0 0;color:var(--ink-3);font-size:13px}.stat-row{display:flex;align-items:center;gap:22px}.mini-stat{min-width:78px}.mini-stat span,.mini-stat small{display:block;color:var(--ink-3)}.mini-stat span{font:500 10px/1.2 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.mini-stat strong{display:flex;align-items:center;gap:5px;margin-top:5px;font-size:21px;font-weight:520;letter-spacing:-.02em}.mini-stat strong svg{color:var(--green)}.mini-stat small{margin-top:2px;font-size:11px}.card{overflow:hidden}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:18px 22px 14px}.card-header h2{margin:0;font-size:14.5px;font-weight:650;letter-spacing:-.01em}.card-header p{margin:3px 0 0;color:var(--ink-3);font-size:12px}.link-button{border:0;background:transparent;color:var(--ink-2);cursor:pointer;padding:0;font-size:12.5px}.readiness-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;border-top:1px solid var(--border);background:var(--border)}.track-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:14px;border:0;background:var(--surface);cursor:pointer;padding:18px 22px;text-align:left}.track-card strong,.story-mini-list strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}.track-card span:not(.pill){display:block;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink-3);font-size:12px}.score-ring{position:relative;flex:0 0 auto}.score-ring svg{display:block;transform:rotate(-90deg)}.score-ring>div{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:2px}.score-ring strong{display:block;font-size:17px;font-weight:650;line-height:1}.score-ring span{display:block;color:var(--ink-3);font:500 8.5px/1 var(--font-mono);letter-spacing:.05em;text-transform:uppercase}.work-list{padding:4px 0}.work-row{display:grid;grid-template-columns:28px minmax(0,1fr) auto auto;align-items:center;gap:14px;padding:14px 22px;border-top:1px solid var(--border)}.work-row:first-child{border-top:0}.row-number{color:var(--ink-4);font:500 11px/1 var(--font-mono)}.work-row strong{display:block;font-size:13.5px;font-weight:560}.work-row p{margin:3px 0 0;color:var(--ink-3);font-size:12px}.small-ghost{border:1px solid var(--border-2);border-radius:8px;background:var(--surface);cursor:pointer;padding:6px 11px;color:var(--ink);font-size:12px}.recommend-card{padding:20px 22px 22px;background:linear-gradient(180deg,#fff,#f4f2ec)}.recommend-card h3{margin:13px 0 0;font:400 22px/1.25 var(--font-serif);letter-spacing:-.005em}.recommend-card p{margin:14px 0 0;color:var(--ink-2);font-size:12.5px;line-height:1.55}.pill-row{flex-wrap:wrap;margin-top:14px}.button-row{margin-top:18px}.button-row.center{justify-content:center}.story-mini-list{padding:6px 22px 18px}.story-mini-list button{width:100%;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;border:0;border-top:1px solid var(--border);background:transparent;cursor:pointer;padding:10px 0;text-align:left}.story-mini-list button:first-child{border-top:0}.story-mini-list small{display:block;color:var(--ink-3);font-size:11.5px}.story-mini-list em{color:var(--ink-3);font:normal 11px/1 var(--font-mono)}.mini-swatch{width:14px;height:14px;border-radius:4px;background:var(--border-2)}.mini-swatch.active{background:var(--blue)}.setup-grid{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:32px;overflow:auto;padding:32px 40px}@keyframes restore-spin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.btn-restore-spin .btn-icon{animation:restore-spin .5s cubic-bezier(.4,0,.2,1);transform-origin:center center}.setup-sections{display:flex;flex-direction:column;gap:28px}.section-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}.section-head.inline{align-items:baseline}.section-head.inline .section-copy{display:flex;align-items:baseline;flex-wrap:wrap;gap:10px}.section-head>span{color:var(--ink-4);font:500 11px/1 var(--font-mono);letter-spacing:.1em}.section-head h2,.section-line h2{margin:0;font-size:16px;font-weight:650;letter-spacing:-.01em}.section-head p{margin:3px 0 0;color:var(--ink-3);font-size:12.5px}.section-head.inline p{margin:0}.section-head.collapsible-head{cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:0;padding-bottom:14px;border-radius:8px;transition:background .12s ease}.section-head.collapsible-head:hover{background:var(--bg-sunken)}.section-head.collapsible-head:hover .section-chevron{color:var(--ink)}.section-toggle{margin-left:auto;display:flex;align-items:center;gap:8px;flex-shrink:0}.section-chevron{color:var(--ink-4);transition:transform .2s ease,color .15s ease;transform:rotate(0)}.section-chevron.open{transform:rotate(90deg)}.section-selected-label{font-size:12px;color:var(--ink-3);font-weight:500;background:var(--bg-sunken);border-radius:6px;padding:3px 8px}.choice-grid{display:grid;gap:12px}.choice-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.choice-card{position:relative;min-height:100px;display:grid;grid-template-columns:auto minmax(0,1fr);align-content:start;gap:8px 12px;border:1px solid var(--border);border-radius:12px;background:var(--surface);cursor:pointer;padding:16px 18px;text-align:left}.choice-card.compact{min-height:86px;display:block}.choice-card.compact span:not(.track-dot):not(.pill){display:inline;margin-left:2px}.choice-card.selected{border-color:var(--ink);box-shadow:inset 0 0 0 1px var(--ink)}.choice-card strong{font-size:14.5px}.choice-card span:not(.track-dot):not(.pill){grid-column:2;color:var(--ink-3);font-size:12.5px;line-height:1.4}.choice-card .pill{grid-column:2;margin-top:4px}.track-dot{width:10px;height:10px;margin-top:5px;border-radius:50%}.chip-cloud{display:flex;flex-wrap:wrap;gap:8px}.chip{border:1px solid var(--border-2);border-radius:999px;background:var(--surface);cursor:pointer;padding:7px 13px;color:var(--ink);font-size:12.5px}.chip.selected{border-color:var(--ink);background:var(--ink);color:#fff}.setup-aside{align-self:start;display:flex;flex-direction:column;gap:14px}.summary-panel{border:1px solid var(--border);border-radius:16px;background:var(--surface);padding:24px}.summary-panel h2{margin:14px 0 0;font:400 26px/1.2 var(--font-serif);letter-spacing:-.01em}.summary-panel h2 span{border-bottom:2px solid var(--blue)}.summary-panel h2 em{font-style:italic}.summary-rows{display:flex;flex-direction:column;gap:14px;margin-top:22px;border-top:1px solid var(--border);padding-top:18px}.summary-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.summary-row>span{flex:0 0 auto;color:var(--ink-3);font:500 10.5px/1.3 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.summary-row strong{color:var(--ink);font-size:12.5px;font-weight:500;line-height:1.4;text-align:right}.prompt-preview{margin:18px 0;border:1px solid var(--border);border-radius:10px;background:var(--bg-sunken);padding:12px 14px}.prompt-preview span{color:var(--ink-3);font:500 10px/1.2 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.prompt-preview p{margin:7px 0 0;color:var(--ink-2);font-size:12.5px;line-height:1.5}.setup-start-panel{--setup-panel-bg: linear-gradient(180deg, #F2F4FF 0%, var(--tint-blue-2) 100%);--setup-panel-shadow: inset 0 1px 0 rgba(255, 255, 255, .6), 0 12px 30px -12px rgba(46, 75, 217, .28);--setup-panel-ink: var(--blue-deep);--setup-panel-muted: rgba(31, 53, 166, .65);--setup-panel-orb: rgba(46, 75, 217, .06);--setup-toggle-bg: rgba(46, 75, 217, .08);--setup-toggle-selected-ink: var(--blue-deep);--setup-toggle-shadow: rgba(46, 75, 217, .18);--setup-btn-bg: var(--blue);--setup-btn-ink: #fff;--setup-btn-shadow: 0 6px 18px -6px rgba(46, 75, 217, .55);--setup-btn-hover-shadow: 0 10px 22px -8px rgba(46, 75, 217, .55);border-radius:16px;background:var(--setup-panel-bg);box-shadow:var(--setup-panel-shadow);color:var(--setup-panel-ink);overflow:hidden;padding:16px 18px;position:relative}.setup-start-panel.tone-tt{--setup-panel-bg: linear-gradient(180deg, #EAF4ED 0%, #D5E8DC 100%);--setup-panel-shadow: inset 0 1px 0 rgba(255, 255, 255, .6), 0 12px 30px -12px rgba(30, 142, 90, .3);--setup-panel-ink: #0E5C3A;--setup-panel-muted: rgba(14, 92, 58, .65);--setup-panel-orb: rgba(30, 142, 90, .08);--setup-toggle-bg: rgba(30, 142, 90, .08);--setup-toggle-selected-ink: #0E5C3A;--setup-toggle-shadow: rgba(30, 142, 90, .18);--setup-btn-bg: var(--green);--setup-btn-ink: #fff;--setup-btn-shadow: 0 6px 18px -6px rgba(30, 142, 90, .55);--setup-btn-hover-shadow: 0 10px 22px -8px rgba(30, 142, 90, .55)}.setup-start-panel.tone-gleeds{--setup-panel-bg: linear-gradient(180deg, #FAF1DB 0%, #F1E2BB 100%);--setup-panel-shadow: inset 0 1px 0 rgba(255, 255, 255, .6), 0 12px 30px -12px rgba(176, 123, 18, .32);--setup-panel-ink: #5A3D08;--setup-panel-muted: rgba(90, 61, 8, .6);--setup-panel-orb: rgba(176, 123, 18, .08);--setup-toggle-bg: rgba(176, 123, 18, .1);--setup-toggle-selected-ink: #5A3D08;--setup-toggle-shadow: rgba(176, 123, 18, .2);--setup-btn-bg: var(--ink);--setup-btn-ink: #fff;--setup-btn-shadow: 0 6px 18px -6px rgba(20, 22, 28, .5);--setup-btn-hover-shadow: 0 10px 22px -8px rgba(20, 22, 28, .45)}.setup-start-panel.tone-general{--setup-panel-bg: linear-gradient(180deg, #1F242D 0%, #0E1116 100%);--setup-panel-shadow: inset 0 1px 0 rgba(255, 255, 255, .06), 0 14px 32px -12px rgba(0, 0, 0, .5);--setup-panel-ink: #fff;--setup-panel-muted: rgba(255, 255, 255, .55);--setup-panel-orb: rgba(255, 255, 255, .04);--setup-toggle-bg: rgba(255, 255, 255, .08);--setup-toggle-selected-ink: var(--ink);--setup-toggle-shadow: rgba(0, 0, 0, .25);--setup-btn-bg: #fff;--setup-btn-ink: var(--ink);--setup-btn-shadow: 0 6px 16px -6px rgba(0, 0, 0, .35);--setup-btn-hover-shadow: 0 10px 22px -8px rgba(0, 0, 0, .35)}.setup-start-orb{position:absolute;top:-30px;right:-30px;width:130px;height:130px;border-radius:50%;background:var(--setup-panel-orb);pointer-events:none}.setup-start-title{margin:14px 0 12px;color:var(--setup-panel-ink);font:400 24px/1.15 var(--font-serif);letter-spacing:-.01em}.setup-start-button{width:100%;min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:0;border:0;border-radius:10px;background:var(--setup-btn-bg);box-shadow:var(--setup-btn-shadow);color:var(--setup-btn-ink);cursor:pointer;padding:11px 16px;text-align:center;font-size:15px;font-weight:600;letter-spacing:-.005em}.setup-start-button span:last-child{font-size:18px;line-height:1}.setup-start-link{width:100%;min-height:21px;margin-top:8px;border:0;background:transparent;color:var(--setup-panel-muted);cursor:pointer;padding:2px 6px 3px;text-align:center;font-size:12px}.setup-start-note{margin-top:10px;color:var(--setup-panel-muted);font-size:12px;line-height:1.45}.setup-mode-toggle{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-bottom:6px;padding:3px;border-radius:8px;background:var(--setup-toggle-bg)}.setup-mode-toggle button{border:0;border-radius:6px;background:transparent;color:var(--setup-panel-muted);cursor:pointer;padding:5px 8px;font-size:11.5px;font-weight:500;line-height:1.2;transition:background .12s ease,color .12s ease}.setup-mode-toggle button.selected{background:var(--surface);color:var(--setup-toggle-selected-ink);box-shadow:0 1px 2px var(--setup-toggle-shadow);font-weight:600}.mock-summary-page{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:24px;padding:24px 40px 40px}.mock-summary-main,.mock-summary-rail{display:flex;flex-direction:column;gap:18px}.biggest-fix{display:flex;flex-direction:column;gap:8px;border-color:#f0c6c6;background:#fff5f5}.biggest-fix h3{margin:4px 0 0;font:500 18px/1.25 var(--font-sans, inherit);color:var(--ink)}.biggest-fix p{margin:0;color:var(--ink-2, var(--ink));font-size:13px;line-height:1.5}.mock-question-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}.mock-question-row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:12px;width:100%;border:1px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;padding:10px 12px;text-align:left;transition:background .12s ease,border-color .12s ease}.mock-question-row:hover:not(:disabled){background:var(--tint-blue-2, #F4F6FF);border-color:#2e4bd940}.mock-question-row:disabled{cursor:default;opacity:.6}.mock-question-row .row-number{font:500 12px/1 var(--font-mono);color:var(--ink-4, var(--ink));letter-spacing:.04em}.mock-question-row strong{display:block;font-size:13.5px;font-weight:500;color:var(--ink);line-height:1.35}.mock-question-row span{display:block;font-size:11.5px;color:var(--ink-4, var(--ink));margin-top:3px}.red-phrase-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:14px}.red-phrase-list blockquote{margin:0;font-style:italic;color:var(--ink);font-size:13.5px;line-height:1.4}.red-phrase-list p{margin:6px 0 0;font-size:12.5px;color:var(--ink-4, var(--ink));line-height:1.45}.vocab-aggregate{display:flex;flex-direction:column;gap:14px;margin-top:10px}.vocab-aggregate .eyebrow{display:block;margin-bottom:8px}.muted{color:var(--ink-4, var(--ink));font-size:12.5px}@media(max-width:980px){.mock-summary-page{grid-template-columns:1fr;padding:18px 20px 28px}}.drill-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;border-bottom:1px solid var(--border);background:var(--surface);padding:16px 32px}.recording-tag{display:inline-flex;align-items:center;gap:6px;color:var(--coral);font:500 11px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.drill-layout{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 320px;overflow:hidden}.drill-stage{min-width:0;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:auto;padding:34px 60px;text-align:center}.prompt-stage{max-width:720px;margin-top:22px;color:var(--ink);font:400 30px/1.3 var(--font-serif);letter-spacing:-.005em}.prompt-stage.hidden-prompt{display:grid;place-items:center;min-height:116px;border:1px dashed var(--border-2);border-radius:12px;background:var(--bg-sunken);color:var(--ink-3);padding:36px 48px;font:400 14px/1.4 var(--font-sans)}.timer-ring{--timer-circ: 515.22px;position:relative;width:176px;height:176px;margin-top:38px}.timer-ring svg{width:176px;height:176px;transform:rotate(-90deg)}.timer-ring circle{fill:none;stroke:var(--border);stroke-width:2}.timer-ring .timer-progress{stroke:var(--blue);stroke-dasharray:var(--timer-circ);stroke-dashoffset:var(--timer-offset);stroke-linecap:round;transition:stroke-dashoffset .12s linear}.timer-ring>div{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:0 22px;text-align:center}.timer-ring strong,.timer-ring span{display:block;max-width:100%}.timer-ring strong{color:var(--ink);font:400 42px/1 var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.timer-ring span{color:var(--ink-3);font:500 10.5px/1.35 var(--font-mono);letter-spacing:.08em;line-height:1.35;text-transform:uppercase;text-wrap:balance}.waveform{height:36px;display:flex;align-items:center;gap:3px;margin-top:24px;opacity:.28;transition:opacity .16s ease}.waveform.is-live{opacity:1}.waveform span{width:3px;min-height:4px;border-radius:2px;background:var(--ink);transition:height 80ms linear}.inline-alert{display:flex;align-items:center;gap:8px;max-width:620px;margin-top:14px;border:1px solid #F0D2C6;border-radius:10px;background:var(--tint-coral);color:var(--coral);padding:10px 12px;font-size:12px}.inline-alert.speech-alert{border-color:#f0e0c6;background:#fff8e8;color:#8a5a12}.transcript-panel{width:min(720px,100%);margin-top:20px;border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:14px;text-align:left}.loading-dots{display:inline-flex;width:16px;justify-content:flex-start}.loading-dots span{display:inline-block;opacity:0}.loading-dots span:nth-child(1){animation:ldot-1 1.2s ease-in-out infinite}.loading-dots span:nth-child(2){animation:ldot-2 1.2s ease-in-out infinite}.loading-dots span:nth-child(3){animation:ldot-3 1.2s ease-in-out infinite}@keyframes ldot-1{0%,5%{opacity:0}10%,94%{opacity:1}99%,to{opacity:0}}@keyframes ldot-2{0%,38%{opacity:0}43%,94%{opacity:1}99%,to{opacity:0}}@keyframes ldot-3{0%,71%{opacity:0}76%,94%{opacity:1}99%,to{opacity:0}}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:14px}.panel-head>div{display:flex;align-items:center;gap:10px}.panel-head span{color:var(--ink-3);font-size:11.5px}.panel-head audio{max-width:260px;height:32px}.transcript-panel textarea{width:100%;min-height:120px;margin-top:12px;resize:vertical;border:1px solid var(--border);border-radius:10px;outline:0;background:var(--surface-2);color:var(--ink);padding:12px;font-size:13px;line-height:1.5}.coach-rail{min-height:0;display:flex;flex-direction:column;gap:22px;overflow:auto;border-left:1px solid var(--border);background:var(--surface-2);padding:28px 24px}.coach-rail h2{margin:7px 0 0;font:400 20px/1.25 var(--font-serif);letter-spacing:-.005em}.coach-rail h3{margin:0 0 10px;color:var(--ink-2);font-size:12px;font-weight:650}.checklist{display:flex;flex-direction:column;gap:9px}.checklist div{display:flex;align-items:flex-start;gap:10px}.checklist span{width:16px;height:16px;display:grid;place-items:center;flex:0 0 auto;margin-top:1px;border:1px solid var(--border-2);border-radius:4px;background:var(--surface)}.checklist .done span{border-color:var(--green);background:var(--green);color:#fff}.checklist p{margin:0;color:var(--ink);font-size:12.5px;line-height:1.4}.checklist .done p{color:var(--ink-3);text-decoration:line-through;text-decoration-color:var(--ink-4)}.term-cloud{display:flex;flex-wrap:wrap;gap:6px}.coach-nudge{border:1px solid var(--tint-blue-2);border-radius:10px;background:var(--surface);padding:12px 14px}.coach-nudge span{color:var(--blue-deep);font:500 11px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.coach-nudge p{margin:7px 0 0;color:var(--ink);font-size:12.5px;line-height:1.45}.coach-bottom{display:flex;flex-direction:column;gap:12px;margin-top:auto;border-top:1px solid var(--border);padding-top:14px}.feedback-grid{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1.45fr) minmax(360px,1fr);overflow:hidden}.feedback-main{min-height:0;display:flex;flex-direction:column;gap:18px;overflow:auto;border-right:1px solid var(--border);padding:28px 40px}.score-strip{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:16px 20px}.score-intro,.tally-row{display:flex;align-items:center;gap:18px}.score-intro h2{max-width:440px;margin:0;font:400 20px/1.28 var(--font-serif);letter-spacing:-.005em}.tally{display:flex;align-items:center;gap:8px}.tally span{width:8px;height:8px;border-radius:50%}.tally-green span{background:var(--green)}.tally-amber span{background:var(--amber)}.tally-red span{background:var(--coral)}.tally strong{font:600 14px/1 var(--font-mono)}.tally small{color:var(--ink-3);font:500 11.5px/1 var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.segmented{display:flex;gap:4px;border:1px solid var(--border);border-radius:8px;background:var(--bg-sunken);padding:3px}.segmented button{border:0;border-radius:5px;background:transparent;cursor:pointer;padding:5px 10px;color:var(--ink-3);font-size:11.5px}.segmented button.selected{background:var(--surface);color:var(--ink);box-shadow:0 1px 2px #0000000a;font-weight:650}.feedback-panel-head{min-height:36px}.feedback-panel-head>div{flex-wrap:wrap}.answer-tabs{flex-shrink:0}.answer-tabs button{font:650 11px/1 var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.transcript-card{flex:1;min-height:360px;overflow:auto;border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:24px 28px;color:var(--ink);font:400 19px/1.62 var(--font-serif);letter-spacing:-.002em}.model-answer-card{font-size:18px;line-height:1.58}.model-answer-body{min-height:100%}.model-answer-body p{margin:0;white-space:pre-wrap}.model-answer-state{display:inline-flex;align-items:baseline;color:var(--ink-3);font:650 12px/1.4 var(--font-mono);letter-spacing:.06em}.model-answer-alert{max-width:none;margin-top:0;font-family:var(--font-sans);line-height:1.4}.hl{display:inline;border:0;border-radius:2px;cursor:pointer;padding:1px 2px;margin:0 -1px;font:inherit;text-align:inherit}.hl-g{border-bottom:2px solid var(--green);background:var(--tint-green)}.hl-y{border-bottom:2px solid var(--amber);background:var(--tint-amber)}.hl-r{border-bottom:2px solid var(--coral);background:var(--tint-coral)}.hl.active{box-shadow:0 0 0 2px currentColor}.feedback-rail{min-height:0;display:flex;flex-direction:column;gap:22px;overflow:auto;background:var(--surface-2);padding:28px 32px}.highlight-detail{flex-shrink:0;overflow:visible;padding:18px 20px}.detail-head{display:flex;align-items:center;gap:8px}.detail-head>span:last-child{color:var(--ink-3);font:500 11px/1 var(--font-mono)}.highlight-detail blockquote,.version-card blockquote,.term-detail blockquote{margin:12px 0 0;border:0;color:var(--ink);font:italic 18px/1.35 var(--font-serif)}.highlight-detail p{margin:12px 0 0;color:var(--ink-2);font-size:13px;line-height:1.5}.try-instead{margin-top:12px;border:1px solid var(--border);border-radius:10px;background:var(--bg-sunken);padding:10px 12px}.try-instead span{display:block;color:var(--ink-3);font:500 10px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.try-instead strong{display:block;margin-top:5px;font:italic 14px/1.35 var(--font-serif)}.segment-actions{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border);flex-wrap:wrap;gap:6px}.score-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.score-row{display:grid;grid-template-columns:minmax(0,1fr) 110px 36px;align-items:center;gap:12px}.score-row span{font-size:13px;font-weight:520}.score-row div{height:4px;overflow:hidden;border-radius:2px;background:var(--border)}.score-row i{display:block;height:100%;background:var(--ink)}.score-row strong{text-align:right;font:600 13px/1 var(--font-mono)}.feedback-subgrid,.story-bottom{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.feedback-subgrid .card,.story-bottom .card{padding:14px 16px}.followups,.actions-list{margin:10px 0 0;padding:0;list-style:none}.followups li,.actions-list li{border-left:2px solid var(--border-2);padding-left:11px;margin-top:8px;color:var(--ink-2);font-size:12px;line-height:1.4}.followup-challenge{display:flex;flex-direction:column;gap:10px;border-color:#2e4bd966;box-shadow:0 0 0 1px #2e4bd914 inset}.followup-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.followup-prompt{margin:0;padding:10px 12px;border-left:2px solid var(--blue);background:#2e4bd90f;color:var(--ink);font-size:13px;line-height:1.45;font-style:italic;border-radius:0 8px 8px 0}.followup-empty{margin:4px 0 0;color:var(--ink-3);font-size:12.5px}.followup-alts{margin-top:4px}.followup-alts ul{margin:6px 0 0;padding:0;list-style:none}.followup-alts li{margin-top:4px}.followup-alt-btn{width:100%;text-align:left;border:0;background:transparent;padding:6px 10px 6px 11px;border-left:2px solid var(--border-2);color:var(--ink-2);font-size:12px;line-height:1.4;cursor:pointer;border-radius:0 6px 6px 0;transition:background .12s,color .12s,border-color .12s}.followup-alt-btn:hover:not(:disabled){background:#2e4bd90f;border-left-color:var(--blue);color:var(--ink)}.followup-alt-btn:disabled{cursor:default;opacity:.7}.table-row.is-followup{background:#2e4bd906}.followup-glyph{color:var(--blue);font-weight:600;margin-right:2px}.library-grid{flex:1;min-height:0;display:grid;grid-template-columns:300px minmax(0,1fr);overflow:hidden}.library-list{min-height:0;overflow:auto;border-right:1px solid var(--border)}.library-search{display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);padding:16px 20px}.library-search input{width:100%;border:1px solid var(--border-2);border-radius:8px;background:var(--surface);outline:0;padding:8px 10px;color:var(--ink);font-size:12.5px}.library-list button{position:relative;width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:3px 10px;border:0;border-left:2px solid transparent;background:transparent;cursor:pointer;padding:12px 20px 12px 18px;text-align:left}.library-list button.selected{border-left-color:var(--ink);background:var(--surface)}.library-list strong,.library-list span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-list strong{font-size:13px}.library-list span{color:var(--ink-3);font-size:11.5px}.library-list em{grid-row:1 / span 2;grid-column:2;align-self:center;color:var(--ink-3);font:normal 11px/1 var(--font-mono)}.story-detail{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:20px;padding:28px 40px}.story-detail h2{margin:7px 0 0;font:400 34px/1.15 var(--font-serif);letter-spacing:-.01em}.story-detail p{max-width:760px;margin:10px 0 0;color:var(--ink-2);font-size:14px;line-height:1.5}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;overflow:hidden;border:1px solid var(--border);border-radius:12px;background:var(--border)}.metric-grid div{background:var(--surface);padding:14px 18px}.metric-grid strong{display:block;font:400 26px/1 var(--font-serif)}.metric-grid span{display:block;margin-top:6px;color:var(--ink-3);font-size:11.5px;line-height:1.35}.version-card{padding:20px 24px}.version-card blockquote{font-size:18px;line-height:1.6}.vocab-page,.history-page{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:22px;padding:24px 40px 32px}.section-line{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:12px}.upgrade-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.upgrade-card{padding:16px 18px}.upgrade-card span{color:var(--ink-4);font:500 10px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.upgrade-card del,.upgrade-card strong{display:block;margin-top:8px;font:italic 16px/1.35 var(--font-serif)}.upgrade-card del{color:var(--ink-3);text-decoration-color:var(--coral)}.upgrade-card strong{color:var(--ink);font-weight:400}.vocab-browser{flex:1;min-height:440px;display:grid;grid-template-columns:230px minmax(0,1fr) 320px;overflow:hidden;border:1px solid var(--border);border-radius:14px;background:var(--surface)}.vocab-browser>aside:first-child,.term-list{overflow:auto;border-right:1px solid var(--border)}.vocab-browser>aside:first-child,.term-list{padding:10px 0}.vocab-browser>aside:first-child button,.term-list button{width:100%;border:0;border-left:2px solid transparent;background:transparent;cursor:pointer;padding:10px 16px;text-align:left}.vocab-browser>aside:first-child button{display:flex;align-items:center;justify-content:space-between;gap:10px}.vocab-browser button.selected{border-left-color:var(--ink);background:var(--bg-sunken)}.vocab-browser button span{font-size:12.5px;font-weight:560}.vocab-browser button small{color:var(--ink-3);font:500 10.5px/1 var(--font-mono)}.term-list button{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;border-bottom:1px solid var(--border)}.term-list strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--ink-4)}.status-dot.active{background:var(--green)}.status-dot.learning{background:var(--amber)}.status-dot.missed{background:var(--coral)}.term-detail{min-height:0;overflow:auto;padding:24px}.term-detail h2{margin:8px 0 0;font:400 28px/1.15 var(--font-serif)}.term-detail p{margin:12px 0 0;color:var(--ink-2);font-size:13px;line-height:1.5}.term-detail blockquote{border:1px solid var(--border);border-radius:10px;background:var(--bg-sunken);padding:12px 14px;font-size:16px}.term-practice{margin-top:16px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2);padding:12px 14px}.term-practice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;overflow:hidden;margin-top:10px;border:1px solid var(--border);border-radius:8px;background:var(--border)}.term-practice-grid div{background:var(--surface);padding:10px 12px}.term-practice-grid span{display:block;color:var(--ink-3);font-size:11px}.term-practice-grid strong{display:block;margin-top:5px;font-size:18px}.term-practice p{margin-top:10px}.term-practice.empty p{color:var(--ink-3)}.mistake-box{margin-top:22px;border-top:1px solid var(--border);padding-top:16px}.mistake-box>div:not(.eyebrow){margin-top:12px}.mistake-box strong{display:block;margin-top:6px;font-size:12.5px}.mistake-meta{display:block;margin-top:6px;color:var(--ink-3);font-size:11px}.history-strip{display:grid;grid-template-columns:auto minmax(260px,1fr) auto;align-items:center;gap:34px;border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:18px 24px}.history-strip h2{display:flex;align-items:baseline;gap:5px;margin:6px 0 0;font:400 38px/1 var(--font-serif)}.history-strip h2 span{color:var(--ink-3);font:400 16px/1 var(--font-sans)}.history-strip p{margin:5px 0 0;color:var(--ink-3);font-size:12px}.sparkline{width:100%;height:64px}.sparkline path:first-child{fill:#2e4bd914;stroke:none}.sparkline path:nth-child(2){fill:none;stroke:var(--blue);stroke-width:1.6}.sparkline circle{fill:var(--blue)}.filter-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.filter-row>div{display:flex;flex-wrap:wrap;gap:6px}.filter-row button{border:1px solid var(--border-2);border-radius:999px;background:transparent;cursor:pointer;padding:5px 12px;color:var(--ink-2);font-size:12.5px}.filter-row button.selected{border-color:var(--ink);background:var(--ink);color:#fff}.filter-row span{color:var(--ink-3);font-size:12px}.attempt-table{min-height:0;overflow:auto;border:1px solid var(--border);border-radius:14px;background:var(--surface)}.table-head,.table-row{display:grid;grid-template-columns:116px 132px minmax(220px,1fr) 88px 72px 102px 62px;align-items:center;gap:14px}.table-head{position:sticky;top:0;z-index:1;border-bottom:1px solid var(--border);background:var(--surface-2);color:var(--ink-3);padding:12px 22px;font:500 10.5px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.table-row{width:100%;border:0;border-bottom:1px solid var(--border);background:transparent;cursor:pointer;padding:14px 22px;text-align:left}.table-row>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink-3);font-size:12px}.table-row>span:nth-child(2){display:flex;align-items:center;gap:7px;color:var(--ink);font-weight:560}.table-row>span:nth-child(2) i{width:6px;height:6px;flex:0 0 auto;border-radius:50%}.table-row>span:nth-child(3){display:flex;align-items:center;gap:6px;color:var(--ink);font-size:13px}.table-row>span:nth-child(3) svg{color:var(--amber);flex:0 0 auto}.table-row strong{color:var(--ink);text-align:right;font:600 14px/1 var(--font-mono)}.dot-bars{display:flex;align-items:center;gap:3px}.dot-bars i{width:6px;height:12px;border-radius:1px}.dot-g{background:var(--green)}.dot-y{background:var(--amber)}.dot-r{background:var(--coral)}.flashcards-page{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;padding:22px 40px 32px}.flash-progress-row{flex:0 0 auto;display:grid;grid-template-columns:auto minmax(140px,1fr) auto;align-items:center;gap:24px;color:var(--ink-3);font:500 11px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.flash-progress-row strong{color:var(--ink)}.flash-progress-row span{opacity:.7}.flash-progress{height:3px;overflow:hidden;border-radius:2px;background:var(--border)}.flash-progress i{display:block;height:100%;border-radius:inherit;background:var(--ink);transition:width .14s ease}.flash-tally{display:flex;align-items:center;gap:16px}.flash-tally span{display:inline-flex;align-items:center;gap:5px}.flash-ok{color:var(--green)}.flash-miss{color:var(--coral)}.flash-layout{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:30px;margin-top:22px}.flash-stage{position:relative;min-height:0;display:flex;flex-direction:column;align-items:center;overflow-y:auto}.flash-card-group{position:relative;display:flex;flex-direction:column;align-items:center;padding-top:18px;width:100%;margin:auto}.flash-stack,.flash-card{width:min(580px,92%);border:1px solid var(--border);border-radius:18px;background:var(--surface);box-shadow:0 22px 60px -42px #15181e80}.flash-stack{height:400px}.flash-card{min-height:400px}.flash-stack{position:absolute;top:18px;pointer-events:none}.flash-stack-back{opacity:.45;transform:translate(14px,18px) rotate(2deg)}.flash-stack-mid{opacity:.74;transform:translate(7px,9px) rotate(.8deg)}.flash-card{position:relative;z-index:1;flex:0 0 auto;display:flex;flex-direction:column;padding:30px 36px 32px;overflow:hidden;transition:transform .16s cubic-bezier(.6,.05,.7,.5),opacity .16s ease}.flash-card.exit-right{opacity:0;transform:translate(120%) rotate(8deg)}.flash-card.exit-left{opacity:0;transform:translate(-120%) rotate(-8deg)}.flash-card-top{display:flex;align-items:center;justify-content:space-between;gap:14px}.flash-card-top>span{color:var(--ink-4);font:500 10.5px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.flash-card h2{min-height:62px;margin:20px 0 0;display:grid;place-items:center;color:var(--ink);font:400 clamp(32px,4.5vw,52px)/1.08 var(--font-serif);letter-spacing:-.01em;text-align:center}.flash-answer{flex:1;min-height:118px;margin-top:24px;border-top:1px dashed var(--border-2);padding-top:20px}.flash-answer-copy{animation:flashFadeIn .12s ease both}.flash-answer-copy span,.flash-hidden-answer span,.flash-hint,.flash-sheet-actions>span,.flash-field>span{color:var(--ink-3);font:500 10.5px/1.3 var(--font-mono);letter-spacing:.1em;text-transform:uppercase}.flash-answer-copy p{margin:10px 0 0;color:var(--ink-2);font-size:15px;line-height:1.55;white-space:pre-line}.flash-hidden-answer{min-height:92px;display:flex;align-items:center;justify-content:center;gap:10px}.flash-hidden-answer i{width:24px;height:1px;background:var(--border-2)}.flash-actions{z-index:2;flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:10px;min-height:82px;margin-top:36px}.flash-show-button,.flash-rate{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:12px;border-radius:12px;cursor:pointer;font-size:14.5px;font-weight:560;letter-spacing:-.005em;white-space:nowrap}.flash-show-button{min-width:220px;border:0;background:var(--ink);box-shadow:0 8px 18px -8px #14161c73;color:#fff;padding:13px 28px}.flash-rate-row{display:flex;gap:14px}.flash-rate{min-width:200px;padding:12px 22px}.flash-rate-ok{border:1px solid rgba(30,142,90,.25);background:var(--tint-green);color:var(--green)}.flash-rate-miss{border:1px solid rgba(187,69,48,.25);background:var(--tint-coral);color:var(--coral)}.flash-rate b{font-size:19px;line-height:1}.flash-show-button kbd,.flash-rate kbd{margin-left:3px;border-radius:4px;padding:2px 6px;font:500 10.5px/1 var(--font-mono);letter-spacing:.04em}.flash-show-button kbd{border:1px solid rgba(255,255,255,.35);color:#ffffffe6}.flash-rate-ok kbd{border:1px solid rgba(30,142,90,.3)}.flash-rate-miss kbd{border:1px solid rgba(187,69,48,.3)}.flash-hint{color:var(--ink-4)}.flash-rail{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:14px}.flash-stat-card{padding:16px 18px}.flash-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:14px}.flash-queue-card{min-height:0}.flash-queue{display:flex;flex-direction:column;padding:4px 0 10px}.flash-queue button{width:100%;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;border:0;border-left:2px solid transparent;border-top:1px solid var(--border);background:transparent;cursor:pointer;padding:10px 16px 10px 14px;text-align:left}.flash-queue button.selected{border-left-color:var(--ink);background:var(--bg-sunken)}.flash-queue strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12.5px}.flash-queue small{color:var(--ink-3);font:500 10.5px/1 var(--font-mono)}.flash-empty{width:min(520px,100%);margin:auto;padding:26px;text-align:center}.flash-empty h2{margin:12px 0 18px;font:400 28px/1.15 var(--font-serif)}.flash-sheet-scrim{position:fixed;inset:0;z-index:20;display:flex;align-items:center;justify-content:center;background:#14161c6b;padding:20px;animation:flashFadeIn .16s ease both}.flash-sheet{width:min(480px,100%);border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:0 32px 80px -36px #14161c8c;padding:28px}.flash-sheet-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:20px}.flash-sheet-head h2{margin:9px 0 0;font:400 28px/1.1 var(--font-serif);letter-spacing:-.01em}.flash-sheet-head p{margin:7px 0 0;color:var(--ink-3);font-size:12.5px}.flash-close{width:32px;height:32px;flex:0 0 auto;display:grid;place-items:center;border:1px solid var(--border-2);border-radius:8px;background:transparent;color:var(--ink-3);cursor:pointer;font-size:20px;line-height:1}.flash-field{display:block;margin-bottom:14px}.flash-field>span{display:block;margin-bottom:6px}.flash-field input,.flash-field textarea{width:100%;border:1px solid var(--border-2);border-radius:8px;background:var(--surface);outline:0;color:var(--ink);padding:10px 12px;font-size:14px;line-height:1.5}.flash-field textarea{resize:vertical}.flash-sheet-actions{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:22px}.flash-sheet-actions>.flash-sheet-error{color:var(--coral);font:500 12px/1.4 var(--font-sans);letter-spacing:0;text-transform:none}.flash-error-banner{max-width:760px;margin:0 auto 14px;border:1px solid #F0D2C6;border-radius:10px;background:var(--tint-coral);color:var(--coral);padding:10px 12px;font-size:12.5px;line-height:1.4}@keyframes flashFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1120px){.app-shell{grid-template-columns:74px minmax(0,1fr)}.sidebar{padding:18px 12px}.identity-copy,.nav-item span:not(.active-dot),.next-card,.connection-card span{display:none}.nav-item{justify-content:center}.dashboard-grid,.setup-grid,.feedback-grid,.drill-layout,.flash-layout{grid-template-columns:1fr}.coach-rail,.feedback-rail{border-left:0;border-top:1px solid var(--border)}}@media(max-width:760px){.app-shell{display:block}.sidebar{position:static;width:100%;height:auto;flex-direction:row;align-items:center;overflow:auto;border-right:0;border-bottom:1px solid var(--border)}.identity{padding:0}.side-nav{flex-direction:row}.app-main{height:auto;min-height:calc(100vh - 75px)}.topbar,.dashboard-grid,.setup-grid,.drill-stage,.feedback-main,.feedback-rail,.story-detail,.vocab-page,.flashcards-page,.history-page{padding-left:18px;padding-right:18px}.topbar,.hero-strip,.score-strip,.history-strip{align-items:flex-start;flex-direction:column}.topbar-actions,.search-button,.stat-row{width:100%;flex-wrap:wrap}.readiness-grid,.choice-grid.two,.choice-grid.four,.upgrade-grid,.metric-grid,.feedback-subgrid,.story-bottom,.vocab-browser,.library-grid,.flash-progress-row{grid-template-columns:1fr}.flash-layout{overflow:visible}.flash-stage{min-height:560px}.flash-card h2{font-size:40px}.flash-rate-row{width:100%;flex-direction:column}.flash-rate{width:100%}.track-card,.work-row,.history-strip,.table-head,.table-row{grid-template-columns:1fr}.table-head{display:none}.library-list,.term-list,.vocab-browser>aside:first-child{border-right:0;border-bottom:1px solid var(--border)}}.onboarding-intro-card{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:start;padding:36px;max-width:760px}.onboarding-intro-body{display:flex;flex-direction:column;gap:14px}.onboarding-intro-body h2{margin:0;font-size:20px;letter-spacing:-.02em;line-height:1.3}.onboarding-intro-body p{margin:0;font-size:14px;line-height:1.65;color:var(--ink-2)}.onboarding-intro-note{font-size:12.5px!important;color:var(--ink-4)!important}.onboarding-intro-stats{display:flex;flex-direction:column;gap:20px;padding-left:32px;border-left:1px solid var(--border);min-width:130px}.onboarding-intro-stats>div{display:flex;flex-direction:column;gap:3px}.onboarding-intro-stats strong{font-size:22px;letter-spacing:-.03em;color:var(--ink)}.onboarding-intro-stats span{font-size:11.5px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.05em}@media(max-width:600px){.onboarding-intro-card{grid-template-columns:1fr;padding:24px;gap:24px}.onboarding-intro-stats{flex-direction:row;border-left:0;padding-left:0;border-top:1px solid var(--border);padding-top:20px}}.onboarding-scrim{position:fixed;inset:0;z-index:200;background:#15181e8a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px}.onboarding-panel{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:32px;display:flex;flex-direction:column;gap:28px;box-shadow:0 24px 64px #15181e2e;animation:flashFadeIn .18s ease}.onboarding-header{display:flex;align-items:flex-start;gap:16px}.onboarding-progress-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.onboarding-eyebrow{font-size:11.5px;font-weight:550;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}.onboarding-progress{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.onboarding-bar{height:100%;background:var(--blue);border-radius:2px;transition:width .22s ease}.onboarding-skip-all{flex:0 0 auto;padding-top:1px;font-size:12.5px;color:var(--ink-4)}.onboarding-card{background:var(--bg-sunken);border:1px solid var(--border);border-radius:16px;padding:28px 28px 24px;display:flex;flex-direction:column;gap:16px;min-height:260px}.onboarding-card-top{display:flex;align-items:center;justify-content:space-between}.onboarding-tally{font-size:12px;color:var(--ink-4)}.onboarding-front{margin:0;font-family:var(--font-serif);font-style:italic;font-size:28px;line-height:1.2;letter-spacing:-.01em;color:var(--ink);text-align:center}.onboarding-hidden{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-end;gap:10px;padding:12px 0 4px;flex:1}.onboarding-hidden .flash-show-button{width:100%;min-width:0}.onboarding-hidden .flash-hint{text-align:center}.onboarding-revealed{display:flex;flex-direction:column;justify-content:space-between;gap:20px;animation:flashFadeIn .15s ease;flex:1}.onboarding-back{margin:0;font-size:15px;font-weight:500;color:var(--blue);line-height:1.45;text-align:center}.onboarding-card-notice{margin:-4px 0 0;border:1px solid rgba(187,69,48,.22);border-radius:8px;background:var(--tint-coral);color:var(--coral);padding:9px 11px;font-size:12px;line-height:1.4;text-align:center}.onboarding-actions{display:flex;flex-direction:column;align-items:stretch;gap:10px}.onboarding-add-btn{flex:none;width:100%;justify-content:center}.onboarding-done{align-items:center;text-align:center;gap:16px}.onboarding-done-icon{width:56px;height:56px;border-radius:50%;background:var(--tint-green);color:var(--green);display:flex;align-items:center;justify-content:center}.onboarding-done h2{margin:0;font-size:22px;letter-spacing:-.02em}.onboarding-done p{margin:0;color:var(--ink-2);font-size:14px;line-height:1.55;max-width:340px}@media(max-width:600px){.onboarding-panel{padding:24px 20px}.onboarding-front{font-size:22px}}.translation-page{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:22px;padding:22px 40px 32px}.translation-progress{display:flex;flex-direction:column;gap:8px;width:100%}.translation-progress-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.translation-progress-head .eyebrow{color:var(--ink-3);font:500 10.5px/1.2 var(--font-mono);letter-spacing:.12em;text-transform:uppercase}.translation-progress-count{color:var(--ink-2);font:500 12px/1 var(--font-mono);letter-spacing:.06em;font-variant-numeric:tabular-nums}.translation-progress-track{position:relative;width:100%;height:8px;border-radius:999px;background:var(--bg-sunken);border:1px solid var(--border-2);overflow:hidden}.translation-progress-fill{height:100%;background:var(--ink);border-radius:999px;transition:width .38s ease}.translation-toolbar{display:flex;flex-direction:column;gap:10px}.translation-toolbar .eyebrow{font:500 10.5px/1.2 var(--font-mono);letter-spacing:.1em}.translation-layout{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:30px}.translation-stage{position:relative;min-height:0;display:flex;flex-direction:column;align-items:center;overflow-y:auto}.translation-card{width:min(640px,100%);margin:auto;border:1px solid var(--border);border-radius:18px;background:var(--surface);box-shadow:0 22px 60px -42px #15181e80;padding:26px 34px 28px;display:flex;flex-direction:column;gap:20px;transition:border-color .16s ease,box-shadow .16s ease}.translation-card.phase-correct{border-color:#1e8e5a73;box-shadow:0 22px 60px -38px #1e8e5a73}.translation-card.phase-incorrect{border-color:#bb453073;box-shadow:0 22px 60px -38px #bb453073}.translation-card-top{display:flex;align-items:center;justify-content:space-between;gap:14px}.translation-card-counter{color:var(--ink-4);font:500 10.5px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.translation-prompt-block{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 0 18px}.translation-prompt-label{color:var(--ink-4);font:500 10.5px/1.3 var(--font-mono);letter-spacing:.12em;text-transform:uppercase}.translation-prompt{margin:0;color:var(--ink);font:400 clamp(28px,4vw,40px)/1.1 var(--font-serif);letter-spacing:-.01em;text-align:center}.translation-form{display:flex;flex-direction:column;gap:14px;border-top:1px dashed var(--border-2);padding-top:18px}.translation-field{display:flex;flex-direction:column;gap:8px}.translation-field>span{color:var(--ink-3);font:500 10.5px/1.3 var(--font-mono);letter-spacing:.1em;text-transform:uppercase}.translation-field input{width:100%;border:1px solid var(--border-2);border-radius:10px;background:var(--surface-2);outline:0;color:var(--ink);padding:12px 14px;font-size:15px;line-height:1.4;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.translation-field input::placeholder{color:var(--ink-4)}.translation-field input:focus{border-color:var(--blue);background:var(--surface);box-shadow:0 0 0 3px #2e4bd91f}.translation-field input:disabled{background:var(--bg-sunken);color:var(--ink-2)}.translation-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:2px}.translation-actions .btn-ghost{border-color:transparent;color:var(--ink-3);padding-left:10px;padding-right:10px}.translation-actions .btn-ghost:hover{color:var(--ink);background:var(--bg-sunken)}.translation-hint{margin-left:auto;color:var(--ink-4);font:500 10.5px/1.3 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.translation-hint kbd{border-radius:4px;padding:1px 5px;font:500 10px/1 var(--font-mono);color:var(--ink-3);background:var(--bg-sunken);margin:0 2px}.translation-result{border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:12px;animation:flashFadeIn .14s ease both}.translation-result.is-correct{border:1px solid rgba(30,142,90,.3);background:var(--tint-green);color:var(--green)}.translation-result.is-incorrect{border:1px solid rgba(187,69,48,.3);background:var(--tint-coral);color:var(--ink-2)}.translation-result-head{display:inline-flex;align-items:center;gap:8px;font:600 13px/1 var(--font-sans);letter-spacing:-.005em}.translation-result.is-correct .translation-result-head{color:var(--green)}.translation-result.is-incorrect .translation-result-head{color:var(--coral)}.translation-result.is-incorrect .translation-result-head span[aria-hidden=true]{font-size:18px;line-height:1}.translation-result.is-correct p{margin:0;font-size:15.5px;font-weight:550;color:var(--green)}.translation-result-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px 18px}.translation-result-body>div{display:flex;flex-direction:column;gap:4px}.translation-result-body span{color:var(--ink-3);font:500 10.5px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.translation-result-body p{margin:0;font-size:14.5px;line-height:1.4;color:var(--ink)}.translation-you-wrote{color:var(--coral)!important}.translation-result-actions{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;padding-top:14px;border-top:1px dashed rgba(187,69,48,.25)}.translation-card-notice{flex:0 0 100%;margin:0;color:var(--coral);font-size:12px;line-height:1.4;text-align:center}.translation-rail{min-height:0;display:flex;flex-direction:column;gap:14px;overflow:auto}.translation-stat-card{padding:16px 18px}.translation-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px;margin-top:14px}.translation-tip-card{padding:16px 18px}.translation-tip-list{margin:10px 0 0;padding:0 0 0 18px;display:flex;flex-direction:column;gap:8px;color:var(--ink-2);font-size:13px;line-height:1.5}.translation-tip-list li::marker{color:var(--ink-4)}.translation-complete{width:min(520px,100%);margin:auto;padding:32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}.translation-complete-icon{width:54px;height:54px;border-radius:50%;background:var(--tint-blue);color:var(--blue);display:grid;place-items:center}.translation-complete h2{margin:6px 0 4px;font:400 28px/1.15 var(--font-serif);letter-spacing:-.01em}.translation-complete p{margin:0;color:var(--ink-2);font-size:14px;line-height:1.55}@media(max-width:1120px){.translation-layout{grid-template-columns:1fr}}@media(max-width:760px){.translation-page{padding:18px 18px 24px}.translation-card{padding:24px 22px 26px}.translation-result-actions{flex-direction:column;align-items:stretch}}.listening-page{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:18px;padding:22px 40px 32px}.listening-progress-row{display:flex;align-items:center;gap:24px;padding:4px 0}.listening-counter{flex-shrink:0;color:var(--ink-3);font:500 11px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;font-variant-numeric:tabular-nums}.listening-counter span{color:var(--ink)}.listening-counter em{font-style:normal;opacity:.5;margin:0 4px}.listening-progress-track{position:relative;flex:1;height:3px;border-radius:2px;background:var(--border)}.listening-progress-fill{position:absolute;inset:0 auto 0 0;border-radius:2px;background:var(--ink);transition:width .24s ease}.listening-progress-tick{position:absolute;top:-3px;bottom:-3px;width:1px;background:var(--border-2)}.listening-tally{flex-shrink:0;display:flex;align-items:center;gap:16px;font:500 12px/1 var(--font-mono);letter-spacing:.04em;font-variant-numeric:tabular-nums}.listening-tally-correct,.listening-tally-missed,.listening-tally-accuracy{display:inline-flex;align-items:center;gap:5px}.listening-tally-correct{color:var(--green)}.listening-tally-missed{color:var(--coral)}.listening-tally-accuracy{color:var(--ink-3)}.listening-tally span[aria-hidden]{font-size:13px}.listening-stack{display:flex;flex-direction:column;gap:18px;width:min(820px,100%);margin:8px auto 0}.listening-player-card{display:flex;align-items:center;gap:28px;padding:24px 28px;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:0 1px #14161c0a,0 1px 2px #14161c0a}.listening-play-button{width:72px;height:72px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:50%;background:var(--ink);color:#fff;cursor:pointer;padding-left:4px;box-shadow:0 8px 18px -8px #14161c73;transition:box-shadow .2s ease,transform .16s ease}.listening-play-button:hover{transform:translateY(-1px);box-shadow:0 12px 24px -10px #14161c8c}.listening-play-button.is-playing{padding-left:0;box-shadow:0 0 0 6px #2e4bd91f,0 8px 18px -8px #14161c73}.listening-player-body{flex:1;min-width:0}.listening-player-meta{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:10px}.listening-player-meta-left{display:inline-flex;align-items:baseline;gap:10px;flex-wrap:wrap}.listening-clip-id{color:var(--ink-3);font:500 11px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.listening-clip-duration,.listening-clip-voice{color:var(--ink-4);font:500 11px/1 var(--font-mono)}.listening-clip-voice{letter-spacing:.02em}.listening-player-meta-right{color:var(--ink-3);font:500 11px/1 var(--font-mono);letter-spacing:.04em;white-space:nowrap}.listening-waveform{display:flex;align-items:center;gap:2px;height:56px;width:100%}.listening-waveform-bar{flex:1;min-width:2px;background:var(--border-2);border-radius:1px;transition:background .12s ease,height 80ms ease}.listening-waveform-bar.is-active{background:var(--ink-2)}.listening-waveform-bar.is-played{background:var(--ink)}.listening-input-card{display:flex;flex-direction:column;gap:12px;padding:20px 22px;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:0 1px #14161c0a,0 1px 2px #14161c0a}.listening-input-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.listening-eyebrow{color:var(--ink-3);font:500 10.5px/1 var(--font-mono);letter-spacing:.1em;text-transform:uppercase}.listening-words{color:var(--ink-4);font:500 10.5px/1 var(--font-mono);letter-spacing:.08em;text-transform:uppercase;font-variant-numeric:tabular-nums}.listening-textarea{width:100%;min-height:92px;resize:vertical;padding:14px 16px;border:1px solid var(--border-2);border-radius:10px;background:var(--surface-2);color:var(--ink);font-family:var(--font-sans);font-size:17px;line-height:1.55;outline:0;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.listening-textarea::placeholder{color:var(--ink-4)}.listening-textarea:focus{border-color:var(--blue);background:var(--surface);box-shadow:0 0 0 3px #2e4bd91f}.listening-input-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:2px}.listening-hint{color:var(--ink-4);font:500 10.5px/1.3 var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.listening-check-button{display:inline-flex;align-items:center;gap:10px;padding:11px 20px;border:0;border-radius:10px;background:var(--ink);color:#fff;cursor:pointer;font:500 13.5px/1 var(--font-sans);letter-spacing:-.005em;box-shadow:0 1px #ffffff14 inset,0 6px 14px -6px #14161c66;transition:opacity .12s ease,transform .16s ease,box-shadow .16s ease}.listening-check-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 1px #ffffff14 inset,0 10px 20px -8px #14161c80}.listening-check-button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.listening-check-button kbd{font:500 10.5px/1 var(--font-mono);letter-spacing:.04em;border:1px solid rgba(255,255,255,.35);border-radius:4px;padding:2px 6px;color:#ffffffeb;background:transparent}.listening-result-card{border:1px solid;border-radius:14px;padding:22px 24px 24px;animation:listeningFadeIn .24s ease both}.listening-result-card.is-correct{background:var(--tint-green);border-color:#1e8e5a47}.listening-result-card.is-incorrect{background:var(--tint-coral);border-color:#bb453047}@keyframes listeningFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.listening-result-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.listening-result-head-left{display:flex;align-items:center;gap:12px}.listening-result-badge{width:40px;height:40px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid;border-radius:50%;background:var(--surface);font-size:18px;font-weight:500}.listening-result-card.is-correct .listening-result-badge{color:var(--green);border-color:#1e8e5a47}.listening-result-card.is-incorrect .listening-result-badge{color:var(--coral);border-color:#bb453047}.listening-result-eyebrow{font:500 10.5px/1 var(--font-mono);letter-spacing:.1em;text-transform:uppercase}.listening-result-card.is-correct .listening-result-eyebrow{color:var(--green)}.listening-result-card.is-incorrect .listening-result-eyebrow{color:var(--coral)}.listening-result-title{margin-top:2px;color:var(--ink);font-family:var(--font-serif);font-size:26px;line-height:1.15;letter-spacing:-.01em}.listening-result-actions{display:flex;align-items:center;gap:8px}.listening-ghost-button,.listening-primary-button{display:inline-flex;align-items:center;gap:8px;border-radius:10px;cursor:pointer;font:500 13.5px/1 var(--font-sans);letter-spacing:-.005em;padding:9px 16px;transition:transform .16s ease,box-shadow .16s ease,background .12s ease}.listening-ghost-button{border:1px solid var(--border-2);background:transparent;color:var(--ink)}.listening-ghost-button:hover{background:var(--surface)}.listening-ghost-button em{font-style:normal;color:var(--ink-3);font-family:var(--font-mono);font-size:12px}.listening-primary-button{border:1px solid transparent;background:var(--ink);color:#fff;box-shadow:0 1px #ffffff14 inset,0 6px 14px -6px #14161c66}.listening-primary-button:hover{transform:translateY(-1px);box-shadow:0 1px #ffffff14 inset,0 10px 20px -8px #14161c80}.listening-primary-button kbd{font:500 10.5px/1 var(--font-mono);letter-spacing:.04em;border:1px solid rgba(255,255,255,.35);border-radius:4px;padding:2px 6px;color:#ffffffeb;background:transparent}.listening-result-body{margin-top:22px;display:grid;grid-template-columns:1fr;gap:14px}.listening-result-label{color:var(--ink-3);font:500 10.5px/1 var(--font-mono);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}.listening-transcript{border:1px solid var(--border);border-radius:10px;background:var(--surface);padding:14px 16px;color:var(--ink);font-family:var(--font-serif);font-size:22px;line-height:1.55;letter-spacing:-.005em}.listening-transcript-mono{font-family:var(--font-mono);font-size:15px;line-height:1.6}.listening-blank{color:var(--ink-4);font-style:italic}.listening-word{color:var(--ink);margin-right:6px}.listening-word-missed{color:var(--ink)}.listening-vocab-mark{display:inline;margin:0 -1px;padding:0 3px;border:0;border-bottom:1.5px solid rgba(46,75,217,.42);border-radius:2px;background:#2e4bd912;color:inherit;transition:background .16s ease,border-color .16s ease}.listening-vocab-mark.is-saved{background:#1e8e5a1a;border-bottom-color:#1e8e5a8c}.listening-vocab-sup{margin-left:2px;color:var(--blue);font:650 9px/1 var(--font-mono);letter-spacing:.02em;vertical-align:super}.listening-vocab-mark.is-saved .listening-vocab-sup{color:var(--green)}.listening-vocab-strip{margin-top:12px;border:1px dashed var(--border-2);border-radius:12px;background:var(--surface);padding:12px 14px 14px}.listening-vocab-strip-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.listening-vocab-strip-label{display:inline-flex;align-items:center;gap:8px;color:var(--ink-3);font:500 10.5px/1 var(--font-mono);letter-spacing:.1em;text-transform:uppercase}.listening-vocab-strip-label .is-saved{color:var(--green)}.listening-vocab-strip-dot{color:var(--ink-4)}.listening-save-all-button{flex-shrink:0;border:1px solid var(--border-2);border-radius:6px;background:transparent;color:var(--ink-2);cursor:pointer;padding:5px 10px;font:650 10.5px/1 var(--font-mono);letter-spacing:.06em;text-transform:uppercase;transition:background .12s ease,color .12s ease,border-color .12s ease}.listening-save-all-button:hover:not(:disabled){background:var(--surface-2);border-color:var(--ink-4)}.listening-save-all-button:disabled{color:var(--green);cursor:default;opacity:.72}.listening-vocab-row{display:flex;flex-wrap:wrap;gap:8px}.listening-vocab-card{min-width:180px;max-width:360px;display:inline-flex;align-items:center;gap:10px;border:1px solid var(--border-2);border-radius:10px;background:var(--surface-2);padding:8px 8px 8px 10px;transition:background .16s ease,border-color .16s ease,transform .12s ease}.listening-vocab-card:hover:not(.is-saved){border-color:var(--ink-4);transform:translateY(-1px)}.listening-vocab-card.is-saved{background:#1e8e5a12;border-color:#1e8e5a4d}.listening-vocab-card.has-error{border-color:#bb453061}.listening-vocab-index{width:20px;height:20px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:#2e4bd91a;color:var(--blue);font:650 10.5px/1 var(--font-mono)}.listening-vocab-card.is-saved .listening-vocab-index{background:#1e8e5a1f;color:var(--green)}.listening-vocab-copy{min-width:0;flex:1;display:flex;flex-direction:column}.listening-vocab-ru,.listening-vocab-en{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-sans);line-height:1.3}.listening-vocab-ru{color:var(--ink-2);font-size:12px}.listening-vocab-en{margin-top:1px;color:var(--ink);font-size:13.5px;font-weight:500}.listening-vocab-error{margin-top:4px;color:var(--coral);font-size:11.5px;line-height:1.25}.listening-vocab-save{width:28px;height:28px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-2);border-radius:8px;background:var(--surface);color:var(--ink-2);cursor:pointer;font:650 12px/1 var(--font-mono);transition:background .14s ease,border-color .14s ease,color .14s ease}.listening-vocab-save:hover:not(:disabled){background:var(--bg-sunken);border-color:var(--ink-4)}.listening-vocab-save:disabled{cursor:default;opacity:.8}.listening-vocab-card.is-saved .listening-vocab-save{border-color:#1e8e5a59;background:#1e8e5a1f;color:var(--green)}.listening-empty{width:min(520px,100%);margin:auto;padding:32px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.listening-empty>svg,.listening-complete-icon{width:54px;height:54px;display:grid;place-items:center;border-radius:50%;background:var(--tint-blue);color:var(--blue)}.listening-complete-icon{background:var(--tint-green);color:var(--green)}.listening-empty h2{margin:6px 0 4px;font:400 28px/1.15 var(--font-serif)}.listening-empty p{margin:0;color:var(--ink-2);font-size:14px;line-height:1.55}@media(max-width:880px){.listening-progress-row{flex-wrap:wrap;gap:14px}.listening-progress-track{order:3;flex-basis:100%}.listening-player-card{gap:18px;padding:18px 20px}.listening-result-head{flex-direction:column;align-items:stretch}.listening-result-actions{flex-wrap:wrap}.listening-vocab-strip-head{align-items:stretch;flex-direction:column}.listening-save-all-button{align-self:flex-start}}@media(max-width:600px){.listening-page{padding:18px 18px 24px}.listening-player-card{flex-direction:column;align-items:stretch;gap:14px}.listening-play-button{align-self:center}.listening-input-foot{flex-direction:column;align-items:stretch;gap:10px}.listening-check-button{justify-content:center}.listening-vocab-strip-label{flex-wrap:wrap;line-height:1.35}.listening-vocab-card{width:100%;max-width:none}.listening-vocab-ru,.listening-vocab-en{white-space:normal}}.dev-mode-wrap{position:fixed;right:18px;bottom:18px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:10px;font-family:inherit}.dev-mode-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid rgba(234,88,12,.45);background:#1c1410;color:#fdba74;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;box-shadow:0 8px 24px #00000040;transition:transform .12s ease,box-shadow .12s ease}.dev-mode-badge:hover{transform:translateY(-1px);box-shadow:0 12px 28px #0000004d}.dev-mode-badge.is-open{background:#2a1a10;color:#fed7aa}.dev-mode-dot{width:8px;height:8px;border-radius:50%;background:#f97316;box-shadow:0 0 0 3px #f9731640}.dev-mode-menu{width:260px;padding:14px;border-radius:14px;background:#18120e;border:1px solid rgba(234,88,12,.35);color:#f9fafb;box-shadow:0 18px 40px #0006;display:flex;flex-direction:column;gap:10px}.dev-mode-menu-head strong{display:block;font-size:13px;letter-spacing:.04em;margin-bottom:4px}.dev-mode-menu-head p{margin:0;font-size:12px;color:#d4d4d8;line-height:1.45}.dev-mode-actions{display:flex;flex-direction:column;gap:6px}.dev-mode-actions button,.dev-mode-off{appearance:none;border:1px solid rgba(255,255,255,.08);background:#251a13;color:#f9fafb;padding:8px 12px;border-radius:8px;font-size:12px;text-align:left;cursor:pointer;transition:background .12s ease,border-color .12s ease}.dev-mode-actions button:hover,.dev-mode-off:hover{background:#321f15;border-color:#f9731673}.dev-mode-off{margin-top:4px;color:#fdba74;border-color:#f9731673;text-align:center;font-weight:600}
