:root{--navy-950:#0b1623;--navy-900:#0f1e30;--navy-800:#16293f;--navy-700:#1f3a56;--navy-600:#2c4d6e;--navy-500:#3e6488;--navy-400:#6b8aa8;--amber-700:#9c6316;--amber-600:#be7c20;--amber-500:#db9a33;--amber-400:#e7b25c;--amber-300:#f0c883;--amber-200:#f7ddae;--paper-50:#fbf8f2;--paper-100:#f5efe4;--paper-200:#ece3d3;--paper-300:#dfd3be;--surface:#fff;--text:#1b2735;--text-muted:#5c6b7a;--text-on-dark:#f3efe7;--success:#3f8f5b;--success-soft:#e6f0e8;--danger:#c2453c;--danger-soft:#f6e3e1;--warning:#c98a1e;--warning-soft:#f6ead2;--info:#3a6ea5;--info-soft:#e2eaf3;--brand:var(--amber-500);--primary:var(--navy-900);--primary-hover:var(--navy-800);--primary-contrast:var(--text-on-dark);--accent:var(--amber-500);--accent-hover:var(--amber-600);--bg:var(--paper-50);--card:var(--surface);--border:var(--paper-300);--ring-focus:0 0 0 3px #db9a334d;--glow-amber:#db9a332e;--cefr-a1:#f0d9b5;--cefr-a2:#e6be86;--cefr-b1:#d79e4f;--cefr-b2:#b97a26;--font-serif:"Newsreader", Georgia, "Times New Roman", serif;--font-ui:"Hanken Grotesk", system-ui, sans-serif;--fs-12:12px;--fs-13:13px;--fs-14:14px;--fs-15:15px;--fs-18:18px;--fs-24:24px;--fs-30:30px;--fs-36:36px;--fs-48:48px;--lh-body:1.55;--tracking-heading:-.01em;--tracking-eyebrow:.06em;--sp-4:4px;--sp-8:8px;--sp-12:12px;--sp-16:16px;--sp-20:20px;--sp-24:24px;--sp-32:32px;--sp-40:40px;--sp-48:48px;--sp-64:64px;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--r-full:9999px;--shadow-sm:0 1px 2px #2b1e0c0f, 0 1px 1px #2b1e0c0a;--shadow-md:0 4px 12px #2b1e0c14, 0 2px 4px #2b1e0c0d;--shadow-lg:0 14px 36px #2b1e0c24;--motion-hover:.12s ease-out;--motion-layout:.18s ease-out;--motion-modal:.24s ease-out}*,:before,:after{box-sizing:border-box}*{margin:0}html{-webkit-text-size-adjust:100%}body{min-height:100vh;font-family:var(--font-ui);font-size:var(--fs-15);line-height:var(--lh-body);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}#root{isolation:isolate;min-height:100vh}h1,h2,h3,h4{font-family:var(--font-serif);letter-spacing:var(--tracking-heading);color:var(--text);font-weight:600;line-height:1.2}p{line-height:var(--lh-body)}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit}img,svg{max-width:100%;display:block}ul,ol{padding:0;list-style:none}:focus-visible{box-shadow:var(--ring-focus);border-radius:var(--r-sm);outline:none}.eyebrow{font-family:var(--font-ui);font-size:var(--fs-12);text-transform:uppercase;letter-spacing:var(--tracking-eyebrow);color:var(--text-muted);font-weight:600}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}.btn{justify-content:center;align-items:center;gap:var(--sp-8);font-family:var(--font-ui);border-radius:var(--r-sm);cursor:pointer;transition:background-color var(--motion-hover), border-color var(--motion-hover), color var(--motion-hover), box-shadow var(--motion-hover);white-space:nowrap;border:1px solid #0000;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--full{width:100%}.btn--sm{font-size:var(--fs-13);padding:var(--sp-8) var(--sp-12)}.btn--md{font-size:var(--fs-14);padding:var(--sp-12) var(--sp-20)}.btn--lg{font-size:var(--fs-15);padding:var(--sp-16) var(--sp-24)}.btn--primary{background:var(--primary);color:var(--primary-contrast);box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){background:var(--primary-hover)}.btn--accent{background:var(--accent);color:var(--navy-950);box-shadow:var(--shadow-sm)}.btn--accent:hover:not(:disabled){background:var(--accent-hover)}.btn--outline{background:var(--surface);color:var(--text);border-color:var(--border)}.btn--outline:hover:not(:disabled){background:var(--paper-100);border-color:var(--paper-200)}.btn--ghost{color:var(--text);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--paper-100)}.btn__icon{align-items:center;display:inline-flex}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-24)}.card--flush{padding:0}.card--interactive{transition:box-shadow var(--motion-hover), transform var(--motion-hover);cursor:pointer}.card--interactive:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.badge{align-items:center;gap:var(--sp-4);font-family:var(--font-ui);font-size:var(--fs-12);padding:var(--sp-4) var(--sp-8);border-radius:var(--r-full);white-space:nowrap;border:1px solid #0000;font-weight:600;line-height:1;display:inline-flex}.badge--neutral{background:var(--paper-100);color:var(--text-muted);border-color:var(--paper-200)}.badge--info{background:var(--info-soft);color:var(--info)}.badge--success{background:var(--success-soft);color:var(--success)}.badge--warning{background:var(--warning-soft);color:var(--warning)}.badge--danger{background:var(--danger-soft);color:var(--danger)}.level-pill{font-family:var(--font-ui);letter-spacing:.02em;border-radius:var(--r-full);justify-content:center;align-items:center;font-weight:700;line-height:1;display:inline-flex}.level-pill--sm{font-size:var(--fs-12);padding:var(--sp-4) var(--sp-8)}.level-pill--md{font-size:var(--fs-13);padding:var(--sp-4) var(--sp-12)}.context-strip{align-items:center;gap:var(--sp-8);font-family:var(--font-ui);font-size:var(--fs-13);color:var(--text-muted);font-weight:600;display:inline-flex}.context-strip__item{white-space:nowrap}.context-strip__sep{color:var(--paper-300)}.context-strip--on-dark{color:var(--text-on-dark)}.context-strip--on-dark .context-strip__sep{color:var(--navy-500)}.progress{align-items:center;gap:var(--sp-12);width:100%;display:flex}.progress__track{background:var(--paper-200);border-radius:var(--r-full);flex:1;height:8px;overflow:hidden}.progress__fill{background:var(--navy-700);border-radius:var(--r-full);height:100%;transition:width var(--motion-layout)}.progress__value{font-family:var(--font-ui);font-size:var(--fs-13);color:var(--text-muted);text-align:right;min-width:36px;font-weight:600}.avatar{border-radius:var(--r-full);font-family:var(--font-ui);background:var(--paper-200);color:var(--navy-800);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.avatar--sm{width:28px;height:28px;font-size:var(--fs-12)}.avatar--md{width:38px;height:38px;font-size:var(--fs-14)}.avatar--on-dark{background:var(--navy-700);color:var(--text-on-dark)}.lang-select{align-items:center;display:inline-flex}.lang-select--inline{border-radius:var(--r-full);background:var(--paper-100);border:1px solid var(--border);gap:2px;padding:2px}.lang-select__btn{appearance:none;cursor:pointer;padding:var(--sp-4) var(--sp-12);border-radius:var(--r-full);color:var(--text-muted);font-family:var(--font-ui);font-size:var(--fs-12);letter-spacing:.03em;transition:background-color var(--motion-hover), color var(--motion-hover);background:0 0;border:none;font-weight:700}.lang-select__btn:hover{color:var(--text)}.lang-select__btn--active{background:var(--surface);color:var(--navy-900);box-shadow:var(--shadow-sm)}.lang-select--on-dark.lang-select--inline{background:var(--navy-800);border-color:var(--navy-700)}.lang-select--on-dark .lang-select__btn{color:var(--navy-400)}.lang-select--on-dark .lang-select__btn:hover{color:var(--text-on-dark)}.lang-select--on-dark .lang-select__btn--active{background:var(--navy-600);color:var(--amber-300);box-shadow:none}.lang-select--dropdown{gap:var(--sp-8);color:var(--text-muted)}.lang-select__icon{color:var(--text-muted);flex-shrink:0}.lang-select__native{appearance:auto;font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-8) var(--sp-12);cursor:pointer;font-weight:600}.lang-select__native:focus-visible{box-shadow:var(--ring-focus);outline:none}.lang-select__sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.sidebar{background:var(--navy-900);width:248px;color:var(--text-on-dark);padding:var(--sp-24) var(--sp-16);gap:var(--sp-32);flex-direction:column;flex-shrink:0;display:flex}.sidebar__brand{align-items:center;gap:var(--sp-12);padding:0 var(--sp-8);border-radius:var(--r-md);transition:opacity var(--motion-hover);text-decoration:none;display:flex}.sidebar__brand:hover{opacity:.85}.sidebar__brand:focus-visible{box-shadow:var(--ring-focus);outline:none}.sidebar__brand-mark{border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);width:34px;height:34px;color:var(--navy-950);flex-shrink:0;justify-content:center;align-items:center;padding:2px;display:inline-flex;overflow:hidden}.sidebar__brand-img{object-fit:contain;width:100%;height:100%}.sidebar__brand-text{font-family:var(--font-ui);font-weight:700;font-size:var(--fs-15);color:var(--text-on-dark);flex-direction:column;line-height:1.2;display:flex}.sidebar__brand-sub{font-weight:500;font-size:var(--fs-12);color:var(--navy-400);letter-spacing:.02em}.sidebar__nav{gap:var(--sp-4);flex-direction:column;flex:1;display:flex}.sidebar__link{align-items:center;gap:var(--sp-12);padding:var(--sp-12) var(--sp-12);border-radius:var(--r-md);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--navy-400);transition:background-color var(--motion-hover), color var(--motion-hover);font-weight:600;display:flex}.sidebar__link:hover{background:var(--navy-800);color:var(--text-on-dark)}.sidebar__link--active{background:var(--navy-800);color:var(--amber-400)}.sidebar__link--active .sidebar__link-icon{color:var(--amber-500)}.sidebar__link-icon{flex-shrink:0}.sidebar__footer{align-items:center;gap:var(--sp-12);padding:var(--sp-12) var(--sp-8);border-top:1px solid var(--navy-800);display:flex}.sidebar__user-block{align-items:center;gap:var(--sp-12);flex:1;min-width:0;display:flex}.sidebar__user{flex-direction:column;min-width:0;line-height:1.3;display:flex}.sidebar__logout{border-radius:var(--r-md);width:34px;height:34px;color:var(--navy-400);cursor:pointer;transition:background-color var(--motion-hover), color var(--motion-hover);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sidebar__logout:hover{background:var(--navy-800);color:var(--text-on-dark)}.sidebar__user-name{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-on-dark);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.sidebar__lang{padding:0 var(--sp-8);display:flex}.sidebar__lang--footer{padding-bottom:var(--sp-8)}.sidebar__guest{gap:var(--sp-8);padding:var(--sp-16) var(--sp-8) var(--sp-8);border-top:1px solid var(--navy-800);flex-direction:column;display:flex}.sidebar__guest-note{font-family:var(--font-ui);font-size:var(--fs-12);color:var(--navy-400);margin-bottom:var(--sp-4)}.sidebar__user-role{font-size:var(--fs-12);color:var(--navy-400)}@media (width<=860px){.sidebar{align-items:center;gap:var(--sp-16);width:100%;padding:var(--sp-12) var(--sp-16);flex-direction:row}.sidebar__brand-text{display:none}.sidebar__nav{flex-flow:wrap;flex:1;justify-content:center}.sidebar__link span:not(.sidebar__link-icon){display:none}.sidebar__link{padding:var(--sp-8)}.sidebar__footer{border-top:none;flex:none;padding:0}.sidebar__user-block{flex:none}.sidebar__user{display:none}.sidebar__guest{align-items:center;gap:var(--sp-8);border-top:none;flex-direction:row;flex:none;padding:0}.sidebar__guest-note,.sidebar__guest .btn--outline{display:none}}.empty-state{text-align:center;align-items:center;gap:var(--sp-12);padding:var(--sp-40) var(--sp-24);flex-direction:column;display:flex}.empty-state__icon{border-radius:var(--r-full);background:var(--paper-100);width:48px;height:48px;color:var(--text-muted);justify-content:center;align-items:center;display:inline-flex}.empty-state__title{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);font-weight:600}.empty-state__desc{font-size:var(--fs-14);color:var(--text-muted);max-width:36ch}.empty-state__action{margin-top:var(--sp-4)}.skeleton{background:linear-gradient(90deg, var(--paper-100) 0%, var(--paper-200) 50%, var(--paper-100) 100%);background-size:200% 100%;animation:1.4s ease-in-out infinite skeleton-shimmer;display:block}.skeleton-text{gap:var(--sp-8);flex-direction:column;display:flex}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion:reduce){.skeleton{animation:none}}.error-state{text-align:center;align-items:center;gap:var(--sp-12);padding:var(--sp-32) var(--sp-24);background:var(--danger-soft);border:1px solid var(--danger-soft);border-radius:var(--r-lg);flex-direction:column;display:flex}.error-state__icon{border-radius:var(--r-full);background:var(--surface);width:48px;height:48px;color:var(--danger);justify-content:center;align-items:center;display:inline-flex}.error-state__title{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);font-weight:600}.error-state__desc{font-size:var(--fs-14);color:var(--text-muted);max-width:40ch}.locale-fallback{align-items:center;gap:var(--sp-8);padding:var(--sp-8) var(--sp-12);margin-bottom:var(--sp-16);background:var(--info-soft);color:var(--info);border-radius:var(--r-md);font-family:var(--font-ui);font-size:var(--fs-13);font-weight:600;display:flex}.locale-fallback svg{flex-shrink:0}.back-link{align-self:flex-start;align-items:center;gap:var(--sp-8);padding:var(--sp-12) var(--sp-20);background:var(--primary);color:var(--primary-contrast);border-radius:var(--r-sm);font-family:var(--font-ui);font-size:var(--fs-14);box-shadow:var(--shadow-sm);transition:background-color var(--motion-hover);font-weight:600;display:inline-flex}.back-link:hover{background:var(--primary-hover)}.back-link--top{margin-bottom:var(--sp-16)}.mascot{flex:none;line-height:0;display:inline-block;position:relative}.mascot__frame{object-fit:contain;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;inset:0}.mascot__frame--talking{opacity:0}.mascot__frame--think{opacity:0;transition:opacity .2s ease-in-out}.mascot--thinking .mascot__frame--think{opacity:1}.mascot__frame--blink{opacity:0;transition:opacity 65ms ease-in-out}.mascot__frame--blink-on{opacity:1}.mascot--talking{animation:1.1s ease-in-out infinite mascot-bob}.mascot--talking .mascot__frame--talking{animation:.32s ease-in-out infinite mascot-talk}.mascot--thinking{animation:3s ease-in-out infinite mascot-bob}@keyframes mascot-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes mascot-talk{0%,to{opacity:0}50%{opacity:1}}.mascot__cloud{border-radius:var(--r-full);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);align-items:center;gap:3px;padding:4px 6px;line-height:0;display:inline-flex;position:absolute;top:-14%;right:-16%}.mascot__cloud:after{content:"";border-radius:var(--r-full);background:var(--surface);border:1px solid var(--border);width:5px;height:5px;position:absolute;bottom:-3px;left:6px}.mascot__dot{border-radius:var(--r-full);background:var(--amber-500);opacity:.35;width:4px;height:4px;animation:1.2s ease-in-out infinite mascot-think}.mascot__dot:nth-child(2){animation-delay:.2s}.mascot__dot:nth-child(3){animation-delay:.4s}@keyframes mascot-think{0%,60%,to{opacity:.35;transform:translateY(0)}30%{opacity:1;transform:translateY(-1px)}}@media (prefers-reduced-motion:reduce){.mascot--talking,.mascot--thinking{animation:none}.mascot--talking .mascot__frame--talking{opacity:1;animation:none}.mascot__dot{opacity:.7;animation:none}.mascot__frame--blink,.mascot__frame--think{transition:none}}.tutor{gap:var(--sp-16);flex-direction:column;display:flex}.tutor__templates{gap:var(--sp-8);flex-wrap:wrap;display:flex}.tutor__template{align-items:center;gap:var(--sp-8);padding:var(--sp-8) var(--sp-16);border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface);font-family:var(--font-ui);font-size:var(--fs-13);color:var(--text);cursor:pointer;transition:border-color var(--motion-hover), background-color var(--motion-hover);font-weight:600;display:inline-flex}.tutor__template:hover:not(:disabled){border-color:var(--amber-400);background:var(--paper-50)}.tutor__template:disabled{cursor:default;opacity:.6}.tutor__thread{gap:var(--sp-16);flex-direction:column;min-height:220px;display:flex}.tutor__turn{display:flex}.tutor__turn--user{justify-content:flex-end}.tutor__turn--assistant{justify-content:flex-start}.tutor__bubble{max-width:80%;padding:var(--sp-12) var(--sp-16);border-radius:var(--r-lg);font-family:var(--font-ui);font-size:var(--fs-15);white-space:pre-wrap;line-height:1.55}.tutor__bubble--user{background:var(--navy-900);color:var(--text-on-dark);border-bottom-right-radius:var(--r-sm)}.tutor__bubble--assistant{background:var(--paper-100);color:var(--text);border-bottom-left-radius:var(--r-sm)}.tutor__bubble--off-topic{background:var(--warning-soft);color:var(--text)}.tutor__off-topic-tag{margin-top:var(--sp-8);font-size:var(--fs-12);letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--warning);font-weight:600;display:block}.tutor__md{white-space:normal;font-size:var(--fs-15);overflow-wrap:anywhere;line-height:1.55}.tutor__md>:first-child{margin-top:0}.tutor__md>:last-child{margin-bottom:0}.tutor__md p{margin:var(--sp-8) 0}.tutor__md ul,.tutor__md ol{margin:var(--sp-8) 0;padding-left:1.4em}.tutor__md li{margin:var(--sp-4) 0}.tutor__md li>p{margin:0}.tutor__md strong{font-weight:700}.tutor__md em{font-style:italic}.tutor__md :not(pre)>code{font-family:var(--font-mono,ui-monospace, SFMono-Regular, Menlo, monospace);border-radius:var(--r-sm);background:var(--surface);border:1px solid var(--border);overflow-wrap:anywhere;word-break:break-word;padding:.1em .35em;font-size:.9em}.tutor__md pre{margin:var(--sp-8) 0;padding:var(--sp-12);border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);overflow-x:auto}.tutor__md pre code{font-family:var(--font-mono,ui-monospace, SFMono-Regular, Menlo, monospace);white-space:pre;background:0 0;border:0;padding:0;font-size:.9em}.tutor__md a{color:var(--amber-600,var(--amber-400));overflow-wrap:anywhere;text-decoration:underline}.tutor__md a:hover{text-decoration:none}.tutor__composer{gap:var(--sp-12);flex-direction:column;display:flex}.tutor__input-row{align-items:flex-end;gap:var(--sp-12);display:flex}.tutor__input{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);padding:var(--sp-12) var(--sp-16);border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);resize:vertical;flex:1;line-height:1.5}.tutor__input:focus-visible{border-color:var(--amber-400)}.tutor__error{font-size:var(--fs-13);color:var(--danger)}.tutor__hint{font-size:var(--fs-13);color:var(--text-muted)}.tutor__guest-intro{font-size:var(--fs-14);color:var(--text-muted);padding:var(--sp-4) 0;line-height:1.55}.tutor__guest-locked{gap:var(--sp-12);padding:var(--sp-16);background:var(--paper-100);border-radius:var(--r-md);flex-direction:column;display:flex}.tutor__guest-locked-text{font-size:var(--fs-14);color:var(--text)}.tutor__sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.tutor-bubble{right:var(--sp-24);bottom:var(--sp-24);z-index:100;align-items:flex-end;gap:var(--sp-12);flex-direction:column;display:flex;position:fixed}.tutor-bubble__fab{border:1px solid var(--navy-700);border-radius:var(--r-full);background:var(--navy-900);width:64px;height:64px;box-shadow:var(--shadow-lg);cursor:pointer;transition:transform var(--motion-hover), box-shadow var(--motion-hover), border-color var(--motion-hover);justify-content:center;align-items:center;padding:0;display:inline-flex}.tutor-bubble__fab:hover{border-color:var(--amber-400);transform:translateY(-2px)}.tutor-bubble__fab:focus-visible{box-shadow:var(--ring-focus), var(--shadow-lg);outline:none}.tutor-bubble__fab-mascot{pointer-events:none}.tutor-bubble__panel{width:380px;max-width:calc(100vw - 2 * var(--sp-24));border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);height:min(560px,80vh);box-shadow:var(--shadow-lg);transform-origin:100% 100%;animation:tutor-bubble-in var(--motion-modal);flex-direction:column;display:flex;overflow:hidden}@keyframes tutor-bubble-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.tutor-bubble__header{align-items:center;gap:var(--sp-12);padding:var(--sp-12) var(--sp-16);background:var(--navy-900);color:var(--text-on-dark);display:flex}.tutor-bubble__header-mascot{flex:none}.tutor-bubble__heading{flex-direction:column;flex:1;min-width:0;display:flex}.tutor-bubble__title{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text-on-dark);font-weight:700}.tutor-bubble__hint{font-size:var(--fs-12);color:var(--navy-400)}.tutor-bubble__close,.tutor-bubble__clear{border-radius:var(--r-sm);width:32px;height:32px;color:var(--text-on-dark);cursor:pointer;transition:background-color var(--motion-hover), color var(--motion-hover), opacity var(--motion-hover);background:0 0;border:none;flex:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.tutor-bubble__close:hover,.tutor-bubble__clear:hover:not(:disabled){background:var(--navy-700)}.tutor-bubble__close:focus-visible,.tutor-bubble__clear:focus-visible{box-shadow:var(--ring-focus);outline:none}.tutor-bubble__clear:disabled{opacity:.45;cursor:default}.tutor-bubble__confirm{align-items:center;gap:var(--sp-4);flex:none;display:inline-flex}.tutor-bubble__confirm-label{font-size:var(--fs-12);color:var(--text-on-dark);white-space:nowrap;font-weight:600}.tutor-bubble__confirm-yes,.tutor-bubble__confirm-no{border-radius:var(--r-sm);cursor:pointer;width:28px;height:28px;transition:background-color var(--motion-hover), opacity var(--motion-hover);border:none;flex:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.tutor-bubble__confirm-yes{background:var(--amber-400);color:var(--navy-900)}.tutor-bubble__confirm-yes:hover:not(:disabled){background:var(--amber-300)}.tutor-bubble__confirm-no{background:var(--navy-700);color:var(--text-on-dark)}.tutor-bubble__confirm-no:hover:not(:disabled){background:var(--navy-600)}.tutor-bubble__confirm-yes:focus-visible,.tutor-bubble__confirm-no:focus-visible{box-shadow:var(--ring-focus);outline:none}.tutor-bubble__confirm-yes:disabled,.tutor-bubble__confirm-no:disabled{opacity:.55;cursor:default}.tutor-bubble__body{min-height:0;padding:var(--sp-16);flex:1;overflow-y:auto}.tutor-bubble__body .tutor__thread{min-height:0}@media (prefers-reduced-motion:reduce){.tutor-bubble__panel{animation:none}.tutor-bubble__fab{transition:none}.tutor-bubble__fab:hover{transform:none}}@media (width<=860px){.tutor-bubble__panel{border-radius:var(--r-lg) var(--r-lg) 0 0;border-bottom:none;width:100%;max-width:100%;height:85vh;position:fixed;inset:auto 0 0}.tutor-bubble--open .tutor-bubble__fab{display:none}}.vocab-card{gap:var(--sp-8);text-align:left;width:100%;padding:var(--sp-16) var(--sp-20);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow var(--motion-hover), transform var(--motion-hover), border-color var(--motion-hover);flex-direction:column;display:flex}.vocab-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.vocab-card:focus-visible{box-shadow:var(--ring-focus);outline:none}.vocab-card--revealed{border-color:var(--amber-300)}.vocab-card__head{justify-content:space-between;align-items:center;gap:var(--sp-12);display:flex}.vocab-card__hint{align-items:center;gap:var(--sp-4);font-family:var(--font-ui);font-size:var(--fs-12);color:var(--text-muted);white-space:nowrap;font-weight:600;display:inline-flex}.vocab-card__term{font-family:var(--font-serif);font-size:var(--fs-24);letter-spacing:var(--tracking-heading);color:var(--text);font-weight:600;line-height:1.2}.vocab-card__example{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);line-height:1.5}.vocab-card__reveal{gap:var(--sp-4);margin-top:var(--sp-8);padding-top:var(--sp-12);border-top:1px solid var(--paper-200);flex-direction:column;display:flex}.vocab-card__translation{font-family:var(--font-ui);font-size:var(--fs-18);color:var(--navy-700);font-weight:600}.vocab-card__example-translation{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-muted);line-height:1.5}.vocab-card__fallback{align-items:center;gap:var(--sp-4);margin-top:var(--sp-4);font-family:var(--font-ui);font-size:var(--fs-12);color:var(--amber-700);display:inline-flex}.review-card{gap:var(--sp-12);width:100%;max-width:560px;padding:var(--sp-24) var(--sp-24);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-direction:column;margin:0 auto;display:flex}.review-card__head{justify-content:space-between;align-items:center;gap:var(--sp-12);display:flex}.review-card__term{font-family:var(--font-serif);font-size:var(--fs-30);letter-spacing:var(--tracking-heading);color:var(--text);font-weight:600;line-height:1.2}.review-card__example{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);line-height:1.5}.review-card__flip{margin-top:var(--sp-8);padding:var(--sp-12) var(--sp-16);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--navy-700);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color var(--motion-hover), box-shadow var(--motion-hover);font-weight:600}.review-card__flip:hover{border-color:var(--accent)}.review-card__flip:focus-visible{box-shadow:var(--ring-focus);outline:none}.review-card__reveal{gap:var(--sp-4);margin-top:var(--sp-8);padding-top:var(--sp-12);border-top:1px solid var(--paper-200);flex-direction:column;display:flex}.review-card__translation{font-family:var(--font-ui);font-size:var(--fs-18);color:var(--navy-700);font-weight:600}.review-card__example-translation{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-muted);line-height:1.5}.review-card__fallback{align-items:center;gap:var(--sp-4);margin-top:var(--sp-4);font-family:var(--font-ui);font-size:var(--fs-12);color:var(--amber-700);display:inline-flex}.review-card__grades{gap:var(--sp-8);margin-top:var(--sp-8);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}@media (width<=480px){.review-card__grades{grid-template-columns:repeat(2,minmax(0,1fr))}}.review-card__grade{padding:var(--sp-12) var(--sp-8);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color var(--motion-hover), box-shadow var(--motion-hover), background var(--motion-hover);font-weight:600}.review-card__grade:hover:not(:disabled){box-shadow:var(--shadow-sm)}.review-card__grade:focus-visible{box-shadow:var(--ring-focus);outline:none}.review-card__grade:disabled{opacity:.55;cursor:default}.review-card__grade--danger:hover:not(:disabled){border-color:var(--danger)}.review-card__grade--warning:hover:not(:disabled){border-color:var(--amber-400)}.review-card__grade--info:hover:not(:disabled){border-color:var(--navy-700)}.review-card__grade--success:hover:not(:disabled){border-color:var(--accent)}.app-layout{background:var(--bg);min-height:100vh;display:flex}.app-layout__main{flex:1;min-width:0;overflow-x:hidden}.app-layout__content{max-width:980px;padding:var(--sp-40) var(--sp-32) var(--sp-64);margin:0 auto}.app-layout__guest-bar{justify-content:center;align-items:center;gap:var(--sp-8) var(--sp-16);padding:var(--sp-12) var(--sp-24);background:var(--paper-100);border-bottom:1px solid var(--border);font-family:var(--font-ui);font-size:var(--fs-13);flex-wrap:wrap;display:flex}.app-layout__guest-bar-text{color:var(--text-muted)}.app-layout__guest-bar-cta{align-items:center;gap:var(--sp-8);color:var(--amber-700);text-underline-offset:2px;font-weight:600;text-decoration:underline;display:inline-flex}.app-layout__guest-bar-cta:hover{color:var(--amber-600)}@media (width<=860px){.app-layout{flex-direction:column}.app-layout__content{padding:var(--sp-24) var(--sp-16) var(--sp-40)}}.auth-gate{justify-content:center;align-items:center;gap:var(--sp-16);background:var(--bg);min-height:100vh;color:var(--text-muted);font-family:var(--font-ui);font-size:var(--fs-14);flex-direction:column;display:flex}.auth-gate__spinner{border:3px solid var(--paper-300);border-top-color:var(--amber-500);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite auth-gate-spin}.auth-gate__label{letter-spacing:.01em}@keyframes auth-gate-spin{to{transform:rotate(360deg)}}.landing{background:radial-gradient(140% 90% at 50% -10%, var(--navy-800) 0%, var(--navy-950) 60%);min-height:100vh;color:var(--text-on-dark)}.landing__nav{justify-content:space-between;align-items:center;gap:var(--sp-16);max-width:1120px;padding:var(--sp-20) var(--sp-24);margin:0 auto;display:flex}.landing__brand{align-items:center;gap:var(--sp-12);display:flex}.landing__brand-mark{border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;padding:2px;display:inline-flex;overflow:hidden}.landing__brand-img{object-fit:contain;width:100%;height:100%}.landing__brand-text{font-family:var(--font-ui);font-weight:700;font-size:var(--fs-15);color:var(--text-on-dark);flex-direction:column;line-height:1.2;display:flex}.landing__brand-sub{font-weight:500;font-size:var(--fs-12);color:var(--navy-400);letter-spacing:.02em}.landing__nav-actions{align-items:center;gap:var(--sp-16);display:flex}.landing__nav-link{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-on-dark);font-weight:600;text-decoration:none}.landing__nav-link:hover{color:var(--amber-300)}.landing__main{gap:var(--sp-48);max-width:1120px;padding:var(--sp-40) var(--sp-24) var(--sp-64);grid-template-columns:1.05fr .95fr;align-items:start;margin:0 auto;display:grid}@media (width<=880px){.landing__main{gap:var(--sp-32);grid-template-columns:1fr}}.landing__eyebrow{font-family:var(--font-ui);font-size:var(--fs-13);letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--amber-300);margin-bottom:var(--sp-16);font-weight:700}.landing__title{font-family:var(--font-serif);font-size:var(--fs-48);letter-spacing:var(--tracking-heading);margin-bottom:var(--sp-20);line-height:1.05}.landing__title-accent{color:var(--amber-400)}.landing__lead{font-family:var(--font-ui);font-size:var(--fs-18);line-height:var(--lh-body);color:var(--text-on-dark);opacity:.88;max-width:48ch;margin-bottom:var(--sp-32)}.landing__hero-actions{gap:var(--sp-16);margin-bottom:var(--sp-32);flex-wrap:wrap;display:flex}.landing__explore-cta{align-items:center;gap:var(--sp-16);padding:var(--sp-16) var(--sp-20);margin-bottom:var(--sp-16);border:1px solid var(--amber-500);border-radius:var(--r-lg);max-width:460px;transition:border-color var(--motion-hover), background-color var(--motion-hover);background:#db9a331a;text-decoration:none;display:flex}.landing__explore-cta:hover{border-color:var(--amber-300);background:#db9a3329}.landing__explore-icon{border-radius:var(--r-md);background:var(--amber-500);width:40px;height:40px;color:var(--navy-950);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.landing__explore-body{gap:var(--sp-4);flex-direction:column;display:flex}.landing__explore-title{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text-on-dark);font-weight:700}.landing__explore-hint{font-family:var(--font-ui);font-size:var(--fs-13);color:var(--navy-400)}.landing__exam-card{align-items:center;gap:var(--sp-16);padding:var(--sp-16) var(--sp-20);border:1px solid var(--navy-600);border-radius:var(--r-lg);max-width:460px;transition:border-color var(--motion-hover), background-color var(--motion-hover);background:#ffffff0a;text-decoration:none;display:flex}.landing__exam-card:hover{border-color:var(--amber-400);background:#ffffff12}.landing__exam-lock{border-radius:var(--r-md);background:var(--navy-700);width:40px;height:40px;color:var(--amber-300);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.landing__exam-body{gap:var(--sp-4);flex-direction:column;display:flex}.landing__exam-title{align-items:center;gap:var(--sp-8);font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text-on-dark);font-weight:700;display:inline-flex}.landing__exam-hint{font-family:var(--font-ui);font-size:var(--fs-13);color:var(--navy-400)}.landing__try{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:var(--sp-24);color:var(--text)}.landing__try-header{align-items:center;gap:var(--sp-12);margin-bottom:var(--sp-16);display:flex}.landing__try-heading{flex-direction:column;flex:1;display:flex}.landing__try-title{font-family:var(--font-ui);font-weight:700;font-size:var(--fs-15);color:var(--text)}.landing__try-sub{font-size:var(--fs-12);color:var(--text-muted)}.landing__counter{font-family:var(--font-ui);font-size:var(--fs-13);color:var(--amber-700);background:var(--amber-200);padding:var(--sp-4) var(--sp-12);border-radius:var(--r-full);white-space:nowrap;font-weight:700}.landing__suggestions{gap:var(--sp-8);flex-wrap:wrap;display:flex}.landing__thread{min-height:160px;max-height:320px;overflow-y:auto}.landing__locked{gap:var(--sp-12);padding:var(--sp-16);border:1px solid var(--amber-300);border-radius:var(--r-md);background:var(--amber-200);flex-direction:column;display:flex}.landing__locked-text{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text);font-weight:600}.landing__locked-cta{text-decoration:none}.login{min-height:100vh;padding:var(--sp-32) var(--sp-16);background:radial-gradient(140% 100% at 50% -10%, var(--navy-800) 0%, var(--navy-950) 60%);justify-content:center;align-items:center;display:flex}.login__panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:var(--sp-32) var(--sp-32) var(--sp-40)}.login__top{justify-content:space-between;align-items:center;gap:var(--sp-16);margin-bottom:var(--sp-32);display:flex}.login__brand{align-items:center;gap:var(--sp-12);display:flex}.login__brand-mark{border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);width:38px;height:38px;color:var(--navy-950);flex-shrink:0;justify-content:center;align-items:center;padding:2px;display:inline-flex;overflow:hidden}.login__brand-img{object-fit:contain;width:100%;height:100%}.login__brand-text{font-family:var(--font-ui);font-weight:700;font-size:var(--fs-15);color:var(--text);flex-direction:column;line-height:1.2;display:flex}.login__brand-sub{font-weight:500;font-size:var(--fs-12);color:var(--text-muted);letter-spacing:.02em}.login__title{font-family:var(--font-serif);font-size:var(--fs-24);margin-bottom:var(--sp-4)}.login__subtitle{color:var(--text-muted);font-size:var(--fs-14);margin-bottom:var(--sp-24)}.login__form{gap:var(--sp-16);flex-direction:column;display:flex}.login__field{gap:var(--sp-8);flex-direction:column;display:flex}.login__label{font-family:var(--font-ui);font-size:var(--fs-13);color:var(--text);font-weight:600}.login__input{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);background:var(--paper-50);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-12) var(--sp-12);transition:border-color var(--motion-hover), box-shadow var(--motion-hover)}.login__input:focus{border-color:var(--amber-500);box-shadow:var(--ring-focus);outline:none}.login__error{background:var(--danger-soft);color:var(--danger);font-size:var(--fs-13);padding:var(--sp-12);border-radius:var(--r-md);font-weight:500;display:block}.login__form .btn{margin-top:var(--sp-8)}.login__alt{margin-top:var(--sp-24);font-size:var(--fs-13);color:var(--text-muted);text-align:center}.login__link{color:var(--amber-500);font-weight:600;text-decoration:none}.login__link:hover{text-decoration:underline}.register__select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a8b3c4' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--sp-12) center;padding-right:var(--sp-32)}.page-header{margin-bottom:var(--sp-32)}.page-header__row{justify-content:space-between;align-items:flex-end;gap:var(--sp-16);flex-wrap:wrap;display:flex}.page-header__titles{gap:var(--sp-8);flex-direction:column;min-width:0;display:flex}.page-header__eyebrow{color:var(--amber-700)}.page-header__title{font-size:var(--fs-36);color:var(--text)}.page-header__actions{flex-shrink:0}.page-header__extra{margin-top:var(--sp-16)}.dashboard{gap:var(--sp-32);flex-direction:column;display:flex}.dashboard__hero{background:var(--navy-900);color:var(--text-on-dark);border-radius:var(--r-xl);padding:var(--sp-32);box-shadow:var(--shadow-lg);gap:var(--sp-16);flex-direction:column;display:flex;position:relative;overflow:hidden}.dashboard__hero:after{content:"";background:radial-gradient(circle, var(--glow-amber), transparent 70%);pointer-events:none;width:320px;height:320px;position:absolute;top:-40%;right:-10%}.dashboard__hero-top{justify-content:space-between;align-items:center;gap:var(--sp-16);flex-wrap:wrap;display:flex;position:relative}.dashboard__hero-eyebrow{color:var(--amber-400)}.dashboard__hero-title{font-size:var(--fs-30);color:var(--text-on-dark);position:relative}.dashboard__hero-progress{max-width:480px;position:relative}.dashboard__hero-progress .progress__track{background:#ffffff29}.dashboard__hero-progress .progress__fill{background:var(--amber-400)}.dashboard__hero-progress .progress__value{color:var(--text-on-dark)}.dashboard__hero-actions{align-items:center;gap:var(--sp-16);flex-wrap:wrap;display:flex;position:relative}.dashboard__hero-link{align-items:center;gap:var(--sp-4);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-on-dark);transition:color var(--motion-hover);font-weight:600;display:inline-flex}.dashboard__hero-link:hover{color:var(--amber-400)}.dashboard__grid{gap:var(--sp-24);grid-template-columns:1fr 1fr;display:grid}.dashboard__card-head{margin-bottom:var(--sp-16);justify-content:space-between;align-items:center;display:flex}.dashboard__card-icon{color:var(--text-muted)}.dashboard__course-title,.dashboard__continue-title{font-size:var(--fs-24);margin-bottom:var(--sp-12)}.dashboard__course-meta{align-items:center;gap:var(--sp-8);margin-bottom:var(--sp-20);display:flex}.dashboard__course-track{font-size:var(--fs-13);color:var(--text-muted);font-weight:600}.dashboard__course-progress{margin-bottom:var(--sp-20)}.dashboard__course-link{align-items:center;gap:var(--sp-4);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--navy-700);transition:color var(--motion-hover);font-weight:600;display:inline-flex}.dashboard__course-link:hover{color:var(--navy-900)}.dashboard__continue-sub{font-size:var(--fs-14);color:var(--text-muted);margin-bottom:var(--sp-20)}.dashboard__review-count{font-size:var(--fs-24);margin-bottom:var(--sp-20)}.dashboard__review-mastered{font-size:var(--fs-14);color:var(--text-muted);margin-top:calc(-1 * var(--sp-12));margin-bottom:var(--sp-20)}.dashboard__review-mastered--center{margin-top:var(--sp-12);text-align:center;margin-bottom:0}@media (width<=720px){.dashboard__grid{grid-template-columns:1fr}}.my-courses{gap:var(--sp-16);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.my-courses__card{align-items:center;gap:var(--sp-20);padding:var(--sp-20);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--motion-hover), transform var(--motion-hover);display:flex}.my-courses__card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.my-courses__main{gap:var(--sp-12);flex-direction:column;flex:1;min-width:0;display:flex}.my-courses__title{font-family:var(--font-serif);font-size:var(--fs-24);letter-spacing:var(--tracking-heading);color:var(--text);font-weight:600}.my-courses__arrow{color:var(--text-muted);flex-shrink:0}.path{gap:var(--sp-24);flex-direction:column;display:flex}.path__intro{align-items:center;gap:var(--sp-12);flex-wrap:wrap;display:flex}.path__intro-track{font-size:var(--fs-13);color:var(--text-muted);font-weight:600}.path__intro-desc{margin:var(--sp-4) 0 0;font-size:var(--fs-15);color:var(--text-muted);flex-basis:100%;max-width:60ch;line-height:1.55}.path__timeline{margin:0;padding:0;list-style:none;position:relative}.path__timeline:before{content:"";background:var(--paper-300);width:2px;position:absolute;top:12px;bottom:12px;left:15px}.path__node{gap:var(--sp-16);padding-bottom:var(--sp-20);display:flex;position:relative}.path__node:last-child{padding-bottom:0}.path__marker{z-index:1;border-radius:var(--r-full);background:var(--surface);border:2px solid var(--paper-300);width:32px;height:32px;color:var(--text-muted);flex-shrink:0;place-items:center;display:grid;position:relative}.path__marker--complete{background:var(--success);border-color:var(--success);color:#fff}.path__marker--in_progress{background:var(--accent);border-color:var(--accent);color:var(--navy-900)}.path__marker--available{border-color:var(--accent);color:var(--accent-hover)}.path__marker--locked{background:var(--paper-100);border-color:var(--paper-300);color:var(--text-muted)}.path__marker--exam,.path__marker--exam-gated{background:var(--navy-900);border-color:var(--navy-900);color:var(--amber-400)}.path__marker--passed{background:var(--accent);border-color:var(--accent);color:var(--navy-900)}.path__node-inner{min-width:0;padding:var(--sp-20);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);color:inherit;flex:1;text-decoration:none;display:block}.path__node-inner--link{transition:box-shadow var(--motion-hover), transform var(--motion-hover)}.path__node-inner--link:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.path__node-inner--link:hover .path__node-cta{color:var(--accent-hover)}.path__node-inner--locked{background:var(--paper-100);box-shadow:none;cursor:default;border-style:dashed}.path__node-body{gap:var(--sp-8);flex-direction:column;display:flex}.path__node-head{align-items:center;gap:var(--sp-12);flex-wrap:wrap;display:flex}.path__node-order{color:var(--text-muted)}.path__node-status{font-size:var(--fs-12);padding:2px var(--sp-8);border-radius:var(--r-full);align-items:center;gap:4px;margin-left:auto;font-weight:600;display:inline-flex}.path__node-status--complete{color:var(--success);background:var(--success-soft)}.path__node-status--in_progress,.path__node-status--available{color:var(--amber-700);background:var(--warning-soft)}.path__node-status--locked,.path__node-status--soon{color:var(--text-muted);background:var(--paper-200)}.path__node-title{font-family:var(--font-serif);font-size:var(--fs-18);letter-spacing:var(--tracking-heading);color:var(--text);margin:0;font-weight:600}.path__node-title--muted{color:var(--text-muted)}.path__node-objective{font-size:var(--fs-14);color:var(--text-muted);margin:0;line-height:1.5}.path__node-cta{margin-top:var(--sp-4);font-size:var(--fs-14);color:var(--navy-700);align-items:center;gap:6px;font-weight:600;display:inline-flex}.path__exam{gap:var(--sp-12);min-width:0;padding:var(--sp-24);border-radius:var(--r-lg);flex-direction:column;flex:1;display:flex}.path__exam--available,.path__exam--passed{background:var(--navy-900);color:var(--text-on-dark);box-shadow:var(--shadow-md)}.path__exam--gated{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.path__exam-eyebrow{color:var(--amber-400);align-items:center;gap:6px;display:inline-flex}.path__exam--gated .path__exam-eyebrow{color:var(--text-muted)}.path__exam-title{font-family:var(--font-serif);font-size:var(--fs-24);letter-spacing:var(--tracking-heading);margin:0;font-weight:600}.path__exam--gated .path__exam-title{color:var(--text)}.path__exam-testout{font-size:var(--fs-15);color:var(--amber-200);margin:0;line-height:1.55}.path__exam-gated-copy{font-size:var(--fs-15);color:var(--text-muted);margin:0;line-height:1.55}.path__exam-meta{gap:var(--sp-16);flex-wrap:wrap;display:flex}.path__exam-meta-item{font-size:var(--fs-13);color:var(--amber-200);align-items:center;gap:6px;font-weight:500;display:inline-flex}.path__exam--gated .path__exam-meta-item{color:var(--text-muted)}.path__exam-cooldown{font-size:var(--fs-14);color:var(--amber-200);margin:0}.path__exam-cta{align-self:flex-start;align-items:center;gap:var(--sp-8);padding:var(--sp-12) var(--sp-20);border-radius:var(--r-md);font-family:inherit;font-size:var(--fs-15);cursor:pointer;border:none;font-weight:600;text-decoration:none;display:inline-flex}.path__exam-cta--go{background:var(--accent);color:var(--navy-900);transition:background var(--motion-hover), transform var(--motion-hover)}.path__exam-cta--go:hover{background:var(--accent-hover);transform:translateY(-1px)}.path__exam-cta--disabled{background:var(--paper-200);color:var(--text-muted);cursor:not-allowed}.path__badge{align-items:center;gap:var(--sp-16);padding:var(--sp-16);border-radius:var(--r-md);background:#e7b25c1f;border:1px solid #e7b25c59;display:flex}.path__badge-medal{border-radius:var(--r-full);background:var(--accent);width:52px;height:52px;color:var(--navy-900);flex-shrink:0;place-items:center;display:grid}.path__badge-text{flex-direction:column;gap:2px;display:flex}.path__badge-level{font-size:var(--fs-18);color:var(--amber-300);font-weight:700}.path__badge-date{font-size:var(--fs-13);color:var(--amber-200)}.path__exam-note{font-size:var(--fs-14);color:var(--amber-200);margin:0;line-height:1.55}@media (width<=600px){.path__exam{padding:var(--sp-20)}.path__exam-cta{justify-content:center;align-self:stretch}}.course__desc{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);line-height:1.6}.course__lessons{margin-top:var(--sp-32)}.course__lessons-title{font-size:var(--fs-24);margin-bottom:var(--sp-16)}.course__list{gap:var(--sp-12);flex-direction:column;display:flex}.course__lesson{align-items:center;gap:var(--sp-16);padding:var(--sp-20);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--motion-hover), transform var(--motion-hover);display:flex}.course__lesson:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.course__lesson-order{border-radius:var(--r-full);background:var(--navy-900);width:36px;height:36px;color:var(--text-on-dark);font-family:var(--font-ui);font-size:var(--fs-15);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.course__lesson-body{gap:var(--sp-4);flex-direction:column;flex:1;min-width:0;display:flex}.course__lesson-title{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);font-weight:600}.course__lesson-objective{font-family:var(--font-serif);font-size:var(--fs-15);color:var(--text-muted);font-style:italic}.course__lesson-arrow{color:var(--text-muted);flex-shrink:0}.lesson{gap:var(--sp-40);grid-template-columns:1fr 240px;align-items:start;display:grid}.lesson__body{gap:var(--sp-40);flex-direction:column;min-width:0;display:flex}.lesson__head{gap:var(--sp-12);flex-direction:column;display:flex}.lesson__eyebrow{color:var(--amber-700)}.lesson__objective{align-items:flex-start;gap:var(--sp-12);font-family:var(--font-serif);font-size:var(--fs-30);letter-spacing:var(--tracking-heading);color:var(--text);font-weight:600;line-height:1.25;display:flex}.lesson__objective-icon{color:var(--amber-600);flex-shrink:0;margin-top:6px}.lesson__section{gap:var(--sp-16);flex-direction:column;display:flex}.lesson__section-title{font-size:var(--fs-24)}.lesson__muted{color:var(--text-muted);font-size:var(--fs-14)}.lesson__material{gap:var(--sp-20);flex-direction:column;display:flex}.lesson__material-heading{font-family:var(--font-serif);font-size:var(--fs-24);letter-spacing:var(--tracking-heading);color:var(--navy-900);padding-left:var(--sp-12);border-left:3px solid var(--amber-500);font-weight:600;line-height:1.2}.lesson__material-heading:not(:first-child){margin-top:var(--sp-12)}.lesson__material-paragraph{max-width:65ch;font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);line-height:1.75}.lesson__audio{gap:var(--sp-8);padding:var(--sp-12) var(--sp-16);background:var(--paper-100);border:1px solid var(--paper-200);border-radius:var(--r-md);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--navy-700);flex-direction:column;font-weight:600;display:flex}.lesson__audio-label{align-items:center;gap:var(--sp-12);display:flex}.lesson__audio-player{width:100%;height:36px}.lesson__phrases{margin:var(--sp-4) 0 0;padding:var(--sp-8);background:var(--paper-50);border:1px solid var(--paper-200);border-radius:var(--r-md)}.lesson__phrase{align-items:baseline;gap:var(--sp-16);padding:var(--sp-8) var(--sp-12);border-radius:var(--r-sm);grid-template-columns:minmax(0,1fr) minmax(0,1fr);display:grid}.lesson__phrase:nth-child(odd){background:var(--surface)}.lesson__phrase-de{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);font-weight:500}.lesson__phrase-en{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-muted);margin:0;line-height:1.45}.lesson__exercises{gap:var(--sp-12);flex-direction:column;display:flex}.lesson__exercise{align-items:center;gap:var(--sp-16);padding:var(--sp-16) var(--sp-20);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--motion-hover), transform var(--motion-hover);display:flex}.lesson__exercise:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.lesson__exercise-icon{border-radius:var(--r-full);background:var(--paper-100);width:36px;height:36px;color:var(--navy-600);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.lesson__exercise-main{gap:var(--sp-4);flex-direction:column;flex:1;min-width:0;display:flex}.lesson__exercise-prompt{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);font-weight:600}.lesson__exercise-meta{font-size:var(--fs-13);color:var(--text-muted)}.lesson__exercise-todo{align-items:center;gap:var(--sp-4);font-size:var(--fs-12);color:var(--text-muted);white-space:nowrap;font-weight:600;display:inline-flex}.lesson__production{gap:var(--sp-12);flex-direction:column;display:flex}.lesson__production-eyebrow{color:var(--amber-700)}.lesson__production-prompt{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);line-height:1.5}.lesson__production-cta{align-self:flex-start;align-items:center;gap:var(--sp-8);margin-top:var(--sp-4);padding:var(--sp-12) var(--sp-20);background:var(--accent);color:var(--navy-950);border-radius:var(--r-sm);font-family:var(--font-ui);font-size:var(--fs-14);box-shadow:var(--shadow-sm);transition:background-color var(--motion-hover);font-weight:600;display:inline-flex}.lesson__production-cta:hover{background:var(--accent-hover)}.lesson__quiz{gap:var(--sp-12);flex-direction:column;display:flex}.lesson__quiz-eyebrow{align-items:center;gap:var(--sp-8);color:var(--navy-600);display:inline-flex}.lesson__quiz-desc{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);line-height:1.5}.lesson__quiz-answered{font-size:var(--fs-13);color:var(--text-muted);font-weight:600}.lesson__quiz-cta{align-self:flex-start;align-items:center;gap:var(--sp-8);margin-top:var(--sp-4);padding:var(--sp-12) var(--sp-20);background:var(--primary);color:var(--primary-contrast);border-radius:var(--r-sm);font-family:var(--font-ui);font-size:var(--fs-14);box-shadow:var(--shadow-sm);transition:background-color var(--motion-hover);font-weight:600;display:inline-flex}.lesson__quiz-cta:hover{background:var(--primary-hover)}.lesson__rail{top:var(--sp-24);position:sticky}.lesson__rail-inner{gap:var(--sp-12);flex-direction:column;display:flex}.lesson__rail-list{gap:var(--sp-4);flex-direction:column;display:flex}.lesson__rail-link{align-items:center;gap:var(--sp-12);padding:var(--sp-12);border-radius:var(--r-md);transition:background-color var(--motion-hover);display:flex}.lesson__rail-link:hover{background:var(--paper-100)}.lesson__rail-order{border-radius:var(--r-full);background:var(--paper-200);width:24px;height:24px;color:var(--navy-700);font-family:var(--font-ui);font-size:var(--fs-12);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.lesson__rail-title{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-muted);font-weight:500}.lesson__rail-item--current .lesson__rail-link{background:var(--paper-100)}.lesson__rail-item--current .lesson__rail-order{background:var(--amber-500);color:var(--navy-950)}.lesson__rail-item--current .lesson__rail-title{color:var(--text);font-weight:600}@media (width<=860px){.lesson{gap:var(--sp-32);grid-template-columns:1fr}.lesson__rail{order:-1;position:static}}.exercise__sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.exercise__prompt{font-family:var(--font-serif);font-size:var(--fs-24);color:var(--text);margin-bottom:var(--sp-20);line-height:1.4}.exercise__instructions{font-size:var(--fs-14);color:var(--text-muted);margin-top:calc(-1 * var(--sp-12));margin-bottom:var(--sp-20)}.exercise__guidance{font-size:var(--fs-14);color:var(--text-muted);margin-bottom:var(--sp-20);padding:var(--sp-12) var(--sp-16);background:var(--paper-100);border-radius:var(--r-md)}.exercise__options{margin:0 0 var(--sp-20);gap:var(--sp-12);border:none;flex-direction:column;padding:0;display:flex}.exercise__option{align-items:center;gap:var(--sp-12);padding:var(--sp-16) var(--sp-20);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color var(--motion-hover), background-color var(--motion-hover);display:flex}.exercise__option:hover{border-color:var(--amber-300);background:var(--paper-50)}.exercise__option--selected{border-color:var(--amber-500);background:var(--amber-200)}.exercise__options:disabled .exercise__option{cursor:default;opacity:.85}.exercise__option input[type=radio]{accent-color:var(--amber-600);flex-shrink:0;width:18px;height:18px}.exercise__option-text{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text)}.exercise__fill{font-family:var(--font-serif);font-size:var(--fs-24);color:var(--text);margin-bottom:var(--sp-20);line-height:1.8}.exercise__blank{font-family:var(--font-ui);font-size:var(--fs-18);width:9ch;margin:0 var(--sp-4);padding:var(--sp-4) var(--sp-8);border:none;border-bottom:2px solid var(--amber-500);background:var(--paper-50);color:var(--navy-800);font-weight:600}.exercise__blank:focus-visible{border-radius:var(--r-sm)}.exercise__blank:disabled{background:var(--paper-100);border-bottom-color:var(--paper-300)}.exercise__textarea{width:100%;font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);padding:var(--sp-16);border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);resize:vertical;margin-bottom:var(--sp-16);line-height:1.6}.exercise__textarea:focus-visible{border-color:var(--amber-400)}.exercise__wordcount{font-size:var(--fs-13);color:var(--text-muted);margin-right:auto}.exercise__record{align-items:center;gap:var(--sp-16);margin-bottom:var(--sp-20);flex-wrap:wrap;display:flex}.exercise__record-btn{align-items:center;gap:var(--sp-8);padding:var(--sp-12) var(--sp-20);border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text);cursor:pointer;transition:background-color var(--motion-hover), border-color var(--motion-hover), color var(--motion-hover);font-weight:600;display:inline-flex}.exercise__record-btn:hover{border-color:var(--amber-400)}.exercise__record-btn--active{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}.exercise__record-status{font-size:var(--fs-13);color:var(--text-muted)}.exercise__actions{align-items:center;gap:var(--sp-16);display:flex}.exercise__error{margin-top:var(--sp-12);font-size:var(--fs-13);color:var(--danger)}.exercise__result{align-items:flex-start;gap:var(--sp-12);padding:var(--sp-16) var(--sp-20);border-radius:var(--r-md);display:flex}.exercise__result--correct{background:var(--success-soft);color:var(--success)}.exercise__result--incorrect{background:var(--danger-soft);color:var(--danger)}.exercise__result-body{gap:var(--sp-4);flex-direction:column;display:flex}.exercise__result-title{font-family:var(--font-ui);font-size:var(--fs-15);font-weight:700}.exercise__result-sub,.exercise__result-meta{font-size:var(--fs-13);color:var(--text-muted)}.exercise__actions--retry{margin-top:var(--sp-16)}.exercise__result-feedback{font-family:var(--font-serif);font-size:var(--fs-15);color:var(--text);margin-top:var(--sp-4);line-height:1.55}.exercise__guest-nudge{margin-top:var(--sp-8)}.exercise__guest-nudge-link{align-items:center;gap:var(--sp-8);font-family:var(--font-ui);font-size:var(--fs-13);color:var(--amber-700);text-underline-offset:2px;font-weight:600;text-decoration:underline;display:inline-flex}.exercise__guest-nudge-link:hover{color:var(--amber-600)}.exercise__guest-subjective{align-items:flex-start;gap:var(--sp-16);padding:var(--sp-20);background:var(--paper-100);border:1px solid var(--border);border-radius:var(--r-md);display:flex}.exercise__guest-subjective-icon{border-radius:var(--r-full);background:var(--surface);width:44px;height:44px;color:var(--amber-600);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.exercise__guest-subjective-body{gap:var(--sp-8);flex-direction:column;align-items:flex-start;display:flex}.exercise__guest-subjective-title{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);font-weight:700}.exercise__guest-subjective-sub{font-size:var(--fs-14);color:var(--text-muted);max-width:52ch}.exercise__awaiting{align-items:flex-start;gap:var(--sp-16);padding:var(--sp-20);background:var(--warning-soft);border-radius:var(--r-md);display:flex}.exercise__awaiting-icon{border-radius:var(--r-full);background:var(--surface);width:44px;height:44px;color:var(--warning);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.exercise__awaiting-title{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);font-weight:700}.exercise__awaiting-sub{font-size:var(--fs-14);color:var(--text-muted);max-width:52ch}.exercise__graded{gap:var(--sp-12);flex-direction:column;display:flex}.exercise__graded-head{align-items:center;gap:var(--sp-12);display:flex}.exercise__graded-score{font-family:var(--font-ui);font-size:var(--fs-15);color:var(--text);font-weight:700}.exercise__feedback{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);padding:var(--sp-16) var(--sp-20);border-left:3px solid var(--amber-500);background:var(--paper-50);border-radius:0 var(--r-md) var(--r-md) 0;line-height:1.6}.exercise__ai-actions{align-items:center;gap:var(--sp-12) var(--sp-16);margin-top:var(--sp-16);padding-top:var(--sp-16);border-top:1px dashed var(--border);flex-wrap:wrap;display:flex}.exercise__ai-note{min-width:18ch;font-size:var(--fs-13);color:var(--text-muted);flex:1}.exercise__ai-actions .exercise__ai-feedback,.exercise__ai-actions .exercise__ai-error{flex-basis:100%}.exercise__ai-feedback{gap:var(--sp-8);margin-top:var(--sp-16);padding:var(--sp-16) var(--sp-20);background:var(--info-soft);border:1px solid var(--info);border-radius:var(--r-md);flex-direction:column;display:flex}.exercise__ai-feedback-head{align-items:center;gap:var(--sp-8);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--info);font-weight:700;display:flex}.exercise__ai-feedback-body{font-family:var(--font-serif);font-size:var(--fs-15);color:var(--text);white-space:pre-wrap;line-height:1.6}.exercise__ai-feedback-disclaimer{font-size:var(--fs-13);color:var(--text-muted)}.exercise__ai-error{margin-top:var(--sp-8);font-size:var(--fs-13);color:var(--danger)}.exercise__audio{gap:var(--sp-8);padding:var(--sp-12) var(--sp-16);margin-bottom:var(--sp-16);background:var(--paper-100);border-radius:var(--r-md);flex-direction:column;display:flex}.exercise__audio-label{align-items:center;gap:var(--sp-8);font-size:var(--fs-14);color:var(--text-muted);display:flex}.exercise__audio-player{width:100%;height:36px}.exercise__vocab,.exercise__matching{gap:var(--sp-12);margin-bottom:var(--sp-20);flex-direction:column;display:flex}.exercise__vocab-row,.exercise__match-row{justify-content:space-between;align-items:center;gap:var(--sp-16);padding:var(--sp-12) var(--sp-16);border:1px solid var(--border);border-radius:var(--r-md);display:flex}.exercise__vocab-term,.exercise__match-left{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text)}.exercise__vocab-input{font-family:var(--font-ui);font-size:var(--fs-15);width:16ch;padding:var(--sp-8) var(--sp-12);border:1px solid var(--border);border-radius:var(--r-sm);background:var(--paper-50);color:var(--text)}.exercise__vocab-input:focus-visible,.exercise__match-select:focus-visible{border-color:var(--amber-400)}.exercise__vocab-input:disabled,.exercise__match-select:disabled{background:var(--paper-100);color:var(--text-muted)}.exercise__match-select{font-family:var(--font-ui);font-size:var(--fs-15);padding:var(--sp-8) var(--sp-12);border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);cursor:pointer}.quiz{gap:var(--sp-20);flex-direction:column;display:flex}.quiz__progress{gap:var(--sp-8);flex-direction:column;display:flex}.quiz__progress-label{font-family:var(--font-ui);font-size:var(--fs-13);color:var(--text-muted);font-weight:600}.quiz__nav{justify-content:flex-end;display:flex}.quiz__nav--score{justify-content:flex-start}.quiz__teacher-note{font-size:var(--fs-13);color:var(--text-muted);margin-bottom:var(--sp-12)}.quiz__score{gap:var(--sp-12);flex-direction:column;display:flex}.quiz__score-number{font-family:var(--font-serif);font-size:var(--fs-48);letter-spacing:var(--tracking-heading);color:var(--text);font-weight:600;line-height:1.1}.quiz__score-sub{font-size:var(--fs-14);color:var(--text-muted)}.quiz__score-message{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);max-width:60ch;line-height:1.5}.quiz__review{gap:var(--sp-16);flex-direction:column;display:flex}.quiz__review-title{font-size:var(--fs-24)}.quiz__review-list{gap:var(--sp-12);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.quiz__review-item{align-items:flex-start;gap:var(--sp-12);padding:var(--sp-12) var(--sp-16);border:1px solid var(--border);border-radius:var(--r-md);background:var(--paper-50);display:flex}.quiz__review-icon{color:var(--amber-600);flex-shrink:0;margin-top:3px}.quiz__review-prompt{font-family:var(--font-serif);font-size:var(--fs-15);color:var(--text);line-height:1.5}.exercise__nav{justify-content:flex-end;margin-top:1.5rem;display:flex}.exam{background:var(--paper-50);width:100%;min-height:100vh;color:var(--text);font-family:var(--font-ui)}.exam--intro{padding:var(--sp-32) var(--sp-24);place-items:center;display:grid}.exam-intro__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:560px;box-shadow:var(--shadow-lg);padding:var(--sp-40);gap:var(--sp-16);flex-direction:column;display:flex}.exam-intro__eyebrow{color:var(--amber-700);align-items:center;gap:6px;display:inline-flex}.exam-intro__title{font-family:var(--font-serif);font-size:var(--fs-36);letter-spacing:var(--tracking-heading);color:var(--text);margin:0;font-weight:600}.exam-intro__lead{font-size:var(--fs-15);line-height:var(--lh-body);color:var(--text-muted);margin:0}.exam-intro__facts{margin:var(--sp-8) 0 0;gap:var(--sp-12);flex-direction:column;padding:0;list-style:none;display:flex}.exam-intro__facts li{align-items:center;gap:var(--sp-12);font-size:var(--fs-14);color:var(--text);display:flex}.exam-intro__facts li svg{color:var(--navy-600);flex-shrink:0}.exam-intro__actions{gap:var(--sp-12);margin-top:var(--sp-8);flex-direction:column;display:flex}.exam-intro__cancel{font-size:var(--fs-14);color:var(--text-muted);font-weight:600;text-decoration:none}.exam-intro__cancel:hover{color:var(--text)}.exam-intro__error{font-size:var(--fs-14);color:var(--danger);margin:0}.exam-intro__gated{margin-top:var(--sp-8);padding:var(--sp-20);border-radius:var(--r-md);background:var(--warning-soft);border:1px solid var(--amber-300);gap:var(--sp-8);flex-direction:column;display:flex}.exam-intro__gated-title{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);margin:0;font-weight:600}.exam-intro__gated-body{font-size:var(--fs-14);line-height:var(--lh-body);color:var(--text-muted);margin:0}.exam-intro__back{margin-top:var(--sp-4);font-size:var(--fs-14);color:var(--navy-700);align-items:center;gap:6px;font-weight:600;text-decoration:none;display:inline-flex}.exam--attempt{flex-direction:column;display:flex}.exam-bar{z-index:10;justify-content:space-between;align-items:center;gap:var(--sp-16);padding:var(--sp-16) var(--sp-24);background:var(--navy-900);color:var(--text-on-dark);box-shadow:var(--shadow-md);display:flex;position:sticky;top:0}.exam-bar__title{align-items:center;gap:var(--sp-8);font-family:var(--font-serif);font-size:var(--fs-18);color:var(--amber-300);min-width:0;font-weight:600;display:inline-flex}.exam-bar__title span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.exam-bar__timer{align-items:center;gap:var(--sp-8);padding:var(--sp-8) var(--sp-16);border-radius:var(--r-full);color:var(--text-on-dark);font-variant-numeric:tabular-nums;transition:background var(--motion-hover), color var(--motion-hover);background:#ffffff14;display:inline-flex}.exam-bar__timer--low{background:var(--warning-soft);color:var(--amber-700)}.exam-bar__time{font-size:var(--fs-18);font-weight:700}.exam-guard{align-items:center;gap:var(--sp-12);padding:var(--sp-12) var(--sp-24);background:var(--info-soft);color:var(--info);font-size:var(--fs-14);font-weight:500;display:flex}.exam-guard__dismiss{border:1px solid var(--info);color:var(--info);font-family:inherit;font-size:var(--fs-13);padding:4px var(--sp-12);border-radius:var(--r-full);cursor:pointer;background:0 0;margin-left:auto;font-weight:600}.exam-body{width:100%;max-width:760px;padding:var(--sp-32) var(--sp-24) var(--sp-64);gap:var(--sp-32);flex-direction:column;flex:1;margin:0 auto;display:flex}.exam-body__hint{font-size:var(--fs-14);color:var(--text-muted);margin:0}.exam-section{gap:var(--sp-16);flex-direction:column;display:flex}.exam-section__title{align-items:center;gap:var(--sp-8);font-family:var(--font-serif);font-size:var(--fs-24);letter-spacing:var(--tracking-heading);color:var(--text);padding-bottom:var(--sp-8);border-bottom:2px solid var(--paper-300);margin:0;font-weight:600;display:inline-flex}.exam-section__items{gap:var(--sp-16);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.exam-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-20)}.exam-item__prompt{margin:0 0 var(--sp-12);font-size:var(--fs-15);color:var(--text);font-weight:600;line-height:1.5}.exam-item__num{color:var(--amber-700);margin-right:4px}.exam-item__instructions{margin:-8px 0 var(--sp-12);font-size:var(--fs-13);color:var(--text-muted)}.exam-section--writing{background:var(--paper-100);border:1px dashed var(--amber-300);border-radius:var(--r-lg);padding:var(--sp-24)}.exam-writing__head{justify-content:space-between;align-items:center;gap:var(--sp-12);flex-wrap:wrap;display:flex}.exam-section--writing .exam-section__title{border-bottom:none;padding-bottom:0}.exam-writing__badge{font-size:var(--fs-12);color:var(--amber-700);background:var(--warning-soft);padding:2px var(--sp-12);border-radius:var(--r-full);align-items:center;font-weight:600;display:inline-flex}.exam-writing__prompt{font-size:var(--fs-15);color:var(--text);margin:0;font-weight:600}.exam-writing__guidance{font-size:var(--fs-14);color:var(--text-muted);margin:0}.exam-writing__textarea{resize:vertical;width:100%;min-height:120px;padding:var(--sp-12);font-family:inherit;font-size:var(--fs-15);line-height:var(--lh-body);color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md)}.exam-writing__textarea:focus-visible{border-color:var(--accent);box-shadow:var(--ring-focus);outline:none}.exam-writing__hint{font-size:var(--fs-13);color:var(--text-muted);margin:0}.exam-submit{gap:var(--sp-12);flex-direction:column;align-items:flex-start;display:flex}.exam-submit__confirm{width:100%;padding:var(--sp-20);background:var(--surface);border:1px solid var(--amber-300);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);gap:var(--sp-16);flex-direction:column;display:flex}.exam-submit__confirm-text{font-size:var(--fs-15);color:var(--text);margin:0;font-weight:600}.exam-submit__confirm-actions{gap:var(--sp-12);flex-wrap:wrap;display:flex}.exam-submit__error{font-size:var(--fs-14);color:var(--danger);margin:0}.exam--result{padding:var(--sp-32) var(--sp-24);place-items:center;display:grid}.exam-result__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:560px;box-shadow:var(--shadow-lg);padding:var(--sp-40);gap:var(--sp-16);flex-direction:column;display:flex}.exam--pass .exam-result__card{background:var(--navy-900);color:var(--text-on-dark);border-color:var(--navy-700)}.exam-result__eyebrow{color:var(--text-muted);align-items:center;gap:6px;display:inline-flex}.exam-result__eyebrow--pass{color:var(--amber-300)}.exam-result__title{font-family:var(--font-serif);font-size:var(--fs-36);letter-spacing:var(--tracking-heading);margin:0;font-weight:600}.exam--pass .exam-result__title{color:var(--text-on-dark)}.exam-result__lead{font-size:var(--fs-15);line-height:var(--lh-body);color:var(--text-muted);margin:0}.exam--pass .exam-result__lead{color:var(--amber-200)}.exam-badge{align-items:center;gap:var(--sp-16);padding:var(--sp-20);border-radius:var(--r-md);background:#e7b25c1f;border:1px solid #e7b25c59;display:flex}.exam-badge__medal{border-radius:var(--r-full);background:var(--accent);width:64px;height:64px;color:var(--navy-900);flex-shrink:0;place-items:center;display:grid}.exam-badge__label{font-family:var(--font-serif);font-size:var(--fs-24);color:var(--amber-300);font-weight:700}.exam-result__soon{align-items:center;gap:var(--sp-8);padding:var(--sp-12) var(--sp-16);border-radius:var(--r-md);font-size:var(--fs-14);color:var(--amber-200);background:#ffffff0f;display:flex}.exam-result__retake{padding:var(--sp-20);border-radius:var(--r-md);background:var(--warning-soft);border:1px solid var(--amber-300);gap:var(--sp-8);flex-direction:column;display:flex}.exam-result__retake-title{font-family:var(--font-serif);font-size:var(--fs-18);color:var(--text);align-items:center;gap:6px;margin:0;font-weight:600;display:inline-flex}.exam-result__retake-body{font-size:var(--fs-14);line-height:var(--lh-body);color:var(--text-muted);margin:0}.exam-result__cta{align-self:flex-start;align-items:center;gap:var(--sp-8);margin-top:var(--sp-8);padding:var(--sp-12) var(--sp-20);border-radius:var(--r-md);font-size:var(--fs-15);transition:background var(--motion-hover), transform var(--motion-hover);font-weight:600;text-decoration:none;display:inline-flex}.exam-result__cta--pass{background:var(--accent);color:var(--navy-900)}.exam-result__cta--pass:hover{background:var(--accent-hover);transform:translateY(-1px)}.exam-result__cta--fail{background:var(--navy-900);color:var(--text-on-dark)}.exam-result__cta--fail:hover{background:var(--navy-800);transform:translateY(-1px)}.exam-breakdown{gap:var(--sp-8);flex-direction:column;display:flex}.exam-breakdown__title{font-size:var(--fs-13);letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--text-muted);margin:0;font-weight:700}.exam--pass .exam-breakdown__title{color:var(--amber-200)}.exam-breakdown__list{gap:var(--sp-4);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.exam-breakdown__row{padding:var(--sp-8) 0;border-bottom:1px solid var(--border);font-size:var(--fs-14);justify-content:space-between;align-items:center;display:flex}.exam--pass .exam-breakdown__row{border-color:#ffffff1a}.exam-breakdown__row:last-child{border-bottom:none}.exam-breakdown__name{color:var(--text)}.exam--pass .exam-breakdown__name{color:var(--text-on-dark)}.exam-breakdown__score{font-variant-numeric:tabular-nums;color:var(--text);align-items:center;gap:6px;font-weight:700;display:inline-flex}.exam--pass .exam-breakdown__score{color:var(--amber-300)}.exam-breakdown__check{color:var(--success)}.exam--pass .exam-breakdown__check{color:var(--amber-300)}@media (width<=600px){.exam-intro__card,.exam-result__card{padding:var(--sp-24)}.exam-body{padding:var(--sp-24) var(--sp-16) var(--sp-48)}.exam-bar{padding:var(--sp-12) var(--sp-16)}}.vocabulary{gap:var(--sp-16);flex-direction:column;display:flex}.vocabulary__levels{gap:var(--sp-8);flex-wrap:wrap;display:flex}.vocabulary__level{padding:var(--sp-4);border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface);cursor:pointer;align-items:center;transition:border-color .15s,box-shadow .15s;display:inline-flex}.vocabulary__level:hover{border-color:var(--accent)}.vocabulary__level--active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.vocabulary__intro{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-muted)}.vocabulary__grid{gap:var(--sp-12);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}@media (width<=640px){.vocabulary__grid{grid-template-columns:1fr}}.vocabulary__stats{gap:var(--sp-12);padding:var(--sp-12) var(--sp-16);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);flex-direction:column;display:flex}.vocabulary__stats-row{justify-content:space-between;align-items:center;gap:var(--sp-12);flex-wrap:wrap;display:flex}.vocabulary__stats-summary{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text);font-weight:600}.vocabulary__breakdown{gap:var(--sp-8);flex-direction:column;display:flex}.vocabulary__bar{border-radius:var(--r-full);background:var(--paper-100);height:8px;display:flex;overflow:hidden}.vocabulary__bar-seg{height:100%;display:block}.vocabulary__bar-seg--review{background:var(--amber-500)}.vocabulary__bar-seg--learning{background:var(--navy-500)}.vocabulary__bar-seg--new{background:var(--paper-300)}.vocabulary__legend{align-items:center;gap:var(--sp-8) var(--sp-16);font-family:var(--font-ui);font-size:var(--fs-13);color:var(--text-muted);flex-wrap:wrap;display:flex}.vocabulary__legend-item{align-items:center;gap:var(--sp-4);display:inline-flex}.vocabulary__dot{border-radius:var(--r-full);flex-shrink:0;width:8px;height:8px}.vocabulary__dot--review{background:var(--amber-500)}.vocabulary__dot--learning{background:var(--navy-500)}.vocabulary__dot--new{background:var(--paper-300)}.vocabulary__legend-percent{color:var(--text);margin-left:auto;font-weight:600}.vocabulary__uptodate{align-items:center;gap:var(--sp-4);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-muted);font-weight:600;display:inline-flex}.vocabulary__review{gap:var(--sp-16);flex-direction:column;display:flex}.vocabulary__review-head{justify-content:space-between;align-items:center;gap:var(--sp-12);display:flex}.vocabulary__review-progress{font-family:var(--font-ui);font-size:var(--fs-14);color:var(--text-muted);font-weight:600}.vocabulary__exit{align-items:center;gap:var(--sp-4);font-family:var(--font-ui);font-size:var(--fs-14);color:var(--navy-700);cursor:pointer;transition:color var(--motion-hover);background:0 0;border:none;padding:0;font-weight:600;display:inline-flex}.vocabulary__exit:hover{color:var(--navy-900)}
