@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400..700;1,400..600&display=swap";:root{--bg:#eef1f6;--bg-elevated:#f8fafc;--surface:#fff;--border:#e2e8f0;--border-strong:#cbd5e1;--text:#0f172a;--text-muted:#64748b;--text-faint:#94a3b8;--accent:#0284c7;--accent-hover:#0369a1;--accent-soft:#0284c71a;--accent-ring:#0284c761;--success:#0f766e;--success-soft:#0f766e1a;--danger:#dc2626;--danger-soft:#dc262614;--radius-xl:20px;--radius-lg:14px;--radius-md:10px;--radius-sm:8px;--radius-pill:9999px;--shadow:0 1px 3px #0f172a0f;--shadow-float:0 12px 40px #0f172a14;--font:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*,:before,:after{box-sizing:border-box}html{scroll-padding-top:5.5rem}body{min-height:100svh;font-family:var(--font);color:var(--text-muted);background:var(--bg);-webkit-font-smoothing:antialiased;margin:0;font-size:.9375rem;font-weight:450;line-height:1.6}#root{min-height:100svh}.app{max-width:40rem;margin:0 auto;padding:2rem 1.125rem 2.5rem}.skip-link{z-index:20;background:var(--text);color:var(--surface);font-family:var(--font);border-radius:var(--radius-sm);padding:.45rem .85rem;font-size:.8125rem;font-weight:600;position:absolute;top:.75rem;left:-9999px}.skip-link:focus{left:.75rem}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.hero{margin-bottom:1.75rem;animation:.5s ease-out both fade-up}.hero-kicker{letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);margin:0 0 .4rem;font-size:.6875rem;font-weight:600}.hero-title{letter-spacing:-.035em;color:var(--text);margin:0 0 .5rem;font-size:clamp(1.875rem,5vw,2.375rem);font-weight:700;line-height:1.15}.hero-subtitle{color:var(--text-muted);letter-spacing:-.01em;margin:0 0 .75rem;font-size:1rem;font-weight:500}.hero-lede{max-width:36rem;color:var(--text-muted);margin:0 0 1.25rem;font-size:.875rem;line-height:1.65}.hero-stats{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);flex-wrap:wrap;gap:0;margin:0;padding:0;list-style:none;display:flex;overflow:hidden}.hero-stats li{border-right:1px solid var(--border);flex-direction:column;flex:1 1 0;gap:.15rem;min-width:5.5rem;padding:.85rem 1rem;display:flex}.hero-stats li:last-child{border-right:none}@media (width<=480px){.hero-stats li{border-right:none;border-bottom:1px solid var(--border);flex:100%}.hero-stats li:last-child{border-bottom:none}}.hero-stat-value{letter-spacing:-.02em;color:var(--text);font-size:.9375rem;font-weight:700}.hero-stat-label{text-transform:lowercase;color:var(--text-faint);font-size:.6875rem;font-weight:500}.app-topbar{justify-content:flex-end;align-items:center;margin-bottom:.5rem;display:flex}.app-topbar-spacer{flex:1}.settings-trigger{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);font-family:var(--font);color:var(--text-muted);cursor:pointer;box-shadow:var(--shadow);align-items:center;gap:.4rem;padding:.4rem .65rem;font-size:.8125rem;font-weight:600;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.settings-trigger:hover{background:var(--bg-elevated);color:var(--text);border-color:var(--border-strong)}.settings-trigger-icon{color:var(--accent);display:block}.translate-fab{right:max(1rem, env(safe-area-inset-right,0px));bottom:max(1.25rem, env(safe-area-inset-bottom,0px));z-index:90;background:var(--accent);color:#fff;cursor:pointer;width:3.25rem;height:3.25rem;box-shadow:var(--shadow-float);border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:transform .15s,background .12s;display:flex;position:fixed}.translate-fab:hover{background:var(--accent-hover);transform:scale(1.04)}.translate-fab-icon{line-height:0;display:flex}@media (width>=641px){.translate-fab{display:none}}.translate-overlay{z-index:190;-webkit-backdrop-filter:blur(4px);background:#0f172a73;justify-content:center;align-items:flex-start;padding:1rem 1rem 2rem;display:flex;position:fixed;inset:0;overflow-y:auto}.translate-dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:22rem;box-shadow:var(--shadow-float);margin-top:min(10vh,3rem)}.translate-dialog-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1rem 1rem .5rem 1.125rem;display:flex}.translate-dialog-title{letter-spacing:-.02em;color:var(--text);margin:0;font-size:1rem;font-weight:700;line-height:1.3}.translate-dialog-close{border-radius:var(--radius-sm);width:2.25rem;height:2.25rem;color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin:-.25rem -.25rem 0 0;padding:0;font-size:1.35rem;line-height:1;display:inline-flex}.translate-dialog-close:hover{background:var(--bg-elevated);color:var(--text)}.translate-dialog-body{padding:1rem 1.125rem 1.125rem}.translate-dir{gap:.35rem;margin-bottom:.85rem;display:flex}.translate-dir-btn{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);font-family:var(--font);color:var(--text-muted);cursor:pointer;flex:1;padding:.45rem .4rem;font-size:.6875rem;font-weight:600;transition:background .12s,border-color .12s,color .12s}.translate-dir-btn.is-active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.translate-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.35rem;font-size:.6875rem;font-weight:700;display:block}.translate-field-head{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.translate-field-head .translate-label{margin-bottom:0}.translate-result-head{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.translate-result-head .translate-result-label{margin-bottom:0}.translate-speak-btn{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);width:2rem;height:2rem;color:var(--text-muted);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.translate-speak-btn:hover:not(:disabled),.translate-speak-btn.is-speaking{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.translate-speak-btn:disabled{opacity:.42;cursor:not-allowed}.translate-speak-actions{flex-shrink:0;align-items:center;gap:.35rem;display:inline-flex}.tts-slow-toggle{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);width:2rem;height:2rem;color:var(--text-muted);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.tts-slow-toggle:hover,.tts-slow-toggle.is-active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.translate-textarea{border:1px solid var(--border);border-radius:var(--radius-md);width:100%;font-family:var(--font);color:var(--text);background:var(--bg-elevated);resize:vertical;min-height:8rem;margin-bottom:.65rem;padding:.55rem .65rem;font-size:.875rem;font-weight:450;line-height:1.5}.translate-textarea:focus{outline:2px solid var(--accent-ring);outline-offset:1px;border-color:var(--accent)}.translate-run{width:100%;margin-bottom:.5rem}.translate-error{color:var(--danger);margin:0 0 .5rem;font-size:.8125rem;font-weight:600}.translate-result-block{border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border);margin-top:.65rem;padding:.65rem .75rem}.translate-result-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.25rem;font-size:.625rem;font-weight:700;display:block}.translate-result{color:var(--text);margin:0;font-size:.9375rem;font-weight:500;line-height:1.55}.translate-note{color:var(--text-faint);margin:.85rem 0 0;font-size:.6875rem;line-height:1.45}.translate-note code{background:var(--bg-elevated);border-radius:4px;padding:.05em .25em;font-size:.8125em}.translate-dock{right:max(1rem, env(safe-area-inset-right,0px));bottom:max(1rem, env(safe-area-inset-bottom,0px));z-index:110;max-width:min(22rem,100vw - 2rem);position:fixed}.translate-dock-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-float);overflow:hidden}.translate-dock-head{border-bottom:1px solid var(--border);background:var(--bg-elevated);justify-content:space-between;align-items:center;gap:.5rem;padding:.65rem .75rem .5rem;display:flex}.translate-dock-title{letter-spacing:-.02em;color:var(--text);margin:0;font-size:.9375rem;font-weight:700}.translate-dock-minimize{border-radius:var(--radius-sm);width:2.25rem;height:2.25rem;color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.translate-dock-minimize:hover{background:var(--surface);color:var(--text)}.translate-dock .translate-dialog-body{max-height:min(85vh,38rem);padding:.85rem 1rem 1rem;overflow-y:auto}.translate-dock-chip{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;box-shadow:var(--shadow-float);align-items:center;gap:.45rem;padding:.55rem .85rem .55rem .65rem;font-size:.8125rem;font-weight:600;transition:transform .15s,background .12s;display:inline-flex}.translate-dock-chip:hover{background:var(--accent-hover);transform:scale(1.02)}.translate-dock-chip-label{padding-right:.15rem}.translate-dock-chip .translate-fab-icon{color:inherit}.translate-dock--minimized .translate-dock-panel{display:none}@media (width<=640px){.translate-dock{display:none}}.app-nav-daily{margin-bottom:.75rem}.app-nav-daily-phases{margin:0 -1.125rem .75rem;padding:0 1.125rem}.app-nav-checklist-wrap{position:relative}.daily-checklist-dock{z-index:10;background:color-mix(in srgb, var(--bg) 88%, transparent);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);margin:0 -1.125rem;padding:.35rem 1.125rem .45rem;position:relative}.daily-checklist-dock.is-collapsed{visibility:hidden;pointer-events:none;-webkit-backdrop-filter:none;border:none;height:0;margin:0;padding:0;overflow:hidden}.daily-checklist-dock.is-document-fixed{box-sizing:border-box;width:min(40rem,100vw);max-width:40rem;padding-left:max(1.125rem, env(safe-area-inset-left,0px));padding-right:max(1.125rem, env(safe-area-inset-right,0px));z-index:100;visibility:visible;pointer-events:auto;border-bottom:1px solid var(--border);height:auto;margin-left:auto;margin-right:auto;position:fixed;top:0;left:0;right:0;overflow:visible;box-shadow:0 4px 20px #0f172a14}.app-nav-daily-spacer{flex-shrink:0}.app-nav-daily-below{margin-top:.85rem}.daily-checklist{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin:0;padding:.55rem .75rem}.daily-checklist--sticky{border-radius:var(--radius-md);box-shadow:none;border:1px solid var(--border);background:var(--surface);width:100%;padding:.45rem .65rem .5rem}.daily-checklist-sticky-head{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin:0 0 .35rem;padding:0;font-size:.5625rem;font-weight:700}.daily-checklist-title{letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.25rem .75rem;margin:0 0 .45rem;padding:0;font-size:.6875rem;font-weight:700;display:flex}.daily-checklist-date{letter-spacing:.04em;text-transform:none;color:var(--text-muted);font-weight:600}.daily-steps{flex-direction:column;align-items:flex-start;gap:.15rem;margin:0;padding:0;list-style:none;display:flex}.daily-step{color:var(--text);flex-direction:row;align-items:baseline;gap:.45rem;font-size:.8125rem;font-weight:600;line-height:1.35;display:flex}.daily-step-num{font-variant-numeric:tabular-nums;min-width:1.05rem;color:var(--text-faint);font-weight:800}.daily-step.is-done .daily-step-num{color:var(--success)}.daily-step-name{color:var(--text-muted);letter-spacing:-.01em;font-weight:600}.daily-step.is-done .daily-step-name{color:var(--success)}.daily-checklist-done{color:var(--success);margin:.45rem 0 0;font-size:.6875rem;font-weight:600}.settings-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);background:#0f172a73;justify-content:center;align-items:flex-start;padding:1.25rem 1rem 2rem;display:flex;position:fixed;inset:0;overflow-y:auto}.settings-dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:22rem;box-shadow:var(--shadow-float);margin-top:min(8vh,4rem)}.settings-dialog-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1rem 1rem .5rem 1.125rem;display:flex}.settings-dialog-title{letter-spacing:-.02em;color:var(--text);margin:0;font-size:1rem;font-weight:700;line-height:1.3}.settings-dialog-close{border-radius:var(--radius-md);width:2.25rem;height:2.25rem;color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin:-.25rem -.25rem 0 0;padding:0;font-size:1.5rem;line-height:1;transition:background .12s,color .12s;display:inline-flex}.settings-dialog-close:hover{background:var(--bg-elevated);color:var(--text)}.settings-dialog-body{padding:.75rem 1.125rem 1.125rem}.tts-settings-hint{color:var(--text-muted);margin:0 0 1rem;font-size:.75rem;line-height:1.5}.tts-settings-hint a{color:var(--accent);font-weight:600;text-decoration:none}.tts-settings-hint a:hover{text-decoration:underline}.tts-settings-grid{grid-template-columns:repeat(auto-fill,minmax(9.5rem,1fr));gap:.65rem 1rem;display:grid}.tts-field{flex-direction:column;gap:.3rem;min-width:0;display:flex}.tts-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);font-size:.625rem;font-weight:700}.tts-select{width:100%;font-family:var(--font);color:var(--text);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;padding:.45rem .55rem;font-size:.8125rem;font-weight:500}.tts-select:focus{outline:2px solid var(--accent-ring);outline-offset:1px}.phase-nav{-webkit-backdrop-filter:none;background:0 0;border-bottom:none;margin:0;padding:0}.phase-nav-track{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:40rem;box-shadow:var(--shadow);margin:0 auto;padding:4px}.phase-nav-list{flex-wrap:wrap;gap:3px;margin:0;padding:0;list-style:none;display:flex}.phase-nav-btn{border-radius:var(--radius-md);cursor:pointer;font:inherit;color:var(--text-muted);background:0 0;border:none;flex-direction:column;align-items:flex-start;gap:0;padding:.5rem .75rem;transition:background .12s,color .12s;display:flex}.phase-nav-btn:hover{background:var(--bg-elevated);color:var(--text)}.phase-nav-btn.is-active{background:var(--accent-soft);color:var(--accent);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent)}.phase-nav-cefr{letter-spacing:.06em;text-transform:uppercase;color:inherit;opacity:.85;font-size:.625rem;font-weight:700}.phase-nav-title{letter-spacing:-.02em;color:inherit;font-size:.8125rem;font-weight:600}.phase-nav-btn.is-active .phase-nav-cefr,.phase-nav-btn.is-active .phase-nav-title{color:var(--accent)}.main{animation:.45s ease-out 40ms both fade-up}.phase-detail{padding-bottom:.5rem}.phase-detail-head{margin-bottom:1.25rem}.phase-detail-badges{flex-wrap:wrap;gap:.375rem;margin-bottom:.625rem;display:flex}.badge{border-radius:var(--radius-pill);letter-spacing:.02em;align-items:center;padding:.2rem .55rem;font-size:.6875rem;font-weight:600;display:inline-flex}.badge-cefr{background:var(--text);color:var(--surface)}.badge-hours{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);font-weight:500}.phase-detail-title{letter-spacing:-.03em;color:var(--text);margin:0 0 .25rem;font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700}.phase-detail-tagline{color:var(--text-muted);margin:0 0 .5rem;font-size:.875rem;font-weight:500}.phase-detail-time{color:var(--text-muted);margin:0;font-size:.8125rem}.phase-detail-time strong{color:var(--text);font-weight:600}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow);margin-bottom:1rem;padding:1.125rem 1.25rem}.panel-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);margin:0 0 .75rem;font-size:.6875rem;font-weight:700}.plan-list{margin:0;padding-left:1.125rem}.plan-list li{margin-bottom:.4rem;font-size:.875rem}.plan-list li:last-child{margin-bottom:0}.panel-ref .panel-title{margin-bottom:.75rem}.panel-title--ref{text-transform:none;letter-spacing:0;flex-direction:column;align-items:flex-start;gap:.3rem;display:flex}.panel-title--ref .panel-title-main{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);font-size:.6875rem;font-weight:700}.panel-title--ref .panel-title-note{letter-spacing:.01em;color:var(--text-muted);font-size:.7rem;font-weight:500}.ref-tabs{flex-direction:column;display:flex}.ref-tablist{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);grid-template-columns:repeat(4,minmax(0,1fr));gap:.35rem;margin-bottom:.85rem;padding:4px;display:grid}.ref-tab{border-radius:var(--radius-md);width:100%;min-width:0;font-family:var(--font);letter-spacing:.02em;color:var(--text-muted);cursor:pointer;text-align:center;white-space:normal;background:0 0;border:none;padding:.45rem .35rem;font-size:.6875rem;font-weight:600;line-height:1.25;transition:background .12s,color .12s}.ref-tab:hover{background:color-mix(in srgb, var(--surface) 70%, transparent);color:var(--text)}.ref-tab.is-active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow)}.ref-tabpanel{margin:0}.ref-table-scroll{-webkit-overflow-scrolling:touch;margin:0 -.25rem;padding:0 .25rem;overflow-x:auto}.ref-table{border-collapse:collapse;width:100%;min-width:16rem;font-size:.8125rem}.ref-table th,.ref-table td{text-align:left;vertical-align:top;border-bottom:1px solid var(--border);padding:.5rem .65rem}.ref-table th{letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);background:var(--bg-elevated);font-size:.6875rem;font-weight:600}.ref-table th:first-child{border-radius:var(--radius-sm) 0 0 0}.ref-table th:last-child{border-radius:0 var(--radius-sm) 0 0}.ref-table tbody tr:last-child td{border-bottom:none}.ref-table td:first-child{color:var(--text);font-weight:600}.ref-td-cell{justify-content:space-between;align-items:center;gap:.5rem;min-width:0;display:flex}.ref-td-fr{white-space:normal;word-break:break-word;min-width:0}.ref-table td:last-child{color:var(--text-muted);font-weight:450}.ref-table--time-clock td:last-child{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.ref-table--conjugation{min-width:min(100%,36rem)}.ref-table--conjugation th,.ref-table--conjugation td{font-size:.75rem}.ref-table--conjugation thead th{text-transform:none;letter-spacing:.02em;font-weight:700}.ref-table--conjugation tbody th[scope=row]{color:var(--text);text-align:left;vertical-align:middle;border-bottom:1px solid var(--border);background:var(--bg-elevated);font-weight:600}.ref-table--conjugation tbody tr:last-child th,.ref-table--conjugation tbody tr:last-child td{border-bottom:none}.ref-table--colors .ref-th-swatch,.ref-table--colors .ref-td-swatch{vertical-align:middle;text-align:center;width:2.5rem;padding-left:.5rem;padding-right:.35rem}.ref-table--colors .ref-th-swatch{font-size:0}.ref-color-dot{width:1.125rem;height:1.125rem;box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--text) 14%, transparent), 0 0 0 1px color-mix(in srgb, var(--border) 80%, transparent);vertical-align:middle;border-radius:50%;display:inline-block}.ref-number-grid{grid-template-columns:repeat(auto-fill,minmax(6.75rem,1fr));gap:.4rem .65rem;padding:.15rem .25rem .35rem;font-size:.8125rem;display:grid}.ref-number-cell{border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);flex-direction:column;gap:.2rem;min-width:0;padding:.4rem .5rem;display:flex}.ref-number-fig{font-variant-numeric:tabular-nums;color:var(--text-faint);font-size:.75rem;font-weight:700;line-height:1.2}.ref-number-cell-row{justify-content:space-between;align-items:center;gap:.35rem;min-width:0;display:flex}.ref-number-fr{color:var(--text);word-break:break-word;min-width:0;font-weight:600;line-height:1.25}.panel-milestones{border-left:3px solid var(--accent);margin-left:0;padding-left:1rem}.panel-head-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.panel-head-row .panel-title{margin:0}.milestone-count{color:var(--text-faint);font-size:.75rem;font-weight:600}.milestone-list{margin:0;padding:0;list-style:none}.milestone-list li+li{margin-top:.5rem}.milestone-label{cursor:pointer;color:var(--text-muted);align-items:flex-start;gap:.5rem;font-size:.875rem;display:flex}.milestone-input{width:1rem;height:1rem;accent-color:var(--accent);border-radius:4px;flex-shrink:0;margin-top:.2rem}.milestone-text{flex:1;line-height:1.5}.daily-reminder{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow);border-inline-start:3px solid var(--accent);margin:0 0 1rem;padding:1rem 1.125rem}.daily-reminder-kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin:0 0 .35rem;font-size:.625rem;font-weight:700}.daily-reminder-fr-row{align-items:flex-start;gap:.5rem;margin-bottom:.35rem;display:flex}.daily-reminder-fr{letter-spacing:-.02em;min-width:0;color:var(--text);flex:1;margin:0;font-size:1rem;font-weight:600;line-height:1.4}.daily-reminder-en{color:var(--text-muted);margin:0;font-size:.8125rem;font-weight:450}.panel-learn{box-shadow:var(--shadow-float);border-top:none}.learn-meta{color:var(--text-faint);font-variant-numeric:tabular-nums;font-size:.75rem;font-weight:600}.learn-hint{color:var(--text-muted);margin:0 0 .875rem;font-size:.8125rem;line-height:1.5}.flash-toolbar{align-items:center;gap:.5rem;margin-bottom:.65rem;display:flex}.flash-toolbar-label{color:var(--text-faint);font-size:.75rem;font-weight:600}.speak-fr{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);width:2.25rem;height:2.25rem;color:var(--accent);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .12s,border-color .12s,color .12s,transform .12s;display:inline-flex}.speak-fr:hover:not(:disabled){background:var(--accent-soft);border-color:color-mix(in srgb, var(--accent) 28%, var(--border));color:var(--accent-hover)}.speak-fr:active:not(:disabled){transform:scale(.96)}.speak-fr:disabled{opacity:.55;cursor:wait}.speak-fr-icon{display:block}.speak-fr-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:1rem;height:1rem;animation:.65s linear infinite speak-spin;display:block}@keyframes speak-spin{to{transform:rotate(360deg)}}.quiz-prompt-row{align-items:flex-start;gap:.5rem;margin-bottom:.75rem;display:flex}.quiz-prompt-row .quiz-prompt{flex:1;min-width:0;margin:0}.quiz-option-row{grid-template-columns:1fr auto;align-items:center;gap:.5rem;display:grid}.quiz-option-row .quiz-opt{min-width:0}.flash-card{cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;background:0 0;border:none;margin:0 0 .875rem;padding:0;display:block}.flash-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-lg)}.flash-stack{width:100%;min-height:10.5rem;display:block;position:relative}.flash-face{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-elevated);flex-direction:column;justify-content:center;gap:.5rem;width:100%;min-height:10.5rem;padding:1.125rem 1.25rem;display:flex}.flash-card:not(.is-flipped) .flash-face-back,.flash-card.is-flipped .flash-face-front{display:none}.flash-face-back{background:var(--surface)}.flash-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);font-size:.625rem;font-weight:700}.flash-text{letter-spacing:-.02em;color:var(--text);font-size:1.0625rem;font-weight:600;line-height:1.35}.flash-hint{color:var(--text-muted);font-size:.8125rem;font-weight:450}.learn-actions{flex-wrap:wrap;justify-content:space-between;gap:.5rem;display:flex}.btn{font-family:var(--font);border-radius:var(--radius-pill);cursor:pointer;border:1px solid #0000;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;transition:background .12s,border-color .12s,color .12s,transform .12s}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-ghost:hover{background:var(--bg-elevated);border-color:var(--border-strong)}.quiz-prompt{letter-spacing:-.02em;color:var(--text);margin:0 0 .75rem;font-size:.9375rem;font-weight:600;line-height:1.45}.quiz-options{flex-direction:column;gap:.375rem;margin:0;padding:0;list-style:none;display:flex}.quiz-opt{text-align:left;width:100%;font:inherit;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;color:var(--text);padding:.65rem .875rem;font-size:.875rem;font-weight:500;transition:border-color .12s,background .12s}.quiz-opt:hover:not(:disabled){border-color:var(--border-strong);background:var(--surface)}.quiz-opt:disabled{cursor:default}.quiz-opt.is-correct{border-color:var(--success);background:var(--success-soft)}.quiz-opt.is-wrong{border-color:var(--danger);background:var(--danger-soft)}.quiz-feedback{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-elevated);margin-top:.875rem;padding:.875rem 1rem}.quiz-feedback.is-correct{border-color:color-mix(in srgb, var(--success) 35%, var(--border))}.quiz-feedback.is-wrong{border-color:color-mix(in srgb, var(--danger) 35%, var(--border))}.quiz-feedback strong{color:var(--text);margin-bottom:.25rem;font-size:.8125rem;font-weight:700;display:block}.quiz-explain{color:var(--text-muted);margin:0 0 .75rem;font-size:.8125rem;line-height:1.55}.quiz-next{margin-top:0}.panel-plan{background:var(--surface)}.plan-columns{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}@media (width<=560px){.plan-columns{grid-template-columns:1fr}}.plan-sub{letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);margin:0 0 .35rem;font-size:.75rem;font-weight:700}.site-footer{border-top:1px solid var(--border);color:var(--text-faint);margin-top:1.75rem;padding-top:1.25rem;font-size:.8125rem;font-weight:450}.site-footer p{margin:0;line-height:1.55}
