.tts-notice[data-v-301e9f6a]{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;border-radius:var(--radius, 10px);background:var(--warning-soft, rgba(245, 158, 11, .12));border:1px solid var(--warning, #f59e0b);color:var(--text-2, #d4d4d8);font-size:.85rem;line-height:1.6}.tts-notice-close[data-v-301e9f6a]{margin-left:auto;flex-shrink:0;width:24px;height:24px;border:none;background:none;color:var(--text-3, #a1a1aa);font-size:1.1rem;line-height:1;cursor:pointer;border-radius:6px}.tts-notice-close[data-v-301e9f6a]:hover{background:#ffffff0f;color:var(--text, #fff)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg:#0c0c0e;--surface:#151517;--surface-2:#1c1c20;--surface-3:#242428;--border:#2a2a2e;--border-light:#333338;--accent:#d4a033;--accent-soft:rgba(212,160,51,.12);--accent-glow:rgba(212,160,51,.06);--text:#f0ece4;--text-2:#b0a99e;--text-3:#6a655e;--text-4:#44403a;--success:#5cb87a;--success-soft:rgba(92,184,122,.12);--warning:#d4a033;--danger:#c45c5c;--danger-soft:rgba(196,92,92,.12);--info:#5c9ec4;--info-soft:rgba(92,158,196,.12);--radius:10px;--radius-lg:16px;--radius-xl:24px;--font-display:"Instrument Serif",Georgia,serif;--font-body:"Noto Sans SC","Helvetica Neue",sans-serif;--font-mono:"DM Mono","Courier New",monospace;--sidebar-w:260px;--transition:.3s cubic-bezier(.4,0,.2,1)}html{font-size:15px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;z-index:9999}::selection{background:var(--accent);color:var(--bg)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}button{font-family:inherit}a{color:inherit;text-decoration:none}.app{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;padding:28px 0}.sidebar-logo{padding:0 28px;margin-bottom:36px}.sidebar-logo h1{font-family:var(--font-display);font-size:1.6rem;font-weight:400;letter-spacing:-.02em;color:var(--accent)}.sidebar-logo span{font-family:var(--font-mono);font-size:.7rem;color:var(--text-3);display:block;margin-top:4px;letter-spacing:.08em;text-transform:uppercase}.sidebar-nav{flex:1;padding:0 12px}.nav-item{display:flex;align-items:center;gap:14px;padding:11px 16px;border-radius:var(--radius);cursor:pointer;transition:var(--transition);color:var(--text-3);font-size:.88rem;font-weight:400;margin-bottom:2px;position:relative}.nav-item:hover{color:var(--text-2);background:var(--surface-2)}.nav-item.router-link-active,.nav-item.active{color:var(--accent);background:var(--accent-soft)}.nav-item.router-link-active:before,.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:0 2px 2px 0}.nav-icon{width:20px;height:20px;flex-shrink:0;opacity:.7}.nav-item.router-link-active .nav-icon,.nav-item.active .nav-icon{opacity:1}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border);margin-top:auto;display:flex;flex-direction:column;gap:10px}.lang-pair{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface-2);border-radius:var(--radius);font-family:var(--font-mono);font-size:.75rem;color:var(--text-2)}.lang-flag{font-size:1.1rem;line-height:1}.lang-arrow{color:var(--text-4);margin:0 2px}.logout-btn{background:none;border:1px solid var(--border);color:var(--text-3);border-radius:var(--radius);padding:8px;font-family:var(--font-mono);font-size:.72rem;cursor:pointer;transition:var(--transition)}.logout-btn:hover{border-color:var(--danger);color:var(--danger)}.main{margin-left:var(--sidebar-w);flex:1;min-height:100vh}.mobile-topbar{display:none;align-items:center;gap:14px;position:fixed;top:0;left:0;right:0;height:56px;padding:0 16px;background:var(--surface);border-bottom:1px solid var(--border);z-index:90}.mobile-topbar-title{font-family:var(--font-display);font-size:1.3rem;color:var(--accent);letter-spacing:-.02em}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:none;color:var(--text-2);cursor:pointer;border-radius:var(--radius);transition:var(--transition);margin-left:-8px}.mobile-menu-btn:hover{background:var(--surface-2);color:var(--text)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition)}.mobile-close-btn{display:none;position:absolute;top:-4px;right:16px;width:36px;height:36px;border:none;background:none;color:var(--text-3);font-size:1.6rem;line-height:1;cursor:pointer;border-radius:var(--radius)}.mobile-close-btn:hover{background:var(--surface-2);color:var(--text)}.page{animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.section-header{padding:40px 48px 0}.section-header h2{font-family:var(--font-display);font-size:2rem;font-weight:400;letter-spacing:-.02em}.section-header p{color:var(--text-3);font-size:.88rem;margin-top:6px;max-width:520px;line-height:1.6}.section-body{padding:28px 48px 48px}.muted{color:var(--text-3)}.empty-hint{padding:40px;text-align:center;color:var(--text-3);font-size:.88rem}.btn-primary{padding:12px 24px;background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius);cursor:pointer;font-family:var(--font-mono);font-size:.82rem;font-weight:500;transition:var(--transition);letter-spacing:.02em;white-space:nowrap}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;position:relative;overflow:hidden;transition:var(--transition)}.stat-card:hover{border-color:var(--border-light);transform:translateY(-2px)}.stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px}.stat-card:nth-child(1):after{background:var(--accent)}.stat-card:nth-child(2):after{background:var(--success)}.stat-card:nth-child(3):after{background:var(--info)}.stat-card:nth-child(4):after{background:var(--danger)}.stat-label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.stat-value{font-family:var(--font-display);font-size:2.4rem;font-weight:400;line-height:1}.stat-value small{font-size:.8rem;color:var(--text-3)}.stat-sub{font-family:var(--font-mono);font-size:.72rem;color:var(--text-3);margin-top:8px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}.dash-card h3{font-family:var(--font-display);font-size:1.2rem;margin-bottom:20px;font-weight:400}.week-chart{display:flex;align-items:flex-end;gap:8px;height:120px;padding-top:8px}.week-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%}.week-bar{width:100%;border-radius:4px 4px 0 0;background:var(--surface-3);flex:1;position:relative;min-height:4px}.week-bar-fill{position:absolute;bottom:0;left:0;right:0;border-radius:4px 4px 0 0;background:linear-gradient(to top,var(--accent),rgba(212,160,51,.4));transition:height 1s ease}.week-label{font-family:var(--font-mono);font-size:.65rem;color:var(--text-4)}.recent-list{display:flex;flex-direction:column;gap:8px}.recent-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface-2);border-radius:var(--radius);transition:var(--transition)}.recent-item:hover{background:var(--surface-3)}.recent-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.recent-text{flex:1;font-size:.85rem;color:var(--text-2)}.recent-text strong{color:var(--text);font-weight:500}.recent-time{font-family:var(--font-mono);font-size:.68rem;color:var(--text-4)}.quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px}.quick-btn{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);text-align:center}.quick-btn:hover{border-color:var(--accent);background:var(--accent-soft)}.quick-btn .q-icon{font-size:1.4rem}.quick-btn .q-label{font-size:.82rem;color:var(--text-2);font-weight:500}.quick-btn .q-desc{font-family:var(--font-mono);font-size:.65rem;color:var(--text-4);line-height:1.4}.islands-top{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.topic-chip{padding:8px 18px;border-radius:999px;font-size:.82rem;border:1px solid var(--border);color:var(--text-3);cursor:pointer;transition:var(--transition);font-weight:400}.topic-chip:hover{border-color:var(--text-3);color:var(--text-2)}.topic-chip.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.sentence-list{display:flex;flex-direction:column;gap:8px}.sentence-card{display:grid;grid-template-columns:1fr auto 1fr auto;gap:20px;align-items:center;padding:20px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition)}.sentence-card:hover{border-color:var(--border-light);background:var(--surface-2)}.sent-source{font-size:.95rem;color:var(--text-2);line-height:1.5}.sent-arrow{color:var(--text-4);font-family:var(--font-mono);font-size:.7rem}.sent-target{color:var(--text);line-height:1.5;font-style:italic;font-family:var(--font-display);font-size:1.05rem}.sent-actions{display:flex;gap:6px}.sent-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:var(--transition)}.sent-btn:hover{border-color:var(--accent);color:var(--accent)}.add-sentence-area{margin-top:24px;padding:28px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-lg);transition:var(--transition)}.add-sentence-area:focus-within{border-color:var(--accent);border-style:solid}.add-row{display:grid;grid-template-columns:1fr 80px 1fr;gap:16px;align-items:end}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}.input-group input,.input-group textarea,.input-group select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;color:var(--text);font-family:var(--font-body);font-size:.9rem;outline:none;transition:var(--transition);width:100%}.input-group input:focus,.input-group textarea:focus{border-color:var(--accent)}.ai-translate-btn{padding:12px 16px;background:var(--info-soft);color:var(--info);border:1px solid rgba(92,158,196,.2);border-radius:var(--radius);cursor:pointer;font-family:var(--font-mono);font-size:.74rem;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.ai-translate-btn:hover{background:#5c9ec433}.ai-translate-btn:disabled{opacity:.5;cursor:not-allowed}.candidate-list{display:flex;flex-direction:column;gap:6px}.candidate{padding:8px 12px;border-radius:var(--radius);font-size:.82rem;cursor:pointer;border:1px solid var(--border);background:var(--surface-3);color:var(--text-2);transition:var(--transition);display:flex;justify-content:space-between;gap:8px;align-items:center}.candidate:hover{border-color:var(--text-3)}.candidate.selected{background:var(--accent-soft);border-color:#d4a03366;color:var(--text)}.candidate .cand-style{font-family:var(--font-mono);font-size:.6rem;color:var(--text-4);text-transform:uppercase;letter-spacing:.06em}.audio-player-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;margin-bottom:28px;position:relative;overflow:hidden}.audio-player-card:before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);pointer-events:none}.audio-now-playing{text-align:center;margin-bottom:32px;position:relative}.audio-now-label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-4);text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px}.audio-sent-source{font-size:1.1rem;color:var(--text-2);margin-bottom:12px;line-height:1.6}.audio-sent-target{font-family:var(--font-display);font-size:1.6rem;color:var(--text);line-height:1.5;font-style:italic}.audio-waveform{display:flex;align-items:center;justify-content:center;gap:3px;height:48px;margin-bottom:28px}.wave-bar{width:3px;border-radius:2px;background:var(--accent);opacity:.4;transition:opacity .3s}.wave-bar.active{opacity:1;animation:waveAnim .8s ease infinite alternate}@keyframes waveAnim{0%{height:8px}to{height:40px}}.audio-controls{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:24px}.audio-ctrl-btn{width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:var(--transition)}.audio-ctrl-btn:hover{border-color:var(--text-3);color:var(--text)}.audio-ctrl-btn.play{width:64px;height:64px;background:var(--accent);color:var(--bg);border:none;font-size:1.2rem}.audio-ctrl-btn.play:hover{filter:brightness(1.15);transform:scale(1.05)}.audio-meta{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}.audio-meta-item{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.72rem;color:var(--text-3)}.speed-btn{padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-3);cursor:pointer;font-family:var(--font-mono);font-size:.72rem;transition:var(--transition)}.speed-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.shadow-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;margin-top:20px;justify-content:center}.toggle-track{width:44px;height:24px;border-radius:12px;background:var(--surface-3);position:relative;transition:var(--transition)}.toggle-track.on{background:var(--accent)}.toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--text);transition:var(--transition)}.toggle-track.on .toggle-thumb{left:23px}.toggle-label{font-family:var(--font-mono);font-size:.75rem;color:var(--text-3)}.audio-playlist{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.playlist-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.playlist-header h3{font-family:var(--font-display);font-size:1.1rem;font-weight:400}.playlist-header span{font-family:var(--font-mono);font-size:.7rem;color:var(--text-4)}.playlist-item{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition)}.playlist-item:last-child{border-bottom:none}.playlist-item:hover{background:var(--surface-2)}.playlist-item.current{background:var(--accent-soft)}.playlist-num{font-family:var(--font-mono);font-size:.7rem;color:var(--text-4);width:24px;text-align:center}.playlist-text{flex:1;font-size:.88rem;color:var(--text-2)}.playlist-item.current .playlist-text{color:var(--text)}.playlist-dur{font-family:var(--font-mono);font-size:.68rem;color:var(--text-4)}.playlist-status{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--surface-3)}.playlist-item.current .playlist-status{background:var(--accent);animation:pulse 1.5s ease infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.recall-container{max-width:640px;margin:0 auto}.recall-progress{display:flex;align-items:center;gap:12px;margin-bottom:28px}.recall-progress-bar{flex:1;height:4px;background:var(--surface-3);border-radius:2px;overflow:hidden}.recall-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .5s ease}.recall-progress-text{font-family:var(--font-mono);font-size:.72rem;color:var(--text-3)}.recall-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);min-height:320px;position:relative;perspective:1000px;cursor:pointer}.recall-card-inner{width:100%;min-height:320px;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d;position:relative}.recall-card.flipped .recall-card-inner{transform:rotateX(180deg)}.recall-front,.recall-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;gap:16px}.recall-back{transform:rotateX(180deg)}.recall-hint{font-family:var(--font-mono);font-size:.68rem;color:var(--text-4);text-transform:uppercase;letter-spacing:.12em}.recall-sentence{font-size:1.4rem;line-height:1.6;max-width:480px}.recall-front .recall-sentence{color:var(--text-2)}.recall-back .recall-sentence{font-family:var(--font-display);font-size:1.6rem;color:var(--text);font-style:italic}.recall-tap-hint{position:absolute;bottom:20px;font-family:var(--font-mono);font-size:.68rem;color:var(--text-4)}.recall-actions{display:flex;gap:12px;margin-top:24px;justify-content:center;transition:opacity .3s}.recall-rate-btn{padding:14px 32px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-family:var(--font-mono);font-size:.82rem;transition:var(--transition);min-width:100px}.recall-rate-btn.again{color:var(--danger);border-color:#c45c5c4d}.recall-rate-btn.again:hover{background:var(--danger-soft)}.recall-rate-btn.hard{color:var(--warning);border-color:#d4a0334d}.recall-rate-btn.hard:hover{background:var(--accent-soft)}.recall-rate-btn.easy{color:var(--success);border-color:#5cb87a4d}.recall-rate-btn.easy:hover{background:var(--success-soft)}.recall-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:32px}.recall-stat{text-align:center;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.recall-stat-val{font-family:var(--font-display);font-size:1.6rem}.recall-stat-label{font-family:var(--font-mono);font-size:.65rem;color:var(--text-4);margin-top:4px;text-transform:uppercase;letter-spacing:.08em}.preinput-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px}.preinput-transcript{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;max-height:600px;overflow-y:auto}.preinput-transcript h3{font-family:var(--font-display);font-size:1.1rem;margin-bottom:20px;font-weight:400}.transcript-input{width:100%;min-height:160px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;color:var(--text);font-family:var(--font-body);font-size:.9rem;line-height:1.7;outline:none;resize:vertical}.transcript-input:focus{border-color:var(--accent)}.transcript-line{padding:10px 14px;border-radius:var(--radius);margin-bottom:4px;font-size:.92rem;line-height:1.7;color:var(--text-2)}.preinput-sidebar{display:flex;flex-direction:column;gap:16px}.vocab-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.vocab-card h4{font-family:var(--font-mono);font-size:.72rem;color:var(--text-4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}.vocab-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);gap:12px}.vocab-item:last-child{border-bottom:none}.vocab-word{font-family:var(--font-display);font-size:1.05rem;font-style:italic}.vocab-meaning{font-size:.82rem;color:var(--text-3);text-align:right}.comprehension-meter{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;text-align:center}.meter-circle{width:120px;height:120px;border-radius:50%;margin:0 auto 16px;position:relative;display:flex;align-items:center;justify-content:center}.meter-circle svg{position:absolute;top:0;right:0;bottom:0;left:0;transform:rotate(-90deg)}.meter-circle circle{fill:none;stroke-width:6}.meter-bg{stroke:var(--surface-3)}.meter-fill{stroke:var(--accent);transition:stroke-dashoffset 1.5s ease}.meter-value{font-family:var(--font-display);font-size:2rem;z-index:1}.meter-label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-4);text-transform:uppercase;letter-spacing:.08em}.content-source{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:14px}.content-thumb{width:64px;height:48px;border-radius:8px;background:var(--surface-3);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.content-info h4{font-size:.9rem;font-weight:500;margin-bottom:4px}.content-info p{font-family:var(--font-mono);font-size:.68rem;color:var(--text-4)}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:700px}.setting-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.setting-card h4{font-size:.9rem;font-weight:500;margin-bottom:6px}.setting-card p{font-size:.78rem;color:var(--text-3);margin-bottom:16px;line-height:1.5}.setting-card select{width:100%;padding:10px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:.88rem;outline:none;cursor:pointer}.setting-card select:focus{border-color:var(--accent)}.goal-options{display:flex;gap:8px;flex-wrap:wrap}.goal-opt{flex:1;padding:12px;text-align:center;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-family:var(--font-mono);font-size:.78rem;color:var(--text-3);transition:var(--transition);min-width:64px}.goal-opt:hover{border-color:var(--text-3)}.goal-opt.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.settings-actions{display:flex;gap:12px;margin-top:24px;max-width:700px}.danger-btn{padding:10px 18px;background:none;border:1px solid rgba(196,92,92,.3);color:var(--danger);border-radius:var(--radius);cursor:pointer;font-family:var(--font-mono);font-size:.78rem;transition:var(--transition)}.danger-btn:hover{background:var(--danger-soft)}.ghost-btn{padding:10px 18px;background:none;border:1px solid var(--border);color:var(--text-2);border-radius:var(--radius);cursor:pointer;font-family:var(--font-mono);font-size:.78rem;transition:var(--transition)}.ghost-btn:hover{border-color:var(--text-3)}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px}.auth-logo{font-family:var(--font-display);font-size:2rem;color:var(--accent);text-align:center;margin-bottom:6px}.auth-sub{font-family:var(--font-mono);font-size:.68rem;color:var(--text-4);text-align:center;text-transform:uppercase;letter-spacing:.12em;margin-bottom:28px}.auth-field{margin-bottom:16px}.auth-field label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:6px}.auth-field input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;color:var(--text);font-family:var(--font-body);font-size:.92rem;outline:none;transition:var(--transition)}.auth-field input:focus{border-color:var(--accent)}.auth-error{color:var(--danger);font-size:.8rem;margin-bottom:12px;min-height:1em}.auth-switch{text-align:center;margin-top:18px;font-size:.82rem;color:var(--text-3)}.auth-switch a{color:var(--accent);cursor:pointer}@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.preinput-layout{grid-template-columns:1fr}.sentence-card{grid-template-columns:1fr;gap:10px}.sent-arrow{display:none}.add-row{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform var(--transition);width:min(280px,82vw);box-shadow:none}.sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 24px #0006}.mobile-topbar{display:flex}.mobile-close-btn{display:flex;align-items:center;justify-content:center}.sidebar-overlay{display:block}.sidebar-overlay.show{opacity:1;pointer-events:auto}.main{margin-left:0;padding-top:56px}.section-header,.section-body{padding-left:20px;padding-right:20px}.stats-grid{grid-template-columns:1fr 1fr}.settings-grid{grid-template-columns:1fr}}
