*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #fdf8f3;--cream-dark: #f3e8df;--soft-pink: #f6d0d8;--pink: #e8a0b4;--lavender: #d4c4ef;--lavender-deep: #9b7ec8;--warm-orange: #f0a878;--deep-purple: #4e3268;--purple-muted: #7a5c96;--text-dark: #3a2d45;--text-muted: #6f5f7d;--white: #ffffff;--glass: rgba(255, 252, 250, .82);--glass-border: rgba(255, 255, 255, .65);--shadow-soft: 0 4px 20px rgba(78, 50, 104, .07);--shadow-card: 0 10px 40px rgba(78, 50, 104, .1);--shadow-btn: 0 6px 24px rgba(240, 168, 120, .35);--radius-sm: 14px;--radius-md: 22px;--radius-lg: 30px;--radius-pill: 999px;--font: "Nunito", system-ui, -apple-system, sans-serif;--bottom-nav-h: 88px;--page-pad-x: 18px}html{font-size:16px;-webkit-text-size-adjust:100%;overflow-x:hidden}body{font-family:var(--font);color:var(--text-dark);background:radial-gradient(ellipse at 10% 0%,rgba(244,196,200,.45) 0%,transparent 55%),radial-gradient(ellipse at 90% 20%,rgba(201,184,232,.4) 0%,transparent 50%),radial-gradient(ellipse at 50% 100%,rgba(240,168,120,.2) 0%,transparent 45%),linear-gradient(165deg,var(--cream) 0%,#fceef3 40%,#eee6f9 75%,var(--cream-dark) 100%);background-attachment:fixed;min-height:100dvh;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{min-height:100dvh;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;-webkit-tap-highlight-color:transparent}.app{min-height:100dvh;display:flex;flex-direction:column;overflow-x:hidden}.app-header{position:sticky;top:0;z-index:100;background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);box-shadow:var(--shadow-soft)}.header-inner{max-width:1100px;margin:0 auto;padding:12px var(--page-pad-x);display:flex;align-items:center;justify-content:space-between;gap:16px}.header-brand{text-align:left;padding:4px 0;border-radius:var(--radius-sm)}.header-brand:hover{opacity:.85}.app-title{font-size:1.2rem;font-weight:800;color:var(--deep-purple);letter-spacing:-.02em;line-height:1.2}.app-subtitle{font-size:.82rem;color:var(--text-muted);font-weight:600;margin-top:2px}.desktop-nav{display:none;gap:4px;flex-shrink:0}.nav-btn{display:flex;align-items:center;gap:5px;padding:8px 11px;border-radius:var(--radius-pill);font-size:.82rem;font-weight:700;color:var(--text-muted);transition:background .2s,color .2s,box-shadow .2s;white-space:nowrap}.nav-btn:hover{background:#9b7ec81f;color:var(--deep-purple)}.nav-btn-active{background:linear-gradient(135deg,var(--lavender),var(--soft-pink));color:var(--deep-purple);box-shadow:0 2px 14px #9b7ec847}.nav-icon{font-size:1.05rem}.app-main{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:20px var(--page-pad-x) calc(var(--bottom-nav-h) + 28px)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;gap:4px;max-width:100%;background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);box-shadow:0 -6px 32px #4e326817;padding:6px 6px calc(10px + env(safe-area-inset-bottom))}.bottom-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 1px;border-radius:var(--radius-sm);color:var(--text-muted);font-weight:700;font-size:.58rem;transition:background .2s,color .2s,transform .15s;min-height:58px;min-width:0}.bottom-nav-btn:active{transform:scale(.96)}.bottom-nav-active{color:var(--deep-purple);background:linear-gradient(180deg,#d4c4ef8c,#f6d0d859);box-shadow:inset 0 0 0 1px #9b7ec833}.bottom-nav-icon{font-size:1.28rem;line-height:1}.bottom-nav-label{line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.screen{animation:fadeIn .28s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.screen-intro{background:#ffffffa6;border:1px solid rgba(255,255,255,.9);border-radius:var(--radius-md);padding:14px 18px;font-size:.98rem;font-weight:600;color:var(--purple-muted);line-height:1.5;margin-bottom:20px;box-shadow:var(--shadow-soft)}.screen-help{text-align:center;margin-top:14px;font-size:.92rem;font-weight:600;color:var(--text-muted)}.screen-title{font-size:1.65rem;font-weight:800;color:var(--deep-purple);margin-bottom:4px;line-height:1.2}.screen-subtitle{font-size:1.02rem;color:var(--text-muted);font-weight:600;margin-bottom:20px;line-height:1.45}.screen-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.screen-header-row .screen-title{margin-bottom:0}.counter-badge{flex-shrink:0;background:var(--white);padding:8px 14px;border-radius:var(--radius-pill);font-weight:800;font-size:.92rem;color:var(--purple-muted);box-shadow:var(--shadow-soft)}.result-count{font-size:.92rem;font-weight:700;color:var(--text-muted);margin-bottom:14px}.empty-message{text-align:center;padding:32px 20px;font-size:1.05rem;font-weight:600;color:var(--text-muted);background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-soft)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:15px 26px;border-radius:var(--radius-pill);font-size:1rem;font-weight:700;transition:transform .15s,box-shadow .15s,opacity .15s;min-height:48px}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#f5b07a,var(--pink));color:var(--white);box-shadow:var(--shadow-btn)}.btn-primary:hover:not(:disabled){box-shadow:0 8px 32px #f0a87873}.btn-secondary{background:var(--white);color:var(--deep-purple);border:2px solid rgba(155,126,200,.22);box-shadow:var(--shadow-soft)}.btn-secondary:hover{border-color:var(--lavender-deep);background:#fffcfa}.btn-card{width:100%;margin-top:4px}.btn-outline{background:var(--white);color:var(--purple-muted);border:2px solid rgba(155,126,200,.18);padding:13px 18px;font-size:.95rem}.btn-listen{background:linear-gradient(135deg,var(--lavender),#e8dff5);color:var(--deep-purple);padding:13px 22px;box-shadow:0 3px 14px #9b7ec838}.btn-small{padding:12px 18px;font-size:.95rem;min-height:44px}.btn-large{padding:18px 28px;font-size:1.08rem;width:100%;min-height:56px}.btn-full{width:100%}.listen-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.listen-hint{font-size:.85rem;font-weight:700;color:#9a4a4a;text-align:center;max-width:220px;line-height:1.35}.practice-feature-card{background:linear-gradient(150deg,#fff9f5,#fff 40%,#f8f0ff);border-radius:var(--radius-lg);padding:28px 22px;box-shadow:var(--shadow-card);margin-bottom:20px;border:1px solid rgba(255,255,255,.95);text-align:center}.practice-feature-title{font-size:1.55rem;font-weight:800;color:var(--deep-purple);margin-bottom:8px;line-height:1.2}.practice-feature-subtitle{font-size:1.08rem;font-weight:600;color:var(--text-muted);margin-bottom:8px;line-height:1.45}.practice-feature-hint{font-size:.88rem;font-weight:700;color:var(--purple-muted);margin-bottom:20px}.practice-feature-btn{margin-bottom:10px}.practice-feature-btn-secondary{width:100%}.home-section-label{font-size:.92rem;font-weight:800;color:var(--purple-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;padding-left:2px}.practice-progress-header{margin-bottom:18px}.practice-step-label{display:block;font-size:1rem;font-weight:800;color:var(--deep-purple);margin-bottom:10px}.practice-progress-track{height:10px;background:#ffffffb3;border-radius:var(--radius-pill);overflow:hidden;box-shadow:inset 0 1px 4px #4e326814}.practice-progress-fill{height:100%;background:linear-gradient(90deg,var(--warm-orange),var(--pink),var(--lavender-deep));border-radius:var(--radius-pill);transition:width .35s ease;min-width:4px}.practice-card{background:linear-gradient(165deg,#fff,#fffaf7,#f9f4ff);border-radius:var(--radius-lg);padding:26px 20px;box-shadow:var(--shadow-card);margin-bottom:16px;text-align:center;border:1px solid rgba(255,255,255,.95)}.practice-english{font-size:1.9rem;font-weight:800;color:var(--deep-purple);line-height:1.2;margin-bottom:6px;word-break:break-word}.practice-phonetic{font-size:1.12rem;font-weight:700;color:var(--warm-orange);margin-bottom:16px}.practice-spanish{font-size:1.3rem;font-weight:700;color:var(--text-muted);margin-bottom:18px;word-break:break-word}.practice-card .listen-wrap{margin-top:18px;width:100%}.practice-feedback{border-radius:var(--radius-md);padding:14px 18px;font-size:1.02rem;font-weight:700;text-align:center;margin-bottom:14px;line-height:1.45}.practice-feedback-success{background:linear-gradient(135deg,#e8f5ec,#f0faf3);border:1px solid rgba(74,154,90,.2);color:#2a6a3a}.practice-feedback-warm{background:linear-gradient(135deg,#fef0e8,#fff5ee);border:1px solid rgba(240,168,120,.25);color:#7a4a2a}.practice-actions{display:flex;flex-direction:column;gap:10px}.practice-complete-card{background:linear-gradient(160deg,#fff,#fff5f8 45%,#f3ecff);border-radius:var(--radius-lg);padding:36px 24px;box-shadow:var(--shadow-card);text-align:center;border:1px solid rgba(255,255,255,.95)}.practice-complete-emoji{font-size:3rem;display:block;margin-bottom:12px;line-height:1}.practice-complete-title{font-size:1.85rem;font-weight:800;color:var(--deep-purple);margin-bottom:8px}.practice-complete-subtitle{font-size:1.15rem;font-weight:700;color:var(--text-muted);margin-bottom:6px}.practice-complete-message{font-size:1.1rem;font-weight:700;color:var(--purple-muted);margin-bottom:28px}.practice-complete-stats{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:28px}.practice-complete-stat{background:var(--white);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-soft)}.practice-complete-stat-value{display:block;font-size:2rem;font-weight:800;color:var(--deep-purple);line-height:1.1}.practice-complete-stat-label{display:block;font-size:.88rem;font-weight:700;color:var(--text-muted);margin-top:4px}.practice-complete-actions{display:flex;flex-direction:column;gap:10px}.practice-next-hint{font-size:1rem;font-weight:700;color:var(--text-muted);line-height:1.45;margin-bottom:18px}.btn-text{background:transparent;border:none;color:var(--purple-muted);font-weight:700;font-size:.92rem;padding:8px 12px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;min-height:44px}.btn-text:hover,.btn-text:focus-visible{color:var(--deep-purple)}.help-box{margin-bottom:12px}.help-box-toggle{background:#ffffffb3;border:1px solid rgba(212,196,239,.45);border-radius:999px;color:var(--purple-muted);font-size:.85rem;font-weight:700;padding:6px 14px;cursor:pointer;min-height:36px}.help-box-toggle:hover,.help-box-toggle:focus-visible{background:var(--white);color:var(--deep-purple)}.help-box-text{margin-top:8px;padding:12px 14px;background:#ffffffd9;border-radius:var(--radius-sm);border:1px solid rgba(212,196,239,.35);font-size:.92rem;font-weight:600;color:var(--text-muted);line-height:1.45}.resume-practice-card{background:linear-gradient(135deg,#fff8f0,#f3ecff);border:2px solid rgba(240,168,120,.35);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-soft)}.resume-practice-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px}.resume-practice-emoji{font-size:1.75rem;line-height:1;flex-shrink:0}.resume-practice-title{font-size:1.15rem;font-weight:800;color:var(--deep-purple);margin-bottom:4px}.resume-practice-subtitle{font-size:.95rem;font-weight:600;color:var(--text-muted);line-height:1.4}.resume-practice-step{font-size:.88rem;font-weight:700;color:var(--warm-orange);margin-top:6px}.review-empty-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}.situation-practiced-btn{margin-top:8px}.situation-phrase-feedback{margin-top:8px;padding:10px 12px;border-radius:var(--radius-sm);background:#e8f5ec;color:#2a6a3a;font-size:.9rem;font-weight:700;text-align:center;line-height:1.4}.situation-pronunciation-toggle{margin-top:8px}.situation-pronunciation-wrap{margin-top:10px;padding-top:10px;border-top:1px solid rgba(212,196,239,.35)}.pronunciation-section{margin-top:16px;padding-top:14px;border-top:1px solid rgba(212,196,239,.35)}.pronunciation-toggle{margin-bottom:0}.pronunciation-section-body{margin-top:12px}.pronunciation-section-title{font-size:.95rem;font-weight:800;color:var(--deep-purple);margin-bottom:10px}.repeat-after-me{display:flex;flex-direction:column;gap:12px}.repeat-after-me-compact{gap:10px}.repeat-english{font-size:1.35rem;font-weight:800;color:var(--deep-purple);line-height:1.25}.repeat-phonetic{font-size:.95rem;font-weight:600;color:var(--purple-muted);font-style:italic;margin-top:4px}.repeat-phonetic-compact{font-size:.9rem;font-weight:600;color:var(--purple-muted);font-style:italic;text-align:center}.repeat-spanish{font-size:1rem;font-weight:700;color:var(--text-muted);margin-top:6px}.repeat-example{font-size:.9rem;font-weight:600;color:var(--text-muted);margin-top:8px;line-height:1.4}.repeat-unsupported{font-size:.9rem;font-weight:600;color:var(--text-muted);line-height:1.45;padding:10px 12px;background:#ffffffb3;border-radius:var(--radius-sm);border:1px solid rgba(212,196,239,.35)}.repeat-after-me-actions{display:flex;flex-direction:column;gap:8px}.pronunciation-result{border-radius:var(--radius-md);padding:16px;text-align:center;line-height:1.45}.pronunciation-result-excellent{background:linear-gradient(135deg,#e8f5ec,#f0faf3);border:1px solid rgba(42,106,58,.2)}.pronunciation-result-good{background:linear-gradient(135deg,#eef6ff,#f5f0ff);border:1px solid rgba(100,120,200,.2)}.pronunciation-result-fair{background:linear-gradient(135deg,#fff8f0,#fef5ee);border:1px solid rgba(240,168,120,.25)}.pronunciation-result-low{background:linear-gradient(135deg,#fff5f8,#faf5ff);border:1px solid rgba(212,196,239,.35)}.pronunciation-result-message{font-size:1.05rem;font-weight:800;color:var(--deep-purple);margin-bottom:10px}.pronunciation-result-detail{font-size:.9rem;font-weight:600;color:var(--text-muted);margin-bottom:6px}.pronunciation-result-label{font-weight:800;color:var(--deep-purple)}.pronunciation-result-confidence{font-size:.82rem;font-weight:600;color:var(--purple-muted);margin-top:8px}.pronunciation-result-error{padding:12px 14px;border-radius:var(--radius-sm);background:#fef0e8;color:#7a4a2a;font-size:.92rem;font-weight:700;text-align:center;line-height:1.4}.daily-routine-pronunciation-note{margin-top:12px;padding:10px 14px;background:#ffffffbf;border-radius:var(--radius-sm);font-size:.88rem;font-weight:700;color:var(--purple-muted);text-align:center}.sound-setting-card{background:linear-gradient(135deg,#fff,#faf5ff);border-radius:var(--radius-md);padding:16px 18px;margin-bottom:18px;box-shadow:var(--shadow-soft);border:1px solid rgba(212,196,239,.35)}.sound-setting-title{font-size:1rem;font-weight:800;color:var(--deep-purple);margin-bottom:10px}.sound-toggle-options{display:flex;gap:8px}.sound-toggle-btn{flex:1;min-height:44px;padding:10px 14px;border-radius:var(--radius-sm);border:2px solid rgba(212,196,239,.45);background:#fffc;color:var(--text-muted);font-size:.92rem;font-weight:700;cursor:pointer}.sound-toggle-btn.sound-toggle-active{background:linear-gradient(135deg,#f3ecff,#fff5f8);border-color:var(--purple-muted);color:var(--deep-purple)}.sound-toggle-btn:focus-visible{outline:2px solid var(--purple-muted);outline-offset:2px}.progress-daily-message{font-size:1rem;font-weight:700;color:var(--warm-orange);margin-top:12px;line-height:1.45}.progress-stat-value-text{font-size:1rem;line-height:1.3;padding:0 4px;text-transform:capitalize}.hero-card{background:linear-gradient(150deg,#fff,#fff9f6 55%,#faf3ff);border-radius:var(--radius-lg);padding:28px 22px;box-shadow:var(--shadow-card);margin-bottom:18px;border:1px solid rgba(255,255,255,.95)}.hero-greeting{font-size:1.45rem;font-weight:800;color:var(--deep-purple);margin-bottom:6px}.hero-question{font-size:1.12rem;font-weight:600;color:var(--text-muted);margin-bottom:22px;line-height:1.45}.mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:22px}.mini-stat{background:var(--white);border-radius:var(--radius-md);padding:16px 8px;text-align:center;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.95)}.mini-stat-value{display:block;font-size:1.6rem;font-weight:800;color:var(--deep-purple);line-height:1.1}.mini-stat-label{display:block;font-size:.72rem;font-weight:700;color:var(--text-muted);margin-top:6px;line-height:1.25;padding:0 2px}.dashboard-cards{display:grid;grid-template-columns:1fr;gap:14px}.dashboard-card{background:var(--white);border-radius:var(--radius-md);padding:22px 20px;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.95);display:flex;flex-direction:column;gap:6px;transition:transform .2s,box-shadow .2s}.dashboard-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card)}.dashboard-card-emoji{font-size:1.85rem;line-height:1;margin-bottom:2px}.dashboard-card-title{font-size:1.18rem;font-weight:800;color:var(--deep-purple)}.dashboard-card-desc{font-size:.98rem;color:var(--text-muted);font-weight:600;margin-bottom:10px;flex:1;line-height:1.45}.home-footer-note{text-align:center;margin-top:24px;font-size:.95rem;font-weight:700;color:var(--purple-muted);padding-bottom:8px}.category-pill{display:inline-block;padding:6px 14px;border-radius:var(--radius-pill);font-size:.78rem;font-weight:800;letter-spacing:.03em;margin-bottom:14px}.pill-small{font-size:.72rem;padding:5px 11px;margin-bottom:8px}.category-daily{background:#e8f4e0;color:#4a7a3a}.category-work{background:#e0eaf8;color:#3a5a8a}.category-deli{background:#fde8d0;color:#8a5a2a}.category-polite{background:#f0e0f8;color:#6a3a8a}.category-numbers{background:#e0f0f8;color:#2a6a8a}.flashcard{background:var(--white);border-radius:var(--radius-lg);padding:26px 20px;box-shadow:var(--shadow-card);margin-bottom:20px;text-align:center;border:1px solid rgba(255,255,255,.95)}.flashcard-label{font-size:.82rem;font-weight:800;color:var(--purple-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.flashcard-english{font-size:1.85rem;font-weight:800;color:var(--deep-purple);line-height:1.2;margin-bottom:6px;word-break:break-word}.flashcard-phonetic{font-size:1.1rem;font-weight:700;color:var(--warm-orange);margin-bottom:18px;letter-spacing:.02em}.flashcard-spanish{font-size:1.28rem;font-weight:700;color:var(--text-muted);margin-bottom:20px;word-break:break-word}.flashcard-examples{background:linear-gradient(180deg,var(--cream),#faf5f0);border-radius:var(--radius-sm);padding:16px;text-align:left}.example-line{font-size:.98rem;font-weight:600;color:var(--text-dark);margin-bottom:8px;line-height:1.5;word-break:break-word}.example-line:last-child{margin-bottom:0}.example-label{font-weight:800;color:var(--purple-muted);margin-right:4px}.known-badge{display:inline-block;margin-top:14px;padding:8px 16px;background:#e0f5e8;color:#2a7a4a;border-radius:var(--radius-pill);font-weight:800;font-size:.88rem}.button-row{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:start;margin-bottom:14px}.button-row .btn-outline{width:100%;padding-left:12px;padding-right:12px;font-size:.88rem}.button-row .listen-wrap{justify-self:center}.filter-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.chip{padding:12px 18px;border-radius:var(--radius-pill);font-size:.92rem;font-weight:700;background:var(--white);color:var(--text-muted);border:2px solid transparent;box-shadow:var(--shadow-soft);transition:all .2s;min-height:44px}.chip-active{background:linear-gradient(135deg,var(--lavender),var(--soft-pink));color:var(--deep-purple);box-shadow:0 3px 14px #9b7ec847}.lesson-cards{display:grid;grid-template-columns:1fr;gap:12px}.lesson-card{background:var(--white);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.95)}.lesson-english{font-size:1.28rem;font-weight:800;color:var(--deep-purple);margin-bottom:4px;word-break:break-word}.lesson-phonetic{font-size:.98rem;font-weight:700;color:var(--warm-orange);margin-bottom:6px}.lesson-spanish{font-size:1.05rem;font-weight:700;color:var(--text-muted);margin-bottom:14px;word-break:break-word}.quiz-card{background:var(--white);border-radius:var(--radius-lg);padding:26px 20px;box-shadow:var(--shadow-card);text-align:center;margin-bottom:18px;border:1px solid rgba(255,255,255,.95)}.quiz-prompt-label{font-size:.98rem;font-weight:700;color:var(--text-muted);margin-bottom:10px}.quiz-english{font-size:1.7rem;font-weight:800;color:var(--deep-purple);margin-bottom:4px;word-break:break-word;line-height:1.25}.quiz-phonetic{font-size:1.05rem;font-weight:700;color:var(--warm-orange);margin-bottom:16px}.quiz-card .listen-wrap{margin-bottom:4px}.quiz-choices{display:flex;flex-direction:column;gap:10px;margin-top:20px}.quiz-choice{width:100%;padding:17px 18px;border-radius:var(--radius-md);font-size:1.05rem;font-weight:700;background:var(--cream);color:var(--text-dark);border:2px solid transparent;text-align:left;transition:all .2s;min-height:54px;word-break:break-word}.quiz-choice:hover:not(:disabled){border-color:var(--lavender-deep);background:var(--white)}.choice-correct{border-color:#4a9a5a!important;background:#e8f5ec!important;color:#2a6a3a}.choice-wrong{border-color:#c85a5a!important;background:#fce8e8!important;color:#8a2a2a}.quiz-feedback{margin-top:18px;padding:14px 16px;border-radius:var(--radius-sm);font-size:1.02rem;font-weight:700;line-height:1.45}.feedback-correct{background:#e8f5ec;color:#2a6a3a}.feedback-wrong{background:#fef0e8;color:#7a4a2a}.progress-hero-card{background:linear-gradient(150deg,#fff,#faf5ff);border-radius:var(--radius-lg);padding:28px 22px;box-shadow:var(--shadow-card);text-align:center;margin-bottom:20px;border:1px solid rgba(255,255,255,.95)}.progress-ring-wrap{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--lavender),var(--soft-pink));display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 6px 28px #9b7ec852}.progress-percent{font-size:1.65rem;font-weight:800;color:var(--deep-purple)}.progress-bar-label{font-size:.92rem;font-weight:700;color:var(--text-muted);margin-bottom:10px}.progress-bar-track{height:16px;background:var(--cream-dark);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:18px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--warm-orange),var(--pink),var(--lavender));border-radius:var(--radius-pill);transition:width .5s ease;min-width:0}.progress-encouragement{font-size:1.1rem;font-weight:700;color:var(--purple-muted);line-height:1.5}.progress-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.progress-stat-card{background:var(--white);border-radius:var(--radius-md);padding:20px 14px;text-align:center;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.95)}.progress-stat-wide{grid-column:1 / -1}.progress-stat-emoji{font-size:1.65rem;display:block;margin-bottom:6px}.progress-stat-value{display:block;font-size:1.85rem;font-weight:800;color:var(--deep-purple);line-height:1.1}.progress-stat-label{display:block;font-size:.82rem;font-weight:700;color:var(--text-muted);margin-top:5px;line-height:1.3}@media(min-width:600px){:root{--page-pad-x: 24px}.app-title{font-size:1.45rem}.app-subtitle{font-size:.92rem}.screen-title{font-size:1.85rem}.dashboard-cards{grid-template-columns:repeat(2,1fr);gap:16px}.lesson-cards{grid-template-columns:repeat(2,1fr)}.mini-stat-value{font-size:1.85rem}.mini-stat-label{font-size:.8rem}.flashcard-english{font-size:2.2rem}.practice-feature-card{padding:32px 28px}.practice-feature-title{font-size:1.75rem}.practice-complete-stats{grid-template-columns:repeat(3,1fr)}.bottom-nav-label{font-size:.62rem}}@media(min-width:900px){.desktop-nav{display:flex}.bottom-nav{display:none}.app-main{padding:28px var(--page-pad-x) 52px}.dashboard-cards{gap:18px}.lesson-cards{grid-template-columns:repeat(3,1fr)}.hero-greeting{font-size:1.65rem}.hero-question{font-size:1.25rem}.button-row{gap:12px}.button-row .btn-outline{font-size:.95rem}}@media(min-width:1100px){.dashboard-cards{grid-template-columns:repeat(4,1fr)}}.review-home-card{background:var(--white);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-soft);border:1px solid rgba(212,196,239,.35);margin-bottom:18px}.review-home-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:12px}.review-home-emoji{font-size:1.75rem;line-height:1;flex-shrink:0}.review-home-title{font-size:1.15rem;font-weight:800;color:var(--deep-purple);margin-bottom:4px}.review-home-subtitle{font-size:.95rem;font-weight:600;color:var(--text-muted);line-height:1.4}.review-home-count{font-size:.92rem;font-weight:800;color:var(--warm-orange);margin-bottom:12px}.review-empty-card{background:linear-gradient(150deg,#fff,#faf5ff);border-radius:var(--radius-lg);padding:36px 24px;text-align:center;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.95)}.review-empty-emoji{font-size:2.5rem;display:block;margin-bottom:12px}.review-empty-text{font-size:1.15rem;font-weight:800;color:var(--deep-purple);margin-bottom:8px}.review-empty-hint{font-size:.98rem;font-weight:600;color:var(--text-muted);line-height:1.45}.review-cards{display:flex;flex-direction:column;gap:16px}.review-card{background:linear-gradient(165deg,#fff,#fffaf7);border-radius:var(--radius-lg);padding:22px 20px;box-shadow:var(--shadow-card);border:1px solid rgba(255,255,255,.95)}.review-examples{background:var(--cream);border-radius:var(--radius-sm);padding:14px;margin:14px 0}.review-actions{display:flex;flex-direction:column;gap:10px;margin-top:14px}.review-feedback{margin-top:12px;padding:12px 14px;border-radius:var(--radius-sm);font-size:.98rem;font-weight:700;text-align:center;line-height:1.4}.review-feedback-success{background:#e8f5ec;color:#2a6a3a}.review-feedback-warm{background:#fef0e8;color:#7a4a2a}.progress-review-banner{display:flex;flex-direction:column;gap:12px;background:linear-gradient(135deg,#fff5f8,#f3ecff);border:1px solid rgba(212,196,239,.4);border-radius:var(--radius-md);padding:18px 20px;margin-bottom:18px;box-shadow:var(--shadow-soft)}.progress-review-banner-text{font-size:1.05rem;font-weight:700;color:var(--deep-purple);line-height:1.45}.progress-review-banner-text strong{color:var(--warm-orange)}.progress-stat-highlight{border:2px solid rgba(212,196,239,.45);background:linear-gradient(180deg,#fff,#faf7ff)}.progress-stat-link{margin-top:10px;width:100%}.view-chips{display:flex;gap:10px;margin-bottom:18px}.chip-view{flex:1;justify-content:center;text-align:center}.situations-list{display:flex;flex-direction:column;gap:16px}.situation-card{background:linear-gradient(165deg,#fff,#fff9f6,#f8f4ff);border-radius:var(--radius-lg);padding:22px 20px;box-shadow:var(--shadow-card);border:1px solid rgba(255,255,255,.95)}.situation-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(212,196,239,.25)}.situation-emoji{font-size:2rem;line-height:1;flex-shrink:0}.situation-title{font-size:1.2rem;font-weight:800;color:var(--deep-purple);margin-bottom:4px;line-height:1.25}.situation-desc{font-size:.92rem;font-weight:600;color:var(--text-muted);line-height:1.4}.situation-phrases{list-style:none;display:flex;flex-direction:column;gap:12px}.situation-phrase{background:var(--white);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-soft)}.situation-phrase-english{font-size:1.12rem;font-weight:800;color:var(--deep-purple);margin-bottom:4px;line-height:1.3;word-break:break-word}.situation-phrase-phonetic{font-size:.95rem;font-weight:700;color:var(--warm-orange);margin-bottom:6px}.situation-phrase-spanish{font-size:1rem;font-weight:700;color:var(--text-muted);margin-bottom:12px;line-height:1.4}.welcome-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;min-height:100dvh;background:#3a2d4580;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:max(12px,env(safe-area-inset-top)) var(--page-pad-x) calc(var(--bottom-nav-h) + 16px)}.welcome-card{display:flex;flex-direction:column;background:linear-gradient(165deg,#fff,#fff8f5,#f5efff);border-radius:var(--radius-lg);max-width:420px;width:100%;margin:0 auto;max-height:calc(100dvh - var(--bottom-nav-h) - 28px - env(safe-area-inset-top));box-shadow:0 16px 48px #4e326838;border:1px solid rgba(255,255,255,.95);overflow:hidden}.welcome-card-content{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:22px 20px 8px;text-align:center}.welcome-emoji{font-size:2.25rem;display:block;margin-bottom:8px}.welcome-title{font-size:1.45rem;font-weight:800;color:var(--deep-purple);margin-bottom:6px}.welcome-lead{font-size:.98rem;font-weight:600;color:var(--text-muted);margin-bottom:14px}.welcome-steps{list-style:none;text-align:left;display:flex;flex-direction:column;gap:8px}.welcome-step{display:flex;align-items:flex-start;gap:10px;background:var(--white);border-radius:var(--radius-md);padding:11px 12px;box-shadow:var(--shadow-soft)}.welcome-step-num{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--lavender),var(--soft-pink));color:var(--deep-purple);font-size:.85rem;font-weight:800;display:flex;align-items:center;justify-content:center}.welcome-step-text{font-size:.94rem;font-weight:700;color:var(--text-dark);line-height:1.4;padding-top:2px}.welcome-actions{flex-shrink:0;display:flex;flex-direction:column;gap:10px;padding:14px 20px 18px;background:linear-gradient(180deg,#fff8f5eb,#fff8f5 30%,#f5efff);border-top:1px solid rgba(155,126,200,.28);box-shadow:0 -8px 24px #4e326814}.welcome-actions-hint{font-size:.9rem;font-weight:700;color:var(--purple-muted);text-align:center;line-height:1.4;margin-bottom:2px}.welcome-actions .btn{width:100%;min-height:52px}.welcome-btn-start{background:linear-gradient(135deg,#f5b07a,var(--pink));color:var(--white);box-shadow:var(--shadow-btn)}.welcome-btn-dismiss{background:#fff;color:var(--deep-purple);border:2px solid var(--lavender-deep);box-shadow:0 4px 16px #4e326824;font-weight:800}.welcome-btn-dismiss:hover{background:#faf5ff;border-color:var(--deep-purple)}.daily-routine-card{background:var(--white);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-soft);border:1px solid rgba(212,196,239,.3);margin-bottom:18px}.daily-routine-compact{margin-bottom:16px;padding:16px}.daily-routine-header{margin-bottom:14px}.daily-routine-title{font-size:1.2rem;font-weight:800;color:var(--deep-purple)}.daily-routine-subtitle{font-size:.9rem;font-weight:600;color:var(--text-muted);margin-top:4px}.daily-routine-steps{list-style:none;display:flex;flex-direction:column;gap:8px}.daily-routine-step-btn{width:100%;display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:10px;padding:14px 12px;border-radius:var(--radius-md);background:linear-gradient(180deg,#fffcfa,#faf7ff);border:1px solid rgba(212,196,239,.25);text-align:left;transition:background .2s,transform .15s;min-height:52px}.daily-routine-step-btn:active{transform:scale(.98)}.daily-routine-step-num{width:24px;height:24px;border-radius:50%;background:var(--lavender);color:var(--deep-purple);font-size:.8rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.daily-routine-step-icon{font-size:1.2rem;line-height:1;flex-shrink:0}.daily-routine-step-label{font-size:.92rem;font-weight:700;color:var(--text-dark);line-height:1.3;min-width:0}.routine-status{font-size:.72rem;font-weight:800;padding:5px 10px;border-radius:var(--radius-pill);white-space:nowrap;flex-shrink:0}.routine-status-done{background:#e8f5ec;color:#2a6a3a}.routine-status-pending{background:#fef0e8;color:#8a5a2a}.routine-status-none{background:#f0f0f5;color:var(--purple-muted)}.progress-routine-section{margin-bottom:18px}.progress-routine-heading{font-size:1.1rem;font-weight:800;color:var(--deep-purple);margin-bottom:10px}.practice-first-reminder{background:#ffffffbf;border:1px dashed rgba(155,126,200,.35);border-radius:var(--radius-md);padding:12px 16px;font-size:.95rem;font-weight:700;color:var(--purple-muted);text-align:center;margin-bottom:16px;line-height:1.45}.review-encouragement{background:linear-gradient(135deg,#fef8f5,#faf5ff);border-radius:var(--radius-md);padding:14px 18px;font-size:1rem;font-weight:700;color:var(--purple-muted);text-align:center;margin-bottom:18px;line-height:1.45;border:1px solid rgba(212,196,239,.25)}@media(max-width:360px){.button-row{grid-template-columns:1fr;justify-items:stretch}.button-row .listen-wrap{justify-self:stretch}.button-row .listen-wrap .btn{width:100%}.mini-stat-label{font-size:.68rem}.bottom-nav-label{font-size:.52rem}.bottom-nav-icon{font-size:1.15rem}.practice-english{font-size:1.6rem}.welcome-card{max-height:calc(100dvh - var(--bottom-nav-h) - 20px - env(safe-area-inset-top))}.welcome-card-content{padding:18px 16px 6px}.welcome-emoji{font-size:1.85rem;margin-bottom:4px}.welcome-title{font-size:1.25rem}.welcome-lead{font-size:.9rem;margin-bottom:12px}.welcome-step-text{font-size:.88rem}.welcome-actions{padding:12px 16px 16px}.welcome-actions-hint{font-size:.85rem}.daily-routine-step-btn{grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:6px 10px}.daily-routine-step-icon{display:none}.routine-status{grid-column:2;justify-self:start}}
