.lp{font-family:DM Sans,system-ui,sans-serif;color:#111926;background:#fff;overflow-x:hidden}.lp-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:64px;background:transparent;transition:background .3s,box-shadow .3s}.lp-nav--scrolled{background:#0f1729;box-shadow:0 4px 24px #00000040}.lp-hero-logo{margin-bottom:16px}.lp-hero-logo img{height:270px;width:auto;display:block;margin:0 auto}.lp-nav-links{display:flex;align-items:center;gap:8px}.lp-nav-signin{padding:8px 18px;border-radius:10px;font-size:14px;font-weight:600;color:#ffffffe6;background:#ffffff14;border:1.5px solid rgba(255,255,255,.35);cursor:pointer;transition:background .2s,border-color .2s,color .2s}.lp-nav-signin:hover{background:#ffffff29;border-color:#fff9;color:#fff}.lp-nav-cta{padding:9px 20px;border-radius:10px;font-size:14px;font-weight:700;color:#0f1729;background:#f0b35f;border:none;cursor:pointer;transition:background .2s,transform .15s}.lp-nav-cta:hover{background:#e8a84a;transform:translateY(-1px)}.lp-hero{min-height:100vh;background:#0f1729;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px 60px;text-align:center;position:relative;overflow:hidden}.lp-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% -10%,rgba(200,150,46,.18) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 80% 80%,rgba(29,64,128,.25) 0%,transparent 60%);pointer-events:none}.lp-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:#f0b35f1f;border:1px solid rgba(240,179,95,.3);border-radius:999px;padding:6px 16px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#f0b35f;margin-bottom:28px}.lp-hero-eyebrow span{width:6px;height:6px;border-radius:50%;background:#f0b35f}.lp-hero h1{font-family:Space Grotesk,sans-serif;font-size:clamp(36px,5.5vw,72px);font-weight:800;line-height:1.08;letter-spacing:-.03em;color:#fff;max-width:820px;margin:0 auto 24px}.lp-hero h1 em{font-style:normal;background:linear-gradient(135deg,#f0b35f,#e8a030);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lp-hero-sub{font-size:clamp(16px,2vw,20px);color:#ffffffa6;max-width:560px;margin:0 auto 40px;line-height:1.6}.lp-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.lp-btn-primary{padding:14px 32px;border-radius:14px;font-size:15px;font-weight:700;color:#0f1729;background:#f0b35f;border:none;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 8px 24px -8px #f0b35f80}.lp-btn-primary:hover{background:#e8a030;transform:translateY(-2px);box-shadow:0 12px 28px -8px #f0b35f99}.lp-btn-ghost{padding:14px 28px;border-radius:14px;font-size:15px;font-weight:600;color:#fffc;background:#ffffff14;border:1px solid rgba(255,255,255,.15);cursor:pointer;transition:background .2s,color .2s}.lp-btn-ghost:hover{background:#ffffff24;color:#fff}.lp-hero-visual{margin-top:64px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;max-width:880px;width:100%}.lp-mock-card{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:20px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.lp-mock-vocab{width:260px;text-align:left}.lp-mock-vocab-word{font-family:Space Grotesk,sans-serif;font-size:26px;font-weight:700;color:#fff;margin-bottom:2px}.lp-mock-vocab-trans{font-size:14px;color:#ffffff80;margin-bottom:18px}.lp-mock-mastery-bars{display:flex;flex-direction:column;gap:8px}.lp-mock-bar-row{display:flex;align-items:center;gap:10px}.lp-mock-bar-label{font-size:12px;color:#ffffff80;width:58px;flex-shrink:0}.lp-mock-bar-track{flex:1;height:6px;border-radius:3px;background:#ffffff1a;overflow:hidden}.lp-mock-bar-fill{height:100%;border-radius:3px}.lp-mock-bar-fill.saved{background:#64748b;width:15%}.lp-mock-bar-fill.learning{background:#3b82f6;width:35%}.lp-mock-bar-fill.familiar{background:#f0b35f;width:30%}.lp-mock-bar-fill.mastered{background:#16a34a;width:20%}.lp-mock-bar-count{font-size:12px;color:#fff6;width:24px;text-align:right}.lp-mock-video{width:280px;text-align:left}.lp-mock-thumb{width:100%;aspect-ratio:16/9;border-radius:10px;background:linear-gradient(135deg,#1d2b3a,#0e1829);margin-bottom:14px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.lp-mock-thumb:after{content:"▶";font-size:24px;color:#ffffffb3}.lp-mock-thumb-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff26}.lp-mock-thumb-bar:after{content:"";display:block;width:45%;height:100%;background:#f0b35f}.lp-mock-video-title{font-size:13px;font-weight:600;color:#ffffffd9;margin-bottom:10px}.lp-mock-tags{display:flex;flex-wrap:wrap;gap:6px}.lp-mock-tag{font-size:11px;padding:3px 9px;border-radius:6px;background:#ffffff1a;color:#ffffffa6;font-weight:500}.lp-mock-tag.gold{background:#f0b35f33;color:#f0b35f}.lp-mock-exercise{width:240px;text-align:left}.lp-mock-ex-label{font-size:10px;font-weight:700;letter-spacing:.1em;color:#fff6;text-transform:uppercase;margin-bottom:10px}.lp-mock-ex-prompt{font-size:14px;color:#fffc;margin-bottom:14px;line-height:1.5}.lp-mock-ex-blank{display:inline-block;width:72px;height:2px;background:#f0b35f;vertical-align:middle;margin:0 4px;border-radius:1px}.lp-mock-ex-opts{display:flex;flex-direction:column;gap:6px}.lp-mock-ex-opt{font-size:13px;padding:7px 12px;border-radius:8px;background:#ffffff12;border:1px solid rgba(255,255,255,.1);color:#ffffffb3}.lp-mock-ex-opt.correct{background:#16a34a33;border-color:#16a34a66;color:#4ade80;font-weight:600}.lp-levels{background:#f3ecdf;padding:20px 40px;display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.lp-levels-label{font-size:13px;font-weight:600;color:#5f7087;margin-right:8px}.lp-level-pill{padding:5px 14px;border-radius:999px;font-size:13px;font-weight:700;letter-spacing:.04em;border:1.5px solid}.lp-level-pill.a1{background:#e4f1e8;color:#15803d;border-color:#bbddc6}.lp-level-pill.a2{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.lp-level-pill.b1{background:#ede9fe;color:#6d28d9;border-color:#ddd6fe}.lp-level-pill.b2{background:#fef3c7;color:#b45309;border-color:#fde68a}.lp-level-pill.c1{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.lp-level-pill.c2{background:#fce7f3;color:#9d174d;border-color:#fbcfe8}.lp-section{padding:100px 24px}.lp-section-cream{background:#fffaf1}.lp-section-white{background:#fff}.lp-section-dark{background:#0f1729}.lp-container{max-width:1100px;margin:0 auto}.lp-eyebrow{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#c8962e;margin-bottom:14px}.lp-section-dark .lp-eyebrow{color:#f0b35f}.lp-h2{font-family:Space Grotesk,sans-serif;font-size:clamp(28px,3.5vw,46px);font-weight:800;letter-spacing:-.025em;line-height:1.12;color:#111926;margin:0 0 16px}.lp-section-dark .lp-h2{color:#fff}.lp-h2 em{font-style:normal;background:linear-gradient(135deg,#c8962e,#f0b35f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lp-lead{font-size:clamp(15px,1.8vw,18px);color:#5f7087;max-width:560px;line-height:1.65;margin:0 0 48px}.lp-section-dark .lp-lead{color:#ffffff8c}.lp-spotlight{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}.lp-spotlight.reverse{direction:rtl}.lp-spotlight.reverse>*{direction:ltr}.lp-spotlight-text{display:flex;flex-direction:column}.lp-spotlight-text .lp-h2{font-size:clamp(24px,3vw,38px)}.lp-spotlight-checklist{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:10px}.lp-spotlight-checklist li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:#27384f;line-height:1.5}.lp-spotlight-checklist li:before{content:"✓";font-size:13px;font-weight:700;color:#fff;background:#16a34a;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.lp-spotlight-visual{border-radius:24px;overflow:hidden;box-shadow:0 32px 80px -20px #0000002e}.lp-panel-video{background:#0f1729;padding:28px}.lp-panel-video-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.lp-panel-video-dot{width:8px;height:8px;border-radius:50%}.lp-panel-video-thumb{width:100%;aspect-ratio:16/9;border-radius:12px;background:linear-gradient(160deg,#1a2744,#0e1829);margin-bottom:18px;display:flex;align-items:center;justify-content:center;font-size:32px;position:relative;overflow:hidden}.lp-panel-video-thumb-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.6) 100%)}.lp-panel-video-thumb-play{width:52px;height:52px;border-radius:50%;background:#ffffffe6;display:flex;align-items:center;justify-content:center;font-size:18px;color:#1d4080;position:relative;z-index:1}.lp-panel-section-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff6;margin-bottom:8px}.lp-panel-vocab-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.lp-panel-vocab-chip{padding:5px 12px;border-radius:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);font-size:13px;font-weight:600;color:#ffffffd9}.lp-panel-vocab-chip .en{font-size:11px;font-weight:400;color:#fff6;margin-left:4px}.lp-panel-ex{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px 16px}.lp-panel-ex-type{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#f0b35f;margin-bottom:6px}.lp-panel-ex-q{font-size:14px;color:#ffffffbf;margin-bottom:10px}.lp-panel-ex-opts{display:flex;gap:6px;flex-wrap:wrap}.lp-panel-ex-opt{font-size:12px;padding:5px 11px;border-radius:7px;background:#ffffff14;color:#fff9;border:1px solid rgba(255,255,255,.1)}.lp-panel-ex-opt.active{background:#16a34a40;border-color:#16a34a80;color:#4ade80;font-weight:600}.lp-panel-book{background:#fffaf1;padding:28px;border:1px solid #e8dcc8}.lp-panel-book-header{font-family:Space Grotesk,sans-serif;font-size:15px;font-weight:700;color:#111926;margin-bottom:4px}.lp-panel-book-author{font-size:12px;color:#5f7087;margin-bottom:20px}.lp-panel-book-text{font-family:Georgia,Times New Roman,serif;font-size:14px;line-height:1.8;color:#27384f;margin-bottom:20px}.lp-panel-book-highlight{background:#c8962e33;border-radius:3px;padding:1px 3px;cursor:pointer;position:relative}.lp-panel-book-popup{background:#0f1729;border-radius:12px;padding:14px 16px;margin-top:12px}.lp-panel-book-popup-word{font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700;color:#fff;margin-bottom:2px}.lp-panel-book-popup-trans{font-size:13px;color:#ffffff8c;margin-bottom:10px}.lp-panel-book-popup-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:6px 14px;border-radius:8px;background:#f0b35f;color:#0f1729;cursor:pointer;border:none}.lp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.lp-grid-card{background:#fffaf1;border:1px solid #e8dcc8;border-radius:20px;padding:28px;transition:transform .22s var(--ease, ease),box-shadow .22s;cursor:default}.lp-grid-card:hover{transform:translateY(-4px);box-shadow:0 20px 48px -16px #49361f33}.lp-grid-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}.lp-grid-card h3{font-family:Space Grotesk,sans-serif;font-size:17px;font-weight:700;color:#111926;margin:0 0 8px}.lp-grid-card p{font-size:14px;color:#5f7087;margin:0;line-height:1.6}.lp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;position:relative}.lp-steps:before{content:"";position:absolute;top:28px;left:calc(16.66% + 28px);right:calc(16.66% + 28px);height:2px;background:linear-gradient(90deg,#c8962e,#f0b35f,#c8962e);opacity:.4}.lp-step{text-align:center}.lp-step-num{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#c8962e,#f0b35f);color:#0f1729;font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;position:relative;z-index:1;box-shadow:0 8px 20px -8px #c8962e80}.lp-step h3{font-family:Space Grotesk,sans-serif;font-size:19px;font-weight:700;color:#111926;margin:0 0 8px}.lp-step p{font-size:14px;color:#5f7087;line-height:1.6;margin:0}.lp-quote{background:linear-gradient(135deg,#0c1322,#131d34);padding:100px 24px;text-align:center}.lp-quote-text{font-family:Space Grotesk,sans-serif;font-size:clamp(24px,4vw,52px);font-weight:800;letter-spacing:-.025em;line-height:1.12;color:#fff;max-width:820px;margin:0 auto 16px}.lp-quote-text em{font-style:normal;color:#f0b35f}.lp-quote-sub{font-size:17px;color:#ffffff80;max-width:480px;margin:0 auto;line-height:1.6}.lp-cta-section{background:#f3ecdf;padding:100px 24px;text-align:center}.lp-cta-section .lp-h2{margin:0 auto 16px;max-width:600px}.lp-cta-section .lp-lead{margin:0 auto 36px}.lp-cta-note{margin-top:16px;font-size:13px;color:#5f7087}.lp-footer{background:#0f1729;padding:40px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.lp-footer-logo img{height:28px;opacity:.7}.lp-footer-copy{font-size:13px;color:#ffffff59}.lp-footer-links{display:flex;gap:20px}.lp-footer-links a{font-size:13px;color:#fff6;text-decoration:none;transition:color .2s}.lp-footer-links a:hover{color:#ffffffbf;text-decoration:none}@media(max-width:900px){.lp-nav{padding:0 20px}.lp-spotlight{grid-template-columns:1fr;gap:40px}.lp-spotlight.reverse{direction:ltr}.lp-grid{grid-template-columns:1fr 1fr}.lp-hero-visual{gap:12px}.lp-mock-card{width:calc(50% - 8px);min-width:200px}.lp-steps{grid-template-columns:1fr;gap:32px}.lp-steps:before{display:none}.lp-step{text-align:left;display:flex;gap:20px;align-items:flex-start}.lp-step-num{flex-shrink:0;margin:0}.lp-footer{flex-direction:column;align-items:flex-start;padding:32px 20px}}@media(max-width:600px){.lp-section{padding:64px 20px}.lp-grid{grid-template-columns:1fr}.lp-hero{padding:56px 20px 40px}.lp-hero-visual,.lp-nav-links .lp-nav-cta{display:none}.lp-levels{padding:16px 20px}}:root{--bg: #f3ecdf;--surface: #fffaf1;--surface-2: #fbf5ea;--line: #decfb8;--line-2: #efe4d1;--ink: #111926;--ink-2: #27384f;--muted: #5f7087;--muted-2: #354963;--muted-foreground: 215 30% 30%;--primary: #1d4080;--primary-rgb: 29, 64, 128;--primary-600: #152e5e;--primary-50: #fdf0d0;--primary-100: #f7e0a0;--success: #4f9b78;--success-50: #e4f1e8;--indigo: hsl(222 47% 11%);--warning: #d08c4b;--danger: #ef4444;--danger-50: #fef2f2;--sidebar: hsl(222 47% 11%);--sidebar-muted: #a9bac0;--warm: #f0b35f;--warm-soft: #f8e8c8;--brown: #996334;--gold: #c8962e;--gold-bright: #e8b84a;--gold-deep: #9e7220;--gold-50: rgba(200, 150, 46, .15);--gold-glow: rgba(232, 184, 74, .45);--radius-sm: 10px;--radius: 16px;--radius-lg: 24px;--radius-xl: 32px;--shadow-sm: 0 10px 30px -22px rgba(73, 54, 31, .45);--shadow: 0 22px 48px -26px rgba(73, 54, 31, .38);--shadow-lg: 0 24px 60px -22px rgba(73, 54, 31, .42);--shadow-primary: 0 16px 32px -18px rgba(29, 64, 128, .38);--ease: cubic-bezier(.2, .7, .2, 1);--paper: var(--bg);--card: var(--surface);--clay: var(--primary);--clay-soft: var(--primary-100);--ok: var(--success)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:DM Sans,system-ui,-apple-system,Segoe UI,sans-serif;font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font:inherit;border:0;background:transparent;cursor:pointer;color:inherit}input,textarea,select{font:inherit;color:inherit}a{color:var(--primary);cursor:pointer;text-decoration:none}a:hover{color:var(--primary-600);text-decoration:underline}h1,h2,h3,h4,h5{font-family:Space Grotesk,system-ui,-apple-system,sans-serif;letter-spacing:0;color:var(--ink)}.paper{min-height:100vh;display:flex;align-items:stretch;background:linear-gradient(90deg,rgba(99,72,45,.04) 1px,transparent 1px),linear-gradient(180deg,rgba(99,72,45,.04) 1px,transparent 1px),var(--bg);background-size:36px 36px}.paper.center{flex-direction:column;align-items:center;justify-content:center}.topbar{width:260px;flex:0 0 260px;background:var(--sidebar);border-right:0;padding:24px 18px;display:flex;flex-direction:column;gap:20px;position:sticky;top:0;height:100vh;z-index:20}.brand{display:flex;align-items:center;gap:10px;font-family:Space Grotesk,system-ui,sans-serif;font-weight:700;font-size:18px;letter-spacing:0;color:#fffaf1;padding:6px 8px 14px}.brand em{font-style:normal;color:#fffaf1;font-weight:700}.brand-dot{width:32px;height:32px;border-radius:10px;background:var(--warm);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 16px 32px #f0b35f40;position:relative;color:var(--ink);font-weight:900}.brand-dot:empty:after{content:"M";color:var(--ink);font-weight:900}.nav{display:flex;flex-direction:column;gap:2px;flex:1}.nav .tab{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:12px;color:var(--sidebar-muted);font-weight:700;font-size:14px;text-align:left;width:100%;transition:color .24s var(--ease),background .24s var(--ease)}.nav .tab:hover{color:#fffaf1;background:#ffffff12}.nav .tab.active{background:linear-gradient(90deg,#c8962e38,#c8962e14);color:var(--gold-bright);font-weight:800;border-left:2px solid var(--gold);padding-left:12px}.nav .tab span{display:inline}.nav .tab svg{color:var(--warm);background:#ffffff14;border-radius:8px;padding:4px;width:23px;height:23px}.nav .tab.active svg{color:var(--gold-bright);background:#c8962e33}.nav .icon-btn{padding:10px;border-radius:10px;color:var(--sidebar-muted);transition:color .24s var(--ease),background .24s var(--ease)}.nav .icon-btn:hover{color:var(--gold-bright);background:#c8962e1f}.nav-icon-row{display:flex;gap:4px;padding:8px;border-top:1px solid rgba(200,150,46,.18)}.nav-icon-row .icon-btn{width:40px;height:40px;padding:10px;border-radius:10px;color:var(--sidebar-muted);transition:color .24s var(--ease),background .24s var(--ease)}.nav-icon-row .icon-btn:hover{color:var(--gold-bright);background:#c8962e24}.sidebar-note{padding:18px;border-radius:22px;background:#ffffff14;border:1px solid rgba(255,255,255,.08);color:#eef5ef}.sidebar-note span{display:block;margin-bottom:8px;color:var(--warm);font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.sidebar-note strong{display:block;color:#fffaf1;font-size:18px;line-height:1.2;margin-bottom:6px}.sidebar-note p{margin:0;color:#eef5efb8;line-height:1.45}.language-switcher{display:inline-flex;align-items:center;gap:6px;color:var(--muted-2);font-size:12px;font-weight:700}.language-switcher span{color:var(--muted);margin-right:4px}.language-switcher button{min-width:38px;padding:7px 10px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--muted-2);font-size:11px;font-weight:800;letter-spacing:.08em;transition:color .24s var(--ease),background .24s var(--ease),border-color .24s var(--ease)}.language-switcher button.active{background:var(--primary);border-color:var(--primary);color:#fff}.topbar .language-switcher{align-self:flex-start;padding:0 8px}.topbar .language-switcher button{border-color:#ffffff1f;background:#ffffff14;color:var(--sidebar-muted)}.topbar .language-switcher button.active{background:var(--warm);border-color:var(--warm);color:var(--sidebar)}.auth-card .language-switcher{display:flex;justify-content:center;margin:6px 0 16px}.auth-card .language-switcher button{border-color:#fffaf157;background:#fffaf114;color:#fffaf1}.auth-card .language-switcher button.active{background:#fffaf1;border-color:#fffaf1;color:var(--primary-600)}.wrap{flex:1;min-width:0;max-width:none;margin:0;padding:40px 46px 80px;overflow-x:clip}.detail{flex:1;min-width:0;max-width:920px;margin:0 auto;padding:40px 48px 80px}.paper.center,.center.paper{display:grid;place-items:center;padding:24px}.center{min-height:100vh;display:grid;place-items:center;padding:24px}.eyebrow{font-family:Space Grotesk,sans-serif;font-size:11px;letter-spacing:.16em;color:var(--muted);font-weight:700;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:8px}h1.display{font-family:Georgia,Times New Roman,serif;font-weight:900;font-size:clamp(36px,3.5vw,48px);line-height:1.04;margin:0 0 6px;letter-spacing:0;color:var(--ink)}h1.display em{font-style:normal;color:var(--gold);font-weight:900;-webkit-text-stroke:.6px rgba(0,0,0,.45);paint-order:stroke fill}.lead{font-size:15px;color:var(--muted-2);max-width:640px;margin:0}.section-title{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:26px;margin:0 0 4px;letter-spacing:-.02em;color:var(--ink)}.section-sub{color:var(--muted-2);margin:0 0 22px;font-size:14px}.add{background:var(--sidebar);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:20px;margin:24px 0;box-shadow:var(--shadow-primary)}.add-label{font-family:Space Grotesk,sans-serif;font-size:11px;letter-spacing:.14em;font-weight:700;color:var(--gold-bright);text-transform:uppercase;display:block;margin-bottom:10px}.add-row{display:flex;gap:10px;flex-wrap:wrap}.session-date-input{flex:0 0 170px}.add-row input,.add-row input[type=date]{flex:1;border:1px solid rgba(255,255,255,.14);background:#ffffff12;border-radius:12px;padding:12px 14px;font-size:14px;color:#fffaf1;transition:border-color .24s var(--ease),box-shadow .24s var(--ease)}.add-row input::placeholder{color:#fffaf1a6}.add-row input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #c8962e38}.btn{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;border-radius:12px;padding:11px 18px;font-weight:600;font-size:14px;border:1px solid var(--primary);box-shadow:var(--shadow-primary);transition:transform .24s var(--ease),box-shadow .24s var(--ease),background .24s var(--ease)}.btn:hover{background:var(--primary-600);border-color:var(--primary-600);transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:wait;transform:none;box-shadow:none}.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line);box-shadow:none}.btn-ghost:hover{background:var(--line-2);color:var(--ink);border-color:var(--line);transform:none}.btn-clay{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-clay:hover{background:var(--primary-600);border-color:var(--primary-600)}.hint{font-size:13px;color:var(--muted-2);margin-top:10px}.ok-note{margin-top:10px;color:var(--success);font-size:13px;font-weight:600}.add .hint,.col-add-bar .hint{color:#fffaf1cc}.add .ok-note,.col-add-bar .ok-note{color:#6ee7b7}.add .err{background:#ef44442e;color:#fca5a5;border-color:#ef44444d}.add .btn{background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 100%);border-color:var(--gold);color:#1a1200;font-weight:800;box-shadow:0 4px 14px #c8962e59}.add .btn:hover{filter:brightness(1.08);border-color:var(--gold);background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 100%)}.add .btn:disabled{opacity:.55;filter:none}.search{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:10px 16px;margin:4px 0 20px;max-width:520px;color:var(--muted);transition:border-color .24s var(--ease),box-shadow .24s var(--ease)}.search:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-100)}.search input{flex:1;min-width:0;border:0;background:transparent;padding:4px 0;color:var(--ink)}.search input:focus{outline:none}.library-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin:16px 0 12px}.library-stats div{border:1px solid var(--line);border-radius:12px;background:color-mix(in srgb,var(--surface) 92%,transparent);padding:9px 11px}.library-stats span{display:block;color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.library-stats strong{display:block;color:var(--ink);font-family:Space Grotesk,sans-serif;font-size:20px;line-height:1.15;margin-top:3px}.lib-toolbar{display:flex;align-items:center;gap:8px;margin:14px 0 0}.lib-toolbar .library-search{flex:1;margin:0}.lib-tool-btn{display:inline-flex;align-items:center;gap:4px;height:40px;padding:0 13px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s,background .15s;white-space:nowrap;position:relative}.lib-tool-btn:hover{border-color:var(--primary);color:var(--primary)}.lib-tool-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.lib-filter-badge{background:var(--warm);color:var(--ink);font-size:10px;font-weight:800;border-radius:999px;padding:0 5px;min-width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.lib-sort-select{height:40px;padding:0 10px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--ink);font:inherit;font-size:13px;cursor:pointer;transition:border-color .15s}.lib-sort-select:hover{border-color:var(--primary)}.lib-select-toggle{margin-left:auto}.lib-filter-panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:14px 16px;margin:8px 0 0;display:grid;gap:12px}.lib-filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lib-filter-label{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);min-width:56px;flex-shrink:0}.lib-chips{display:flex;gap:5px;flex-wrap:wrap}.lib-chips .chip{min-height:28px;padding:0 10px;border-radius:999px;font-size:12px}.lib-filter-selects{gap:6px;border-top:1px solid var(--line);padding-top:12px;margin-top:2px}.lib-filter-selects select{height:34px;padding:0 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);color:var(--ink);font:inherit;font-size:12px;cursor:pointer}.lib-filter-selects select:hover{border-color:var(--primary)}.chip-reset{border-color:color-mix(in srgb,var(--danger) 22%,var(--line))!important;color:var(--danger)!important;font-size:12px;min-height:28px;padding:0 10px;border-radius:999px}.chip-reset:hover{background:color-mix(in srgb,var(--danger) 9%,transparent)!important}.lib-clear-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--muted);cursor:pointer;padding:2px;border-radius:4px}.lib-clear-btn:hover{color:var(--ink)}@media(max-width:560px){.lib-toolbar{flex-wrap:wrap}.lib-toolbar .library-search{min-width:0}}.library-groups{display:grid;gap:24px;min-width:0;width:100%;max-width:100%}.library-group{display:grid;gap:10px;min-width:0;width:100%;max-width:100%;container-type:inline-size}.library-group-head{display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid var(--line);padding-bottom:7px}.library-group-head h3{margin:0;font-family:Space Grotesk,sans-serif;font-size:16px;color:var(--ink);text-transform:capitalize}.library-group-head span{min-width:28px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--line-2);color:var(--muted);font-size:12px;font-weight:800}@media(max-width:900px){.lib-toolbar{flex-wrap:wrap}.lib-toolbar .library-search{flex-basis:100%;min-width:0;margin-bottom:2px}}@media(max-width:560px){.library-stats{gap:6px}.library-stats div{padding:7px 6px}.library-stats span{font-size:9px;letter-spacing:.06em}.library-stats strong{font-size:15px}.collections-hub-tab{padding:12px}}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.word-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:6px;margin-top:12px;min-width:0;width:100%;max-width:100%}.word-row{position:relative;display:flex;flex-direction:column;gap:3px;min-width:0;width:100%;max-width:100%;padding:9px 10px 8px 8px;background:var(--surface);border:1px solid var(--line);border-left-width:3px;border-left-color:var(--line);border-radius:8px;text-align:left;cursor:pointer;transition:border-color .18s var(--ease),background .18s var(--ease)}.word-row:hover{border-color:var(--primary);background:var(--surface-2)}.word-row--saved{border-left-color:#64748b!important}.word-row--learning{border-left-color:#3b82f6!important}.word-row--familiar{border-left-color:var(--warning)!important}.word-row--mastered{border-left-color:#16a34a!important}.word-row .wr-text{font-family:Space Grotesk,sans-serif;font-weight:600;font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:22px}.wr-bottom{display:flex;align-items:center;gap:5px;min-width:0}.wr-bottom .wr-trans{flex:1;font-size:13px;color:var(--ink-2);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.wr-meta{font-size:10px;color:var(--ink);font-weight:600;white-space:nowrap;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;max-width:40%;letter-spacing:.03em}.wr-actions{display:flex;align-items:center;gap:3px;flex-shrink:0}@container (max-width: 640px){.word-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr))}}@container (max-width: 430px){.wr-bottom{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center}.wr-meta{max-width:100%}.wr-actions{grid-row:1 / span 2;grid-column:2}}.wr-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;border:none;background:transparent;color:var(--ink);cursor:pointer;padding:0;transition:background .14s,color .14s}.wr-btn:hover{background:var(--line);color:var(--ink)}.wr-btn-del:hover{background:#ef44441f;color:var(--danger)}.wr-note-dot{position:absolute;top:9px;right:10px;display:flex;align-items:center;color:var(--muted-2);opacity:.7}.wr-coll-wrap{position:relative}.wr-coll-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:5px;min-height:15px;max-height:15px;overflow:hidden;align-content:flex-start}.wr-coll-tags--empty{pointer-events:none}.wr-coll-tag{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:600;letter-spacing:.04em;color:var(--ink);background:var(--line-2);border-radius:4px;padding:1px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.wr-status-wrap{position:relative}.wr-status{display:inline-flex;align-items:center;justify-content:center;gap:3px;min-width:0;max-width:92px;height:20px;padding:0 7px;border:1px solid transparent;border-radius:999px;color:#fff;font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;line-height:1;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wr-status:disabled{opacity:.65;cursor:wait}.wr-status--saved{background:#64748b;border-color:#64748b}.wr-status--learning{background:#3b82f6;border-color:#3b82f6}.wr-status--familiar{background:var(--warning);border-color:var(--warning)}.wr-status--mastered{background:#16a34a;border-color:#16a34a}.wr-status-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:210;min-width:150px;padding:5px;border:1px solid var(--line);border-radius:10px;background:var(--surface);box-shadow:0 12px 30px #00000029}.wr-status-option{width:100%;display:flex;align-items:center;gap:8px;border:0;border-radius:7px;background:transparent;color:var(--ink);padding:7px 8px;font-size:12px;font-weight:700;text-align:left;cursor:pointer}.wr-status-option:hover,.wr-status-option.active{background:var(--surface-2)}.wr-status-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.wr-status-dot--saved{background:#64748b}.wr-status-dot--learning{background:#3b82f6}.wr-status-dot--familiar{background:var(--warning)}.wr-status-dot--mastered{background:#16a34a}.wr-checkbox{position:absolute;top:9px;right:9px;color:var(--ink);display:flex;align-items:center}.word-row.selected{border-color:var(--primary);background:var(--primary-50)}.bulk-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;border-radius:12px;padding:10px 16px;box-shadow:0 8px 32px #00000038;z-index:300;white-space:nowrap;max-width:calc(100vw - 32px);overflow-x:auto}.bulk-count{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:13px;padding-right:6px;border-right:1px solid rgba(255,255,255,.18)}.bulk-select{background:#ffffff1f;border:1px solid rgba(255,255,255,.22);color:#fff;border-radius:7px;padding:6px 10px;font:inherit;font-size:13px;cursor:pointer}.bulk-select option{color:var(--ink);background:var(--surface)}.bulk-new-input{width:180px;min-width:0;border:1px solid rgba(255,255,255,.24);background:#ffffff1a;color:#fff;border-radius:8px;padding:7px 10px;font:inherit;font-size:13px}.bulk-new-input::placeholder{color:#ffffff94}.bulk-cancel{background:#fffffff5;color:var(--ink);border-color:#ffffffe0}.bulk-cancel:hover{background:#fff;color:var(--ink)}.bulk-select-all{background:#ffffff1f;color:#ffffffe6;border-color:#ffffff40}.bulk-select-all:hover:not(:disabled){background:#ffffff38;color:#fff}.bulk-sep{width:1px;height:20px;background:#ffffff38;flex-shrink:0}.bulk-label{font-size:12px;color:#ffffffa6;white-space:nowrap}.bulk-mastery-btn{font-size:12px;padding:5px 11px;opacity:.88}.bulk-mastery-btn:hover:not(:disabled){opacity:1}.bulk-mastery-saved{background:#64748b;color:#fff;border-color:#64748b}.bulk-mastery-learning{background:#3b82f6;color:#fff;border-color:#3b82f6}.bulk-mastery-familiar{background:var(--warning);color:#fff;border-color:var(--warning)}.bulk-mastery-mastered{background:#16a34a;color:#fff;border-color:#16a34a}.bulk-mastery-btn:disabled{opacity:.4;cursor:default}.coll-popover{position:absolute;top:calc(100% + 6px);right:0;width:215px;background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 28px #00000021;z-index:200}.coll-popover-header{padding:10px 12px 4px;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.coll-popover-list{list-style:none;margin:0;padding:2px 0;max-height:160px;overflow-y:auto}.coll-popover-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;font-size:13px;color:var(--ink);background:none;border:none;text-align:left;cursor:pointer;transition:background .12s}.coll-popover-item:hover{background:var(--surface-2)}.coll-popover-item.active{color:var(--primary)}.coll-popover-empty{padding:10px 12px;font-size:12px;color:var(--muted-2)}.coll-popover-new{display:flex;align-items:stretch;border-top:1px solid var(--line);padding:7px 8px}.coll-popover-new input{flex:1;min-height:unset;height:28px;padding:0 8px;font-size:12px;border:1px solid var(--line);border-right:none;border-radius:6px 0 0 6px;background:var(--surface-2);color:var(--ink)}.coll-popover-new input:focus{outline:none;border-color:var(--primary)}.coll-popover-new button{height:28px;width:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border:none;border-radius:0 6px 6px 0;cursor:pointer}.coll-popover-new button:disabled{opacity:.45;cursor:default}.card-wrap{display:flex;flex-direction:column;gap:0}.card-wrap .card{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:none}.card-wrap:hover .card{border-color:var(--primary)}.card-actions{display:flex;border:1px solid var(--line);border-top:none;border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius);overflow:hidden}.card-wrap:hover .card-actions{border-color:var(--primary)}.card-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:8px 4px;font-size:11px;font-weight:600;letter-spacing:.02em;cursor:pointer;border:none;background:var(--surface-2, var(--line-2));color:var(--muted);transition:background .15s,color .15s}.card-action-btn+.card-action-btn{border-left:1px solid var(--line)}.card-action-btn:hover:not(:disabled){background:var(--line);color:var(--ink)}.card-action-btn.action-saved:hover:not(:disabled){background:#64748b1f;color:#64748b}.card-action-btn.action-learning:hover:not(:disabled){background:#3b82f61f;color:#3b82f6}.card-action-btn.action-familiar:hover:not(:disabled){background:#d08c4b1f;color:var(--warning)}.card-action-btn.action-mastered:hover:not(:disabled){background:#16a34a1f;color:#16a34a}.card-action-btn:disabled{opacity:.5;cursor:default}.card{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:12px 16px;min-height:0;box-shadow:var(--shadow-sm);transition:border-color .24s var(--ease),box-shadow .24s var(--ease);display:flex;flex-direction:column;gap:6px;cursor:pointer}.card:hover{border-color:var(--primary);box-shadow:var(--shadow)}.card h3{font-family:Space Grotesk,sans-serif;font-size:15px;margin:0;font-weight:700;letter-spacing:-.01em;color:var(--ink)}.card .trans{color:var(--ink-2);margin:0;font-size:15px;font-weight:500}.tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto}.tag{background:var(--primary-50);color:var(--ink-2);border:1px solid var(--primary-100);border-radius:999px;padding:3px 10px;font-size:11px;font-weight:600;letter-spacing:.02em}.tag.muted{background:var(--primary-50);color:var(--muted-2);border-color:var(--primary-100)}.tag.ok{background:var(--success-50);color:var(--success);border:none}.tag-level{background:var(--primary-50);color:var(--ink-2);border:1px solid var(--primary-100)}.entry-meta-tags{display:flex;gap:7px;flex-wrap:wrap;margin:10px 0 16px}.empty{background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius);padding:44px;text-align:center;color:var(--muted);font-size:14px}.reverse-match{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius);padding:14px 16px;margin:-4px 0 18px;color:var(--primary-600)}.reverse-match.muted{color:var(--muted-2);background:var(--surface);border-color:var(--line)}.reverse-match span{display:block;margin-bottom:2px;font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.reverse-match strong{display:block;color:var(--ink);font-size:20px;line-height:1.2}.reverse-match p{margin:3px 0 0;color:var(--muted-2)}.link{display:inline-flex;gap:6px;align-items:center;color:var(--muted);margin-bottom:16px;font-size:14px;background:transparent;transition:color .24s var(--ease)}.link:hover{color:var(--primary)}.detail-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-top:8px}.detail-card-header{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.detail-card-body:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.detail-card-header{padding:36px 40px 28px;background:linear-gradient(180deg,var(--surface-2) 0%,var(--surface) 100%);border-bottom:1px solid var(--line-2);position:relative}.detail-header-actions{position:absolute;top:18px;right:18px;display:flex;gap:4px;align-items:center}.detail-action-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.detail-action-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--surface-2)}.detail-action-btn--del:hover{border-color:var(--danger);color:var(--danger);background:#ef44440f}.trans-editable{cursor:pointer;display:inline-flex;align-items:center;gap:5px}.trans-edit-icon{opacity:0;color:var(--muted);flex-shrink:0;transition:opacity .15s}.trans-editable:hover .trans-edit-icon{opacity:1}.trans-edit-input{font:inherit;font-size:inherit;color:inherit;background:var(--surface-2);border:1px solid var(--primary);border-radius:6px;padding:2px 8px;width:100%;outline:none;box-shadow:0 0 0 3px var(--primary-50)}.note-save-status{margin-left:8px;font-size:11px;font-weight:500;color:var(--muted)}.note-save-status.saved{color:var(--success)}.confirm-overlay{position:fixed;inset:0;background:#1d408066;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:2000}.confirm-dialog{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:28px 28px 22px;width:min(380px,calc(100vw - 40px));display:flex;flex-direction:column;gap:6px}.confirm-title{font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700;color:var(--ink);margin:0}.confirm-body{font-size:13px;color:var(--muted-2);margin:0 0 4px}.confirm-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.detail-card-body{padding:8px 40px 16px}.detail-card-body section{border-top:none;padding:20px 0}.detail-hero{padding:20px 0 24px;border-bottom:1px solid var(--line)}.detail-card-header .detail-hero{padding:0;border-bottom:none}.detail h1{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:40px;line-height:1.05;margin:4px 0 8px;letter-spacing:-.02em;color:var(--ink)}.detail .trans{font-size:22px;color:var(--ink-2);margin:0 0 18px;font-weight:500}.detail section{border-top:1px solid var(--line);padding:22px 0}.detail h4{font-family:Space Grotesk,sans-serif;font-size:10px;letter-spacing:.18em;font-weight:700;color:var(--muted);text-transform:uppercase;margin:0 0 12px}.detail-body{font-size:14px;color:var(--ink);line-height:1.65;margin:0}.ex-card{background:var(--surface-2);border-radius:10px;padding:13px 16px 13px 18px;margin:8px 0;border-left:3px solid var(--primary)}.ex-card b{display:block;font-size:14px;font-weight:600;margin-bottom:5px;color:var(--ink)}.ex-card em{color:var(--ink-2);font-style:normal;font-size:14px}.grammar-box{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:14px 16px;font-size:14px;color:var(--ink);line-height:1.65}.tags-section{border-top:1px solid var(--line);padding:22px 0;display:flex;flex-direction:column;gap:18px}.tags-group{display:flex;flex-direction:column;gap:8px}.tag-list{display:flex;flex-wrap:wrap;gap:7px}.tag{padding:5px 13px;border-radius:999px;background:var(--primary-50);border:1px solid var(--primary-100);font-size:13px;color:var(--ink-2);font-weight:500}.tag--ant{background:var(--surface-2);border-color:color-mix(in srgb,var(--danger) 30%,var(--line));color:var(--danger)}.tag--colloc{background:var(--primary-50);border-color:var(--primary-100);color:var(--ink-2)}.country-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px}.country-item{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:10px 14px;display:flex;flex-direction:column;gap:3px}.country-key{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.country-val{font-size:14px;color:var(--ink);font-weight:500}textarea{width:100%;min-height:110px;border:1px solid var(--line);border-radius:12px;padding:14px;background:var(--surface);color:var(--ink);font-family:inherit;font-size:14px;line-height:1.6;transition:border-color .24s var(--ease),box-shadow .24s var(--ease)}textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-100)}.notebook-textarea{--notebook-line: rgba(42, 31, 28, .105);--notebook-margin: rgba(204, 74, 43, .34);min-height:170px;padding:20px 22px 20px 56px;border-color:color-mix(in srgb,var(--line) 84%,var(--warm));border-radius:18px;background:linear-gradient(90deg,transparent 0 39px,var(--notebook-margin) 40px,transparent 41px),repeating-linear-gradient(180deg,transparent 0 31px,var(--notebook-line) 32px),linear-gradient(180deg,#fffdf7fa,#fff8edfa);background-attachment:local;color:var(--ink);font-family:DM Sans,sans-serif;font-size:16px;line-height:32px;box-shadow:inset 0 1px #ffffffb8,0 16px 36px -34px #2a1f1c6b}.notebook-textarea::placeholder{color:color-mix(in srgb,var(--muted) 78%,transparent)}.notebook-textarea:focus{border-color:color-mix(in srgb,var(--primary) 72%,var(--line));box-shadow:inset 0 1px #ffffffb8,0 0 0 4px color-mix(in srgb,var(--primary-100) 74%,transparent),0 20px 42px -34px #2a1f1c7a}.entry-notes-paper{min-height:190px;margin-top:4px}.danger{color:var(--danger);font-weight:600;display:inline-flex;gap:8px;align-items:center;margin-top:18px;font-size:14px;background:transparent}.danger:hover{text-decoration:underline}.mastery-row{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.mastery-row .chip{padding:7px 14px;border-radius:999px;border:1px solid var(--line);background:var(--surface);cursor:pointer;font-size:12px;font-weight:600;color:var(--muted-2);transition:all .24s var(--ease)}.mastery-row .chip:hover{border-color:var(--primary);color:var(--primary)}.mastery-row .chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.auth-card{width:min(680px,calc(100vw - 32px));background:linear-gradient(145deg,color-mix(in srgb,var(--primary) 94%,#fff 6%),var(--primary-600));color:#fffaf1;border:1px solid color-mix(in srgb,var(--primary-100) 28%,transparent);border-radius:var(--radius-lg);padding:48px 64px;box-shadow:0 30px 70px -26px #1d40809e}.auth-logo{display:flex;justify-content:center;margin:0 0 18px}.auth-logo img{display:block;width:min(380px,80%);max-height:168px;object-fit:contain;height:auto}.auth-card .brand{padding:0;margin-bottom:24px}.auth-card h1{font-family:Space Grotesk,sans-serif;font-size:28px;margin:6px 0 4px;font-weight:700;letter-spacing:-.02em;color:#fffaf1}.auth-card .sub{color:color-mix(in srgb,#fffaf1 80%,var(--primary-100));margin:0 0 22px;font-size:14px}.auth-card .hint{color:color-mix(in srgb,#fffaf1 72%,var(--primary-100))}.field{display:grid;gap:6px;margin-bottom:14px}.field label{font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;font-family:Space Grotesk,sans-serif}.auth-card .field label{color:color-mix(in srgb,#fffaf1 72%,var(--primary-100))}.field input{border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:12px 14px;font-size:14px;transition:border-color .24s var(--ease),box-shadow .24s var(--ease)}.auth-card .field input{border-color:color-mix(in srgb,var(--primary-100) 54%,transparent);background:#fffaf1f5;color:var(--ink)}.field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-100)}.auth-card .field input:focus{border-color:var(--warm);box-shadow:0 0 0 4px #f0b35f3d}.auth-card .btn{width:100%;justify-content:center;padding:14px;margin-top:4px}.auth-card .btn{background:var(--warm);border-color:var(--warm);color:var(--ink);box-shadow:0 18px 34px -22px #f0b35fd9}.auth-card .btn:hover{background:#f6c276;border-color:#f6c276}.auth-card .btn-ghost{background:#fffaf114;color:#fffaf1;border-color:#fffaf147}.auth-card .btn-ghost:hover{background:#fffaf124;color:#fffaf1;border-color:#fffaf16b}.auth-toggle{text-align:center;margin-top:14px;color:color-mix(in srgb,#fffaf1 76%,var(--primary-100));font-size:14px}.auth-toggle a{color:#fffaf1;font-weight:800}.auth-toggle a:hover{color:var(--warm)}.auth-switch{text-align:center;margin-top:14px;color:color-mix(in srgb,#fffaf1 72%,var(--primary-100));font-size:14px}.auth-switch-link{color:var(--warm);font-weight:700;text-decoration:underline}.auth-switch-link:hover{color:#f6c276}.auth-legal-links{display:flex;justify-content:center;gap:8px;margin-top:12px;color:var(--muted);font-size:12px}.auth-legal-links button{color:var(--muted);font-weight:700}.auth-legal-links button:hover{color:var(--primary)}.auth-confirm-icon{font-size:48px;text-align:center;margin:12px 0 16px}@media(max-width:560px){.auth-card{width:min(100%,calc(100vw - 24px));padding:32px 22px}.auth-logo img{width:min(280px,82%)}}.err{background:var(--danger-50);color:var(--danger);border:1px solid #fecaca;padding:10px 12px;border-radius:10px;font-size:13px;margin-bottom:12px}.practice-hub{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}@media(max-width:900px){.practice-hub{grid-template-columns:repeat(2,1fr)}}@media(max-width:520px){.practice-hub{grid-template-columns:1fr}}.practice-card{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:28px 22px 22px;border-radius:var(--radius-lg);background:var(--card-bg, hsl(222 47% 9%));border:1px solid rgba(255,255,255,.08);text-align:left;cursor:pointer;transition:transform .24s var(--ease),box-shadow .24s var(--ease),border-color .24s var(--ease);min-height:210px}.practice-card:before{content:"";position:absolute;top:-50px;left:-50px;width:220px;height:220px;border-radius:50%;background:var(--card-color, #4f8ef8);opacity:.13;filter:blur(55px);pointer-events:none;transition:opacity .3s var(--ease)}.practice-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--card-color, #4f8ef8) 0%,transparent 100%);opacity:.5;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.practice-card:hover:not(:disabled){transform:translateY(-6px);border-color:#ffffff26;box-shadow:0 28px 56px -18px #000000a6}.practice-card:hover:not(:disabled):before{opacity:.22}.practice-card>*{position:relative;z-index:1}.practice-card--locked{opacity:.5;cursor:not-allowed}.practice-card-icon{color:var(--card-color, #4f8ef8);margin-bottom:2px}.practice-card-title{font-family:Space Grotesk,sans-serif;font-size:17px;font-weight:700;color:#fff;line-height:1.25}.practice-card-desc{font-size:13px;color:#fff;line-height:1.5;margin:0;flex:1}.practice-card-footer{margin-top:auto}.practice-card-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:999px;background:#ffffff1a;color:#ffffffa6}.practice-card-badge--pro{background:var(--gold-50);color:var(--gold-bright)}.practice-back{display:inline-flex;align-items:center;gap:6px;margin-bottom:20px;padding:6px 14px;font-size:13px;font-weight:600;color:var(--muted);border-radius:999px;border:1px solid var(--line);background:var(--surface);cursor:pointer;transition:color .18s,border-color .18s}.practice-back:hover{color:var(--ink);border-color:var(--ink-2)}.practice-col-picker{display:flex;align-items:center;gap:10px;margin-bottom:14px}.practice-col-label{font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;white-space:nowrap}.practice-col-select{background:var(--card);border:1px solid var(--border);color:var(--fg);border-radius:8px;padding:6px 10px;font-size:13px;cursor:pointer;min-width:160px;max-width:260px}.practice-col-select:focus{outline:2px solid var(--accent);outline-offset:1px}.practice-exercise-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.practice-set-summary,.video-practice-summary{display:grid;grid-template-columns:auto minmax(120px,1fr) auto;align-items:center;gap:16px;margin:0 0 18px;padding:14px 16px;border:1px solid rgba(200,150,46,.28);border-radius:18px;background:#fffaf1d1;box-shadow:0 16px 38px -30px #49361f94}.practice-set-summary>div:first-child,.video-practice-summary>div:first-child{display:grid;gap:2px}.practice-set-kicker{font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--brown)}.practice-set-summary strong,.video-practice-summary strong{color:var(--ink);font-weight:900}.practice-set-meter{height:10px;border-radius:999px;background:#decfb8b3;overflow:hidden;box-shadow:inset 0 1px 2px #49361f1f}.practice-set-meter span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#1d4080,#0f8793,#e8b84a);transition:width .28s var(--ease)}.practice-set-score{justify-self:end;padding:7px 10px;border-radius:999px;background:#1d408014;color:var(--primary);font-size:12px;font-weight:900;white-space:nowrap}.practice-fc{display:grid;gap:14px}.practice-fc-done{display:flex;flex-direction:column;align-items:center;gap:16px;padding:64px 24px;color:var(--muted)}.practice-fc-done h3{font-family:Space Grotesk,sans-serif;font-size:22px;color:var(--ink);margin:0}.practice-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;align-items:center}.practice-tabs .chip{padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:var(--surface);font-weight:600;font-size:13px;color:var(--muted-2);transition:all .24s var(--ease)}.practice-tabs .chip:hover{color:var(--primary);border-color:var(--primary)}.practice-tabs .chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.picture-practice{display:grid;gap:18px}.picture-stage{display:grid;grid-template-columns:minmax(280px,.95fr) minmax(320px,1.05fr);gap:18px;align-items:stretch}.picture-photo-wrap{position:relative;min-height:420px;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);background:var(--line-2)}.picture-photo{width:100%;height:100%;object-fit:cover;display:block}.picture-photo-caption{position:absolute;left:18px;right:18px;bottom:18px;display:flex;align-items:center;gap:10px;color:#fff;text-shadow:0 1px 14px rgba(0,0,0,.48)}.picture-photo-caption span{background:#00000061;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900}.picture-photo-caption strong{font-family:Space Grotesk,sans-serif;font-size:24px}.picture-pad{border:1px solid var(--line);border-radius:var(--radius-lg);background:#fffaf1f0;box-shadow:var(--shadow);padding:22px;display:flex;flex-direction:column;gap:14px}.picture-pad-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.picture-pad h3{margin:6px 0 0;font-size:24px}.picture-pad textarea{flex:1;min-height:245px;resize:vertical;font-size:16px;line-height:32px}.picture-pad textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-100)}.picture-pad textarea.notebook-textarea:focus{box-shadow:inset 0 1px #ffffffb8,0 0 0 4px color-mix(in srgb,var(--primary-100) 74%,transparent),0 20px 42px -34px #2a1f1c7a}.picture-pad-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.picture-pad-footer span{color:var(--muted);font-size:13px;font-weight:700}.picture-support{border:1px dashed var(--line);border-radius:var(--radius);padding:14px;background:#fffaf18f}.picture-support-toggle{border:0;background:transparent;color:var(--primary);font-weight:800;cursor:pointer;padding:0}.picture-help-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:12px}.picture-help-grid h4,.picture-review h4{margin:0 0 10px;color:var(--brown);font-size:11px;letter-spacing:.14em;text-transform:uppercase}.picture-chip-list{display:flex;flex-wrap:wrap;gap:8px}.picture-chip-list button{border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:999px;padding:8px 11px;font-weight:800;cursor:pointer}.picture-chip-list button small{display:inline-block;margin-left:7px;color:var(--muted);font-weight:600}.picture-review{display:grid;grid-template-columns:1fr;gap:18px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);padding:20px}.picture-confidence-label{display:inline-flex;width:fit-content;margin:0 0 8px;padding:5px 10px;border-radius:999px;background:color-mix(in srgb,var(--success) 14%,var(--surface));color:color-mix(in srgb,var(--success) 78%,var(--ink));border:1px solid color-mix(in srgb,var(--success) 24%,var(--line));font-size:12px;font-weight:900}.picture-verdict{margin:0 0 14px;font-size:17px;color:var(--ink);font-weight:700}.picture-review-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.picture-review-grid>div,.picture-phrases{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fffaf1c7}.picture-review-grid p,.picture-review-columns p{margin:0;line-height:1.55}.picture-review-columns{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:16px}.picture-review-columns div{min-width:0}.picture-review-columns p{color:var(--muted-2);font-size:14px;margin-bottom:8px}.picture-phrases{margin-top:16px}.picture-phrase-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-top:1px solid var(--line)}.picture-phrase-row:first-of-type{border-top:0}.picture-phrase-row strong{display:block;color:var(--ink)}.picture-phrase-row span{display:block;color:var(--muted);font-size:13px;margin-top:2px}@media(max-width:940px){.picture-stage,.picture-review,.picture-review-grid,.picture-review-columns,.picture-help-grid{grid-template-columns:1fr}.picture-photo-wrap{min-height:320px}}.exercise{position:relative;overflow:hidden;background:linear-gradient(135deg,#ffffffb8,#fbf5eae6),var(--surface);border:1px solid rgba(200,150,46,.28);border-radius:20px;padding:24px;margin-bottom:16px;box-shadow:0 18px 42px -30px #49361f8c}.exercise:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:linear-gradient(180deg,#1d4080d9,#0f8793c2);opacity:.55;transition:background .22s var(--ease),opacity .22s var(--ease)}.exercise:after{content:"";position:absolute;right:-70px;top:-90px;width:210px;height:210px;border-radius:999px;background:radial-gradient(circle,rgba(232,184,74,.22),transparent 68%);pointer-events:none}.exercise>*{position:relative;z-index:1}.exercise--correct:before{background:#2f9b63;opacity:.9}.exercise--almost:before{background:var(--gold);opacity:.9}.exercise--wrong:before{background:#dc5148;opacity:.9}.exercise-topline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 12px}.exercise-topline span,.exercise-topline strong{display:inline-flex;align-items:center;min-height:28px;border-radius:999px;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.exercise-topline span{color:var(--brown)}.exercise-topline strong{padding:5px 9px;background:#1d408014;color:var(--primary)}.exercise--correct .exercise-topline strong{background:#e8f6ed;color:#16734a}.exercise--almost .exercise-topline strong{background:#fff2d6;color:#996334}.exercise--wrong .exercise-topline strong{background:#fde7e4;color:#a33a34}.exercise .prompt{font-family:Space Grotesk,sans-serif;font-size:clamp(17px,1.4vw,20px);margin:0 0 18px;font-weight:800;color:var(--ink);line-height:1.45}.gap-blank{display:inline-block;min-width:72px;border-bottom:3px solid var(--gold-bright);vertical-align:baseline;margin:0 2px 2px}.exercise-target-verb{display:inline-flex;align-items:baseline;gap:8px;margin:0 0 12px;padding:8px 12px;border:1px solid rgba(200,150,46,.45);border-radius:999px;background:linear-gradient(180deg,#fff4d6f2,#f8e8c8d1);color:var(--ink);box-shadow:0 8px 24px -18px #99633499}.exercise-target-verb span{font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep)}.exercise-target-verb strong{font-size:15px;font-weight:900;color:var(--ink)}.exercise .meta{color:var(--muted-2);font-size:13px;margin-bottom:12px}.exercise input.answer{width:100%;border:1px solid rgba(153,99,52,.24);border-radius:14px;padding:13px 15px;background:#fffaf1e6;color:var(--ink);font-size:15px;transition:border-color .24s var(--ease),box-shadow .24s var(--ease),background .24s var(--ease)}.exercise input.answer::placeholder{color:#7a8798}.exercise input.answer:focus{outline:none;border-color:var(--primary);background:#fffdfa;box-shadow:0 0 0 4px #1d40801f}.exercise input.answer.correct{border-color:#2f9b63;background:#eefaf2}.exercise input.answer.almost{border-color:var(--gold);background:#fff7e4}.exercise input.answer.wrong{border-color:#dc5148;background:#fff0ee}.exercise .feedback{margin-top:12px;padding:12px 14px;border-radius:14px;font-weight:800;font-size:14px;border:1px solid transparent}.exercise .feedback.ok,.exercise .feedback.correct{background:#e8f6ed;color:#16734a;border-color:#16734a2e}.exercise .feedback.almost{background:#fff2d6;color:#996334;border-color:#c8962e42}.exercise .feedback.bad,.exercise .feedback.wrong{background:#fde7e4;color:#a33a34;border-color:#a33a3433}.exercise .answer-reveal{color:var(--ink-2);font-size:14px;margin-top:12px;background:#fffaf1db;border-color:#99633433;box-shadow:inset 0 1px #ffffffb3}.exercise .answer-diff{color:var(--muted-2);margin:10px 0 0}.exercise .answer-diff .miss{background:#fff2d6;color:#b42318;border-bottom:2px solid #dc5148}.exercise .opts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}.exercise .opt{text-align:left;min-height:52px;padding:13px 16px;border:1.5px solid rgba(153,99,52,.25);border-radius:14px;background:#fffaf1e0;cursor:pointer;font-size:15px;font-weight:800;color:var(--ink);box-shadow:0 10px 26px -24px #49361fcc;transition:transform .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease),box-shadow .18s var(--ease)}.exercise .opt:hover:not(:disabled){transform:translateY(-1px);background:#fff7e4;border-color:var(--gold);box-shadow:0 16px 30px -24px #49361fe6}.exercise .opt.correct{background:#e8f6ed;border-color:#2f9b63;color:#155f3f;font-weight:900}.exercise .opt.wrong{background:#fde7e4;border-color:#dc5148;color:#8f2f2a;font-weight:800}.exercise .opt:disabled{cursor:default}@media(max-width:720px){.practice-set-summary,.video-practice-summary{grid-template-columns:1fr;gap:10px}.practice-set-score{justify-self:start}.exercise{padding:20px;border-radius:18px}.exercise .opts{grid-template-columns:1fr}}.lesson{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;margin-bottom:18px;box-shadow:var(--shadow-sm)}.lesson-done-badge{font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--success, #22c55e);background:#22c55e1a;border-radius:999px;padding:3px 10px;white-space:nowrap}.lesson-complete-banner{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--radius);background:#22c55e1a;color:var(--success, #22c55e);font-weight:700;font-size:15px}.card--done{background:var(--success-50);border-color:#4f9b7866}.card--done h3{color:var(--success)}.card--done .trans{opacity:.75}.card--done:hover{border-color:var(--success);box-shadow:var(--shadow-sm)}.card--next{border-color:var(--primary);border-width:2px;box-shadow:var(--shadow-primary)}.card--next:hover{box-shadow:var(--shadow)}.card--locked{opacity:.45;cursor:not-allowed!important;pointer-events:none}.card--locked:hover{border-color:var(--line);box-shadow:var(--shadow-sm)}.card--quiz{background:#d08c4b14;border-color:#d08c4b73}.card--quiz h3{color:var(--warning)}.card--quiz:hover{border-color:var(--warning)}.card--quiz.card--done{background:var(--success-50);border-color:#4f9b7866}.card--quiz.card--done h3{color:var(--success)}.score-fail-banner{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius);background:var(--danger-50);color:var(--danger);font-weight:600;font-size:14px}.lesson-reorder-list{display:flex;flex-direction:column;gap:5px;margin-top:8px}.lesson-reorder-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);transition:border-color .12s,background .12s,opacity .12s;-webkit-user-select:none;user-select:none;cursor:default}.lesson-reorder-item.dragging{opacity:.35}.lesson-reorder-item.drag-over{border-color:var(--primary);background:var(--primary-50)}.drag-handle{cursor:grab;color:var(--muted-2);flex-shrink:0;display:flex;align-items:center;padding:2px}.drag-handle:active{cursor:grabbing}.lesson-up-next{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius);padding:14px 18px;margin-bottom:8px}.lesson-up-next-label{font-size:11px;font-weight:700;letter-spacing:.07em;color:var(--primary);text-transform:uppercase;margin-bottom:2px}.lesson-up-next h4{margin:0;font-family:Space Grotesk,sans-serif;font-size:15px;font-weight:700;color:var(--ink)}.lesson-up-next .trans{color:var(--muted-2);font-size:13px;margin:2px 0 0}.lesson-progress{font-size:12px;color:var(--muted);margin:4px 0 16px}.lesson h3{font-family:Space Grotesk,sans-serif;font-size:24px;margin:0 0 8px;font-weight:700;letter-spacing:-.02em}.lesson .key{display:grid;gap:6px;padding-left:18px;margin:10px 0;color:var(--ink-2)}.quiz-q{border-top:1px solid var(--line);padding-top:16px;margin-top:16px}.quiz-q .opts{display:grid;gap:8px;margin-top:10px}.exercise-editor-row{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:8px;background:var(--surface-2);overflow:hidden}.exercise-editor-item{display:flex;align-items:flex-start;gap:12;padding:12px 14px;justify-content:space-between}.exercise-editor-meta{flex:1;min-width:0}.exercise-editor-meta p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exercise-editor-actions{display:flex;gap:4px;align-items:center;flex-shrink:0;margin-left:12px}.exercise-form{border-top:1px solid var(--line);padding:16px;background:var(--surface)}.quiz-q .opt{text-align:left;padding:11px 14px;border:1px solid var(--line);border-radius:12px;background:var(--surface);transition:all .24s var(--ease)}.quiz-q .opt:hover{border-color:var(--primary)}.quiz-q .opt.correct{background:var(--success-50);border-color:var(--success);color:var(--success);font-weight:600}.quiz-q .opt.wrong{background:var(--danger-50);border-color:var(--danger);color:var(--danger)}.selection-popover{position:fixed;z-index:80;transform:translate(-50%);width:min(320px,calc(100vw - 24px));padding:14px 16px;border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--shadow-lg);color:var(--ink)}.selection-popover:before{content:"";position:absolute;left:50%;top:-7px;width:12px;height:12px;transform:translate(-50%) rotate(45deg);background:var(--surface);border-left:1px solid var(--line);border-top:1px solid var(--line)}.selection-term{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:17px;margin-bottom:4px;color:var(--ink)}.selection-translation{color:var(--primary);font-size:16px;line-height:1.4;font-weight:600}.selection-muted,.selection-error,.selection-source{color:var(--muted-2);font-size:12px}.selection-error{color:var(--danger)}.selection-source{display:flex;justify-content:space-between;gap:10px;margin-top:8px;text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:600}.selection-add{width:100%;margin-top:12px;padding:10px 12px;border-radius:10px;background:var(--primary);color:#fff;font-weight:600;font-size:13px;transition:background .24s var(--ease)}.selection-add:hover{background:var(--primary-600)}.selection-add:disabled{cursor:default;opacity:.65}.selection-coll-row{margin-top:8px;border-top:1px solid var(--line);padding-top:8px}.selection-coll-toggle{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--muted);background:transparent;border:none;cursor:pointer;padding:2px 0;transition:color .14s}.selection-coll-toggle:hover{color:var(--primary)}.selection-coll-chips{display:flex;flex-wrap:wrap;gap:5px}.selection-coll-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:4px 9px;border-radius:999px;border:1px solid var(--line);background:var(--surface-2);color:var(--muted);cursor:pointer;transition:border-color .14s,color .14s,background .14s}.selection-coll-chip:hover{border-color:var(--primary);color:var(--primary)}.selection-coll-chip.done{border-color:var(--success);color:var(--success);background:var(--success-50);cursor:default}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;display:inline-block;vertical-align:middle}.btn-ghost .spinner,.search .spinner{border:2px solid var(--line);border-top-color:var(--primary)}.add .spinner{border:2px solid rgba(255,255,255,.2);border-top-color:var(--gold-bright)}.modal-backdrop{position:fixed;inset:0;background:#0f172a59;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;max-width:460px;width:100%;box-shadow:var(--shadow-lg)}.modal h3{font-family:Space Grotesk,sans-serif!important;font-weight:700;letter-spacing:-.02em}.main-header{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:32px}.main-header .greet-sub{color:var(--muted-2);margin:4px 0 0;font-size:14px}.streak-pill{display:inline-flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:12px 16px;box-shadow:var(--shadow-sm)}.streak-pill .num{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:22px;color:var(--warning);display:inline-flex;align-items:center;gap:6px}.streak-pill .meta{display:flex;flex-direction:column;line-height:1.15}.streak-pill .meta .lbl{font-family:Space Grotesk,sans-serif;font-size:10px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;font-weight:700}.streak-pill .meta .sub{font-size:12px;color:var(--ink-2);font-weight:600}.level-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:0 0 24px}.level-label{font-family:Space Grotesk,sans-serif;font-size:11px;letter-spacing:.16em;font-weight:700;color:var(--muted);text-transform:uppercase}.level-chips{display:flex;gap:6px;flex-wrap:wrap}.level-chips .chip,.chip{padding:6px 14px;border-radius:999px;border:1px solid var(--line);font-size:12px;font-weight:600;color:var(--muted-2);background:var(--surface);transition:all .24s var(--ease)}.level-chips .chip:hover{color:var(--primary);border-color:var(--primary)}.level-chips .chip.active,.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.chip--saved.active{background:#64748b;border-color:#64748b;color:#fff}.chip--learning.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.chip--familiar.active{background:var(--warning);border-color:var(--warning);color:#fff}.chip--mastered.active{background:#16a34a;border-color:#16a34a;color:#fff}.dash-grid{display:grid;gap:20px;grid-template-columns:repeat(12,1fr)}.dash-mobile-page{display:contents}.widget-progress-page0{display:none!important}@media(min-width:761px)and (max-width:900px){.widget-progress-page0{display:block!important}.widget-progress-page0{padding:14px 16px}.widget-progress-page0 .progress-list{gap:7px}.widget-progress-page0 .progress-track{height:5px}.widget-progress-page0 .progress-item .progress-meta{font-size:12px}.widget-progress-page0 .widget-h{margin-bottom:8px}.widget-progress-page0 .widget-sub{display:none}}@media(min-width:901px){.widget-recent-videos-compact{display:none!important}}.widget{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.widget-hero{grid-column:span 8;position:relative;overflow:hidden}.widget-goal{grid-column:span 4}.widget-suggestions{grid-column:span 8}.widget-wod-compact{grid-column:span 4}.widget-progress{grid-column:span 12}.widget-week{grid-column:span 6}.widget-streak{grid-column:span 4}.widget-recents{grid-column:span 12;background:transparent;border:0;padding:0;box-shadow:none}.widget-h{margin-bottom:16px;display:flex;flex-direction:column;gap:4px}.widget-eyebrow{font-family:Space Grotesk,sans-serif;font-size:11px;letter-spacing:.16em;font-weight:700;color:var(--muted);text-transform:uppercase}.widget-sub{color:var(--muted-2);font-size:13px}.widget-hero{background:radial-gradient(1200px 320px at -10% -40%,rgba(59,130,246,.1),transparent 60%),radial-gradient(800px 260px at 110% 120%,rgba(99,102,241,.08),transparent 60%),var(--surface);padding:36px;min-height:280px;justify-content:space-between}.hero-eyebrow{font-family:Space Grotesk,sans-serif;font-size:11px;letter-spacing:.16em;font-weight:700;color:var(--primary);text-transform:uppercase}.hero-title{font-family:Space Grotesk,sans-serif;font-size:30px;line-height:1.1;margin:10px 0 8px;font-weight:700;letter-spacing:-.02em;color:var(--ink);max-width:540px}.hero-lead{color:var(--muted-2);margin:0 0 18px;max-width:520px;font-size:14px}.hero-stats{display:flex;align-items:center;gap:20px;margin:0 0 20px}.hero-stats>div{display:flex;flex-direction:column;gap:2px}.hero-stat-num{font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-.01em}.hero-stat-lbl{font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-weight:600}.hero-stat-sep{width:1px;height:28px;background:var(--line)}.hero-actions{display:flex;gap:10px;flex-wrap:wrap}.hero-steps{list-style:none;padding:0;margin:4px 0 20px;display:flex;flex-direction:column;gap:8px}.hero-steps li{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--ink-2);font-weight:500}.hero-steps li span{width:24px;height:24px;border-radius:50%;background:var(--primary-50);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-family:Space Grotesk,sans-serif;font-weight:700;font-size:12px}.widget-goal{align-items:stretch}.goal-ring-wrap{position:relative;align-self:center;margin:6px 0 14px;width:120px;height:120px}.goal-ring{display:block}.goal-ring-track{fill:none;stroke:var(--line-2);stroke-width:10}.goal-ring-fill{fill:none;stroke:var(--primary);stroke-width:10;stroke-linecap:round;transition:stroke-dasharray .5s var(--ease)}.goal-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.goal-num{font-family:Space Grotesk,sans-serif;font-size:26px;font-weight:700;color:var(--ink);letter-spacing:-.02em}.goal-num small{font-size:14px;color:var(--muted);font-weight:600}.goal-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;font-weight:700}.goal-streak{display:inline-flex;align-items:center;gap:8px;align-self:center;background:var(--primary-50);color:var(--primary);padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600}.goal-streak b{font-family:Space Grotesk,sans-serif;font-weight:700}.suggestion-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.suggestion-card{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:6px;cursor:pointer;transition:transform .24s var(--ease),border-color .24s var(--ease),box-shadow .24s var(--ease)}.suggestion-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:var(--shadow)}.suggestion-eyebrow{display:inline-flex;align-items:center;gap:6px;font-family:Space Grotesk,sans-serif;font-size:10px;letter-spacing:.14em;font-weight:700;text-transform:uppercase;color:var(--muted)}.suggestion-card.tone-review .suggestion-eyebrow{color:var(--primary)}.suggestion-card.tone-new .suggestion-eyebrow{color:var(--indigo)}.suggestion-card.tone-challenge .suggestion-eyebrow{color:var(--warning)}.suggestion-card h4{font-family:Space Grotesk,sans-serif;font-size:18px;margin:2px 0 0;font-weight:700;letter-spacing:-.01em;color:var(--ink)}.suggestion-card .trans{color:var(--ink-2);font-size:14px;margin:0;font-weight:500}.suggestion-cta{margin-top:auto;padding-top:8px;display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--primary)}.widget-wod-compact .wod-compact-text{font-family:Space Grotesk,sans-serif;font-size:26px;margin:4px 0;font-weight:700;letter-spacing:-.015em;color:var(--ink)}.widget-wod-compact .trans{color:var(--ink-2);font-size:15px;margin:0 0 12px;font-weight:500}.widget-wod-compact .wod-compact-actions{display:flex;align-items:center;gap:8px;margin-top:auto;flex-wrap:wrap}.btn.btn-sm{padding:7px 12px;font-size:13px;box-shadow:none}.progress-list{display:flex;flex-direction:column;gap:14px}.progress-item .progress-meta{display:flex;justify-content:space-between;font-size:12px;font-weight:600;margin-bottom:6px;font-family:Space Grotesk,sans-serif}.progress-item .progress-meta .count{color:var(--muted)}.progress-track{width:100%;height:8px;background:var(--line-2);border-radius:999px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;transition:width .4s var(--ease)}.widget-week{background:var(--primary);color:#fff;border-color:transparent;box-shadow:var(--shadow-primary)}.widget-week .widget-eyebrow{color:#ffffffbf}.widget-week .widget-sub{color:#fffc}.widget-week .week-num{font-family:Space Grotesk,sans-serif;font-size:38px;font-weight:700;line-height:1;margin-top:8px;display:inline-flex;align-items:center;gap:10px;letter-spacing:-.02em}.widget-week .week-sub{color:#ffffffd9;font-size:13px;margin-top:6px}.recents-head{display:flex;justify-content:space-between;align-items:center;margin:8px 0 16px}.recents-head h2{font-size:20px;margin:0;font-weight:700;letter-spacing:-.01em}.recents-head .link-blue{color:var(--primary);font-size:13px;font-weight:600}@media(max-width:1100px){.widget-hero,.widget-goal,.widget-suggestions,.widget-wod-compact,.widget-progress{grid-column:span 12}.widget-week{grid-column:span 6}}@media(max-width:760px){.widget-progress,.widget-week{grid-column:span 12}.suggestion-grid{grid-template-columns:1fr}.hero-title{font-size:24px}}.main-header{padding-right:150px;margin-bottom:28px}.main-header .greet-sub{color:var(--muted-2);margin-top:10px}.dash-grid{gap:22px}.widget{background:#fffaf1f0;border-color:var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.widget-h{margin-bottom:18px}.widget-eyebrow,.hero-eyebrow{color:var(--brown);font-weight:900;letter-spacing:.14em}.widget-sub,.hero-lead{color:var(--muted-2)}.widget-hero{min-height:292px;padding:28px;background:radial-gradient(circle at 83% 12%,rgba(29,64,128,.2),transparent 34%),linear-gradient(135deg,#fffaf1f7,#fffaf1bd),linear-gradient(90deg,#fff1d9 0 62%,#d7e9e5 62% 100%)}.hero-title{font-size:clamp(26px,2.35vw,31px);line-height:1.08;color:var(--ink);letter-spacing:0}.hero-stats{gap:22px}.hero-stat-num{color:var(--ink);font-size:29px}.hero-stat-lbl{color:var(--ink);font-size:10px;font-weight:900}.hero-stat-sep{background:#1d40801f}.hero-actions .btn{border-radius:16px;padding:13px 18px;font-weight:900}.widget-goal{color:#fffaf1;min-height:292px;justify-content:space-between;overflow:hidden;border-color:#fffaf12e;background:radial-gradient(circle at 84% 12%,rgba(255,250,241,.08),transparent 34%),linear-gradient(135deg,#0f1729,#1a293c);box-shadow:var(--shadow-primary)}.widget-goal .widget-eyebrow,.widget-goal .widget-sub{color:var(--gold-bright);letter-spacing:.1em}.goal-momentum{display:grid;grid-template-columns:124px minmax(0,1fr);align-items:center;gap:18px;flex:1;min-width:0}.goal-ring-track{stroke:#fffaf129}.goal-ring-fill{stroke:var(--gold-bright);filter:drop-shadow(0 0 10px var(--gold-glow))}.goal-ring-center .goal-num{color:#fffaf1;font-size:29px}.widget-goal .goal-num small,.widget-goal .goal-lbl{color:#fffaf1b8}.goal-streak,.streak-pill{background:#c8962e2e;color:var(--gold-bright);border:1px solid rgba(200,150,46,.28);box-shadow:none}.streak-pill{padding:6px 12px;border-radius:999px}.streak-pill .num{color:var(--gold-bright);font-size:13px}.streak-pill .meta .lbl{color:var(--gold-bright);letter-spacing:.12em}.streak-pill .meta .sub{color:#e8b84ab8;font-size:12px}.momentum-stats{display:grid;gap:12px;min-width:0}.momentum-stat{padding:12px 13px;border:1px solid rgba(200,150,46,.22);border-radius:18px;background:#c8962e14;min-width:0}.momentum-stat span{display:block;margin-bottom:8px;color:#e8b84abf;font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.momentum-stat strong{display:inline-flex;align-items:center;gap:8px;color:#fffaf1;font-family:Space Grotesk,sans-serif;font-size:clamp(24px,2.45vw,34px);line-height:1;white-space:nowrap}.momentum-stat p{margin:8px 0 0;color:#fffaf1d1;font-size:13px}.widget-goal .streak-pill{justify-content:flex-start;padding:10px 12px;border:1px solid rgba(200,150,46,.3);background:#c8962e24}.widget-goal .streak-pill .num{color:var(--gold-bright)}.widget-goal .streak-pill .meta .lbl,.widget-goal .streak-pill .meta .sub{color:#e8b84ae6}@media(max-width:1320px){.widget-hero,.widget-goal{grid-column:span 12}.widget-goal{min-height:0}.goal-momentum{grid-template-columns:120px minmax(0,1fr)}.momentum-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}.widget-suggestions,.widget-wod-compact,.widget-progress{background:#fffaf1f0}.suggestion-grid{gap:14px}.suggestion-card{min-height:160px;border-color:var(--line);border-radius:20px;background:#fffaf1c7;box-shadow:none}.suggestion-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.suggestion-card.tone-review .suggestion-eyebrow,.suggestion-card.tone-new .suggestion-eyebrow,.suggestion-card.tone-challenge .suggestion-eyebrow{color:var(--primary-600)}.suggestion-card h4,.widget-wod-compact .wod-compact-text{font-size:20px;color:var(--ink)}.suggestion-card .trans,.widget-wod-compact .trans{color:var(--muted-2)}.suggestion-cta{color:var(--primary)}.tag{background:var(--primary-50);color:var(--primary-600);font-weight:800}.tag.muted{background:var(--line-2);color:var(--muted-2)}.tag.ok{background:var(--success-50);color:var(--success)}.tag.tag-level{background:var(--primary-50);color:var(--primary-600)}.progress-track{background:#eadfcf}.progress-fill.saved{background:#64748b}.progress-fill.learning{background:#3b82f6}.progress-fill.familiar{background:var(--warning)}.progress-fill.mastered{background:#16a34a}.widget-week{color:#fffaf1;background:radial-gradient(circle at 84% 12%,rgba(255,250,241,.08),transparent 34%),linear-gradient(135deg,#0f1729,#1a293c);box-shadow:var(--shadow-primary)}.widget-week .widget-eyebrow,.widget-week .widget-sub,.widget-week .week-sub{color:#fffaf1d6}.widget-week .week-num{color:#fffaf1;font-size:48px;line-height:1}@media(max-width:760px){.goal-momentum{grid-template-columns:1fr;justify-items:center}.momentum-stats{width:100%}}.recents-head h2{font-size:22px;letter-spacing:0}.card,.card-actions{background:#fffaf1f0;border-color:var(--line)}.card h3{color:var(--ink)}.card:hover,.card-wrap:hover .card,.card-wrap:hover .card-actions{border-color:var(--primary)}.dot-mastery.saved{background:#64748b!important}.dot-mastery.learning{background:#3b82f6!important}.dot-mastery.familiar{background:var(--warning)!important}.dot-mastery.mastered{background:#16a34a!important}.session-back-btn{width:fit-content;margin-bottom:18px;padding:9px 14px;border-color:var(--line);background:color-mix(in srgb,var(--surface) 92%,transparent);color:var(--ink-2);box-shadow:0 10px 24px -20px #2a1f1c8c}.session-back-btn:hover{border-color:var(--primary);background:var(--primary-50);color:var(--primary)}.session-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin:8px 0 0}.session-title{flex:1;min-width:280px;border:0;background:transparent;font-family:Space Grotesk,sans-serif;font-weight:700;font-size:32px;line-height:1.1;letter-spacing:-.025em;color:var(--ink);padding:4px 0;border-bottom:1px solid transparent}.session-title:focus{outline:none;border-bottom-color:var(--primary)}.session-date{border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:8px 14px;color:var(--muted-2);font-size:13px}.session-layout{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:24px;align-items:start;margin-top:24px}.session-side-wrap{position:sticky;top:24px}@media(max-width:980px){.session-layout{grid-template-columns:1fr}.session-side-wrap{position:static}}.notebook{position:relative;--notebook-line: rgba(42, 31, 28, .095);--notebook-margin: rgba(204, 74, 43, .3);background:linear-gradient(90deg,transparent 0 43px,var(--notebook-margin) 44px,transparent 45px),repeating-linear-gradient(180deg,transparent 0 31px,var(--notebook-line) 32px),linear-gradient(180deg,#fffdf7fa,#fff8edfa);background-attachment:local;border:1px solid color-mix(in srgb,var(--line) 84%,var(--warm));border-radius:var(--radius-lg);padding:32px 36px 44px 64px;min-height:68vh;box-shadow:inset 0 1px #ffffffb8,var(--shadow-sm)}.notebook-label{font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;font-weight:700;display:block;margin-bottom:18px;background:color-mix(in srgb,var(--surface) 78%,transparent);width:fit-content;padding:3px 8px 3px 0}.notebook-editor-wrap{width:100%}.notebook-editor-wrap .notebook-toolbar{width:fit-content;margin-bottom:18px;background:color-mix(in srgb,var(--surface) 88%,transparent);border:1px solid color-mix(in srgb,var(--line) 76%,transparent);border-radius:12px;padding:4px;box-shadow:0 12px 24px -24px #2a1f1c61}.notebook-toolbar .icon-btn.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}.notebook-toolbar .icon-btn:disabled{opacity:.45;cursor:not-allowed}.note-tool-sep{width:1px;margin:4px 3px;background:#2a1f1c24}.notebook-editor{border:0;background:transparent;padding:0;font-family:DM Sans,sans-serif;font-size:16px;line-height:32px;color:var(--ink);min-height:60vh;box-shadow:none}.notebook-editor:focus{outline:none;box-shadow:none;border:0}.notebook-editor h2,.notebook-editor h3{margin:1.1em 0 .45em;font-family:Fraunces,serif}.notebook-editor h2{font-size:1.35rem}.notebook-editor h3{font-size:1.15rem}.notebook-editor ul,.notebook-editor ol{margin:.55em 0 .55em 1.4em;padding:0}.notebook-editor blockquote{margin:.9em 0;padding:.2em 0 .2em 1em;border-left:2px solid var(--primary);color:var(--muted)}.notebook-editor p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--muted);pointer-events:none;height:0}.session-reflection{margin-top:28px;padding-top:24px;border-top:1px solid color-mix(in srgb,var(--line) 82%,transparent)}.session-reflection-lead{margin:-4px 0 14px;color:var(--muted-2);font-size:14px;line-height:1.5}.session-reflection-targets{margin-bottom:14px}.session-reflection .target-chip{background:color-mix(in srgb,var(--surface) 82%,transparent)}.session-reflection-textarea{min-height:118px;background:linear-gradient(90deg,transparent 0 39px,rgba(204,74,43,.26) 40px,transparent 41px),repeating-linear-gradient(180deg,transparent 0 30px,rgba(42,31,28,.085) 31px),#fffdf7b8;padding-left:58px;line-height:31px}.session-reflection-feedback{display:grid;gap:12px}@media(max-width:640px){.notebook{padding:24px 20px 34px 48px}.notebook-textarea{padding-left:48px}}.session-side{display:flex;flex-direction:column;gap:14px}.side-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}.side-card h4{font-family:Space Grotesk,sans-serif;font-size:11px;letter-spacing:.16em;font-weight:700;color:var(--muted);text-transform:uppercase;margin:0 0 12px;display:flex;justify-content:space-between;align-items:baseline}.side-card h4 .count{font-family:Space Grotesk,sans-serif;font-weight:700;color:var(--primary);font-size:14px;letter-spacing:0}.side-add{background:var(--sidebar);border-color:#ffffff1a}.side-add h4{color:var(--gold-bright)}.side-add .add-row{flex-direction:column;gap:8px;margin:0}.side-add .add-row .btn{width:100%;justify-content:center}.side-words{max-height:52vh;overflow-y:auto;padding-right:2px}.side-words::-webkit-scrollbar{width:6px}.side-words::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}.side-words .word-row{border:1px solid var(--line);border-radius:12px;background:var(--surface);margin-bottom:8px;overflow:hidden;transition:border-color .24s var(--ease)}.side-words .word-row:hover{border-color:var(--primary)}.word-row-head{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;text-align:left}.word-row-head:hover{background:var(--line-2)}.word-row-head .word-text{font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:600;color:var(--ink)}.word-row-head .word-trans{color:var(--muted-2);margin-left:4px;flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.word-row-body{padding:6px 14px 14px;border-top:1px solid var(--line);display:grid;gap:10px;font-size:13px}.word-row-body h5{font-family:Space Grotesk,sans-serif;font-size:10px;letter-spacing:.16em;color:var(--muted);font-weight:700;text-transform:uppercase;margin:8px 0 4px}.bottom-nav,.dash-page-fab,.mobile-top-logo,.mobile-topbar-strip,.mobile-home-btn,.mobile-strip-right,.mobile-hamburger,.mobile-goal-btn,.mobile-lookup-btn,.lookup-panel-overlay{display:none}.quick-lookup-panel{position:fixed;top:44px;left:0;right:0;z-index:150;background:radial-gradient(circle at 80% 0%,rgba(255,250,241,.07),transparent 50%),linear-gradient(135deg,#0f1729,#1a293c);border-bottom:1px solid rgba(255,250,241,.12);padding:12px 16px 16px;transform:translateY(calc(-100% - 50px));transition:transform .28s cubic-bezier(.4,0,.2,1);pointer-events:none;display:none}.quick-lookup-panel.open{transform:translateY(0);pointer-events:all}.lookup-form{display:flex;align-items:center;gap:8px}.lookup-icon{color:#fffaf180;flex-shrink:0}.lookup-input{flex:1;min-width:0;background:#ffffff14;border:1.5px solid rgba(255,250,241,.18);border-radius:10px;padding:8px 12px;color:#fffaf1;font:inherit;font-size:15px;outline:none}.lookup-input::placeholder{color:#fffaf166}.lookup-input:focus{border-color:var(--gold-bright)}.lookup-btn{background:var(--warm);border:none;border-radius:10px;padding:8px 14px;color:var(--sidebar);font:inherit;font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0;white-space:nowrap}.lookup-btn:disabled{opacity:.5;cursor:not-allowed}.lookup-close{background:none;border:none;color:#fffaf180;cursor:pointer;padding:4px;flex-shrink:0;display:flex}.lookup-result{margin-top:12px;padding:12px 14px;background:#ffffff12;border:1px solid rgba(255,250,241,.12);border-radius:12px}.lookup-word{font-size:20px;font-weight:700;color:#fffaf1;display:block;margin-bottom:2px}.goal-sheet-overlay{display:none}.goal-bottom-sheet{position:fixed;left:0;right:0;bottom:0;height:67vh;background:var(--sidebar);border-radius:20px 20px 0 0;z-index:200;transform:translateY(100%);transition:transform .3s ease;overflow-y:auto;padding:8px 20px 40px}.goal-bottom-sheet.open{transform:translateY(0)}.goal-sheet-handle{width:40px;height:4px;background:#ffffff40;border-radius:2px;margin:0 auto 20px;cursor:pointer}.mobile-drawer-overlay{display:none}.mobile-drawer{position:fixed;top:0;left:0;bottom:0;width:260px;background:var(--sidebar);z-index:300;transform:translate(-100%);transition:transform .25s ease;display:flex;flex-direction:column;padding:24px 0 32px;box-shadow:4px 0 24px #0000004d}.mobile-drawer.open{transform:translate(0)}.mobile-drawer-close{align-self:flex-end;margin-right:16px;margin-bottom:16px;background:none;border:none;color:var(--sidebar-muted);cursor:pointer;padding:4px}.mobile-drawer-item{display:flex;align-items:center;gap:14px;padding:16px 24px;background:none;border:none;color:var(--warm);font-size:16px;font-weight:500;cursor:pointer;text-align:left;width:100%;transition:background .15s}.mobile-drawer-item:hover{background:#ffffff0f}@media(max-width:900px){.paper{flex-direction:column;background:var(--bg);background-image:none}.mobile-topbar-strip{display:flex;align-items:center;position:fixed;top:0;left:0;right:0;height:44px;background:var(--sidebar);z-index:90;padding:0 8px}.topbar{width:100%;flex:0 0 auto;height:141px;position:relative;margin-top:44px;flex-direction:row;align-items:flex-start;justify-content:space-between;padding:8px 12px 0 4px;gap:0;overflow:visible}.topbar>.nav{display:none}.topbar>.sidebar-note{display:none}.topbar>.language-switcher{display:none}.topbar>.legal-links{display:none}.topbar>.brand.brand-logo{display:none}.topbar>.nav-icon-row{display:none}.brand{padding:4px;flex-shrink:0}.mobile-topbar-strip{display:flex;justify-content:space-between;align-items:center}.mobile-strip-right{display:flex;align-items:center;gap:0}.mobile-home-btn,.mobile-lookup-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--warm);cursor:pointer;padding:8px;flex-shrink:0}.lookup-panel-overlay{display:block;position:fixed;inset:0;background:#0006;z-index:149}.quick-lookup-panel{display:block}.quick-lookup-panel.open{transform:translateY(0);pointer-events:all}.mobile-hamburger,.mobile-goal-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--warm);cursor:pointer;padding:8px;flex-shrink:0}.goal-sheet-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:199}.dash-grid .widget-goal{display:none}.goal-bottom-sheet .widget-goal{display:flex;grid-column:unset}.widget-quick-search{display:none}.widget-recent-videos-compact{display:block}.widget-recent-videos{display:none}.dash-mobile-page{display:flex;flex-direction:column;gap:20px;grid-column:1 / -1}.mobile-drawer-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:299}.mobile-top-logo{display:block;height:108px;width:auto;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.nav-icon-row{border:0;padding:0;margin-left:auto;gap:2px}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--sidebar);border-top:1px solid rgba(200,150,46,.2);z-index:100;padding-bottom:env(safe-area-inset-bottom,0);align-items:stretch}.bottom-nav .tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 2px;min-height:56px;color:var(--sidebar-muted);background:none;border:none;border-left:none!important;cursor:pointer;font-family:inherit;font-size:10px;font-weight:600;letter-spacing:.01em;min-width:0;transition:color .2s}.bottom-nav .tab span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.bottom-nav .tab svg{width:22px;height:22px;flex-shrink:0;background:none!important;border-radius:0!important;padding:0!important;color:inherit}.bottom-nav .tab.active{color:var(--gold-bright)}.wrap,.detail{padding:20px 16px 90px}.word-row{padding:5px 8px;gap:0px}.word-row .wr-text{font-size:15px;padding-right:0}.wr-bottom .wr-trans{font-size:14px}.wr-note-dot{display:none}.wr-coll-tags{display:none!important}.wr-meta,.wr-status-wrap,.wr-coll-wrap{display:none}.wr-btn-del{width:34px;height:34px;border-radius:8px}.dash-grid>*{grid-column:span 12}h1.display,.detail h1{font-size:32px}.detail-card-header{padding:24px 20px 20px}.detail-card-body{padding:0 20px 8px}.session-title{min-width:0;font-size:22px;width:100%}.session-header{flex-direction:column;align-items:flex-start;gap:8px}.session-date{align-self:flex-start}.session-layout{gap:16px;grid-template-columns:minmax(0,1fr)}.session-layout>*{min-width:0;overflow:hidden}.notebook{padding:20px 14px 28px;background:repeating-linear-gradient(180deg,transparent 0 31px,var(--notebook-line) 32px),linear-gradient(180deg,#fffdf7fa,#fff8edfa);min-height:40vh}.notebook-editor-wrap .notebook-toolbar{width:100%;max-width:100%;display:flex;flex-wrap:wrap}.notebook-toolbar{flex-wrap:wrap;width:100%}.side-card{width:100%}.side-card .seg{width:100%;display:flex}.side-card .seg button{flex:1}.sessions-toolbar{gap:8px}.sessions-search{max-width:100%}.session-date-input{flex:1 1 auto;min-width:0}}.settings-page{max-width:640px;margin:0 auto}.settings-back{display:inline-flex;align-items:center;gap:6px;margin-bottom:18px}.settings-card{background:var(--surface, #fff);border:1px solid var(--line);border-radius:16px;padding:22px;margin-bottom:18px}.settings-card-head{display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.08em;font-weight:700;color:var(--muted-2);text-transform:uppercase;margin-bottom:16px}.settings-card-head svg{color:var(--primary)}.settings-card .field{margin-bottom:16px}.plan-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.paywall-wall{background:var(--warm-soft);border:1px solid #e8d4a8;border-radius:var(--radius-sm);padding:14px 18px;margin:10px 0 14px}.paywall-wall p{margin:0 0 4px;font-weight:600;color:var(--brown)}.paywall-wall .hint{color:var(--muted-2);font-size:13px}.lesson-rich{line-height:1.7;color:var(--ink, #2a2a2a)}.lesson-rich h1,.lesson-rich h2,.lesson-rich h3{font-family:inherit;font-weight:700;line-height:1.25;margin:1.4em 0 .5em;color:var(--ink, #2a2a2a)}.lesson-rich h1{font-size:1.7rem}.lesson-rich h2{font-size:1.35rem}.lesson-rich h3{font-size:1.1rem}.lesson-rich p{margin:.7em 0}.lesson-rich ul,.lesson-rich ol{margin:.6em 0 .6em 1.4em;padding:0}.lesson-rich li{margin:.25em 0}.lesson-rich a{color:var(--accent, #b35a2a);text-decoration:underline;text-underline-offset:2px}.lesson-rich blockquote{margin:1em 0;padding:.6em 1em;border-left:3px solid var(--accent, #b35a2a);background:#b35a2a0f;border-radius:6px;font-style:italic;color:var(--muted, #6b6b6b)}.lesson-rich code{background:#0000000d;padding:.1em .4em;border-radius:4px;font-size:.9em}.lesson-rich pre{background:#1a1a1a;color:#f0f0f0;padding:14px 16px;border-radius:10px;overflow-x:auto;font-size:.9em}.lesson-rich pre code{background:transparent;padding:0;color:inherit}.lesson-rich img{max-width:100%;height:auto;border-radius:10px;box-shadow:0 6px 18px #00000014;margin:.8em 0}.lesson-rich strong{font-weight:700}.lesson-rich em{font-style:italic}.lesson-rich table,.le-editor table{border-collapse:separate;border-spacing:0;width:100%;margin:1em 0;border-radius:10px;overflow:hidden;box-shadow:0 1px 3px #0000000d;border:1px solid var(--line, #e5dccb)}.lesson-rich th,.lesson-rich td,.le-editor th,.le-editor td{padding:10px 14px;border-bottom:1px solid var(--line, #e5dccb);border-right:1px solid var(--line, #e5dccb);text-align:left;vertical-align:top}.lesson-rich th,.le-editor th{background:#b35a2a14;font-weight:600;color:var(--ink, #2a2a2a)}.lesson-rich tr:last-child td,.le-editor tr:last-child td{border-bottom:none}.lesson-rich td:last-child,.lesson-rich th:last-child,.le-editor td:last-child,.le-editor th:last-child{border-right:none}.lesson-rich tbody tr:nth-child(2n) td{background:#00000004}.le-wrap{border:1px solid var(--line, #e5dccb);border-radius:12px;background:var(--card, #fff);overflow:hidden;margin-top:12px}.le-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:2px;padding:8px 10px;border-bottom:1px solid var(--line, #e5dccb);background:var(--bg-soft, #faf6ee);position:sticky;top:0;z-index:5}.le-btn{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:30px;padding:0 7px;background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;color:var(--ink, #2a2a2a);font-size:12px;font-weight:600}.le-btn:hover:not(:disabled){background:#0000000d}.le-btn.is-active{background:var(--accent, #b35a2a);color:#fff}.le-btn:disabled{opacity:.35;cursor:not-allowed}.le-sep{width:1px;height:20px;background:var(--line, #e5dccb);margin:0 4px}.le-status{font-size:12px;color:var(--muted, #6b6b6b)}.le-editor{min-height:320px;padding:18px 22px;outline:none}.le-editor:focus{outline:none}.le-editor p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:#b8a98a;pointer-events:none;height:0}.le-editor .ProseMirror-selectednode{outline:2px solid var(--accent, #b35a2a);border-radius:6px}.widget-quick-search{grid-column:span 12;background:radial-gradient(circle at 84% 12%,rgba(255,250,241,.08),transparent 34%),linear-gradient(135deg,#0f1729,#1a293c)!important;border-color:#fffaf12e!important;box-shadow:var(--shadow-primary)!important}.widget-quick-search .widget-eyebrow{color:var(--gold-bright)}.widget-quick-search .widget-sub{color:#fffaf18c}.quick-search-row{display:flex;gap:10px;align-items:stretch}.quick-search-input{flex:1;padding:10px 14px;border:1.5px solid rgba(255,250,241,.18);border-radius:var(--radius-sm);background:#ffffff0f;font-size:15px;color:#fffaf1;outline:none;transition:border-color .15s,background .15s}.quick-search-input:focus{border-color:var(--gold-bright);background:#ffffff1a}.quick-search-input::placeholder{color:#fffaf161}.widget-quick-search .btn{background:var(--warm);color:var(--sidebar);border-color:var(--warm);font-weight:700}.widget-quick-search .btn:hover:not(:disabled){background:var(--gold-bright);border-color:var(--gold-bright)}.widget-quick-search .btn:disabled{opacity:.5}.quick-search-result{margin-top:16px;padding:14px 16px;background:#ffffff0f;border:1px solid rgba(255,250,241,.13);border-radius:var(--radius-sm)}.quick-search-word{font-size:20px;font-weight:700;color:#fffaf1;line-height:1.2}.widget-quick-search .trans{color:#fffaf1bf}.widget-quick-search .tag{background:#ffffff1a;color:#fffaf1b3;border-color:transparent}.widget-quick-search .tag.ok{background:#34d39926;color:#34d399;border-color:transparent}.widget-quick-search .btn-sm{background:transparent;color:var(--warm);border-color:var(--warm);font-weight:600}.widget-quick-search .btn-sm:hover:not(:disabled){background:var(--warm);color:var(--sidebar)}.onboarding-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px 32px 32px;width:100%;max-width:440px;box-shadow:0 4px 24px #00000014}.onboarding-levels{display:flex;flex-direction:column;gap:8px}.onboarding-level-btn{display:flex;align-items:center;gap:14px;width:100%;padding:12px 14px;background:var(--surface-2);border:2px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s,background .15s;text-align:left}.onboarding-level-btn:hover,.onboarding-level-btn.active{border-color:var(--primary);background:var(--primary-50)}.onboarding-level-btn.active .onboarding-level-tag{background:var(--primary);color:#fff}.onboarding-level-tag{font-size:13px;font-weight:800;letter-spacing:.03em;padding:4px 10px;border-radius:8px;background:var(--line);color:var(--ink-2);flex-shrink:0;min-width:36px;text-align:center;transition:background .15s,color .15s}@media(max-width:480px){.onboarding-card{padding:24px 16px 20px}}.brand.brand-logo{padding:8px 0 4px;display:flex;align-items:center;justify-content:flex-start}.brand.brand-logo img{width:100%;max-width:230px;height:auto;display:block}.col-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}.col-loading{padding:40px;text-align:center;color:var(--muted);font-size:14px}.col-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.col-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;text-align:left;cursor:pointer;transition:border-color .22s var(--ease),box-shadow .22s var(--ease),transform .18s var(--ease);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px}.col-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}.col-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.col-card-title{font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-card-desc{font-size:13px;color:var(--muted-2);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.col-card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:auto}.col-count{font-size:12px;font-weight:700;color:var(--muted)}.col-vis-pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;letter-spacing:.04em;padding:3px 9px;border-radius:999px;flex-shrink:0}.col-vis-pill.private{background:var(--line-2);color:var(--muted-2)}.col-vis-pill.public{background:var(--primary-50);color:var(--primary)}.col-detail{display:flex;flex-direction:column;gap:0}.col-back-btn{align-self:flex-start;margin-bottom:20px}.col-detail-header{margin-bottom:24px}.col-detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.col-detail-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:10px}.col-detail-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;flex-shrink:0}.col-words-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.col-exercises-panel{margin:24px 0 8px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden}.col-exercises-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--surface)}.col-exercises-loading{display:flex;flex-direction:column;align-items:center;gap:10px;padding:40px 20px;color:var(--muted)}.col-exercises-list{display:flex;flex-direction:column;gap:1px;background:var(--line)}.col-ex-card{background:var(--bg);padding:18px 20px;display:flex;flex-direction:column;gap:12px;transition:background .15s}.col-ex-card.col-ex-correct{background:#f4faf7}.col-ex-card.col-ex-wrong{background:#faf4f4}.col-ex-meta{display:flex;align-items:center;gap:8px}.col-ex-num{width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.col-ex-type{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.col-ex-prompt{font-size:15px;font-weight:500;color:var(--ink);margin:0;line-height:1.5}.col-ex-options{display:flex;flex-wrap:wrap;gap:8px}.col-ex-opt{padding:7px 14px;border-radius:8px;border:1.5px solid var(--line);background:var(--surface);font-size:14px;cursor:pointer;transition:border-color .15s,background .15s;color:var(--text);font-family:inherit}.col-ex-opt:hover:not(:disabled){border-color:var(--primary);background:var(--primary-soft, #eef2ff)}.col-ex-opt:disabled{cursor:default}.col-ex-opt-correct{border-color:#16a34a!important;background:#e8f7ee!important;color:#15803d;font-weight:600}.col-ex-opt-wrong{border-color:#dc2626!important;background:#f9ecec!important;color:#b91c1c}.col-ex-reveal-row{display:flex;align-items:center;gap:10px}.col-ex-answer{font-size:15px;color:var(--ink);background:#eaf6ee;border:1px solid hsl(142 40% 80%);border-radius:8px;padding:8px 14px}.col-ex-footer{display:flex;flex-direction:column;gap:6px}.col-ex-hint-btn{align-self:flex-start;font-size:12px;color:var(--primary);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline;font-family:inherit}.col-ex-hint{font-size:13px;color:var(--muted);margin:0;font-style:italic}.col-ex-explanation{font-size:13px;color:var(--ink-2);margin:0}.col-ex-verdict{font-size:13px;font-weight:600;margin:0}.col-ex-verdict-ok{color:#15803d}.col-ex-verdict-err{color:#b91c1c}.col-words-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:6px;min-width:0;width:100%;max-width:100%;container-type:inline-size}.col-word-row{background:var(--surface);border:1px solid var(--line);border-radius:8px;overflow:hidden;transition:border-color .18s var(--ease),background .18s var(--ease)}.col-word-row:hover{border-color:var(--primary);background:var(--surface-2)}.col-word-row .wr-actions{gap:5px}.col-word-row .wr-status{pointer-events:none}.col-word-main{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;gap:12px}.col-word-content{display:flex;align-items:baseline;gap:10px;flex:1;min-width:0}.col-word-es{font-weight:700;font-size:15px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-word-en{color:var(--muted-2);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-word-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.col-word-expand,.col-word-btn{display:inline-flex;align-items:center;justify-content:center;padding:6px;border-radius:8px;color:var(--muted);transition:background .15s,color .15s}.col-word-expand:hover,.col-word-btn:hover{background:var(--line-2);color:var(--ink)}.col-word-btn.danger:hover{background:var(--danger-50);color:var(--danger)}.col-word-extra{padding:0 16px 12px;display:flex;flex-direction:column;gap:4px}.col-word-example{font-size:13px;color:var(--muted-2);margin:0}.col-word-notes{font-size:13px;color:var(--muted);margin:0}.col-word-form{background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius);padding:16px;margin-bottom:12px;display:flex;flex-direction:column;gap:10px}.col-word-form input{flex:1;border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:10px 12px;font-size:14px;color:var(--ink);transition:border-color .2s,box-shadow .2s}.col-word-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.col-word-form-row{display:flex;gap:10px;flex-wrap:wrap}.col-word-form-btns{display:flex;gap:8px;justify-content:flex-end}.modal-overlay{position:fixed;inset:0;background:#121d267a;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:100}.modal-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.modal-header h3{font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700;margin:0}.modal-close{color:var(--muted);padding:6px;border-radius:8px;transition:background .15s,color .15s}.modal-close:hover{background:var(--line-2);color:var(--ink)}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.modal-body p{margin:0;color:var(--muted-2);font-size:14px;line-height:1.5}.modal-row{display:flex;gap:12px}.modal-row .field-label{flex:1}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:0 24px 20px}.modal-warn{display:flex;gap:10px;align-items:flex-start;background:#fff8ec;border:1px solid #f0c87a;border-radius:10px;padding:12px 14px;color:var(--warning);font-size:13px}.modal-warn svg{flex-shrink:0;margin-top:2px}.modal-warn p{margin:0;color:var(--ink-2)}.field-label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--muted-2)}.field-label input,.field-label select,.field-label textarea{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:10px 12px;font-size:14px;color:var(--ink);font-family:inherit;transition:border-color .2s,box-shadow .2s}.field-label input:focus,.field-label select:focus,.field-label textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626;border-color:#dc2626}.btn.btn-ghost.btn-danger{background:transparent;color:var(--danger);border-color:var(--line)}.btn.btn-ghost.btn-danger:hover{background:var(--danger-50);border-color:var(--danger)}.collections-hub{display:flex;flex-direction:column;gap:18px}.collections-hub-hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-end}.collections-hub-hero .section-title{margin-bottom:4px}.collections-hub-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:4px}.collections-hub-tab{min-width:0;text-align:left;padding:14px 15px;border:1px solid rgba(255,255,255,.1);border-radius:14px;background:var(--sidebar);box-shadow:var(--shadow-primary);display:grid;grid-template-columns:auto minmax(0,1fr);column-gap:10px;row-gap:1px;align-items:center;transition:border-color .18s var(--ease),background .18s var(--ease),transform .18s var(--ease)}.collections-hub-tab:hover{border-color:#fff3;background:#16213c;transform:translateY(-1px)}.collections-hub-tab.active{border-color:var(--gold);background:var(--gold-bright);box-shadow:0 4px 16px #c8962e66}.collections-hub-tab>span{grid-row:span 2;width:32px;height:32px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:#fffaf1d9;background:#ffffff1a;border:1px solid rgba(255,255,255,.12)}.collections-hub-tab.active>span{color:var(--sidebar);background:#0f1e3a26;border-color:#0f1e3a33}.collections-hub-tab strong{font-family:Space Grotesk,system-ui,sans-serif;font-size:14px;color:#fffaf1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collections-hub-tab.active strong{color:var(--sidebar);font-weight:900;-webkit-font-smoothing:auto}.collections-hub-tab small{color:#fffaf1b8;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collections-hub-tab.active small{color:var(--sidebar);opacity:.7}.col-panel-title{margin:0 0 4px;font-size:24px;letter-spacing:0}.regional-panel{display:flex;flex-direction:column;gap:14px}.regional-picker{display:flex;flex-wrap:wrap;gap:8px}.discover-page{display:flex;flex-direction:column}.discover-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center}.filter-select-wrap{position:relative;display:inline-flex;align-items:center}.filter-select{appearance:none;-webkit-appearance:none;border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:8px 32px 8px 12px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;transition:border-color .2s}.filter-select:focus{outline:none;border-color:var(--primary)}.filter-select-icon{position:absolute;right:10px;pointer-events:none;color:var(--muted)}.discover-tabs{display:flex;gap:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;width:fit-content;margin-bottom:24px;background:var(--surface)}.discover-tab{padding:9px 20px;font-size:13px;font-weight:700;color:var(--muted-2);border-right:1px solid var(--line);transition:background .18s,color .18s}.discover-tab:last-child{border-right:none}.discover-tab:hover{background:var(--line-2);color:var(--ink)}.discover-tab.active{background:var(--primary);color:#fff}.discover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.discover-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;transition:border-color .22s var(--ease),box-shadow .22s var(--ease)}.discover-card:hover{border-color:var(--primary-100);box-shadow:var(--shadow)}.discover-card-body{padding:18px 20px 12px;flex:1}.discover-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px}.discover-card-creator{display:flex;align-items:center;gap:8px;cursor:pointer;color:var(--muted-2);font-size:13px;font-weight:600;transition:color .15s}.discover-card-creator:hover{color:var(--primary)}.creator-avatar{width:28px;height:28px;border-radius:999px;background:var(--primary-50);color:var(--primary);font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.creator-avatar img{width:100%;height:100%;object-fit:cover}.discover-card-tags{display:flex;gap:5px;flex-wrap:wrap}.discover-card-title{font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700;color:var(--ink);margin:0 0 4px;letter-spacing:-.01em}.discover-card-desc{font-size:13px;color:var(--muted-2);margin:0 0 10px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.discover-card-stats{display:flex;gap:14px;font-size:12px;color:var(--muted);font-weight:600;margin-top:8px}.discover-card-stats span{display:flex;align-items:center;gap:4px}.discover-card-stats svg.liked,.disc-icon-btn.like-active svg{color:#e85d5d}.disc-icon-btn.like-active svg{fill:#e85d5d}.disc-icon-btn.saved{border-color:#16a34a;color:#16a34a;background:color-mix(in srgb,#16a34a 14%,transparent)}.disc-icon-btn.saved svg{color:#16a34a;stroke-width:3}.discover-card-preview{padding:12px 20px 4px;border-top:1px solid var(--line-2);background:var(--bg);display:flex;flex-direction:column;gap:6px}.discover-word-row{display:flex;gap:10px;align-items:baseline;font-size:13px}.discover-card-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:10px}.disc-card-actions{display:flex;gap:6px;flex-shrink:0}.disc-icon-btn{width:30px;height:30px;border:1.5px solid var(--border);border-radius:6px;background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:border-color .15s,color .15s,background .15s;padding:0}.disc-icon-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.disc-icon-btn.active{border-color:var(--primary);color:var(--primary);background:color-mix(in srgb,var(--primary) 12%,transparent)}.disc-icon-btn:disabled{opacity:.55;cursor:default}.profile-page{display:flex;flex-direction:column;gap:0}.profile-header{display:flex;gap:24px;align-items:flex-start;margin:20px 0 32px;padding:28px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.profile-avatar-lg{width:72px;height:72px;border-radius:999px;background:var(--primary-50);color:var(--primary);font-size:28px;font-weight:900;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.profile-avatar-lg img{width:100%;height:100%;object-fit:cover}.profile-info{flex:1}.profile-name{font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:800;margin:0 0 4px;color:var(--ink)}.profile-username{font-size:14px;color:var(--muted);margin:0 0 8px}.profile-bio{font-size:14px;color:var(--muted-2);margin:0;line-height:1.5}.profile-section-title{display:flex;align-items:center;gap:8px;font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700;color:var(--ink);margin-bottom:16px}.profile-edit-input{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:8px 12px;font-size:16px;font-weight:700;font-family:Space Grotesk,sans-serif;color:var(--ink);width:100%}.profile-edit-bio{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:8px 12px;font-size:14px;color:var(--ink);width:100%;resize:vertical;font-family:inherit;margin-top:8px}.profile-edit-input:focus,.profile-edit-bio:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:var(--sidebar);color:#fffaf1;padding:12px 24px;border-radius:999px;font-size:14px;font-weight:600;box-shadow:0 8px 32px #123f4952;z-index:200;animation:toast-in .22s var(--ease);white-space:nowrap}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.col-add-bar{background:var(--sidebar);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:14px 16px;margin-bottom:16px;display:flex;flex-direction:column;gap:0;box-shadow:var(--shadow-primary)}.col-add-input{width:100%;border:1px solid rgba(255,255,255,.14);background:#ffffff12;border-radius:10px;padding:11px 14px;font-size:14px;color:#fffaf1;font-family:inherit;transition:border-color .2s,box-shadow .2s}.col-add-input::placeholder{color:#fffaf1a6}.col-add-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #c8962e38}.col-add-bar .btn{background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 100%);border-color:var(--gold);color:#1a1200;font-weight:800;box-shadow:0 4px 14px #c8962e59}.col-add-bar .btn:hover{filter:brightness(1.08);border-color:var(--gold)}.col-add-bar .btn:disabled{opacity:.55;filter:none}.col-suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);z-index:50;overflow:hidden}.col-suggestions-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:8px 14px 4px}.col-suggestion-row{display:flex;align-items:baseline;gap:10px;width:100%;padding:9px 14px;text-align:left;transition:background .14s}.col-suggestion-row:hover{background:var(--primary-50)}.col-suggestion-kind{font-size:11px;color:var(--muted);margin-left:auto;flex-shrink:0}.col-mastery-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.legal-links{display:flex;justify-content:flex-start;gap:10px;padding:0 8px;margin-top:-14px}.legal-links button{padding:0;color:var(--sidebar-muted);font-size:11px;font-weight:700;text-decoration:underline;text-underline-offset:3px;opacity:.72}.legal-links button:hover,.legal-links button.active{color:#fffaf1;opacity:1}.legal-page{max-width:860px;margin:0 auto;padding-bottom:80px}.legal-hero{margin:22px 0 28px;padding-bottom:28px;border-bottom:1px solid var(--line)}.legal-hero span{display:block;margin-bottom:12px;color:var(--primary);font-size:12px;font-weight:900;letter-spacing:.22em;text-transform:uppercase}.legal-hero h1{margin:0;font-family:var(--serif);font-size:clamp(44px,7vw,78px);line-height:.95}.legal-hero p{margin:16px 0 0;color:var(--muted)}.legal-card{border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--surface) 88%,transparent);box-shadow:var(--shadow-soft);padding:clamp(22px,4vw,40px)}.legal-card section+section{margin-top:26px;padding-top:24px;border-top:1px solid var(--line)}.legal-card h2{margin:0 0 10px;font-family:var(--serif);font-size:24px}.legal-card p{margin:0 0 10px;color:var(--ink);line-height:1.68}@media(max-width:680px){.col-grid,.discover-grid{grid-template-columns:1fr}.col-detail-title-row{flex-direction:column}.col-detail-actions{width:100%}.modal-row{flex-direction:column}.profile-header{flex-direction:column;align-items:center;text-align:center}.legal-links{width:100%;justify-content:center}}.sessions-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-top:24px}.sessions-toolbar-right{display:flex;gap:8px;margin-left:auto;flex-wrap:wrap}.sessions-search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:8px 12px;flex:1 1 260px;max-width:420px;color:var(--muted)}.sessions-search input{flex:1;border:0;outline:0;background:transparent;font:inherit;color:var(--ink);padding:0}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--muted);cursor:pointer;transition:all .18s var(--ease)}.icon-btn:hover{background:var(--line-2);color:var(--ink)}.seg{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:10px;overflow:hidden}.seg button{background:transparent;border:0;padding:7px 14px;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--muted);cursor:pointer;transition:all .18s var(--ease)}.seg button:hover{color:var(--ink)}.seg button.on{background:var(--primary);color:#fff}.tag-soft{background:var(--line-2);color:var(--ink);border-radius:999px;padding:3px 10px;font-size:12px;display:inline-flex;align-items:center;gap:4px}.tag-chip{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 12px;font-size:12px;color:var(--muted);cursor:pointer;transition:all .18s var(--ease);font-family:Space Grotesk,sans-serif;font-weight:600}.tag-chip:hover{color:var(--ink);border-color:var(--ink)}.tag-chip.on{background:var(--primary);color:#fff;border-color:var(--primary)}.tag-filter-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:14px}.tag-filter-label{font-family:Space Grotesk,sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700;margin-right:4px}.tag-x{display:inline-flex;align-items:center;justify-content:center;border:0;background:transparent;cursor:pointer;padding:0;color:var(--muted)}.tag-x:hover{color:var(--ink)}.dot-sep{margin:0 4px;color:var(--muted-2)}.calendar{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}.cal-head{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px}.cal-month{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:16px;text-transform:capitalize}.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:700;color:var(--muted);text-align:center;text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-cell{min-height:88px;border:1px solid var(--line);border-radius:10px;padding:6px;display:flex;flex-direction:column;gap:4px;background:var(--bg, var(--surface))}.cal-cell.empty{border-color:transparent;background:transparent}.cal-cell.has{border-color:var(--primary);background:var(--surface)}.cal-day{font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:2px}.cal-pill{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--primary);color:#fff;border:0;border-radius:6px;cursor:pointer;font-size:11px;font-weight:600;text-align:left;transition:filter .15s var(--ease)}.cal-pill:hover{filter:brightness(1.1)}.cal-pill-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-pill-count{background:#ffffff40;padding:1px 6px;border-radius:999px;font-size:10px}.session-meta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin:6px 0 14px}.session-teacher{border:0;border-bottom:1px dashed var(--line);background:transparent;padding:4px 0;font-family:Space Grotesk,sans-serif;font-size:14px;color:var(--ink);min-width:200px}.session-teacher:focus{outline:none;border-bottom-color:var(--primary)}.session-teacher::placeholder{color:var(--muted-2)}.session-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center;flex:1}.session-tags input{border:0;background:transparent;outline:0;font:inherit;color:var(--ink);min-width:160px;padding:4px 0}.session-tags input::placeholder{color:var(--muted-2);font-size:13px}.notebook-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}.notebook-bar .notebook-label{margin:0}.notebook-toolbar{display:inline-flex;gap:2px;background:var(--line-2);border-radius:8px;padding:2px}.notebook-toolbar .icon-btn{width:26px;height:26px;border-radius:6px}.notebook-status{margin-left:auto;display:inline-flex;align-items:center;gap:12px;font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--muted);letter-spacing:.05em}.notebook-wc{color:var(--muted-2)}.fc-progress{font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px;text-align:center}.flashcard{position:relative;width:100%;height:160px;border:0;padding:0;cursor:pointer;perspective:1000px;background:transparent}.fc-face{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border-radius:14px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);backface-visibility:hidden;transition:transform .5s var(--ease);padding:16px}.fc-front{transform:rotateY(0)}.fc-back{transform:rotateY(180deg);background:var(--primary);color:#fff;border-color:var(--primary)}.flashcard.flipped .fc-front{transform:rotateY(-180deg)}.flashcard.flipped .fc-back{transform:rotateY(0)}.fc-word{font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700;color:var(--ink);text-align:center}.fc-trans{font-size:20px;font-weight:600;text-align:center}.fc-hint{font-family:Space Grotesk,sans-serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.fc-actions{display:flex;gap:8px;margin-top:10px}.fc-actions .btn{flex:1;justify-content:center}@media(max-width:640px){.cal-cell{min-height:64px;padding:4px}.cal-pill-title{display:none}.sessions-toolbar-right{margin-left:0}}.journal-card{margin-top:24px;background:radial-gradient(circle at 10% 0%,rgba(255,190,92,.14),transparent 28%),linear-gradient(180deg,#fffaf2,#fff7ec);border-radius:var(--radius-lg, 16px);box-shadow:var(--shadow, 0 10px 30px -10px rgba(0,0,0,.12));overflow:hidden;border:1px solid hsl(var(--border, 220 14% 92%))}.journal-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 24px;background:linear-gradient(135deg,hsl(var(--primary)/.08),transparent 70%);border-bottom:1px solid hsl(var(--border, 220 14% 92%))}.journal-title{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;color:hsl(var(--foreground))}.journal-header-right{display:inline-flex;align-items:center;gap:10px}.streak-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:#fee7d7;color:#a14112}.streak-chip.is-today{background:#fa7938;color:#fff}.journal-card-body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:18px}.journal-prompt-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:hsl(var(--muted-foreground, 220 9% 46%))}.journal-prompt h3{font-size:22px;line-height:1.25;margin:4px 0 2px}.journal-prompt-helper{font-size:12px;color:hsl(var(--muted-foreground, 220 9% 46%));font-style:italic}.journal-prompt-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:-4px}.journal-prompt-chip{border:1px solid var(--line);background:#ffffffb8;color:#2b211d;border-radius:999px;padding:7px 11px;font:inherit;font-size:12px;line-height:1;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease}.journal-prompt-chip:hover{transform:translateY(-1px);border-color:#cf563661}.journal-prompt-chip.active{background:#0e7c86;color:#fff;border-color:#0e7c86;box-shadow:0 8px 18px #0e7c862e}.journal-targets-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:12px;color:hsl(var(--muted-foreground, 220 9% 46%));text-transform:uppercase;letter-spacing:.05em}.journal-targets-list{display:flex;flex-wrap:wrap;gap:8px}.target-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 8px 6px 12px;border-radius:999px;background:hsl(var(--muted, 220 14% 96%));border:1px solid hsl(var(--border, 220 14% 92%));font-size:13px;transition:all .15s ease}.target-chip strong{font-weight:600}.target-chip em{font-style:normal;color:hsl(var(--muted-foreground, 220 9% 46%));font-size:12px}.target-chip.used{background:#dbfae6;border-color:#99e6b5;color:#196636}.target-chip.used em{color:#2d864d}.target-chip-x{background:transparent;border:none;cursor:pointer;padding:2px;opacity:.5;display:inline-flex}.target-chip-x:hover{opacity:1}.journal-writing-shell{position:relative;overflow:hidden;border:1px solid hsl(var(--border, 220 14% 88%));border-radius:16px;background:#fffdf7;box-shadow:inset 0 1px #ffffffd9}.journal-writing-label{position:absolute;top:10px;right:14px;z-index:1;color:#8f7d6a;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;pointer-events:none}.journal-textarea{width:100%;min-height:190px;padding:38px 18px 18px 54px;border:0;border-radius:0;background:linear-gradient(90deg,transparent 0 39px,rgba(207,86,54,.24) 39px 40px,transparent 40px),repeating-linear-gradient(180deg,transparent 0 31px,rgba(43,33,29,.08) 31px 32px),#fffdf7;color:hsl(var(--foreground));font-family:inherit;font-size:15px;line-height:32px;resize:vertical}.journal-textarea:focus{outline:none;box-shadow:inset 0 0 0 2px #0e7c8642}.journal-meta{display:flex;justify-content:space-between;font-size:12px}.char-count{color:hsl(var(--muted-foreground, 220 9% 46%))}.char-count.ok{color:#248f4b;font-weight:600}.journal-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.journal-actions .primary{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:10px;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border:none;font-weight:600;font-size:14px;cursor:pointer;transition:opacity .15s}.journal-actions .primary:disabled{opacity:.45;cursor:not-allowed}.journal-hint{font-size:12px}.journal-error{color:#df2020;font-size:13px;padding:8px 12px;background:#fceded;border-radius:8px}.ghost-btn.tiny{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:999px;background:transparent;border:1px solid hsl(var(--border, 220 14% 92%));font-size:11px;cursor:pointer;color:hsl(var(--foreground))}.ghost-btn.tiny:hover{background:hsl(var(--muted, 220 14% 96%))}.ghost-btn.danger{color:#df2020;border-color:#f2a6a6}.ghost-btn.danger:hover{background:#fceded}.journal-feedback{gap:16px}.journal-feedback-top{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#0e7c861a,#ffbe5c1f),var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px 16px}.journal-feedback-meta{flex:1}.journal-feedback-meta p{margin:8px 0 0;line-height:1.5;font-weight:600;color:#2b211d}.confidence-chip{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;background:hsl(var(--primary)/.1);color:hsl(var(--primary));font-weight:600}.target-checks{display:flex;flex-wrap:wrap;gap:6px}.target-check{display:inline-flex;align-items:baseline;gap:5px;padding:4px 10px;border-radius:999px;font-size:12px}.target-check em{font-style:normal;font-size:11px}.target-check.good{background:#dbfae6;color:#196636}.target-check.careful{background:#fdf4d8;color:#825517}.target-check.missing{background:#f3f4f6;color:#6b7280}.feedback-block{border-radius:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--line)}.feedback-block h4{margin:0 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:hsl(var(--muted-foreground, 220 9% 46%))}.feedback-block p{margin:0;line-height:1.55}.feedback-block ul{margin:4px 0 0;padding-left:18px}.feedback-block li{margin:3px 0;line-height:1.5}.feedback-block--paper{background:linear-gradient(90deg,transparent 0 34px,rgba(207,86,54,.18) 34px 35px,transparent 35px),repeating-linear-gradient(180deg,transparent 0 29px,rgba(43,33,29,.07) 29px 30px),#fffdf7;padding-left:50px}.next-upgrade{display:inline-flex;align-items:center;gap:6px;font-weight:600}.journal-mistake-list{display:grid;gap:10px}.journal-mistake-card{padding:12px;border-radius:10px;background:#fffdf7;border:1px solid hsl(var(--border, 220 14% 92%));border-left:3px solid #cf5636}.journal-mistake-card p{margin:0 0 7px}.journal-mistake-card em{display:block;color:hsl(var(--primary));font-style:normal;font-weight:650}.journal-drill-list{display:grid;gap:8px}.journal-drill-card{display:grid;gap:6px;padding:10px 12px;border-radius:10px;background:#fffdf7;border:1px dashed rgba(207,86,54,.34)}.journal-drill-card strong{color:#2b211d}.journal-drill-card span{color:#0e7c86;font-weight:750}.suggested-phrases{display:flex;flex-direction:column;gap:8px}.suggested-phrase{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:hsl(var(--background));border:1px solid hsl(var(--border, 220 14% 92%));border-radius:10px}.suggested-phrase strong{display:block;font-size:14px}.suggested-phrase em{display:block;font-style:italic;color:hsl(var(--muted-foreground, 220 9% 46%));font-size:12px;margin-top:2px}.suggested-phrase.added{opacity:.7;background:#edfdf3;border-color:#c2f0d3}.journal-page{max-width:760px;margin:24px auto;padding:0 16px}.journal-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.journal-page-header h1{font-size:28px;margin:0}.journal-list{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:12px}.journal-list-item{background:var(--surface);border:1px solid hsl(var(--border, 220 14% 92%));border-radius:14px;padding:16px 18px;cursor:pointer;transition:transform .15s,box-shadow .15s}.journal-list-item:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.journal-list-item h3{margin:4px 0 6px;font-size:16px}.journal-list-item .snippet{margin:0;font-size:13px;color:hsl(var(--muted-foreground, 220 9% 46%));line-height:1.45}.journal-list-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px}.journal-list-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.tiny-tag{font-size:10px;padding:2px 7px;border-radius:999px;background:hsl(var(--muted, 220 14% 96%));color:hsl(var(--muted-foreground, 220 9% 46%))}.journal-detail{max-width:760px;margin:16px auto;padding:0 16px;display:flex;flex-direction:column;gap:18px}.journal-detail-header{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:18px 20px 16px}.journal-detail-header h1{font-size:24px;margin:6px 0}@media(max-width:640px){.journal-card-header,.journal-card-body{padding-left:16px;padding-right:16px}.journal-prompt h3{font-size:18px}}.video-page,.video-detail{max-width:1040px;margin:0 auto;width:100%}.video-hero{display:grid;grid-template-columns:minmax(0,1fr) 170px;gap:24px;align-items:center;margin:12px 0 18px}.video-hero h1{margin:0;max-width:760px;font-family:Space Grotesk,sans-serif;font-size:clamp(20px,2.5vw,28px);font-weight:800;line-height:1.2;letter-spacing:-.01em}.video-hero p{max-width:640px;margin:8px 0 0;color:var(--muted-2);font-size:14px}.video-hero-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--primary);color:#fffaf1;padding:22px;box-shadow:var(--shadow)}.video-hero-card strong{display:block;margin-top:16px;font-family:Space Grotesk,sans-serif;font-size:42px;line-height:1}.video-hero-card span{display:block;margin-top:4px;color:#fffaf1bf;font-weight:700}.video-import-card{background:var(--sidebar);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm);margin-bottom:28px}.video-import-card .btn{background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 100%);border-color:var(--gold);color:#1a1200;font-weight:800;box-shadow:0 4px 14px #c8962e59}.video-import-card .btn:hover{filter:brightness(1.08);border-color:var(--gold);background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 100%)}.video-import-card .btn:disabled{opacity:.55;filter:none}.video-import-card .lang-toggle{border-color:#ffffff2e}.video-import-card .lang-toggle button{color:#ffffff8c}.video-import-card .lang-toggle button:first-child{border-right-color:#ffffff2e}.video-import-card .lang-toggle button:hover{background:#ffffff1a;color:#fff}.video-import-card .lang-toggle button.active{background:var(--gold);color:#1a1200;font-weight:800}.video-import-card .video-busy-msg{color:#fffaf1a6}.video-import-card .video-transcript-fallback{color:#fffaf1b3}.video-import-card .video-transcript-fallback summary{color:var(--gold-bright)}.video-import-card .video-transcript-fallback p{color:#fffaf1a6}.video-import-card .video-transcript-fallback textarea{background:#ffffff12;border-color:#ffffff24;color:#fffaf1}.video-import-card .video-transcript-fallback textarea::placeholder{color:#fffaf173}.lang-toggle{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden;flex-shrink:0}.lang-toggle button{padding:0 14px;height:40px;font-size:12px;font-weight:700;letter-spacing:.06em;color:var(--muted-2);background:none;border:none;cursor:pointer;transition:background .12s,color .12s}.lang-toggle button:first-child{border-right:1px solid var(--line)}.lang-toggle button:hover{background:var(--surface-2);color:var(--ink)}.lang-toggle button.active{background:var(--primary);color:#fff}.lang-toggle button:disabled{opacity:.5;cursor:default}.video-busy-msg{margin-top:8px;font-size:.8rem;color:var(--muted-2)}.video-transcript-fallback{margin-top:14px;color:var(--muted-2)}.video-transcript-fallback summary{cursor:pointer;font-weight:800;color:var(--primary)}.video-transcript-fallback p{margin:8px 0;font-size:13px}.video-transcript-fallback textarea{width:100%;min-height:140px;resize:vertical;border:1px solid var(--line);border-radius:12px;background:var(--surface-2);padding:12px}.section-heading-row{display:flex;justify-content:space-between;align-items:end;gap:16px;margin-bottom:16px}.video-lesson-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.video-lesson-card{min-height:190px;overflow:hidden;display:flex;flex-direction:column;align-items:stretch;text-align:left;gap:0;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:0;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),border-color .2s var(--ease)}.video-lesson-card-body{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:16px 20px 20px;flex:1}.video-lesson-card:hover{transform:translateY(-2px);border-color:var(--primary)}.video-lesson-card span,.video-date{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;background:var(--primary-50);color:var(--primary-600);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.video-lesson-card h3{margin:0;font-size:24px}.video-lesson-card p{flex:1;margin:0;color:var(--muted-2);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.video-lesson-card em{color:var(--muted);font-style:normal;font-size:12px}.video-detail-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:color-mix(in srgb,var(--surface) 92%,transparent);box-shadow:var(--shadow-sm);margin-top:18px;overflow:hidden}.video-detail-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;padding:clamp(26px,5vw,54px);border-bottom:1px solid var(--line)}.video-detail-header h1{margin:0;max-width:820px;font-family:Georgia,Times New Roman,serif;font-size:clamp(42px,6vw,74px);line-height:.96}.video-detail-header p{max-width:720px;color:var(--muted-2);font-size:16px}.video-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.danger-link{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 28%,var(--line))}.video-lesson-tabs{display:flex;align-items:stretch;gap:0;padding:0;border-bottom:none;background:var(--sidebar);position:sticky;top:0;z-index:8;border-radius:16px 16px 0 0}.video-back-link{display:inline-flex;align-items:center;justify-content:center;min-width:44px;border:none;border-right:1px solid rgba(255,255,255,.1);background:transparent;color:var(--sidebar-muted);cursor:pointer;flex-shrink:0;transition:color .15s,background .15s}.video-back-link:hover{color:#fff;background:#ffffff12}.video-lesson-tab-list{display:flex;align-items:stretch;gap:0;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none}.video-lesson-tab-list::-webkit-scrollbar{display:none}.video-lesson-tab-list button{border:none;border-radius:0;background:transparent;color:var(--sidebar-muted);min-height:48px;padding:0 16px;font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;position:relative;transition:color .18s var(--ease)}.video-lesson-tab-list button:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--warm);border-radius:2px 2px 0 0;opacity:0;transition:opacity .18s var(--ease)}.video-lesson-tab-list button:hover{color:#fff}.video-lesson-tab-list button.active{color:#fff;font-weight:900}.video-lesson-tab-list button.active:after{opacity:1}.video-lesson-tab-list button span,.video-tab-menu button span{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:999px;background:#f0b35f2e;color:inherit;font-size:11px}.video-lesson-tab-list button.active span{background:#f0b35f47}.video-tab-title-only{padding:20px clamp(20px,5vw,54px) 4px;border-bottom:1px solid var(--line)}.video-tab-title-only h2{margin:0;font-size:17px;font-weight:900;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-tab-add{position:relative;display:flex;align-items:center;padding:0 10px;border-left:1px solid rgba(255,255,255,.1);flex-shrink:0}.video-tab-add-btn{width:34px;height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:none!important;border-radius:8px!important;background:var(--warm)!important;color:var(--sidebar)!important;font-weight:900;transition:background .15s,transform .15s!important;box-shadow:0 2px 8px #f0b35f59}.video-tab-add-btn:hover{background:#d9933a!important;transform:translateY(-1px)!important}.video-tab-add-btn:disabled{opacity:.6}.video-tab-menu{position:absolute;right:0;top:calc(100% + 10px);width:min(280px,calc(100vw - 36px));padding:8px;border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:0 24px 60px -32px #0f172a73;z-index:20}.video-tab-menu button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;border:0;border-radius:12px;background:transparent;color:var(--ink);padding:11px 12px;font-weight:900;text-align:left}.video-tab-menu button:hover{background:var(--surface-2)}.video-tab-menu p{margin:0;padding:10px;color:var(--muted-2);font-size:13px}.video-tab-panel{min-height:260px}.video-empty-tab{margin:30px clamp(22px,5vw,54px);padding:28px;border:1px dashed var(--line);border-radius:18px;background:#fffaf199;color:var(--ink-2);font-weight:800}.video-section{padding:30px clamp(22px,5vw,54px);border-bottom:1px solid var(--line)}.video-section h2{margin:0 0 16px;font-size:22px}.video-section>p{max-width:760px;margin:0;color:var(--ink-2);line-height:1.75}.video-key-list{display:grid;gap:8px;max-width:820px;padding-left:20px}.video-examples{display:grid;gap:10px;margin-top:16px}.video-item-grid,.video-mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.video-item,.video-mini-card,.video-task,.video-exercise{border:1px solid var(--line);border-radius:14px;background:var(--surface);padding:16px}.video-item{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.video-item.added{background:var(--success-50);border-color:color-mix(in srgb,var(--success) 40%,var(--line))}.video-item strong,.video-mini-card strong{display:block;font-family:Space Grotesk,sans-serif;font-size:17px}.video-item em,.video-mini-card em{display:block;margin-top:4px;color:var(--primary);font-style:italic}.video-item p,.video-mini-card p,.video-task p{margin:8px 0 0;color:var(--muted-2);font-size:13px}.video-flashcard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:18px}.video-flashcard{min-height:148px;display:flex;flex-direction:column;justify-content:space-between;gap:18px;border:1px solid rgba(200,150,46,.32);border-radius:18px;background:radial-gradient(circle at 100% 0%,rgba(232,184,74,.16),transparent 34%),#fffcf6f0;padding:20px;text-align:left;color:var(--ink);box-shadow:0 16px 38px -32px #49361f80;cursor:pointer;transition:transform .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease)}.video-flashcard:hover{transform:translateY(-2px);border-color:#0f87936b}.video-flashcard.flipped{background:radial-gradient(circle at 100% 0%,rgba(15,135,147,.15),transparent 34%),#f4fcfbf0;border-color:#0f879352}.video-flashcard span{font-family:Space Grotesk,sans-serif;font-size:21px;line-height:1.25;font-weight:900}.video-flashcard small{color:var(--ink-3);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.video-task{display:flex;flex-direction:column;gap:10px}.video-task-prompt{font-weight:700!important;color:var(--ink)!important;margin:0!important}.video-task-actions{display:flex;gap:8px;flex-wrap:wrap}.video-task-watch{color:var(--primary)!important;border-color:color-mix(in srgb,var(--primary) 30%,var(--line))!important}.video-task-answer{background:var(--surface-2);border-radius:8px;padding:10px 12px;font-size:13px;margin:0!important;color:var(--ink-2)!important}.video-exercise-list{display:grid;gap:16px}.video-exercise{display:grid;gap:12px;position:relative;overflow:hidden;padding:22px;border-radius:20px;border-color:#c8962e47;background:radial-gradient(circle at 96% 0%,rgba(232,184,74,.13),transparent 32%),linear-gradient(135deg,#fffcf6fa,#fff8ebdb);box-shadow:0 18px 42px -34px #49361f94}.video-exercise:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:linear-gradient(180deg,#1d4080d9,#0f8793c2);opacity:.55;transition:background .22s var(--ease),opacity .22s var(--ease)}.video-exercise--correct:before{background:#2f9b63;opacity:.9}.video-exercise--almost:before{background:var(--gold);opacity:.9}.video-exercise--wrong:before{background:#dc5148;opacity:.9}.video-exercise>*{position:relative;z-index:1}.video-exercise-topline{margin-bottom:2px}.video-exercise>span,.video-exercise-type{width:fit-content;border-radius:999px;background:var(--line-2);color:var(--muted-2);padding:3px 9px;font-size:10px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.video-exercise-prompt,.video-exercise p{margin:0;font-weight:700}.video-exercise-prompt{font-family:Space Grotesk,sans-serif;font-size:clamp(17px,1.35vw,20px);line-height:1.45;color:var(--ink)}.video-exercise-hint{font-size:13px;font-weight:400!important;color:var(--muted-2);font-style:italic}.video-input-row{display:flex;gap:8px;align-items:center}.video-input-row input{flex:1}.video-exercise input{width:100%;border:1px solid var(--line);border-radius:10px;background:var(--surface-2);padding:11px 12px}.video-exercise.correct input{border-color:var(--success);background:var(--success-50)}.video-exercise.wrong input{border-color:var(--danger);background:var(--danger-50)}.video-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.video-options button{border:1px solid var(--line);border-radius:14px;background:#fffcf6eb;padding:13px 14px;text-align:left;font-weight:700;min-height:52px;transition:transform .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease)}.video-options button:hover{border-color:#c8962e8c;transform:translateY(-1px)}.video-options button.correct,.video-feedback.good{border-color:var(--success);background:var(--success-50);color:#276749}.video-options button.wrong,.video-feedback.bad{border-color:var(--danger);background:var(--danger-50);color:#991b1b}.video-feedback{border-radius:12px;border:1px solid transparent;padding:11px 13px;font-weight:800}.video-answer-toggle{justify-self:start}.video-writing-task{border:1px solid var(--line);border-radius:16px;padding:22px 24px 22px 58px;background:linear-gradient(90deg,transparent 0 39px,rgba(239,68,68,.22) 40px,transparent 41px),repeating-linear-gradient(180deg,#fffaf1 0 31px,#eadcc8 32px);min-height:126px}.video-writing-task strong{display:block;font-size:18px}.video-writing-task p{margin:10px 0 0;color:var(--muted-2)}.writing-task-starter{font-style:italic}.writing-task-input-wrap{margin-top:14px;display:flex;flex-direction:column;gap:10px}.video-writing-input{display:block;width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#ffffffb3;font-family:inherit;font-size:.95rem;line-height:1.6;resize:vertical;color:var(--fg);box-sizing:border-box}.writing-feedback-card{background:var(--surface-2, #f8f7f4);border:1px solid var(--line);border-radius:12px;padding:18px 20px;display:flex;flex-direction:column;gap:12px}.writing-feedback-top{display:flex;align-items:center;gap:12px}.writing-label{font-size:.85rem;font-weight:600;color:var(--muted-2);text-transform:uppercase;letter-spacing:.04em}.writing-verdict{font-size:.95rem;line-height:1.5}.writing-correction,.writing-upgrade{font-size:.9rem;line-height:1.5}.writing-correction strong,.writing-upgrade strong{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-2);margin-bottom:4px}.video-embed-container{position:relative;width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow:hidden;background:#000}.video-embed-sentinel{width:100%;padding-bottom:56.25%}.video-embed-wrapper{position:absolute;inset:0;background:#000}.video-embed-wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:none}.video-embed-wrapper.video-embed-sticky{position:fixed;border-radius:12px;z-index:1000;overflow:hidden;box-shadow:0 8px 32px #00000073;-webkit-user-select:none;user-select:none}.video-embed-drag-strip{position:absolute;top:0;left:0;right:0;height:36px;background:linear-gradient(to bottom,rgba(0,0,0,.65) 0%,transparent 100%);display:flex;align-items:center;justify-content:space-between;padding:0 6px;cursor:grab;z-index:3}.video-embed-drag-strip:active{cursor:grabbing}.video-embed-resize-nw{width:22px;height:22px;cursor:nw-resize;flex-shrink:0;position:relative}.video-embed-resize-nw:before,.video-embed-resize-nw:after{content:"";position:absolute;background:#ffffffb3;border-radius:2px}.video-embed-resize-nw:before{top:6px;left:4px;width:10px;height:2px}.video-embed-resize-nw:after{top:4px;left:6px;width:2px;height:10px}.video-embed-close-btn{width:24px;height:24px;border-radius:50%;background:#000000a6;color:#fff;border:none;cursor:pointer;font-size:17px;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0}.video-embed-close-btn:hover{background:#000000e6}@keyframes sticky-pulse{0%,to{box-shadow:0 8px 32px #00000073}50%{box-shadow:0 0 0 6px #6366f1bf,0 8px 32px #00000073}}.video-embed-wrapper.video-embed-pulse{animation:sticky-pulse .45s ease-in-out 2}.video-recs-section{margin-bottom:28px}.video-rec-carousel{position:relative;display:flex;align-items:center;gap:6px;margin-top:14px}.video-rec-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-ms-overflow-style:none;scrollbar-width:none;flex:1}.video-rec-track::-webkit-scrollbar{display:none}.video-rec-arrow{flex-shrink:0;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--fg);transition:background .15s,border-color .15s;z-index:1}.video-rec-arrow:hover{background:var(--surface-2, #f0ede8);border-color:var(--primary)}.video-rec-card{display:flex;flex-direction:column;text-align:left;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s;padding:0;flex-shrink:0;width:154px;scroll-snap-align:start}.video-rec-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 6px 22px #00000012}.video-rec-thumb{width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--line)}.video-rec-thumb img{width:100%;height:100%;object-fit:cover;display:block}.video-rec-info{padding:8px 10px;display:flex;flex-direction:column;gap:4px}.video-rec-info strong{font-size:11px;font-weight:800;line-height:1.3}.video-rec-info p{margin:0;font-size:9.5px;color:var(--muted-2);line-height:1.4}.answer-reveal{border:1px solid var(--line);border-radius:10px;background:var(--surface-2);padding:10px 13px;font-size:14px}.answer-reveal p{margin:0 0 4px}.answer-reveal p:last-child{margin-bottom:0}.widget-recent-videos{grid-column:span 12}.widget-recent-videos .widget-h{flex-direction:row;align-items:center;justify-content:space-between;gap:0;margin-bottom:16px}.widget-view-all{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;opacity:.85;transition:opacity .15s}.widget-view-all:hover{opacity:1}.recent-videos-grid{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}.recent-videos-grid .recent-video-card{flex:1 1 0;min-width:180px}.recent-video-card{display:flex;flex-direction:column;background:var(--surface-2, hsl(220 14% 97%));border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;text-align:left;padding:0;transition:transform .15s,box-shadow .15s}.recent-video-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.recent-video-thumb{position:relative;width:100%;aspect-ratio:16 / 9;background:var(--line);overflow:hidden}.recent-video-thumb img{width:100%;height:100%;object-fit:cover;display:block}.recent-video-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted)}.recent-video-info{padding:10px 12px 12px;display:flex;flex-direction:column;gap:6px;flex:1}.recent-video-title{font-size:13px;font-weight:600;line-height:1.4;color:var(--foreground);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recent-video-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.recent-video-date{font-size:11px;color:var(--muted)}@media(max-width:900px){.recent-videos-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.recent-videos-grid{grid-template-columns:repeat(2,1fr);gap:10px}}.widget-video-hero{background:linear-gradient(135deg,#0f1729,#1a293c 60%,#1f3047);color:#fff;position:relative;overflow:hidden;padding:32px 36px 28px}.widget-video-hero:before{content:"";position:absolute;top:-60px;right:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(200,150,46,.22) 0%,transparent 70%);pointer-events:none}.video-hero-eyebrow{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--gold-bright);text-transform:uppercase;margin-bottom:12px}.video-hero-title{font-size:clamp(20px,2.2vw,26px);font-weight:800;line-height:1.25;color:#fff;margin:0 0 8px}.video-hero-lead{font-size:14px;color:#ffffffa6;margin:0 0 20px;max-width:460px}.video-hero-form{display:flex;gap:8px;max-width:520px;margin-bottom:20px}.video-hero-input{flex:1;padding:10px 14px;border-radius:8px;border:1.5px solid rgba(255,255,255,.18);background:#ffffff14;color:#fff;font-size:13.5px;outline:none;transition:border-color .15s,background .15s}.video-hero-input::placeholder{color:#ffffff59}.video-hero-input:focus{border-color:var(--gold);background:#ffffff1f;box-shadow:0 0 0 3px #c8962e33}.video-hero-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:8px;background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 100%);color:#1a1200;font-size:13.5px;font-weight:800;border:none;cursor:pointer;white-space:nowrap;transition:filter .15s,transform .1s,box-shadow .15s;box-shadow:0 4px 16px #c8962e61}.video-hero-cta:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 6px 22px #c8962e80}.video-hero-cta:active{transform:translateY(0)}.video-hero-chips{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.video-hero-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:12px;background:#ffffff1a;color:#ffffffb3;border:1px solid rgba(255,255,255,.12)}.video-hero-chip strong{color:#fff;font-weight:700}.video-hero-lang{border-color:#ffffff2e}.video-hero-lang button{color:#ffffff8c;border-right-color:#ffffff2e}.video-hero-lang button:hover{background:#ffffff1a;color:#fff}.video-hero-lang button.active{background:var(--gold);color:#1a1200;font-weight:800}.video-hero-error{font-size:12.5px;color:#fca5a5;background:#ef44441f;border:1px solid rgba(239,68,68,.25);border-radius:6px;padding:6px 10px;margin:-8px 0 12px;max-width:520px}.video-hero-cta:disabled{opacity:.75;cursor:not-allowed;transform:none}.video-hero-input:disabled{opacity:.6}.video-hero-chip.chip-level{background:#c8962e2e;border-color:#c8962e52;color:var(--gold-bright);font-weight:700;text-transform:capitalize}.recent-video-featured{display:flex;gap:0;background:var(--surface-2, hsl(220 14% 97%));border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;text-align:left;width:100%;padding:0;margin-bottom:14px;transition:transform .15s,box-shadow .15s}.recent-video-featured:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.recent-video-featured-thumb{flex:0 0 42%;aspect-ratio:16 / 9;background:var(--line);overflow:hidden;position:relative}.recent-video-featured-thumb img{width:100%;height:100%;object-fit:cover;display:block}.recent-video-featured-info{flex:1;padding:14px 16px;display:flex;flex-direction:column;gap:6px;justify-content:center}.recent-video-featured-title{font-size:15px;font-weight:700;line-height:1.35;color:var(--foreground);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:2px 0}.recent-video-featured-stats{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--muted)}.recent-video-cta{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--accent);margin-top:4px}.video-lesson-thumb{position:relative;width:100%;aspect-ratio:16 / 9;background:var(--line);overflow:hidden;border-radius:8px 8px 0 0}.video-lesson-thumb img{width:100%;height:100%;object-fit:cover;display:block}.video-lesson-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted)}.video-lesson-level-badge{position:absolute;top:7px;right:8px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;background:#0000008c;color:#fff;text-transform:capitalize;letter-spacing:.03em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.video-lesson-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11.5px;color:var(--muted)}.video-lesson-summary{font-size:12px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.45;margin:2px 0 0}.video-lesson-date{font-size:11px;color:var(--muted);margin-left:auto}.trans,.wr-trans,.selection-translation,.reverse-match p,.video-item em,.video-mini-card em,.video-lesson-card p,.video-detail-header p,.lesson-up-next .trans,.picture-phrase-row span,.journal-list-item .snippet,.suggested-phrase em{color:var(--ink-2)}.wr-trans,.card .trans,.suggestion-card .trans,.widget-wod-compact .trans,.lesson-up-next .trans,.video-lesson-card p,.video-item em,.video-mini-card em,.reverse-match p{font-size:max(14px,.95rem)}.selection-muted,.selection-source,.video-item p,.video-mini-card p,.video-task p,.video-exercise-hint,.journal-prompt-helper,.char-count,.tiny-tag,.video-lesson-summary,.video-lesson-card-meta,.video-lesson-date,.recent-video-featured-stats{color:var(--muted-2)}@media(max-width:760px){.video-hero,.video-detail-header{grid-template-columns:1fr}.video-import-card .add-row{flex-direction:column}.section-heading-row{align-items:flex-start;flex-direction:column}.widget-recent-videos-compact{display:block}.widget-recent-videos{display:none}.widget-video-hero{padding:18px 16px 16px}.video-hero-lead,.video-hero-chips{display:none}.video-hero-title{font-size:17px;margin-bottom:10px}.video-hero-form{flex-direction:column;margin-bottom:0}.video-hero-cta{justify-content:center}.recent-video-featured{flex-direction:column}.recent-video-featured-thumb{flex:unset;width:100%;aspect-ratio:16 / 9}}@media(min-width:761px)and (max-width:900px){.widget-recent-videos-compact{padding:18px 20px 12px}.recent-video-compact-item{padding:14px 0;gap:16px}.recent-video-compact-thumb{width:140px;height:79px;border-radius:8px}.recent-video-compact-title{font-size:16px;-webkit-line-clamp:2}}.widget-recent-videos-compact{padding:12px 14px 4px}.recent-videos-compact-list{margin-top:8px}.recent-video-compact-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 0;background:none;border:none;border-top:1px solid var(--line);cursor:pointer;text-align:left}.recent-video-compact-item:first-child{border-top:none}.recent-video-compact-thumb{width:72px;height:41px;border-radius:5px;overflow:hidden;flex-shrink:0;background:var(--line);display:flex;align-items:center;justify-content:center}.recent-video-compact-thumb img{width:100%;height:100%;object-fit:cover}.recent-video-compact-title{flex:1;font-size:13px;font-weight:500;color:var(--text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recent-video-compact-arrow{flex-shrink:0;color:var(--muted)}.books-page{max-width:960px;margin:0 auto;padding:24px 20px 48px}.books-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:28px;color:var(--primary)}.books-header svg{flex-shrink:0;margin-top:2px}.books-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:260px;color:var(--muted)}.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:20px}.book-card{display:flex;flex-direction:column;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:0;text-align:left;cursor:pointer;overflow:hidden;transition:box-shadow .18s,border-color .18s,transform .15s}.book-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}.book-cover{position:relative;aspect-ratio:2 / 3;background:var(--surface-2);overflow:hidden}.book-cover img{width:100%;height:100%;object-fit:cover;display:block}.book-cover-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,#e8dcc8,#c8b898);color:#7a6040}.book-level-badge{position:absolute;top:8px;left:8px;font-size:10px;font-weight:700;letter-spacing:.06em;padding:2px 7px;border-radius:6px;color:#fff}.book-meta{display:flex;flex-direction:column;gap:3px;padding:10px 12px 14px}.book-title{font-size:13px;font-weight:700;color:var(--ink);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-author{font-size:11px;color:var(--muted)}.book-description{font-size:11px;color:var(--muted-2);margin:4px 0 0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.reader-shell{display:flex;flex-direction:column;height:calc(100vh + -0px);background:#f5efe0;overflow:hidden}.wrap .reader-shell{height:calc(100vh - 56px)}.reader-topbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--line);flex-shrink:0;min-height:52px}.reader-back{background:none;border:none;cursor:pointer;color:var(--primary);display:flex;align-items:center;padding:4px;border-radius:6px;transition:background .12s}.reader-back:hover{background:var(--primary-50)}.reader-title-area{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.reader-book-title{font-size:14px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reader-book-author{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reader-progress{font-size:12px;color:var(--muted);flex-shrink:0;font-variant-numeric:tabular-nums}.reader-viewport{flex:1;position:relative;overflow:hidden;display:flex;align-items:stretch}.reader-content{flex:1;overflow:hidden;-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}.reader-content iframe{border:none!important;width:100%!important;height:100%!important;background:#fffaf1;-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}.reader-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);background:#f5efe0;z-index:5}.reader-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:300px;color:var(--danger)}.reader-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#fffaf1d9;border:1px solid var(--line);border-radius:50%;cursor:pointer;color:var(--ink-2);transition:background .14s,opacity .14s,box-shadow .14s;box-shadow:var(--shadow-sm);z-index:10}.reader-arrow:hover:not(:disabled){background:var(--surface);box-shadow:var(--shadow)}.reader-arrow:disabled{opacity:.28;cursor:default}.reader-arrow-left{left:10px}.reader-arrow-right{right:10px}.reader-lookup-panel{position:absolute;bottom:16px;left:50%;transform:translate(-50%);width:min(420px,calc(100vw - 32px));background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:16px 18px 18px;z-index:20;max-height:min(48vh,360px);overflow:auto;-webkit-overflow-scrolling:touch}.reader-lookup-close{position:absolute;top:10px;right:10px;background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:6px;display:flex;align-items:center;transition:background .12s}.reader-lookup-close:hover{background:var(--surface-2)}.reader-lookup-loading{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.reader-lookup-result{display:flex;flex-direction:column;gap:8px}.reader-lookup-word{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.reader-lookup-word strong{font-size:18px;color:var(--ink)}.reader-lookup-pos{font-size:11px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:5px;padding:1px 7px}.reader-lookup-level{font-size:10px;font-weight:700;letter-spacing:.05em;color:var(--primary);background:var(--primary-50);border-radius:5px;padding:2px 7px}.reader-lookup-trans{font-size:15px;color:var(--ink-2);margin:0}.reader-save-btn{align-self:flex-start;margin-top:4px}.reader-save-btn.saved{background:var(--success)!important;border-color:var(--success)!important;pointer-events:none}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@media(max-width:700px){.books-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:14px}.reader-arrow{width:36px;height:36px}.reader-arrow-left{left:4px}.reader-arrow-right{right:4px}.reader-lookup-panel{bottom:70px}}
