:root{--bg: #1a1a2e;--bg2: #16213e;--bg3: #0f3460;--card: #1e2a4a;--card-hover: #253358;--border: #2a3a5c;--text: #e8e8e8;--text2: #cdd4e0;--text3: #c0c8dc;--accent: #c7553b;--accent2: #e07b5f;--accent-bg: rgba(199,85,59,.15);--green: #4caf50;--green-bg: rgba(76,175,80,.15);--red: #ef5350;--red-bg: rgba(239,83,80,.15);--yellow: #ffc107;--yellow-bg: rgba(255,193,7,.15);--blue: #42a5f5;--blue-bg: rgba(66,165,245,.15);--masc: #42a5f5;--fem: #f06292;--radius: 12px;--radius-sm: 8px;--shadow: 0 2px 8px rgba(0,0,0,.3);--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-lg: 0 4px 16px rgba(0,0,0,.4);--font: "Segoe UI", system-ui, -apple-system, sans-serif;--mono: "Cascadia Code", "Fira Code", monospace;--transition: .2s ease;--max-w: 640px;--card-bg: var(--card);--text1: var(--text);--surface: var(--bg3);--incorrect: var(--red);--yellow-text: #ffc107}[data-region=latam] .spain-only{display:none}[data-theme=light]{--bg: #f5f0eb;--bg2: #ede5db;--bg3: #ddd3c6;--card: #ffffff;--card-hover: #f8f4ef;--border: #d4c8b8;--text: #2c2418;--text2: #6b5d4f;--text3: #7a6b5a;--shadow: 0 2px 8px rgba(0,0,0,.1);--shadow-lg: 0 4px 16px rgba(0,0,0,.12);--yellow-text: #b38600}[data-palette=oaxaca]{--accent: #d4442a;--accent2: #e8694f;--accent-bg: rgba(212,68,42,.15)}[data-palette=patagonia]{--accent: #2196f3;--accent2: #64b5f6;--accent-bg: rgba(33,150,243,.15)}[data-palette=flamenco]{--accent: #b71c1c;--accent2: #e53935;--accent-bg: rgba(183,28,28,.15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}h1{font-size:1.5rem;font-weight:700;line-height:1.3;margin:0 0 .75rem}h2{font-size:1.15rem;font-weight:600;line-height:1.3;margin:0 0 .5rem}h3{font-size:1rem;font-weight:600;line-height:1.3;margin:0 0 .4rem}h4{font-size:.9rem;font-weight:600;line-height:1.3;margin:0 0 .3rem}a{color:var(--accent2);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:var(--text);background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;outline:none;transition:border-color var(--transition)}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.app-container{max-width:var(--max-w);margin:0 auto;padding-bottom:80px;min-height:100dvh}.navbar{position:sticky;top:0;z-index:100;background:var(--bg2);border-bottom:1px solid var(--border);padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem}.navbar .nav-back{font-size:1.25rem;padding:.25rem;display:none}.navbar .nav-back.visible{display:block}.navbar .nav-title{font-weight:700;font-size:1.1rem;flex:1}.navbar .nav-stats{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--text2)}.navbar .nav-stats .xp{color:var(--yellow-text);font-weight:600}.navbar .nav-stats .streak{color:var(--accent2);font-weight:600}.nav-btn{padding:.35rem;border-radius:var(--radius-sm);font-size:1.15rem;transition:background var(--transition);min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.nav-btn:hover{background:var(--bg3)}.tab-bar{position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--bg2);border-top:1px solid var(--border);display:flex;justify-content:center;max-width:var(--max-w);margin:0 auto}.tab-bar .tab{flex:1;display:flex;flex-direction:column;align-items:center;padding:.5rem .25rem;font-size:.75rem;color:var(--text3);transition:color var(--transition);position:relative;min-height:44px;max-width:120px}.tab-bar .tab .tab-icon{font-size:1.2rem;margin-bottom:.1rem}.tab-bar .tab.active{color:var(--accent)}.tab-bar .tab.active:after{content:"";position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--accent);border-radius:0 0 2px 2px}.tab-bar .tab:hover{color:var(--text)}.tab-bar .tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-radius:4px}.tab-wrapper{flex:1;position:relative;max-width:120px}.tab-wrapper .tab{max-width:none;width:100%}.tab-dropdown{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:160px;padding:.25rem 0;display:none;z-index:200}.tab-dropdown.open{display:block}.tab-dropdown .dropdown-item{display:block;width:100%;padding:.5rem 1rem;text-align:left;color:var(--text);font-size:.85rem;transition:background var(--transition)}.tab-dropdown .dropdown-item:hover{background:var(--bg3)}.screen{display:none;padding:1rem}.screen.active{display:block}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.75rem;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);cursor:pointer}.card:hover{background:var(--card-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.card[data-action],[data-action].stat-cards{cursor:pointer}.card-title{font-weight:700;font-size:1rem;margin-bottom:.25rem}.card-subtitle{color:var(--text2);font-size:.85rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.card-grid .card{text-align:center;cursor:pointer}.card-grid .card .card-icon{font-size:1.5rem;margin-bottom:.25rem}.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.nav-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;transition:all var(--transition)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}.btn-secondary{background:var(--bg3);color:var(--text)}.btn-secondary:hover{background:var(--border)}.btn-outline{border:1px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-outline.active{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.btn-block{display:flex;width:100%}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn:disabled,.btn.disabled{opacity:.5;filter:saturate(.5) grayscale(40%);cursor:not-allowed;pointer-events:none}.progress-bar{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}.progress-bar .fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease}.progress-bar.green .fill{background:var(--green)}.flashcard{appearance:none;text-align:left;font:inherit;width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);min-height:220px;cursor:pointer;user-select:none;position:relative;-webkit-perspective:800px;perspective:800px}.flashcard:hover{box-shadow:var(--shadow-lg)}.flashcard:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.flashcard-inner{width:100%;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;position:relative;transition:-webkit-transform .5s ease,transform .5s ease;-webkit-transform-style:preserve-3d;transform-style:preserve-3d}.flashcard.flipped .flashcard-inner{-webkit-transform:rotateY(180deg);transform:rotateY(180deg)}.flashcard .front,.flashcard .back{width:100%;backface-visibility:hidden;-webkit-backface-visibility:hidden}.flashcard .back{position:absolute;inset:0;-webkit-transform:rotateY(180deg);transform:rotateY(180deg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.flashcard .word-main{font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.flashcard .word-detail{font-size:1rem;color:var(--text2)}.flashcard .word-gender{font-size:.8rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;display:inline-block;margin-bottom:.5rem}.flashcard .word-gender.m{background:var(--blue-bg);color:var(--masc)}.flashcard .word-gender.f{background:#f0629226;color:var(--fem)}.rating-bar{display:flex;gap:.5rem;margin-top:1rem}.rating-bar .rating-btn{flex:1;padding:.5rem;border-radius:var(--radius-sm);font-weight:600;font-size:.8rem;text-align:center;border:1px solid var(--border);transition:all var(--transition)}.rating-bar .rating-btn:hover{transform:translateY(-1px)}.rating-bar .rating-btn[data-rating="1"]{color:var(--red);border-color:var(--red);background:var(--red-bg)}.rating-bar .rating-btn[data-rating="2"]{color:var(--yellow);border-color:var(--yellow);background:var(--yellow-bg)}.rating-bar .rating-btn[data-rating="3"]{color:var(--green);border-color:var(--green);background:var(--green-bg)}.rating-bar .rating-btn[data-rating="4"]{color:var(--blue);border-color:var(--blue);background:var(--blue-bg)}.quiz-container{max-width:100%}.quiz-progress{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.85rem;color:var(--text2)}.quiz-question{font-size:1.1rem;font-weight:600;margin-bottom:1rem;line-height:1.4}.quiz-options{display:flex;flex-direction:column;gap:.5rem}.quiz-option{display:block;width:100%;text-align:left;padding:.75rem 1rem;background:var(--card);border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;transition:all var(--transition)}.quiz-option:hover:not(.disabled){border-color:var(--accent);background:var(--accent-bg)}.quiz-option:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.quiz-option.selected{border-color:var(--accent);background:var(--accent-bg)}.quiz-option.disabled{cursor:default;opacity:.55;pointer-events:none}.quiz-option.correct{border-color:var(--green);background:var(--green-bg)}.quiz-option.incorrect{border-color:var(--red);background:var(--red-bg)}.quiz-input-row{display:flex;gap:.5rem;margin-bottom:.75rem}.quiz-input-row input{flex:1}.quiz-feedback{padding:.75rem;border-radius:var(--radius-sm);margin-top:.75rem;font-size:.9rem}.quiz-feedback.correct{background:var(--green-bg);color:var(--green)}.quiz-feedback.incorrect{background:var(--red-bg);color:var(--red)}.accent-bar{display:flex;gap:.25rem;flex-wrap:wrap;margin-top:.5rem}.accent-bar .accent-btn{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg3);border:1px solid var(--border);border-radius:6px;font-size:.95rem;font-weight:600;transition:all var(--transition)}.accent-bar .accent-btn:hover{background:var(--accent-bg);border-color:var(--accent)}.accent-bar .accent-btn:active{transform:scale(.93);background:var(--accent-bg);border-color:var(--accent)}.conj-table th,.conj-table td{padding:.4rem .6rem;border:1px solid var(--border);text-align:left}.conj-table th{background:var(--bg3);font-weight:600;color:var(--text2)}.conj-table td{background:var(--card)}.conj-table .highlight{color:var(--accent);font-weight:600}.mastery-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.7rem;font-weight:600;padding:.1rem .4rem;border-radius:4px}.mastery-0{background:var(--bg3);color:var(--text3)}.mastery-1{background:var(--red-bg);color:var(--red)}.mastery-2{background:var(--yellow-bg);color:var(--yellow)}.mastery-3{background:var(--green-bg);color:var(--green)}.mastery-4{background:var(--blue-bg);color:var(--blue)}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border)}.stat-row:last-child{border-bottom:none}.stat-label{color:var(--text2);font-size:.85rem}.stat-value{font-weight:700;font-size:1rem}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.5rem;margin-bottom:1rem}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem;text-align:center}.stat-card .stat-num{font-size:1.5rem;font-weight:700;color:var(--accent)}.stat-card .stat-desc{font-size:.7rem;color:var(--text2);margin-top:.15rem}.today-header{text-align:center;padding:1.5rem 0}.today-header h1{font-size:1.3rem;margin-bottom:.25rem}.today-header .date{color:var(--text2);font-size:.85rem}.today-section{margin-bottom:1.25rem}.today-section h2{font-size:.9rem;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.wotd-word{font-size:1.5rem;margin-bottom:.25rem}.wotd-english{color:var(--text2);font-size:1rem}.card.completed{opacity:.6}.dialogue-line{padding:.4rem .6rem;border-radius:.5rem;margin-bottom:.3rem;background:var(--card-bg)}.dialogue-line.player{background:var(--accent-bg)}.error-sentence{font-size:1.1rem;padding:.5rem;background:var(--card-bg);border-radius:.5rem;margin-top:.5rem}#bd-chat{max-height:50vh;overflow-y:auto;padding:.5rem 0;scroll-behavior:smooth}.bd-msg{padding:.5rem .75rem;border-radius:var(--radius-sm);margin-bottom:.4rem;max-width:85%}.bd-msg-npc{background:var(--card-bg);margin-right:auto;border-bottom-left-radius:2px}.bd-msg-player{background:var(--accent-bg);margin-left:auto;border-bottom-right-radius:2px;text-align:right}.bd-msg-name{font-size:.7rem;font-weight:600;color:var(--text2);margin-bottom:.15rem;text-transform:uppercase;letter-spacing:.03em}.bd-msg-text{font-size:.95rem;line-height:1.4}.bd-msg-en{font-size:.8rem;color:var(--text3);margin-top:.15rem}.bd-choice-btn{text-align:left!important;white-space:normal;line-height:1.3;padding:.6rem .75rem;margin-bottom:.4rem}.bd-choice-en{display:block;font-size:.8rem;margin-top:.2rem}.bd-feedback-box{background:var(--green-bg);color:var(--text);border-left:3px solid var(--green);padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.9rem;line-height:1.4}.profile-screen{flex-direction:column;align-items:center;justify-content:center;min-height:80dvh;text-align:center}.profile-screen.active{display:flex}.profile-screen h1{font-size:1.5rem;margin-bottom:.5rem}.profile-screen .subtitle{color:var(--text2);margin-bottom:2rem}.profile-list{width:100%;max-width:300px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.profile-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.profile-item:hover{border-color:var(--accent)}.profile-item .avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700}.profile-item .name{flex:1;text-align:left;font-weight:600}.settings-group{margin-bottom:1.5rem}.settings-group h3{font-size:.85rem;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-label{font-size:.9rem}.setting-desc{font-size:.75rem;color:var(--text3)}.toggle{position:relative;width:44px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle .slider{position:absolute;inset:0;background:var(--bg3);border-radius:12px;cursor:pointer;transition:background var(--transition)}.toggle .slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform var(--transition)}.toggle input:checked+.slider{background:var(--accent)}.toggle input:checked+.slider:before{transform:translate(20px)}.pill-group{display:flex;flex-wrap:wrap;gap:.25rem;background:var(--bg3);border-radius:var(--radius-sm);padding:.2rem}.pill-group .pill{padding:.4rem .75rem;border-radius:6px;font-size:.8rem;font-weight:500;color:var(--text2);white-space:nowrap;transition:all var(--transition)}.pill-group .pill.active{background:var(--accent);color:#fff}.verb-list{display:flex;flex-direction:column;gap:.35rem}.verb-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.verb-item:hover{border-color:var(--accent)}.verb-item .verb-name{font-weight:600}.verb-item .verb-eng{color:var(--text2);font-size:.85rem}.verb-type-badge{font-size:.65rem;font-weight:600;padding:.1rem .35rem;border-radius:4px}.verb-type-badge.regular{background:var(--green-bg);color:var(--green)}.verb-type-badge.irregular{background:var(--red-bg);color:var(--red)}.verb-type-badge.stem-changing{background:var(--yellow-bg);color:var(--yellow)}.verb-type-badge.reflexive{background:var(--blue-bg);color:var(--blue)}.lesson-content{line-height:1.7;font-size:.95rem}.lesson-content p{margin-bottom:.75rem}.lesson-content strong{color:var(--accent2)}.lesson-content code{background:var(--bg3);padding:.1rem .35rem;border-radius:4px;font-family:var(--mono);font-size:.85em}.example-box{background:var(--bg2);border-left:3px solid var(--accent);padding:.75rem 1rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:.5rem}.example-box .es{font-weight:600;font-size:1rem}.example-box .en{color:var(--text2);font-size:.85rem}.phrase-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.5rem}.phrase-card .phrase-es{font-size:1.1rem;font-weight:600;margin-bottom:.2rem}.phrase-card .phrase-en{color:var(--text2);font-size:.9rem;margin-bottom:.5rem}.phrase-card .phrase-reply{padding-top:.5rem;border-top:1px solid var(--border);font-size:.85rem}.phrase-card .phrase-reply .label{color:var(--text3);font-size:.75rem}.chat-bubble{max-width:80%;padding:.75rem 1rem;border-radius:1rem;margin-bottom:.5rem;font-size:.9rem;line-height:1.4}.chat-bubble.speaker-a{background:var(--bg3);margin-right:auto;border-bottom-left-radius:4px}.chat-bubble.speaker-b{background:var(--accent-bg);margin-left:auto;border-bottom-right-radius:4px}.chat-bubble .speaker-name{font-size:.7rem;font-weight:600;color:var(--text3);margin-bottom:.2rem}.conv-chat{display:flex;flex-direction:column;max-height:50vh;overflow-y:auto;padding:.5rem 0}.modal-overlay{position:fixed;inset:0;z-index:1000;background:#0000;display:flex;align-items:center;justify-content:center;padding:1rem;pointer-events:none;transition:background .2s ease}.modal-overlay.open{background:#0009;pointer-events:auto}.modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);max-width:var(--max-w);width:100%;max-height:85dvh;overflow-y:auto;padding:1.5rem;box-shadow:var(--shadow-lg);transform:scale(.92);opacity:0;transition:transform .2s ease,opacity .2s ease}.modal-overlay.open .modal{transform:scale(1);opacity:1}.modal h2{font-size:1.15rem;margin-bottom:1rem}.modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.search-box{position:relative;margin-bottom:1rem}.search-box input{width:100%;padding-left:2.25rem}.search-box .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text3);font-size:.9rem}.wave-locked{opacity:.5;pointer-events:none}.wave-locked:after{content:"\1f512";position:absolute;top:.5rem;right:.5rem}.streak-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.streak-day{aspect-ratio:1;border-radius:4px;font-size:.55rem;display:flex;align-items:center;justify-content:center}.streak-day.practiced{background:var(--green);color:#fff}.streak-day.empty{background:var(--bg3)}.streak-day.today{border:1px solid var(--accent)}.results-screen{text-align:center;padding:2rem 1rem}.results-screen .score{font-size:3rem;font-weight:700;color:var(--accent)}.results-screen .score-label{color:var(--text2);margin-bottom:1.5rem}.results-screen .score-emoji{font-size:2.5rem;margin-bottom:.5rem}.results-screen .score-message{font-size:1rem;font-weight:600;margin-bottom:.75rem}.results-screen .score.excellent{color:var(--green);animation:scorePopIn .5s ease}.results-screen .score.good{color:var(--accent)}.results-screen .score.needs-work{color:var(--yellow)}@keyframes scorePopIn{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tts-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);font-size:.9rem;transition:all var(--transition)}.tts-btn:hover{background:var(--accent-bg);border-color:var(--accent)}.guide-section details summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between}.guide-section details summary:after{content:"\25b8";color:var(--text3);transition:transform var(--transition)}.guide-section details[open] summary:after{transform:rotate(90deg)}.guide-section details summary::-webkit-details-marker{display:none}.guide-section ul{line-height:1.7}.guide-section li{margin-bottom:.35rem}@media (max-width: 480px){.card-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.flashcard{min-height:180px}.flashcard-inner{min-height:180px;padding:1.5rem}.flashcard .word-main{font-size:1.4rem}.conj-table{font-size:.75rem}.conj-table th,.conj-table td{padding:.3rem .4rem}.modal{padding:1rem;max-height:80dvh}.modal-overlay{padding:.5rem}}@media (min-width: 768px){:root{--max-w: 720px}.card-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.stat-cards{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.flashcard{min-height:260px}.flashcard-inner{min-height:260px;padding:2.5rem}.flashcard .word-main{font-size:2rem}}.fade-in{animation:fadeIn .25s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes xpPop{0%{transform:scale(1)}30%{transform:scale(1.3);color:var(--green)}to{transform:scale(1)}}.xp-pop{animation:xpPop .4s ease}.text-center{text-align:center}.text-muted{color:var(--text2)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.m-0{margin:0}.mb-05{margin-bottom:.5rem}.text-left{text-align:left}.text-correct{color:var(--green)}.text-incorrect{color:var(--red)}.text-warning{color:var(--yellow)}.text-dim{color:var(--text3)}.text-xxs{font-size:.7rem}.text-xxxs{font-size:.6rem}.level-tag{font-size:.6rem;padding:.1rem .4rem;background:var(--bg3);color:var(--text3);border-radius:3px}.gap-1{gap:.5rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.w-full{width:100%}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.empty-state{text-align:center;padding:2rem 1rem;color:var(--text3)}.empty-state-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.6}.empty-state-text{font-size:.95rem;line-height:1.5}.nav-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:55vw}.conj-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -.5rem;padding:0 .5rem;mask-image:linear-gradient(to right,black calc(100% - 24px),transparent);-webkit-mask-image:linear-gradient(to right,black calc(100% - 24px),transparent)}.conj-table-scroll .conj-table{min-width:320px}.placement-header{margin-bottom:1.5rem}.pt-progress-bar{width:100%;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden;margin-bottom:.75rem}.pt-progress-bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.placement-meta{display:flex;justify-content:space-between;align-items:center}.placement-level-tag{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;color:#fff;background:var(--accent)}.placement-level-badge{display:inline-flex;align-items:center;justify-content:center;width:100px;height:100px;border-radius:50%;font-size:2.5rem;font-weight:700;color:#fff;margin:1rem auto}.placement-level-name{font-size:1.3rem;font-weight:600;color:var(--text);margin-bottom:.5rem}.placement-breakdown{max-width:400px;margin:0 auto}.placement-breakdown-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.placement-breakdown-label{font-weight:600;font-size:.85rem;min-width:28px}.placement-breakdown-bar{flex:1;height:12px;background:var(--bg3);border-radius:6px;overflow:hidden}.placement-breakdown-fill{height:100%;border-radius:6px;transition:width .3s ease}.placement-breakdown-score{font-size:.8rem;color:var(--text3);min-width:50px;text-align:right}.cloze-passage{line-height:2.2;font-size:1.05rem}.cloze-blank{min-width:90px;width:auto;max-width:200px;border:none;border-bottom:2px solid var(--accent);background:transparent;color:var(--text1);font-size:1rem;text-align:center;padding:.1rem .25rem;outline:none}.cloze-blank:focus-visible{border-bottom-color:var(--text1);outline:2px solid var(--accent);outline-offset:1px}.cloze-blank.correct{border-color:var(--green);color:var(--green)}.cloze-blank.incorrect{border-color:var(--red);color:var(--red)}.cloze-explanation{font-size:.85rem;color:var(--text2);margin-top:.5rem;padding-left:.5rem;border-left:2px solid var(--accent)}.sb-answer-row{min-height:52px;display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem;border:2px dashed var(--border);border-radius:var(--radius);margin-bottom:.75rem;align-items:center}.sb-answer-row:empty:after{content:"Tap words below";color:var(--text3);font-style:italic;font-size:.9rem}.sb-word-bank{display:flex;flex-wrap:wrap;gap:.5rem}.sb-word-tile{padding:.5rem .85rem;border-radius:20px;background:var(--bg2);border:1px solid var(--border);color:var(--text1);font-weight:500;cursor:pointer;transition:transform .1s;user-select:none;font-size:.95rem}.sb-word-tile:active{transform:scale(.94)}.sb-word-tile.distractor-wrong{border-color:var(--red);color:var(--red)}.sb-divider{border:none;border-top:1px solid var(--border);margin:.75rem 0}.dict-audio-controls{display:flex;gap:.75rem;margin-bottom:1rem;justify-content:center}.dict-word{display:inline}.dict-word.correct{color:var(--green)}.dict-word.accent{color:var(--yellow)}.dict-word.typo{color:var(--yellow);text-decoration:underline}.dict-word.wrong{color:var(--red);text-decoration:line-through}.dict-word.missing{color:var(--red);font-style:italic}.mp-contrast{margin-top:.75rem;padding:.75rem;border-left:3px solid var(--accent);background:var(--bg2);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.9rem}.reading-passage{line-height:1.8;font-size:1rem}.conj-table{width:100%;border-collapse:collapse;font-size:.85rem}.conj-table td{padding:.3rem .5rem;border-bottom:1px solid var(--border)}.conj-table td:first-child{color:var(--text2)}.conj-table td.irreg{color:var(--accent);font-weight:600}.conj-table th{padding:.3rem .5rem;border-bottom:2px solid var(--border);color:var(--text2);font-weight:600;text-align:left;font-size:.8rem}.mood-header{font-size:1rem;font-weight:700;margin:1.5rem 0 .5rem;padding-bottom:.25rem;border-bottom:2px solid}.mood-indicative{border-color:var(--blue);color:var(--blue)}.mood-subjunctive{border-color:var(--accent);color:var(--accent)}.mood-imperative{border-color:var(--green);color:var(--green)}.vref-suggestion{padding:.5rem .75rem;cursor:pointer;border-bottom:1px solid var(--border)}.vref-suggestion:hover{background:var(--card-hover)}.pron-letter{font-size:1.3rem;font-weight:700;color:var(--accent);min-width:3rem;display:inline-block}.pron-ipa{color:var(--text2);font-size:.85rem;font-style:italic}.pron-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.pron-row:last-child{border-bottom:none}.tts-inline{background:none;border:1px solid var(--border);color:var(--text2);border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:.75rem;flex-shrink:0}.offline-disabled{opacity:.4;pointer-events:none}.streak-calendar{display:grid;grid-template-columns:repeat(14,1fr);gap:3px}.streak-day{aspect-ratio:1;border-radius:3px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:.55rem;color:var(--text3)}.streak-day.low{background:#4caf5040;color:var(--text2)}.streak-day.med{background:#4caf5080;color:var(--text)}.streak-day.high{background:var(--green);color:#fff}.streak-day.today{outline:2px solid var(--accent)}.mastery-bar{display:flex;height:14px;border-radius:4px;overflow:hidden;background:var(--bg3)}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--text3);padding:.2rem;line-height:1}.btn-icon.bookmarked{color:var(--yellow, #f5a623)}.tv-dialogue-line{display:flex;gap:.5rem;margin-bottom:.5rem;font-size:.9rem}.tv-speaker{font-weight:700;color:var(--accent);min-width:5rem;flex-shrink:0}.track-card{margin-bottom:.75rem;transition:transform .1s}.track-card:active{transform:scale(.98)}.track-progress-wrap{height:6px;border-radius:3px;background:var(--bg3);overflow:hidden}.track-progress-bar{height:100%;border-radius:3px;transition:width .3s}.track-completion-ring{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;background:conic-gradient(var(--clr) calc(var(--pct) * 1%),var(--bg3) 0);position:relative;flex-shrink:0}.track-completion-ring>span{background:var(--surface);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center}.track-module-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-bottom:1px solid var(--border);transition:background .1s}.track-module-item:last-child{border-bottom:none}.track-module-item:active{background:var(--bg3)}.track-module-item.completed{opacity:.7}.track-module-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.module-type-badge{font-size:.65rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.pt-self-assess{display:flex;flex-direction:column;gap:.5rem}.pt-level-choice{text-align:left;cursor:pointer;transition:transform .1s;border:none}.pt-level-choice:active{transform:scale(.98)}.pt-controls-row{display:flex;gap:.5rem;justify-content:center;margin-top:.5rem;flex-wrap:wrap}.btn-xs{font-size:.7rem;padding:.2rem .5rem}.btn-xs.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pt-end-btn{color:var(--incorrect);border-color:var(--incorrect)}.pt-end-btn:disabled{opacity:.4;cursor:not-allowed}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem}.badge-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.5rem .25rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg2);transition:all var(--transition)}.badge-item.locked{opacity:.35;filter:grayscale(1)}.badge-item.unlocked{border-color:var(--accent);background:var(--accent-bg)}.badge-icon{font-size:1.5rem;margin-bottom:.15rem}.badge-name{font-size:.65rem;font-weight:600;line-height:1.2}.badge-date{font-size:.55rem;color:var(--text3);margin-top:.1rem}#toast-container{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:1100;display:flex;flex-direction:column;gap:.5rem;pointer-events:none;max-width:var(--max-w);width:90%}.toast{background:var(--card);border:1px solid var(--accent);border-radius:var(--radius);padding:.75rem 1rem;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.5rem;animation:toastIn .3s ease,toastOut .3s ease 4.5s forwards;pointer-events:auto}.toast .toast-icon{font-size:1.3rem}.toast .toast-text{font-size:.85rem;font-weight:600}@keyframes toastIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:none}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.due-breakdown{list-style:none;padding:0;margin:0 0 .5rem}.due-breakdown li{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.9rem}.due-breakdown li .due-icon{width:1.5rem;text-align:center}.due-breakdown li .due-count{font-weight:700;min-width:1.5rem;text-align:right}.due-breakdown .due-total{border-top:1px solid var(--border);margin-top:.35rem;padding-top:.35rem;font-weight:700}.weak-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.85rem}.weak-item:last-child{border-bottom:none}.weak-item .weak-label{flex:1;font-weight:600}.weak-item .weak-rate{color:var(--red);font-weight:600;min-width:3rem;text-align:right}#share-overlay{display:none}#share-overlay.open{display:flex}#reading-type-filters .btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.sat-badge{font-size:.55rem;padding:.05rem .3rem;background:var(--yellow-bg);color:var(--yellow);border-radius:3px;font-weight:700}.question-type-tag{font-size:.6rem;padding:.1rem .3rem;background:var(--bg3);color:var(--text3);border-radius:3px;margin-left:.25rem}.offline-badge{font-size:.7rem;font-weight:600;padding:.1rem .4rem;border-radius:4px;background:var(--yellow-bg);color:var(--yellow)}.loading-overlay{position:fixed;inset:0;z-index:1000;background:#0006;display:flex;align-items:center;justify-content:center}.loading-overlay.hidden{display:none}.quiz-option.correct:before{content:"\2713";font-weight:700}.quiz-option.incorrect:before{content:"\2717";font-weight:700}.quiz-feedback.correct:before{content:"\2713";font-weight:700}.quiz-feedback.incorrect:before{content:"\2717";font-weight:700}.cloze-blank.correct{text-decoration:underline 2px var(--green)}.cloze-blank.incorrect{text-decoration:underline wavy 2px var(--red)}.dict-word.correct:before{content:"\2713";font-size:.7em;margin-right:.1em}.dict-word.wrong:before{content:"\2717";font-size:.7em;margin-right:.1em}.mastery-0:before{content:"\25cb"}.mastery-1:before{content:"\2606"}.mastery-2:before{content:"\2606\2606";letter-spacing:-.15em}.mastery-3:before{content:"\2605\2605\2605";letter-spacing:-.15em}.mastery-4:before{content:"\2605\2605\2605\2605";letter-spacing:-.15em}.error-state{text-align:center;padding:2rem 1rem;color:var(--text2)}.error-state-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.7}.error-state-text{font-size:.95rem;line-height:1.5;margin-bottom:1rem}:root{--text3: #c0c8dc}[data-theme=light]{--text3: #5c5047}.loading-overlay .loading-content{display:flex;flex-direction:column;align-items:center;gap:.75rem}.loading-overlay .loading-text{font-size:.85rem;color:var(--text2);font-weight:500}.loading-progress{width:200px;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}.loading-progress .loading-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease;width:0%}.offline-banner{display:none;align-items:center;justify-content:center;gap:.5rem;padding:.4rem 1rem;background:var(--yellow-bg);border-bottom:1px solid rgba(255,193,7,.3);font-size:.8rem;font-weight:600;color:var(--yellow-text)}.offline-banner.visible{display:flex}.offline-banner:before{content:"\26a0"}@supports (padding-bottom: env(safe-area-inset-bottom)){.app-container{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.tab-bar{padding-bottom:env(safe-area-inset-bottom)}}@media (max-width: 480px){.app-container{padding-bottom:96px}}@media print{.navbar,.tab-bar,#toast-container,.loading-overlay,.modal-overlay,.offline-banner,.offline-badge{display:none!important}.app-container{padding-bottom:0;max-width:100%}.screen{padding:0}.card{break-inside:avoid;border:1px solid #ccc}.flashcard{break-inside:avoid;min-height:auto;border:1px solid #ccc}.flashcard .front,.flashcard .back{position:static;transform:none;backface-visibility:visible;-webkit-backface-visibility:visible}.flashcard .back{padding:1rem;border-top:1px dashed #ccc}.flashcard-inner{transform:none!important}.conj-table th,.conj-table td{border:1px solid #ccc}.example-box{border-left:3px solid #666}.btn{border:1px solid #ccc}.rating-bar,.accent-bar{display:none}body{background:#fff;color:#000}.lesson-content{font-size:11pt}a{color:inherit;text-decoration:underline}}.session-summary-overlay{position:fixed;inset:0;z-index:1000;background:#0009;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease}.session-summary{background:var(--card);border-radius:var(--radius);padding:1.5rem;max-width:360px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}.session-summary .summary-emoji{font-size:2.5rem;margin-bottom:.5rem}.session-summary .summary-title{font-size:1.25rem;font-weight:700;margin-bottom:.75rem;color:var(--text)}.session-summary .summary-stats{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.session-summary .summary-stat{background:var(--bg2);border-radius:var(--radius-sm);padding:.5rem}.session-summary .summary-stat-num{font-size:1.25rem;font-weight:700;color:var(--accent)}.session-summary .summary-stat-label{font-size:.75rem;color:var(--text3)}.kbd-shortcuts-list{list-style:none;padding:0;margin:0}.kbd-shortcuts-list li{display:flex;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.kbd-shortcuts-list li:last-child{border-bottom:none}.kbd-key{display:inline-block;background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:.15rem .5rem;font-family:var(--mono);font-size:.8rem;min-width:2rem;text-align:center;margin-right:.75rem;color:var(--text);flex-shrink:0}.review-dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.review-dash-card{background:var(--bg2);border-radius:var(--radius-sm);padding:.75rem;text-align:center}.review-dash-card.overdue{border:1px solid var(--red)}.review-dash-count{font-size:1.5rem;font-weight:700}.review-dash-label{font-size:.75rem;color:var(--text3)}.review-dash-overdue{font-size:.7rem;color:var(--red);margin-top:.25rem}.skill-radar-container{display:flex;justify-content:center;padding:1rem 0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.skip-link{position:absolute;top:-100%;left:0;z-index:1100;padding:.5rem 1rem;background:var(--accent);color:#fff;font-weight:700;text-decoration:none;border-radius:0 0 var(--radius-sm) 0}.skip-link:focus{top:0}.shortcuts-table{width:100%;border-collapse:collapse}.shortcuts-table td{padding:.4rem .5rem;border-bottom:1px solid var(--bg3)}.shortcuts-table td:first-child{font-family:var(--mono);font-size:.8rem;color:var(--accent);white-space:nowrap;width:8rem}.shortcuts-table td:last-child{color:var(--text2);font-size:.85rem}.writing-area{width:100%;min-height:150px;padding:.75rem;border:1px solid var(--bg3);border-radius:var(--radius-sm);background:var(--bg2);color:var(--text);font-family:var(--font);font-size:.9rem;resize:vertical}.writing-area:focus-visible{outline:2px solid var(--accent);border-color:var(--accent)}.self-check-item{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.85rem;color:var(--text2)}.self-check-item input[type=checkbox]{accent-color:var(--accent)}.prep-card{display:flex;align-items:baseline;gap:.5rem;padding:.6rem .75rem}.prep-card .prep-verb{font-weight:700;color:var(--accent)}.prep-card .prep-prep{font-weight:700;color:var(--yellow)}.radar-label{font-size:.7rem;fill:var(--text2)}.review-type-card{display:flex;align-items:center;gap:.75rem;padding:.75rem}.review-type-icon{font-size:1.5rem}.review-type-count{font-size:1.2rem;font-weight:700;color:var(--accent)}.review-type-label{font-size:.85rem;color:var(--text2)}.review-overdue{color:var(--red);font-weight:700}.session-summary{text-align:center}.session-summary .summary-stat{display:inline-block;margin:.5rem;text-align:center}.session-summary .summary-num{font-size:1.5rem;font-weight:700;color:var(--accent)}.session-summary .summary-label{font-size:.75rem;color:var(--text3)}.session-summary .summary-accuracy{font-size:2rem;font-weight:700;margin:.5rem 0}.session-summary .accuracy-great{color:var(--green)}.session-summary .accuracy-ok{color:var(--yellow)}.session-summary .accuracy-poor{color:var(--red)}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:1100;display:flex;flex-direction:column;align-items:center;gap:.5rem;pointer-events:none}.toast{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:.6rem 1.25rem;box-shadow:var(--shadow-lg, 0 4px 16px rgba(0,0,0,.25));font-size:.9rem;opacity:0;transform:translateY(12px);transition:opacity .25s ease,transform .25s ease;pointer-events:auto;max-width:90vw;text-align:center}.toast.visible{opacity:1;transform:translateY(0)}.toast.toast-success{border-left:3px solid var(--green)}.toast.toast-error{border-left:3px solid var(--red)}.toast.toast-info{border-left:3px solid var(--accent)}.toast-undo-btn{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:.15rem .6rem;margin-left:.6rem;font-size:.8rem;font-weight:700;cursor:pointer;vertical-align:middle}.toast-undo-btn:hover{opacity:.85}.learning-plan-modal{max-width:420px;text-align:center;padding:1.5rem}.learning-plan-title{margin-bottom:.25rem;font-size:1.2rem}.learning-plan-subtitle{margin-bottom:1rem}.learning-plan-checklist{text-align:left;max-width:360px;margin:0 auto}.lp-item{display:flex;align-items:center;gap:.65rem;padding:.55rem .75rem;margin-bottom:.35rem;border-radius:.5rem;background:var(--bg2);transition:background .15s ease}.lp-item:hover{background:var(--bg3)}.lp-icon{font-size:1.25rem;flex-shrink:0;width:1.75rem;text-align:center}.lp-label{flex:1;font-size:.88rem;font-weight:500;color:var(--text1)}.lp-check{color:var(--green);font-weight:700;font-size:1rem;flex-shrink:0}.analytics-bar-row{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;border-bottom:1px solid var(--border)}.analytics-bar-row:last-child{border-bottom:none}.analytics-bar-label{min-width:5.5rem;font-size:.8rem;color:var(--text2);flex-shrink:0}.analytics-bar-track{flex:1;height:10px;background:var(--bg3);border-radius:5px;overflow:hidden}.analytics-bar-fill{height:100%;background:var(--accent);border-radius:5px;transition:width .3s ease}.analytics-bar-fill.accent2{background:var(--blue, #4a90d9)}.analytics-bar-value{min-width:3rem;text-align:right;font-size:.8rem;font-weight:600;color:var(--text1);flex-shrink:0}.analytics-chart{display:flex;align-items:flex-end;gap:3px;height:100px;position:relative;padding-bottom:1.2rem}.analytics-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative}.analytics-chart-bar{width:100%;min-height:2px;background:var(--accent);border-radius:3px 3px 0 0;transition:height .3s ease}.analytics-chart-col.today .analytics-chart-bar{background:var(--green)}.analytics-chart-label{position:absolute;bottom:-1.1rem;font-size:.55rem;color:var(--text3);text-align:center}.analytics-goal-line{position:absolute;left:0;right:0;height:1px;border-top:1px dashed var(--yellow, #e6a817);z-index:1;pointer-events:none}
