:root{--bg-deep: #0c0a09;--bg-base: #131110;--bg-raised: #1c1917;--bg-surface: #252220;--accent: #d4a24c;--accent-dim: rgba(212, 162, 76, .1);--accent-text: #e8b960;--success: #6b9b5a;--error: #b85450;--text-1: #ede8e3;--text-2: #9e968d;--text-3: #5e564e;--border: rgba(255, 255, 255, .05);--border-lit: rgba(212, 162, 76, .15);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-xs: 6px;--radius-sm: 10px;--radius-md: 14px;--radius-full: 100px;--ease: cubic-bezier(.16, 1, .3, 1);--dur: .25s;--dur-slow: .4s;--nav-h: 56px;--col-w: 480px;font-size:16px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}body{font-family:Plus Jakarta Sans,system-ui,-apple-system,sans-serif;background:var(--bg-deep);color:var(--text-1);line-height:1.55;min-height:100dvh}#app{min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3{font-family:"DM Serif Display",Georgia,serif;font-weight:400;letter-spacing:-.01em}h1{font-size:1.75rem;line-height:1.15}h2{font-size:1.35rem;line-height:1.2}h3{font-size:1.05rem;line-height:1.3}.nav{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#0c0a09eb;backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border-top:1px solid var(--border);padding:var(--space-1) 0;padding-bottom:max(var(--space-1),env(safe-area-inset-bottom))}.nav-brand{display:none}.nav-tabs{display:flex;justify-content:space-around;max-width:var(--col-w);margin:0 auto}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:1px;padding:var(--space-2) var(--space-4);background:none;border:none;cursor:pointer;color:var(--text-3);font-family:inherit;font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:color var(--dur) var(--ease)}.nav-tab svg{width:21px;height:21px;stroke-width:1.6}.nav-tab.active{color:var(--accent-text)}.main{flex:1;width:100%;max-width:var(--col-w);margin:0 auto;padding:var(--space-6) var(--space-5);padding-bottom:calc(var(--nav-h) + var(--space-10))}.view{display:none}.view.active{display:block;animation:fadeIn var(--dur-slow) var(--ease)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dashboard-hero{padding:var(--space-8) 0 var(--space-4)}.hero-greeting h1{font-size:2rem;color:var(--text-1)}.hero-subtitle{color:var(--text-2);font-size:.88rem;margin-top:var(--space-1)}.sync-pill{display:inline-flex;align-items:center;margin-top:var(--space-4);padding:6px 10px;border-radius:var(--radius-full);border:1px solid var(--border);color:var(--text-2);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}.sync-pill.saving{color:var(--accent-text);border-color:var(--border-lit)}.sync-pill.synced{color:var(--success)}.sync-pill.offline,.sync-pill.offline-with-pending-changes{color:#c9935a;border-color:#c9935a4d}.sync-pill.offline-failed,.sync-pill.sync-failed,.sync-pill.reauth-required{color:var(--error)}.foundation-home-card{margin-top:var(--space-5);padding-top:var(--space-3);border-top:1px solid var(--border)}.hero-stats{display:flex;gap:var(--space-8);margin-top:var(--space-6);padding:var(--space-4) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.stat-card{background:none;border:none;display:flex;flex-direction:column;gap:2px}.stat-value{font-family:"DM Serif Display",Georgia,serif;font-size:1.5rem;color:var(--text-1);line-height:1}.stat-label{font-size:.65rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.quick-actions{margin-top:var(--space-5);display:flex;flex-direction:column}.action-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) 0;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;color:var(--text-1);font-family:inherit;text-align:left;transition:opacity var(--dur) var(--ease)}.action-card:first-child{border-top:none}.action-card:last-child{border-bottom:none}.action-card:hover{opacity:.8}.action-card.action-primary .action-icon{color:var(--accent-text)}.action-icon{font-size:1.25rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.action-text{flex:1;min-width:0}.action-text strong{display:block;font-size:.9rem;font-weight:600}.action-text span{font-size:.78rem;color:var(--text-2)}.action-card>svg{color:var(--text-3);flex-shrink:0;width:18px;height:18px}.view-header{margin-bottom:var(--space-5)}.view-header h2{margin-bottom:2px}.view-subtitle{color:var(--text-3);font-size:.8rem}.chapters-list{display:flex;flex-direction:column}.part-separator{padding:var(--space-6) 0 var(--space-2)}.part-separator-label{font-size:.7rem;color:var(--accent-text);text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-family:inherit}.chapter-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity var(--dur) var(--ease)}.chapter-card:hover{opacity:.75}.chapter-card.completed .chapter-num{color:var(--success);border-color:var(--success)}.foundation-card .chapter-num{border-color:var(--border-lit);color:var(--accent-text)}.foundation-inline-btn{margin-left:auto;flex-shrink:0}.foundation-list{margin-bottom:var(--space-6)}.chapter-status{color:var(--text-2);font-size:.78rem}.chapter-num{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--text-3);border-radius:var(--radius-xs);font-family:"DM Serif Display",Georgia,serif;font-size:.85rem;color:var(--text-2);flex-shrink:0}.chapter-info{flex:1;min-width:0}.chapter-title{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chapter-meta{display:flex;align-items:center;gap:var(--space-3);font-size:.7rem;color:var(--text-3);margin-top:2px}.cefr-badge{display:inline-block;font-size:.6rem;font-weight:800;letter-spacing:.05em;color:var(--accent-text)}.back-btn{display:inline-flex;align-items:center;gap:var(--space-2);background:none;border:none;color:var(--text-3);font-family:inherit;font-size:.82rem;cursor:pointer;padding:var(--space-1) 0;margin-bottom:var(--space-4);transition:color var(--dur) var(--ease)}.back-btn:hover{color:var(--accent-text)}.chapter-header{margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--border)}.chapter-header h2{margin-top:var(--space-2)}.section-title{margin:var(--space-8) 0 var(--space-3);font-size:.7rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-family:inherit}.objectives-list,.grammar-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.objectives-list li{font-size:.88rem;line-height:1.6;color:var(--text-2);padding-left:var(--space-4);position:relative}.objectives-list li:before{content:"—";position:absolute;left:0;color:var(--accent-text)}.grammar-list li{padding:var(--space-4) 0;border-bottom:1px solid var(--border);font-size:.88rem;line-height:1.6}.grammar-list li strong{display:block;color:var(--text-1);font-size:.9rem;margin-bottom:var(--space-1)}.examples{margin-top:var(--space-2);font-size:.8rem;color:var(--text-3);font-style:italic}.vocab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.vocab-chip{padding:var(--space-3);background:var(--bg-base);text-align:center}.vocab-chip .es{display:block;font-weight:700;font-size:.85rem;color:var(--text-1)}.vocab-chip .en{display:block;font-size:.7rem;color:var(--text-3);margin-top:1px}.chapter-actions{display:flex;gap:var(--space-3);margin-top:var(--space-8)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);font-family:inherit;font-weight:700;font-size:.82rem;cursor:pointer;transition:all var(--dur) var(--ease);border:none;white-space:nowrap}.btn-primary{background:var(--accent);color:var(--bg-deep)}.btn-primary:hover{filter:brightness(1.1)}.btn-secondary{background:var(--bg-raised);color:var(--text-1);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-surface)}.quiz-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-8)}.quiz-progress{flex:1;display:flex;align-items:center;gap:var(--space-3)}.quiz-progress-bar{flex:1;height:3px;background:var(--bg-surface);border-radius:3px;overflow:hidden}.quiz-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width var(--dur-slow) var(--ease)}.quiz-progress-text{font-size:.7rem;color:var(--text-3);font-weight:700;font-variant-numeric:tabular-nums}.quiz-question{animation:fadeIn var(--dur) var(--ease)}.quiz-question-text{font-family:"DM Serif Display",Georgia,serif;font-size:1.3rem;line-height:1.4;margin-bottom:var(--space-6)}.quiz-options{display:flex;flex-direction:column;gap:var(--space-2)}.quiz-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-raised);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.9rem;color:var(--text-1);transition:border-color var(--dur) var(--ease);text-align:left}.quiz-option:hover{border-color:var(--text-3)}.quiz-option.selected{border-color:var(--accent);background:var(--accent-dim)}.quiz-option-letter{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border);border-radius:var(--radius-xs);font-weight:800;font-size:.7rem;color:var(--text-3);flex-shrink:0}.quiz-option.selected .quiz-option-letter{background:var(--accent);color:var(--bg-deep);border-color:var(--accent)}.chat-container{display:flex;flex-direction:column;height:calc(100dvh - var(--nav-h) - var(--space-12))}.chat-header{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--border);margin-bottom:var(--space-4)}.chat-avatar{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.chat-header h3{font-size:1rem}.chat-status{font-size:.72rem;color:var(--text-3)}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-2) 0;scrollbar-width:thin;scrollbar-color:var(--bg-raised) transparent}.chat-bubble{max-width:82%;padding:var(--space-3) var(--space-4);font-size:.88rem;line-height:1.55;animation:fadeIn var(--dur) var(--ease)}.chat-bubble.assistant{align-self:flex-start;background:var(--bg-raised);border-radius:var(--radius-sm) var(--radius-sm) var(--radius-sm) 2px;color:var(--text-1)}.chat-bubble.user{align-self:flex-end;background:var(--accent);color:var(--bg-deep);border-radius:var(--radius-sm) var(--radius-sm) 2px var(--radius-sm);font-weight:500}.chat-bubble p{margin:0}.chat-input-container{display:flex;gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--border);margin-top:var(--space-3)}.chat-input{flex:1;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-full);padding:var(--space-3) var(--space-4);color:var(--text-1);font-family:inherit;font-size:.88rem;outline:none;transition:border-color var(--dur) var(--ease)}.chat-input::placeholder{color:var(--text-3)}.chat-input:focus{border-color:var(--accent)}.btn-send{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--accent);border:none;border-radius:50%;cursor:pointer;color:var(--bg-deep);flex-shrink:0;transition:filter var(--dur) var(--ease)}.btn-send:hover{filter:brightness(1.1)}.btn-send:disabled{opacity:.35;cursor:not-allowed}.vocab-summary{text-align:center;padding:var(--space-8) 0;color:var(--text-2)}.flashcard-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-6)}.flashcard{width:100%;max-width:320px;height:190px;perspective:700px;cursor:pointer;position:relative}.flashcard-front,.flashcard-back{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-md);backface-visibility:hidden;transition:transform .45s var(--ease);padding:var(--space-6)}.flashcard-front{background:var(--bg-raised);border:1.5px solid var(--border-lit)}.flashcard-back{background:var(--bg-surface);border:1.5px solid var(--accent);transform:rotateY(180deg)}.flashcard.flipped .flashcard-front{transform:rotateY(180deg)}.flashcard.flipped .flashcard-back{transform:rotateY(0)}.flashcard-word{font-family:"DM Serif Display",Georgia,serif;font-size:1.8rem;color:var(--text-1)}.flashcard-translation{font-family:"DM Serif Display",Georgia,serif;font-size:1.4rem;color:var(--accent-text)}.flashcard-type{font-size:.7rem;color:var(--text-3);margin-top:var(--space-2);text-transform:uppercase;letter-spacing:.08em}.flashcard-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2);width:100%;max-width:320px}.fc-btn{padding:var(--space-3);border-radius:var(--radius-xs);font-family:inherit;font-size:.78rem;font-weight:700;cursor:pointer;border:1px solid var(--border);background:none;color:var(--text-2);transition:all var(--dur) var(--ease)}.fc-btn:hover{background:var(--bg-raised)}.fc-again{color:var(--error);border-color:#b854504d}.fc-again:hover{background:#b8545014}.fc-hard{color:#c9935a;border-color:#c9935a4d}.fc-hard:hover{background:#c9935a14}.fc-good{color:var(--success);border-color:#6b9b5a4d}.fc-good:hover{background:#6b9b5a14}.fc-easy{color:#8b80b8;border-color:#8b80b84d}.fc-easy:hover{background:#8b80b814}.placement-welcome{text-align:center;padding:var(--space-12) 0}.placement-welcome h2{font-size:1.6rem;margin-bottom:var(--space-3)}.placement-welcome p{color:var(--text-2);font-size:.88rem;max-width:340px;margin:0 auto;line-height:1.6}.result-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-10) 0}.result-value{font-family:"DM Serif Display",Georgia,serif;font-size:3.5rem;color:var(--accent-text);line-height:1}.result-label{font-size:.75rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.practice-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-6)}.practice-step+.practice-step{margin-top:var(--space-6)}.token-row{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}.token-btn,.token-chip{border-radius:var(--radius-full);padding:8px 12px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-1);font:inherit}.token-btn{cursor:pointer}.token-chip{background:var(--accent-dim);border-color:var(--border-lit)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-12) 0;color:var(--text-3)}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-surface);border-radius:4px}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(min-width:640px){:root{--col-w: 560px}.nav{bottom:auto;top:0;border-top:none;border-bottom:1px solid var(--border);padding:0 var(--space-6);display:flex;align-items:center;justify-content:space-between;max-width:100%}.nav-brand{display:flex;align-items:center;gap:var(--space-2)}.nav-logo{font-size:1.2rem}.nav-title{font-family:"DM Serif Display",Georgia,serif;font-size:1rem;color:var(--text-1)}.nav-tabs{justify-content:flex-end}.nav-tab{flex-direction:row;gap:var(--space-2);padding:var(--space-4) var(--space-3);font-size:.7rem}.main{padding-top:calc(var(--nav-h) + var(--space-8));padding-bottom:var(--space-8)}}@media(min-width:768px){:root{--col-w: 620px}.vocab-grid{grid-template-columns:repeat(auto-fill,minmax(145px,1fr))}}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--bg-deep);display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.auth-screen.hidden{display:none}.auth-card{width:100%;max-width:340px}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-field{margin-bottom:var(--space-4)}.auth-field label{display:block;font-size:.72rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:var(--space-1)}.auth-field input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-raised);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-1);font-family:inherit;font-size:.9rem;outline:none;transition:border-color var(--dur) var(--ease)}.auth-field input::placeholder{color:var(--text-3)}.auth-field input:focus{border-color:var(--accent)}.auth-toggle{text-align:center;margin-top:var(--space-4);font-size:.82rem;color:var(--text-3)}.auth-toggle a{color:var(--accent-text);text-decoration:none;font-weight:600}.auth-toggle a:hover{text-decoration:underline}.auth-error{text-align:center;color:var(--error);font-size:.82rem;margin-top:var(--space-4);padding:var(--space-3);background:#b8545014;border-radius:var(--radius-sm)}.auth-user-bar{display:flex;align-items:center;gap:var(--space-2);font-size:.72rem;color:var(--text-3);margin-top:var(--space-1)}.auth-user-bar button{background:none;border:none;color:var(--accent-text);font-family:inherit;font-size:.72rem;font-weight:600;cursor:pointer}.auth-user-bar button:hover{text-decoration:underline}
