@import"https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Outfit:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #faf9f7;--bg-secondary: #f4f2ee;--surface: #ffffff;--surface-2: #f8f7f4;--surface-3: #ede9e3;--border: rgba(0,0,0,.08);--border-hover: rgba(0,0,0,.16);--border-focus: rgba(180,130,80,.5);--text: #1c1917;--text-muted: #78716c;--text-faint: #a8a29e;--accent: #b07d4a;--accent-light: rgba(176,125,74,.1);--accent-hover: #9a6a38;--success: #4a7c59;--success-bg: rgba(74,124,89,.08);--success-border: rgba(74,124,89,.2);--error: #9b3a3a;--error-bg: rgba(155,58,58,.08);--error-border: rgba(155,58,58,.2);--vocab-bg: rgba(176,125,74,.12);--vocab-text: #7a5230;--radius: 12px;--radius-sm: 8px;--radius-xs: 5px;--shadow: 0 1px 3px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.04);--shadow-md: 0 8px 32px rgba(0,0,0,.12);--transition: .18s ease}[data-theme=dark]{--bg: #0e0d0b;--bg-secondary: #141310;--surface: #1a1916;--surface-2: #211f1b;--surface-3: #2a2824;--border: rgba(255,255,255,.07);--border-hover: rgba(255,255,255,.14);--border-focus: rgba(200,155,100,.5);--text: #f0ece6;--text-muted: #7c7570;--text-faint: #4a4540;--accent: #c8975a;--accent-light: rgba(200,151,90,.12);--accent-hover: #d4a86a;--success: #6aad80;--success-bg: rgba(106,173,128,.08);--success-border: rgba(106,173,128,.2);--error: #d47070;--error-bg: rgba(212,112,112,.08);--error-border: rgba(212,112,112,.2);--vocab-bg: rgba(200,151,90,.15);--vocab-text: #d4a86a;--shadow: 0 1px 3px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.3);--shadow-md: 0 8px 32px rgba(0,0,0,.5)}body{font-family:Outfit,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;font-size:15px;-webkit-font-smoothing:antialiased;transition:background var(--transition),color var(--transition)}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--bg);border-bottom:1px solid var(--border);padding:0 2rem;position:sticky;top:0;z-index:100;transition:background var(--transition),border-color var(--transition)}[data-theme=dark] .header{background:rgba(14,13,11,.9);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:58px}.logo{display:flex;align-items:baseline;gap:2px;cursor:default;-webkit-user-select:none;user-select:none}.logo-word{font-family:Lora,Georgia,serif;font-size:1.25rem;font-weight:600;letter-spacing:-.02em;color:var(--text)}.logo--clickable{cursor:pointer;transition:opacity var(--transition)}.logo--clickable:hover{opacity:.75}.logo-dot{width:5px;height:5px;background:var(--accent);border-radius:50%;margin-bottom:3px;margin-left:1px;flex-shrink:0;display:inline-block}.header-right{display:flex;align-items:center;gap:.75rem}.user-name{font-size:.875rem;font-weight:500;color:var(--text-muted);letter-spacing:.01em;white-space:nowrap}.btn-logout{font-family:Outfit,sans-serif;font-size:.875rem;font-weight:500;padding:.45rem 1.1rem;min-width:88px;border-radius:8px;border:1.5px solid var(--border-hover);background:transparent;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:border-color var(--transition),color var(--transition),background var(--transition)}.btn-logout:hover{border-color:var(--error);color:var(--error);background:var(--error-bg)}nav{display:flex;gap:.15rem}.nav-btn{background:none;border:none;color:var(--text-muted);padding:.4rem .9rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;font-weight:500;font-family:inherit;transition:color var(--transition),background var(--transition);letter-spacing:-.01em}.nav-btn:hover{color:var(--text);background:var(--surface-3)}.nav-btn.active{color:var(--text);background:var(--surface-2)}.theme-toggle{width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;display:grid;place-items:center;font-size:.875rem;transition:all var(--transition);margin-left:.25rem;flex-shrink:0}.theme-toggle:hover{border-color:var(--border-hover);color:var(--text);background:var(--surface-2)}.main{max-width:1200px;margin:0 auto;padding:2.5rem 2rem;width:100%;flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);transition:background var(--transition),border-color var(--transition)}.builder-wrap{display:flex;flex-direction:column;gap:1.25rem;width:100%}.builder h2{font-family:Lora,serif;font-size:1.25rem;font-weight:600;margin-bottom:.3rem;letter-spacing:-.02em}.subtitle{color:var(--text-muted);margin-bottom:1.75rem;font-size:.875rem}.field-label{display:block;font-weight:500;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.5rem;color:var(--text-muted)}.textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.9rem;font-family:inherit;resize:vertical;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);margin-bottom:1.25rem;background:var(--surface-2);color:var(--text);line-height:1.65}.textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-light)}.textarea:disabled{opacity:.45;cursor:not-allowed}.textarea::placeholder{color:var(--text-faint)}.select{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.65rem 2.2rem .65rem .9rem;font-size:.875rem;font-family:inherit;background:var(--surface-2);color:var(--text);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%2378716c' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .8rem center;transition:border-color var(--transition)}.select:focus{outline:none;border-color:var(--border-focus)}.row{display:flex;gap:.875rem}.gap{margin-bottom:1.5rem}.field{flex:1}.btn-primary{display:block;width:100%;padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;letter-spacing:-.01em;transition:background var(--transition),transform .1s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-primary:disabled{opacity:.35;cursor:not-allowed}.error-box{background:var(--error-bg);color:var(--error);border:1px solid var(--error-border);border-radius:var(--radius-sm);padding:.7rem 1rem;margin-bottom:1rem;font-size:.84rem}.hint{color:var(--text-muted);font-size:.8rem;margin-top:.75rem;text-align:center}.hint.success{color:var(--success)}.filter-row{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.filter-group{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.filter-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-faint);min-width:68px}.chips{display:flex;flex-wrap:wrap;gap:.28rem}.chip{background:none;border:1px solid var(--border);border-radius:99px;padding:.2rem .72rem;font-size:.77rem;font-family:inherit;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.chip:hover{border-color:var(--border-hover);color:var(--text)}.chip.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.lesson-list{display:flex;flex-direction:column;gap:.35rem}.lesson-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.85rem 1.1rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:border-color var(--transition),background var(--transition)}.lesson-item:hover{border-color:var(--border-hover);background:var(--surface-3)}.lesson-item-body{display:flex;flex-direction:column;gap:.12rem}.lesson-title{font-size:.9rem;font-weight:500;letter-spacing:-.01em}.lesson-item-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.diff-badge{font-size:.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.15rem .55rem;border-radius:99px}.diff-beginner{background:rgba(74,124,89,.12);color:var(--success)}.diff-intermediate{background:rgba(176,125,74,.12);color:var(--accent)}.diff-advanced{background:rgba(120,80,160,.1);color:#9b72cf}[data-theme=dark] .diff-advanced{color:#c4a3ef}.category-badge{font-size:.72rem;color:var(--text-muted);background:var(--surface-3);border:1px solid var(--border);border-radius:99px;padding:.15rem .6rem;white-space:nowrap}.meta{color:var(--text-muted);font-size:.77rem;display:block;margin-top:.1rem}.count{color:var(--text-faint);font-weight:400;font-size:.85em}.btn-delete{background:none;border:none;cursor:pointer;font-size:.75rem;opacity:0;padding:.25rem .35rem;border-radius:var(--radius-xs);transition:opacity var(--transition),background var(--transition),color var(--transition);color:var(--text-muted);font-family:inherit}.lesson-item:hover .btn-delete{opacity:1}.btn-delete:hover{background:var(--error-bg);color:var(--error)}.loading-state{padding:3rem;text-align:center;color:var(--text-muted);font-size:.875rem}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 1rem}.empty-state{text-align:center;padding:3.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}.empty-icon{font-size:2rem;line-height:1;opacity:.5}.empty-state p{color:var(--text-muted);font-size:.875rem}.lesson-display{display:flex;flex-direction:column;gap:1.5rem;width:100%}.lesson-header{display:flex;align-items:center;gap:1rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.btn-back{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);padding:.4rem .9rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.82rem;font-family:inherit;font-weight:500;white-space:nowrap;transition:all var(--transition);flex-shrink:0}.btn-back:hover{border-color:var(--border-hover);color:var(--text);background:var(--surface-2)}.lesson-header-info{flex:1}.lesson-header-info h2{font-family:Lora,serif;font-size:1.35rem;font-weight:600;letter-spacing:-.025em;line-height:1.3}.lesson-body{display:grid;grid-template-columns:1fr 300px;gap:1.5rem;align-items:start;width:100%}.lesson-main{display:flex;flex-direction:column;gap:1.25rem}.vocab-sidebar{position:sticky;top:78px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);max-height:calc(100vh - 100px);overflow-y:auto;transition:background var(--transition),border-color var(--transition)}.vocab-sidebar::-webkit-scrollbar{width:4px}.vocab-sidebar::-webkit-scrollbar-track{background:transparent}.vocab-sidebar::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:2px}.sidebar-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.sidebar-title{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.sidebar-count{margin-left:auto;font-size:.7rem;color:var(--text-faint);font-family:JetBrains Mono,monospace}.vocab-list{display:flex;flex-direction:column;gap:0}.vocab-item{padding:.6rem 0;border-bottom:1px solid var(--border);transition:background var(--transition)}.vocab-item:last-child{border-bottom:none}.vocab-word-label{font-weight:600;color:var(--text);font-size:.875rem;letter-spacing:-.01em;display:block}.vocab-native{color:var(--accent);font-size:.8rem;font-weight:500;display:block;margin-top:.1rem}.vocab-def{color:var(--text-muted);font-size:.72rem;font-style:italic;margin-top:.15rem;display:block;line-height:1.4}.section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1.75rem;box-shadow:var(--shadow);transition:background var(--transition),border-color var(--transition)}.section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.1rem}.section-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.story-hint{font-size:.77rem;color:var(--text-faint);margin-bottom:1.1rem;font-style:italic}.story-box{font-family:Lora,Georgia,serif;font-size:1rem;line-height:2;color:var(--text);font-weight:400}.sentence-group{display:inline}.word{cursor:pointer;border-radius:3px;padding:0 1px;transition:background var(--transition)}.word:hover{background:var(--surface-3)}.vocab-word{background:var(--vocab-bg);color:var(--vocab-text);font-weight:600;padding:1px 5px;border-radius:4px;cursor:pointer;font-style:normal;transition:all .12s}.vocab-word:hover{filter:brightness(.92)}.vocab-word.sample{font-size:1em}.translate-btn{background:none;border:none;cursor:pointer;font-size:.65rem;opacity:0;margin-left:2px;padding:1px 5px;border-radius:3px;transition:opacity var(--transition),background var(--transition);color:var(--text-faint);font-family:JetBrains Mono,monospace;letter-spacing:.02em}.sentence-group:hover .translate-btn{opacity:1}.translate-btn:hover{background:var(--surface-3);color:var(--text-muted);opacity:1}.tooltip{position:fixed;z-index:999;background:var(--surface);border:1px solid var(--border-hover);color:var(--text);border-radius:var(--radius-sm);padding:.7rem 1rem;min-width:160px;max-width:250px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:.25rem;animation:tip-in .14s ease}@keyframes tip-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.tooltip-word{font-weight:600;font-size:.9rem;letter-spacing:-.01em}.tooltip-trans{color:var(--accent);font-size:.82rem;font-style:italic}.tooltip-close{position:absolute;top:.4rem;right:.55rem;background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:.7rem;padding:.15rem;transition:color var(--transition)}.tooltip-close:hover{color:var(--text-muted)}.overlay-disable{position:fixed;top:0;left:0;right:0;bottom:0;z-index:998;pointer-events:auto;cursor:not-allowed}.tooltip-loading{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-muted);padding:.3rem 0}.spinner{width:12px;height:12px;border:2px solid var(--text-faint);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.question-block{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem 1.1rem;margin-bottom:.6rem;transition:border-color .2s,background .2s}.question-block.q-correct{border-color:var(--success-border);background:var(--success-bg)}.question-block.q-wrong{border-color:var(--error-border);background:var(--error-bg)}.q-text{margin-bottom:.6rem;font-size:.9rem;line-height:1.55}.q-num{font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--text-faint);margin-right:.45rem}.feedback{display:flex;gap:.6rem;margin-top:.6rem;align-items:flex-start}.feedback-icon{font-size:.85rem;line-height:1.7;flex-shrink:0}.feedback p{font-size:.82rem;color:var(--text-muted);line-height:1.55}.search-bar-wrap{margin-bottom:1.1rem;display:flex;flex-direction:column;gap:.4rem}.search-bar{display:flex;align-items:center;gap:.5rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 .75rem;transition:border-color var(--transition),box-shadow var(--transition)}.search-bar:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-light)}.search-icon{font-size:1.1rem;color:var(--text-faint);flex-shrink:0;line-height:1;margin-top:1px}.search-input{flex:1;background:none;border:none;outline:none;padding:.65rem 0;font-size:.9rem;font-family:inherit;color:var(--text)}.search-input::placeholder{color:var(--text-faint)}.search-clear{background:none;border:none;cursor:pointer;color:var(--text-faint);font-size:.7rem;padding:.2rem .25rem;border-radius:var(--radius-xs);transition:color var(--transition),background var(--transition);flex-shrink:0;line-height:1}.search-clear:hover{color:var(--text-muted);background:var(--surface-3)}.search-meta{font-size:.72rem;color:var(--text-faint);padding-left:.25rem;letter-spacing:.01em}.browse-layout{display:grid;grid-template-columns:1fr 240px;gap:1.25rem;align-items:start}.browse-lessons{min-width:0}.browse-topbar{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.1rem}.browse-topbar .search-bar-wrap{flex:1;margin-bottom:0}.btn-new-lesson{flex-shrink:0;padding:.6rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background var(--transition);letter-spacing:-.01em}.btn-new-lesson:hover{background:var(--accent-hover)}.generate-options-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.875rem;margin-bottom:1.25rem}.gen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:overlay-in .18s ease}.gen-modal{background:var(--surface);border:1px solid var(--border-hover);border-radius:16px;width:100%;max-width:700px;padding:2rem;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:1.25rem;animation:modal-in .2s cubic-bezier(.34,1.2,.64,1);position:relative}.gen-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.gen-modal-title{font-family:Lora,serif;font-size:1.2rem;font-weight:600;letter-spacing:-.025em;margin-bottom:.2rem}.gen-modal-subtitle{font-size:.82rem;color:var(--text-muted);line-height:1.5}.gen-modal-footer{display:flex;justify-content:flex-end;gap:.6rem;padding-top:.25rem;border-top:1px solid var(--border)}.gen-btn-cancel{padding:.65rem 1.1rem;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.gen-btn-cancel:hover{border-color:var(--border-hover);color:var(--text);background:var(--surface-2)}.gen-btn-submit{width:auto;padding:.65rem 1.5rem}.gen-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1rem;text-align:center}.gen-spinner{width:48px;height:48px;position:relative}.gen-spinner-ring{width:100%;height:100%;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.gen-loading-title{font-family:Lora,serif;font-size:1rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.gen-loading-sub{font-size:.8rem;color:var(--text-muted);line-height:1.5}.level-options{display:flex;gap:.4rem}.level-option{flex:1;padding:.45rem .5rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-muted);font-family:inherit;font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition);text-align:center}.level-option:hover{border-color:var(--border-hover);color:var(--text)}.level-option.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.generate-summary{margin-top:.5rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.generate-summary-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem .85rem;border-bottom:1px solid var(--border)}.generate-summary-row:last-child{border-bottom:none}.generate-summary-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint)}.generate-summary-value{font-size:.82rem;font-weight:500;color:var(--text)}.quiz-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);position:sticky;top:78px;transition:background var(--transition),border-color var(--transition)}.quiz-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.quiz-panel-title{font-family:Lora,serif;font-size:.95rem;font-weight:600;letter-spacing:-.01em}.quiz-panel-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;background:var(--accent-light);color:var(--accent);border:1px solid rgba(176,125,74,.25);border-radius:99px;padding:.1rem .5rem}.quiz-panel-desc{font-size:.78rem;color:var(--text-muted);line-height:1.5}.quiz-panel-stats{display:flex;gap:0;margin:1rem 0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.quiz-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:.6rem .4rem;border-right:1px solid var(--border);gap:.1rem}.quiz-stat:last-child{border-right:none}.quiz-stat-value{font-family:JetBrains Mono,monospace;font-size:.95rem;font-weight:500;color:var(--text);line-height:1.2}.quiz-stat-label{font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint)}.quiz-start-btn{margin-top:.25rem;width:100%;background:var(--accent)}.quiz-panel-empty{font-size:.78rem;color:var(--text-faint);text-align:center;padding:1rem .5rem;margin-top:.75rem}.quiz-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:overlay-in .2s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.quiz-modal{background:var(--surface);border:1px solid var(--border-hover);border-radius:18px;width:100%;max-width:620px;padding:3rem;box-shadow:var(--shadow-md),0 0 0 1px var(--border);position:relative;animation:modal-in .22s cubic-bezier(.34,1.3,.64,1);display:flex;flex-direction:column;gap:1.5rem}@keyframes modal-in{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.quiz-close{position:absolute;top:1rem;right:1rem;background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);width:28px;height:28px;border-radius:var(--radius-xs);cursor:pointer;font-size:.75rem;display:grid;place-items:center;transition:all var(--transition)}.quiz-close:hover{background:var(--error-bg);color:var(--error);border-color:var(--error-border)}.quiz-scoreboard{display:flex;align-items:center;gap:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;flex-wrap:wrap;position:relative}.quiz-score-item{display:flex;flex-direction:column;align-items:center;padding:.55rem .8rem;border-right:1px solid var(--border);gap:.05rem;flex:1;min-width:60px}.quiz-score-divider{display:none}.quiz-score-value{font-family:JetBrains Mono,monospace;font-size:1.05rem;font-weight:500;line-height:1.2;color:var(--text)}.quiz-score-correct{color:var(--success)}.quiz-score-mistakes{color:var(--error)}.quiz-score-streak{font-size:.85rem}.quiz-score-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-faint)}.quiz-progress-bar{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--border)}.quiz-progress-fill{height:100%;background:var(--accent);transition:width .5s ease;border-radius:0 2px 2px 0}.quiz-word-count{position:absolute;top:.4rem;right:.6rem;font-size:.6rem;color:var(--text-faint);letter-spacing:.03em}.quiz-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 1.75rem;text-align:center;animation:card-in .18s ease}@keyframes card-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.quiz-card-hint{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin-bottom:.75rem}.quiz-word{font-family:Lora,serif;font-size:2rem;font-weight:600;letter-spacing:-.02em;color:var(--text);line-height:1.2}.quiz-definition{margin-top:.6rem;font-size:.8rem;color:var(--text-muted);font-style:italic;line-height:1.5}.quiz-input-area{display:flex;flex-direction:column;gap:.75rem}.quiz-input-wrap{border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition),box-shadow var(--transition)}.quiz-input-wrap:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-light)}.quiz-input-wrap.quiz-input-wrong{border-color:var(--error-border);box-shadow:0 0 0 3px var(--error-bg)}.quiz-input{width:100%;padding:.8rem 1rem;background:var(--surface-2);border:none;border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--text);outline:none}.quiz-input::placeholder{color:var(--text-faint)}.quiz-feedback{display:flex;align-items:center;gap:.6rem;padding:.65rem .9rem;border-radius:var(--radius-sm);font-size:.875rem;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.quiz-feedback-correct{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.quiz-feedback-wrong{background:var(--error-bg);color:var(--error);border:1px solid var(--error-border)}.quiz-feedback-revealed{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.quiz-feedback-icon{font-size:.9rem;flex-shrink:0}.quiz-feedback strong{color:var(--text);font-weight:600}.quiz-actions{display:flex;gap:.6rem}.quiz-btn{flex:1;padding:.7rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition);border:none}.quiz-btn:disabled{opacity:.35;cursor:not-allowed}.quiz-btn-primary{background:var(--accent);color:#fff}.quiz-btn-primary:hover:not(:disabled){background:var(--accent-hover)}.quiz-btn-secondary{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.quiz-btn-secondary:hover{background:var(--surface-3);color:var(--text);border-color:var(--border-hover)}.quiz-key-hint{text-align:center;font-size:.72rem;color:var(--text-faint)}@media (max-width: 900px){.browse-layout,.quiz-panel,.lesson-body{grid-template-columns:1fr}.vocab-sidebar{position:static;max-height:none;order:-1}.main{padding:1.5rem 1rem}}@media (max-width: 600px){.row{flex-direction:column}.card{padding:1.25rem}.section{padding:1.1rem 1.2rem}.header{padding:0 1rem}.quiz-modal{padding:1.5rem}.quiz-word{font-size:1.6rem}}.landing{min-height:100vh;background:var(--bg);color:var(--text);display:flex;flex-direction:column}.landing-nav{position:sticky;top:0;z-index:200;background:var(--bg);border-bottom:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}[data-theme=dark] .landing-nav{background:rgba(14,13,11,.85)}.landing-nav-inner{width:100%;box-sizing:border-box;padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap}.landing-nav-inner .logo{flex:0 0 auto}.landing-nav-right{flex:0 0 auto;display:flex;align-items:center;gap:.75rem}.landing-login-btn{font-family:Outfit,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1.25rem;border-radius:100px;border:1.5px solid var(--accent);background:transparent;color:var(--accent);cursor:pointer;transition:background var(--transition),color var(--transition);letter-spacing:.01em}.landing-login-btn:hover{background:var(--accent);color:#fff}.hero{position:relative;overflow:hidden;padding:7rem 2rem 6rem;text-align:center}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(176,125,74,.12) 0%,transparent 70%);pointer-events:none}[data-theme=dark] .hero:before{background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(200,151,90,.1) 0%,transparent 70%)}.hero-inner{position:relative;max-width:740px;margin:0 auto;animation:fadeUp .7s ease both}.hero-badge{display:inline-block;font-size:.78rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);border:1px solid rgba(176,125,74,.2);padding:.3rem .9rem;border-radius:100px;margin-bottom:1.75rem}.hero-title{font-family:Lora,Georgia,serif;font-size:clamp(2.4rem,6vw,3.8rem);font-weight:500;line-height:1.15;color:var(--text);margin-bottom:1.5rem;letter-spacing:-.02em}.hero-title em{font-style:italic;color:var(--accent)}.hero-sub{font-size:1.05rem;color:var(--text-muted);line-height:1.75;max-width:580px;margin:0 auto 2.5rem}.hero-actions{display:flex;align-items:center;justify-content:center;gap:1.25rem;flex-wrap:wrap}.btn-cta{font-family:Outfit,sans-serif;font-size:.95rem;font-weight:600;padding:.75rem 2rem;border-radius:100px;border:none;background:var(--accent);color:#fff;cursor:pointer;letter-spacing:.01em;transition:background var(--transition),transform .12s ease,box-shadow var(--transition);box-shadow:0 4px 14px #b07d4a59}.btn-cta:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #b07d4a66}.btn-cta:active{transform:translateY(0)}.btn-cta--light{background:#fff;color:var(--accent);box-shadow:0 4px 14px #00000026}.btn-cta--light:hover{background:#f8f6f2;box-shadow:0 6px 20px #0000002e}.hero-note{font-size:.82rem;color:var(--text-faint);letter-spacing:.02em}.hero-flags{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hero-flag{position:absolute;font-size:1.6rem;opacity:.5;animation:floatOrb 7s ease-in-out infinite}.hero-flag-0{top:15%;left:6%;animation-delay:0s}.hero-flag-1{top:70%;left:3%;animation-delay:1.1s}.hero-flag-2{top:30%;right:5%;animation-delay:.4s}.hero-flag-3{top:65%;right:8%;animation-delay:2s}.hero-flag-4{top:8%;left:20%;animation-delay:1.6s}.hero-flag-5{top:80%;left:22%;animation-delay:.8s}.hero-flag-6{top:5%;right:18%;animation-delay:2.4s}.hero-flag-7{top:82%;right:20%;animation-delay:1.3s}@keyframes floatOrb{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.section-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}.section-heading{font-family:Lora,Georgia,serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:500;color:var(--text);margin-bottom:1rem;letter-spacing:-.02em}.section-sub{color:var(--text-muted);font-size:1rem;line-height:1.7;max-width:560px;margin-bottom:3rem}.sample-section{padding:5rem 2rem;background:var(--bg-secondary)}.sample-inner{max-width:760px;margin:0 auto}.lesson-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-md);overflow:hidden;animation:fadeUp .5s ease both}.lesson-card-header{padding:1.5rem 1.75rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface-2)}.lesson-card-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.lc-flag{font-size:1.1rem}.lc-lang{font-size:.82rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.lc-level{font-size:.75rem;background:var(--accent-light);color:var(--accent);border:1px solid rgba(176,125,74,.2);padding:.15rem .6rem;border-radius:100px;font-weight:500;letter-spacing:.03em}.lc-title{font-family:Lora,Georgia,serif;font-size:1.1rem;font-weight:500;color:var(--text)}.lc-sentences{padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:.75rem}.lc-sentence{padding:1rem 1.25rem;border-radius:12px;border:1.5px solid transparent;background:var(--surface-2);cursor:pointer;transition:all var(--transition)}.lc-sentence:hover{border-color:var(--border-hover)}.lc-sentence--active{border-color:#b07d4a4d;background:var(--accent-light)}.lc-original{font-family:Lora,Georgia,serif;font-size:1.05rem;font-style:italic;line-height:1.6;margin-bottom:.35rem;display:flex;flex-wrap:wrap;align-items:center;gap:.3rem}.lc-translation{font-size:.875rem;color:var(--text-muted);line-height:1.5}.lc-footer{padding:1.25rem 1.75rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface-2)}.lc-dots{display:flex;gap:.5rem}.lc-dot{width:8px;height:8px;border-radius:50%;background:var(--border-hover);border:none;cursor:pointer;padding:0;transition:background var(--transition),transform var(--transition)}.lc-dot--active{background:var(--accent);transform:scale(1.2)}.btn-preview-cta{font-family:Outfit,sans-serif;font-size:.875rem;font-weight:500;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;transition:opacity var(--transition);letter-spacing:.01em}.btn-preview-cta:hover{opacity:.7}.vocab-chip{position:relative;display:inline-block;background:var(--vocab-bg);color:var(--vocab-text);padding:2px 8px;border-radius:5px;cursor:default;font-style:italic;font-family:Lora,Georgia,serif;transition:background var(--transition)}.vocab-chip:hover,.vocab-chip:focus{outline:none;background:rgba(176,125,74,.22)}.vocab-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--text);color:var(--bg);font-family:Outfit,sans-serif;font-style:normal;font-size:.78rem;font-weight:500;white-space:nowrap;padding:5px 10px;border-radius:7px;pointer-events:none;z-index:50;box-shadow:0 4px 12px #0003}.vocab-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--text)}.features-section{padding:6rem 2rem}.features-inner{max-width:1100px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:2rem;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.feature-card:hover{border-color:#b07d4a4d;transform:translateY(-3px);box-shadow:var(--shadow-md)}.feature-icon{font-size:1.4rem;color:var(--accent);margin-bottom:1rem}.feature-title{font-family:Lora,Georgia,serif;font-size:1.05rem;font-weight:500;color:var(--text);margin-bottom:.5rem}.feature-desc{font-size:.9rem;color:var(--text-muted);line-height:1.65}.cta-band{background:var(--accent);padding:5rem 2rem;text-align:center;position:relative;overflow:hidden}.cta-band:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(255,255,255,.1) 0%,transparent 70%)}.cta-band-inner{position:relative;max-width:600px;margin:0 auto}.cta-band-title{font-family:Lora,Georgia,serif;font-size:clamp(1.8rem,4vw,2.5rem);font-weight:500;color:#fff;margin-bottom:.75rem;letter-spacing:-.02em}.cta-band-sub{color:#ffffffc7;font-size:1rem;margin-bottom:2rem;line-height:1.6}.landing-footer{padding:2.5rem 2rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.lf-copy{font-size:.85rem;color:var(--text-faint)}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:2.5rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;box-shadow:var(--shadow-md);min-width:300px}.auth-error{color:var(--error);font-size:.9rem;text-align:center}.auth-spinner{display:flex;align-items:center;justify-content:center}.gen-spinner-ring{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.hero{padding:5rem 1.25rem 4rem}.hero-flags{display:none}.sample-section,.features-section{padding:4rem 1.25rem}.lc-footer{flex-direction:column;gap:1rem;align-items:flex-start}}.vocab-item{position:relative}.vocab-remove-btn{position:absolute;top:50%;right:0;transform:translateY(-50%);background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:.7rem;padding:4px 6px;border-radius:4px;opacity:0;transition:opacity var(--transition),color var(--transition),background var(--transition);line-height:1}.vocab-item:hover .vocab-remove-btn{opacity:1}.vocab-remove-btn:hover{color:var(--error);background:var(--error-bg)}.tooltip-add-btn{display:block;width:100%;margin-top:.5rem;padding:.3rem .6rem;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:500;background:var(--accent-light);color:var(--accent);border:1px solid rgba(176,125,74,.25);border-radius:6px;cursor:pointer;transition:background var(--transition);text-align:center}.tooltip-add-btn:hover{background:rgba(176,125,74,.2)}.tooltip-in-vocab{display:block;margin-top:.5rem;font-size:.72rem;color:var(--success);font-weight:500;text-align:center}.quiz-swap-btn{font-family:Outfit,sans-serif;font-size:.78rem;font-weight:500;padding:.35rem .9rem;border-radius:100px;border:1.5px solid var(--border-hover);background:transparent;color:var(--text-muted);cursor:pointer;transition:border-color var(--transition),color var(--transition),background var(--transition);letter-spacing:.01em}.quiz-swap-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
