@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Lora:ital,wght@0,400;0,500;1,400&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0B0E19;--surface: #131826;--surface-raised: #192034;--surface-hover: #1F2840;--shadow-card: 0 2px 8px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.04);--shadow-md: 0 4px 20px rgba(0,0,0,.55);--shadow-lg: 0 8px 40px rgba(0,0,0,.65);--border: rgba(255,255,255,.055);--border-strong: rgba(255,255,255,.11);--text-primary: #E8EEFF;--text-secondary: #7B87A0;--text-muted: #3E4A5E;--accent: #4E80EE;--accent-dim: rgba(78,128,238,.14);--accent-glow: rgba(78,128,238,.38);--accent-2: #FF8C42;--accent-2-dim: rgba(255,140,66,.14);--accent-3: #34D399;--accent-3-dim: rgba(52,211,153,.14);--accent-4: #A78BFA;--accent-4-dim: rgba(167,139,250,.14);--radius: 10px;--radius-lg: 14px;--radius-xl: 20px}[data-theme=light]{--bg: #EBF0FF;--surface: #FFFFFF;--surface-raised: #FFFFFF;--surface-hover: #F2F6FF;--shadow-card: 0 2px 8px rgba(60,80,160,.09), 0 0 0 1px rgba(0,0,0,.04);--shadow-md: 0 4px 20px rgba(60,80,160,.13);--shadow-lg: 0 8px 40px rgba(60,80,160,.16);--border: rgba(0,0,0,.055);--border-strong: rgba(0,0,0,.11);--text-primary: #0B0E19;--text-secondary: #4A5568;--text-muted: #8892A4;--accent: #3B6FE0;--accent-dim: rgba(59,111,224,.11);--accent-glow: rgba(59,111,224,.28);--accent-2: #E8760A;--accent-2-dim: rgba(232,118,10,.11);--accent-3: #059669;--accent-3-dim: rgba(5,150,105,.11);--accent-4: #7C3AED;--accent-4-dim: rgba(124,58,237,.11);--radius: 10px;--radius-lg: 14px;--radius-xl: 20px}html{background:var(--bg);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .25s ease,color .25s ease}body{min-height:100dvh;background:var(--bg);overscroll-behavior:none}.app-shell{display:flex;min-height:100dvh;align-items:flex-start}.sidebar{width:64px;flex-shrink:0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;align-items:center;background:var(--surface);border-right:1px solid var(--border);padding:1rem 0;z-index:10;box-shadow:2px 0 16px #0003}.sidebar-logo{display:flex;align-items:center;justify-content:center;width:100%;padding:.4rem 0 1rem}.sidebar-logo-mark{font-family:Inter,sans-serif;font-size:1rem;font-weight:800;color:var(--text-primary);line-height:1;letter-spacing:-.03em}.sidebar-logo-mark .accent{color:var(--accent)}.sidebar-nav{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding-top:.25rem;width:100%}.sidebar-bottom{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding-bottom:.25rem;width:100%}.sidebar-item{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:10px;cursor:pointer;color:var(--text-muted);transition:background-color .15s ease,color .15s ease}.sidebar-item:hover:not(:disabled){background:var(--surface-hover);color:var(--text-secondary)}.sidebar-item--active{color:var(--accent);background:var(--accent-dim)}.sidebar-item--active:hover:not(:disabled){color:var(--accent);background:var(--accent-dim)}.sidebar-item--soon{cursor:default;opacity:.28}.sidebar-divider{width:24px;height:1px;background:var(--border);margin:.4rem 0}.main-content{flex:1;min-width:0;min-height:100vh;background:var(--bg)}.view-shell{padding:2rem 2.5rem 5rem;max-width:1060px;margin:0 auto;width:100%}.view-shell--reading{max-width:860px;margin:0 auto;display:flex;flex-direction:column;height:100vh;overflow:hidden;padding:1.5rem 2.5rem 0}.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.app-wordmark{font-family:Inter,sans-serif;font-size:1.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;line-height:1}.app-wordmark .accent{color:var(--accent)}.app-tagline{font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;color:var(--text-muted);letter-spacing:.01em}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:2rem;animation:fade-up .35s ease both}.stat-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:1.1rem 1.15rem 1rem;display:flex;flex-direction:column;gap:0}.stat-icon{font-size:1.3rem;line-height:1;margin-bottom:.55rem}.stat-value{font-family:Inter,sans-serif;font-size:1.8rem;font-weight:800;color:var(--text-primary);line-height:1;letter-spacing:-.03em}.stat-label{font-family:Inter,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-top:.3rem}.stat-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.45rem}.stat-goal-fraction{font-family:Inter,sans-serif;font-size:.82rem;font-weight:600;color:var(--text-secondary);letter-spacing:-.01em}.stat-goal-fraction .stat-sep{color:var(--text-muted);margin:0 .1em;font-weight:400}.stat-progress-bar{height:5px;background:var(--surface-hover);border-radius:3px;overflow:hidden;margin-top:.3rem}.stat-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-3),#6ee7b7);border-radius:3px;transition:width .5s ease;min-width:0}.story-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;animation:fade-up .38s ease both}.genre-prompt{font-family:Inter,sans-serif;font-size:1.45rem;font-weight:700;color:var(--text-primary);line-height:1.2;letter-spacing:-.02em}.story-count{font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;color:var(--text-muted);letter-spacing:.01em;white-space:nowrap;flex-shrink:0}.length-control{margin-bottom:1.75rem;padding:1rem 1.15rem;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);animation:fade-up .4s .04s ease both}.length-label{font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;color:var(--text-secondary);letter-spacing:.01em;margin:0 0 .75rem}.length-options{display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem}.length-btn{display:flex;flex-direction:column;align-items:center;gap:.18rem;padding:.6rem .25rem;background:var(--surface-hover);border:1.5px solid transparent;border-radius:10px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.length-btn:hover,.length-btn--active{background:var(--accent-dim);border-color:var(--accent)}.length-btn-label{font-family:Inter,sans-serif;font-size:.78rem;font-weight:700;color:var(--text-primary);transition:color .15s ease}.length-btn--active .length-btn-label{color:var(--accent)}.length-btn-words{font-family:Inter,sans-serif;font-size:.59rem;font-weight:500;color:var(--text-muted);transition:color .15s ease}.length-btn--active .length-btn-words{color:var(--accent);opacity:.8}.category-filter{display:flex;gap:.45rem;overflow-x:auto;padding-bottom:.6rem;margin-bottom:1.1rem;-webkit-overflow-scrolling:touch;scrollbar-width:none;animation:fade-up .4s .03s ease both}.category-filter::-webkit-scrollbar{display:none}.category-chip{font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-secondary);background:var(--surface);border:1px solid var(--border-strong);border-radius:20px;padding:6px 14px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background-color .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease;letter-spacing:.01em}.category-chip:hover{background:var(--surface-hover);color:var(--text-primary)}.category-chip--active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 10px var(--accent-glow)}.category-chip--active:hover{background:var(--accent);color:#fff}.story-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.85rem;animation:fade-up .42s .06s ease both}.story-tile{aspect-ratio:3 / 4;border:none;border-radius:18px;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;padding:.9rem;box-shadow:0 4px 20px #00000059,0 0 0 1px #ffffff12;transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden;text-align:left}.story-tile:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(0,0,0,.52) 100%);border-radius:inherit;pointer-events:none}.story-tile:hover{transform:translateY(-6px) scale(1.025);box-shadow:0 14px 40px #00000080,0 0 0 1px #ffffff1f}.story-tile:active{transform:translateY(-2px) scale(1.005);transition-duration:.08s}.story-tile-emoji{font-size:2.1rem;line-height:1;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));position:relative;z-index:1}.story-tile-content{position:relative;z-index:1;width:100%}.story-tile-title{font-family:Inter,sans-serif;font-size:.8rem;font-weight:700;color:#fff;line-height:1.25;letter-spacing:-.01em;text-shadow:0 1px 5px rgba(0,0,0,.55);margin-bottom:.18rem}.story-tile-subtitle{font-family:Inter,sans-serif;font-size:.66rem;font-weight:400;color:#ffffffb3;line-height:1.3;text-shadow:0 1px 3px rgba(0,0,0,.45)}.loading-screen{background:var(--surface);border-radius:var(--radius-xl);min-height:54vh;display:flex;align-items:center;justify-content:center;animation:fade-up .3s ease both;box-shadow:var(--shadow-md);overflow:hidden}.loading-content{text-align:center;padding:2rem}.loading-emoji{font-size:3.2rem;line-height:1;display:block;margin-bottom:1rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.5));animation:float 2.2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.loading-genre{font-family:Inter,sans-serif;font-size:1.4rem;font-weight:700;color:#fff;letter-spacing:-.02em;text-shadow:0 2px 8px rgba(0,0,0,.7);margin-bottom:.45rem}.loading-text{font-family:Inter,sans-serif;font-size:.82rem;font-weight:500;color:#ffffff8c}.loading-dots{animation:blink 1.5s step-start infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.error-screen{display:flex;flex-direction:column;align-items:flex-start;gap:1.25rem;padding:1.75rem;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border-left:3px solid #f87171;margin-top:2rem}.error-msg{font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;color:#f87171}.back-btn{font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-muted);background:transparent;border:1px solid var(--border-strong);border-radius:20px;cursor:pointer;padding:5px 13px;transition:background-color .15s ease,color .15s ease,border-color .15s ease;letter-spacing:.01em}.back-btn:hover{background:var(--surface-hover);color:var(--accent);border-color:var(--accent)}.genre-tag{display:inline-flex;align-items:center;gap:.35rem;padding:4px 12px 4px 10px;border-radius:20px;font-family:Inter,sans-serif;font-size:.72rem;font-weight:600;color:var(--accent);background:var(--accent-dim);border:1px solid var(--genre-color, var(--accent));margin-bottom:1.25rem;letter-spacing:.01em}.story-hint--touch{display:none}.story-hint--desktop{display:block}@media(hover:none)and (pointer:coarse){.story-hint--touch{display:block}.story-hint--desktop{display:none}}.story-hint{font-family:Inter,sans-serif;font-size:.72rem;font-weight:500;color:var(--text-muted);margin-bottom:1.25rem;letter-spacing:.01em}.story-area{flex:1;min-height:0;overflow:hidden;position:relative}.story{font-size:var(--story-font-size, 1rem);line-height:var(--story-line-height, 1.75);color:var(--text-primary);font-family:Lora,Georgia,serif;text-align:justify;-webkit-hyphens:auto;hyphens:auto;column-count:1;column-fill:auto;column-gap:0;transition:transform .3s ease;will-change:transform}.story-paragraph{margin-bottom:1.6rem}.story-paragraph:last-child{margin-bottom:0}.word-wrapper{position:relative;display:inline-block;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.word{cursor:pointer;padding:2px 1px;border-radius:3px;transition:background-color .12s ease;display:inline}.word--trailing{padding-right:0}.word-punctuation{display:inline}.word.known{background-color:transparent}.word.unknown{background-color:var(--accent-2-dim);border-bottom:1.5px solid var(--accent-2);color:var(--accent-2)}.word-wrapper:hover .word.known{background-color:var(--accent-dim)}.word-wrapper:hover .word.unknown{filter:brightness(1.1)}.word-wrapper:after{content:"";position:absolute;bottom:100%;left:-8px;right:-8px;height:10px}.word-popup{position:fixed;background:var(--surface-raised);border:1px solid var(--border-strong);border-radius:10px;display:flex;align-items:center;gap:0;padding:3px;z-index:1000;box-shadow:var(--shadow-md);white-space:nowrap}.word-popup:after{content:"";position:absolute;top:calc(100% - 1px);left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--border-strong)}.word-popup:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--surface-raised);z-index:1}.word-popup-btn{display:flex;align-items:center;justify-content:center;width:28px;height:26px;border:none;background:none;border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:background-color .1s ease,color .1s ease;flex-shrink:0}.word-popup-btn:hover:not(:disabled){background-color:var(--accent-dim);color:var(--accent)}.word-popup-btn--soon{cursor:default;opacity:.3}.word-popup-btn--active{background:#ffffff1f;color:var(--accent)}.word-popup-btn--close{display:none;font-size:.7rem;color:var(--text-secondary)}.word-popup-divider--close{display:none}.word-popup-divider{width:1px;height:16px;background:var(--border);flex-shrink:0;margin:0 1px}.word-popup-abc{font-family:Inter,sans-serif;font-size:.68rem;font-weight:600;letter-spacing:.04em;color:inherit;line-height:1}.word-popup-pronunciation{padding:6px 12px 8px;border-top:1px solid rgba(255,255,255,.1);text-align:center}.word-popup-phonetic{font-size:.85rem;color:var(--accent, #e8d5b0);letter-spacing:.05em;font-family:Lora,serif}.finish-bar{position:absolute;bottom:1.25rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.75rem;z-index:10}.finish-btn{font-family:Inter,sans-serif;font-size:.88rem;font-weight:700;color:#fff;background:var(--accent);border:none;border-radius:var(--radius);padding:.65rem 1.75rem;cursor:pointer;box-shadow:0 4px 16px var(--accent-glow);transition:opacity .15s ease,transform .15s ease,box-shadow .15s ease;letter-spacing:.01em}.finish-btn:hover:not(:disabled){opacity:.92;transform:translateY(-2px);box-shadow:0 6px 22px var(--accent-glow)}.finish-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px var(--accent-glow)}.finish-btn:disabled{opacity:.38;cursor:not-allowed;box-shadow:none}.submit-msg{font-family:Inter,sans-serif;font-size:.82rem;font-weight:600}.submit-msg.success{color:var(--accent-3)}.submit-msg.error{color:#f87171}.page-footer{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:.6rem 0 .9rem;border-top:1px solid var(--border);margin-top:.5rem}.page-nav{display:flex;align-items:center;justify-content:center;gap:1.25rem;width:100%}.page-nav--desktop{display:flex}.page-nav--mobile{display:none}@media(max-width:640px){.page-nav--desktop{display:none}.page-nav--mobile{display:flex}}.page-nav-btn{font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-secondary);background:var(--surface);border:1px solid var(--border-strong);border-radius:20px;padding:5px 16px;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease;letter-spacing:.01em;flex-shrink:0}.page-nav-btn:hover:not(:disabled){background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.page-nav-btn:disabled{opacity:.28;cursor:default}.page-dots{display:flex;align-items:center;justify-content:center;gap:7px;padding:.1rem 0}.page-dot{width:6px;height:6px;border-radius:50%;background:var(--border-strong);transition:background .25s ease,transform .25s ease;flex-shrink:0}.page-dot--active{background:var(--accent);transform:scale(1.4)}.page-counter{font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;color:var(--text-muted);letter-spacing:.04em}@keyframes finish-pop{0%{opacity:0;transform:translateY(18px) scale(.88)}65%{opacity:1;transform:translateY(-4px) scale(1.03)}to{opacity:1;transform:translateY(0) scale(1)}}.finish-btn--pop{animation:finish-pop .45s cubic-bezier(.34,1.56,.64,1) both}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ob-shell{min-height:100vh;display:flex;flex-direction:column;max-width:760px;margin:0 auto;padding:0 2rem;background:var(--bg)}.ob-shell--story{height:100vh;overflow:hidden}.ob-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.ob-header--hero{flex-direction:column;align-items:center;gap:.4rem;padding-top:3rem;padding-bottom:1.5rem;border-bottom:none}.ob-hero-wordmark{font-size:2rem!important}.ob-step-pill{font-family:Inter,sans-serif;font-size:.72rem;font-weight:600;color:var(--text-muted);background:var(--surface);border:1px solid var(--border-strong);border-radius:20px;padding:3px 12px;letter-spacing:.03em}.ob-content{flex:1;overflow-y:auto;padding:2.5rem 0 1rem}.ob-heading{font-family:Inter,sans-serif;font-size:1.7rem;font-weight:800;color:var(--text-primary);line-height:1.2;margin-bottom:.55rem;letter-spacing:-.03em}.ob-subheading{font-family:Inter,sans-serif;font-size:.88rem;font-weight:400;color:var(--text-secondary);line-height:1.65;margin-bottom:2rem;max-width:52ch}.ob-footer{flex-shrink:0;position:sticky;bottom:0;padding:1rem 0 1.5rem;background:var(--bg);border-top:1px solid var(--border)}.ob-score-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.65rem;animation:fade-up .35s ease both}@media(min-width:520px){.ob-score-grid{grid-template-columns:repeat(3,1fr)}}.ob-score-card{display:flex;flex-direction:column;align-items:flex-start;gap:.2rem;padding:1rem 1.1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;box-shadow:var(--shadow-card);transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.ob-score-card:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow-md)}.ob-score-card--selected{border-color:var(--accent);background:var(--accent-dim)}.ob-score-card--selected:hover{border-color:var(--accent);transform:none}.ob-score-num{font-family:Inter,sans-serif;font-size:1.4rem;font-weight:800;color:var(--accent);line-height:1;letter-spacing:-.02em}.ob-score-label{font-family:Inter,sans-serif;font-size:.92rem;font-weight:700;color:var(--text-primary);line-height:1.2}.ob-score-desc{font-family:Inter,sans-serif;font-size:.74rem;color:var(--text-secondary);line-height:1.4}.ob-tense-grid{display:grid;grid-template-columns:1fr;gap:.65rem;animation:fade-up .35s ease both}@media(min-width:600px){.ob-tense-grid{grid-template-columns:repeat(2,1fr)}}.ob-tense-card{padding:1rem 1.1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:.55rem}.ob-tense-top{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.ob-tense-name{font-family:Inter,sans-serif;font-size:.92rem;font-weight:700;color:var(--text-primary)}.ob-tense-english{font-family:Inter,sans-serif;font-size:.72rem;font-weight:500;color:var(--text-muted);white-space:nowrap}.ob-tense-example{font-family:Lora,serif;font-size:.8rem;font-style:italic;color:var(--text-secondary);letter-spacing:.01em}.ob-comfort-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.3rem}.ob-comfort-btn{font-family:Inter,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-muted);background:var(--surface-hover);border:1px solid var(--border);border-radius:6px;padding:5px 2px;cursor:pointer;text-align:center;line-height:1.3;transition:color .12s ease,border-color .12s ease,background-color .12s ease}.ob-comfort-btn:hover{color:var(--text-secondary);border-color:var(--border-strong);background:var(--surface)}.ob-comfort-btn--active,.ob-comfort-btn--active:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.ob-story-meta{display:flex;align-items:center;gap:.75rem;padding:1rem 0 .75rem;flex-shrink:0}.ob-level-badge{font-family:Inter,sans-serif;font-size:.72rem;font-weight:700;color:var(--accent);background:var(--accent-dim);border-radius:20px;padding:3px 10px;letter-spacing:.04em;text-transform:uppercase}.ob-story-area{flex:1;min-height:0;overflow:visible;position:relative}.ob-page-footer{flex-shrink:0;display:flex;flex-direction:column;gap:.6rem;padding:.75rem 0 1rem;border-top:1px solid var(--border);margin-top:.5rem}.ob-completing{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem}.ob-completing-spinner{width:32px;height:32px;border:2.5px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:ob-spin .8s linear infinite}@keyframes ob-spin{to{transform:rotate(360deg)}}.ob-completing-text{font-family:Inter,sans-serif;font-size:.88rem;font-weight:500;color:var(--text-secondary)}.surprise-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:1rem 1.25rem;background:linear-gradient(135deg,#667eea,#f5576c,#fda085);border:none;border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:opacity .15s,transform .15s;margin-bottom:.25rem}.surprise-btn:hover{opacity:.9;transform:translateY(-1px)}.surprise-btn:active{transform:translateY(0)}.surprise-btn-emoji{font-size:1.6rem;line-height:1;flex-shrink:0}.surprise-btn-text{font-family:Playfair Display,Georgia,serif;font-size:1.05rem;font-weight:700;color:#fff}.surprise-btn-sub{font-family:Inter,sans-serif;font-size:.78rem;color:#fffc;margin-left:auto;flex-shrink:0}.cal-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:1.5rem 1.5rem 1.75rem;max-width:500px;animation:fade-up .35s ease both}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.cal-title{font-family:Inter,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.cal-nav-btn{width:30px;height:30px;border:1px solid var(--border-strong);border-radius:8px;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:1.15rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}.cal-nav-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text-primary)}.cal-nav-btn:disabled{opacity:.2;cursor:default}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-dow{font-family:Inter,sans-serif;font-size:.65rem;font-weight:700;color:var(--text-muted);text-align:center;padding:2px 0 8px;letter-spacing:.04em;text-transform:uppercase}.cal-cell{aspect-ratio:1;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:3px 2px;transition:transform .1s ease}.cal-cell--empty{pointer-events:none}.cal-day-num{font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;color:var(--text-secondary);line-height:1}.cal-day-words{font-family:Inter,sans-serif;font-size:.58rem;font-weight:500;color:var(--text-muted);line-height:1}.cal-cell--partial{background:var(--accent-4-dim)}.cal-cell--partial .cal-day-num{color:var(--accent-4)}.cal-cell--partial .cal-day-words{color:var(--accent-4);opacity:.75}.cal-cell--hit{background:var(--accent-4)}.cal-cell--hit .cal-day-num,.cal-cell--hit .cal-day-words{color:#fff}.cal-cell--today{box-shadow:0 0 0 2px var(--accent-4)}.cal-cell--today:not(.cal-cell--hit):not(.cal-cell--partial) .cal-day-num{color:var(--accent-4);font-weight:800}.progress-section{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:1.5rem;max-width:500px;animation:fade-up .35s ease both}.progress-section-title{font-family:Inter,sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0 0 1.1rem}.progress-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1.25rem}.progress-mini-stat{background:var(--surface-2);border-radius:var(--radius-lg);padding:.6rem .4rem;text-align:center}.progress-mini-value{font-family:Inter,sans-serif;font-size:1.15rem;font-weight:800;color:var(--accent);margin:0 0 .15rem;letter-spacing:-.03em}.progress-mini-label{font-family:Inter,sans-serif;font-size:.62rem;color:var(--text-muted);margin:0;line-height:1.2}.vocab-chart{margin-bottom:1.25rem;height:180px}.progress-empty{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-muted);text-align:center;padding:1.5rem 0;margin:0 0 1.25rem}.pos-breakdown{display:flex;flex-direction:column;gap:.55rem}.pos-bar-row{display:flex;align-items:center;gap:.6rem}.pos-bar-label{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-secondary);width:70px;flex-shrink:0}.pos-bar-track{flex:1;height:7px;background:var(--surface-2);border-radius:99px;overflow:hidden}.pos-bar-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .4s ease}.pos-bar-count{font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;color:var(--text-muted);width:28px;text-align:right;flex-shrink:0}.mastered-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}.mastered-item{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border)}.mastered-item:last-child{border-bottom:none}.mastered-word{font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;color:var(--text-primary);display:flex;align-items:baseline;gap:.35rem;flex-shrink:0}.mastered-pos{font-size:.68rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.mastered-dates{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-muted);text-align:right;line-height:1.4}.progress-show-more{margin-top:.85rem;background:none;border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;padding:.45rem 1rem;width:100%;transition:background .15s ease,color .15s ease}.progress-show-more:hover{background:var(--surface-hover);color:var(--text-primary)}@media(max-width:960px){.story-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.view-shell{padding:1.75rem 1.75rem 5rem}}@media(max-width:640px){.app-shell{flex-direction:column;height:100dvh;overflow:hidden}.main-content{flex:1;width:100%;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar{order:999;position:static;width:100%;height:56px;flex-shrink:0;top:auto;flex-direction:row;justify-content:space-evenly;align-items:center;border-right:none;border-top:1px solid var(--border);padding:0 .5rem;box-shadow:0 -4px 20px #0003;z-index:200}.sidebar-logo{display:none}.sidebar-nav,.sidebar-bottom{display:contents}.sidebar-item--soon,.sidebar-divider{display:none}.view-shell{padding:1.25rem 1rem 5rem}.view-shell--reading{padding:1rem 1rem 0;height:100%}.page-footer{padding:.75rem 0 1rem;gap:.75rem}.stat-grid{grid-template-columns:1fr 1fr}.stat-grid .stat-card:last-child{grid-column:1 / -1;flex-direction:row;align-items:center;gap:1rem;padding:.9rem 1.15rem}.stat-grid .stat-card:last-child .stat-card-top{flex-direction:column;align-items:flex-start;gap:.1rem;margin-bottom:0;flex-shrink:0}.stat-grid .stat-card:last-child .stat-label{margin-top:0}.stat-grid .stat-card:last-child .stat-progress-bar{flex:1;margin-top:0;align-self:center}.story-grid{grid-template-columns:1fr 1fr;gap:.65rem}.story-tile{aspect-ratio:3 / 2}.story-tile-emoji{font-size:1.6rem}.app-header{margin-bottom:1.25rem;padding-bottom:.75rem}.app-tagline{display:none}.genre-prompt{font-size:1.2rem}.length-control{margin-bottom:1.25rem}.story-hint{font-size:.68rem}.loading-screen{min-height:44vh}}@media(max-width:360px){.story-grid{grid-template-columns:1fr 1fr;gap:.5rem}.story-tile{aspect-ratio:2 / 3}}@media(hover:none)and (pointer:coarse){.word-popup-btn--close,.word-popup-divider--close{display:flex}.word-wrapper:hover .word.known{background-color:transparent}.word-wrapper:hover .word.unknown{filter:none}.word{padding:3px 1px}.word--trailing{padding-right:0}.sidebar-item{min-width:44px;min-height:44px}.category-chip{min-height:44px;padding:0 1rem}}.app-shell{padding-top:env(safe-area-inset-top)}@media(max-width:640px){.sidebar{padding-bottom:env(safe-area-inset-bottom);height:calc(56px + env(safe-area-inset-bottom))}}.rating-page{background:var(--surface);border-radius:var(--radius-xl);min-height:54vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.rating-page-content{display:flex;flex-direction:column;align-items:center;gap:1.1rem;text-align:center;padding:2.5rem 2rem;animation:fade-up .35s ease both}.rating-page-saved{font-family:Inter,sans-serif;font-size:.72rem;font-weight:700;color:#fff9;letter-spacing:.1em;text-transform:uppercase}.rating-page-emoji{font-size:3.6rem;line-height:1;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.25));animation:float 3s ease-in-out infinite}.rating-page-title{font-family:Inter,sans-serif;font-size:1.4rem;font-weight:700;color:#fff;margin:0;text-shadow:0 1px 4px rgba(0,0,0,.3)}.rating-page-question{font-family:Lora,Georgia,serif;font-size:1.05rem;font-style:italic;color:#ffffffd1;margin:.15rem 0 .35rem}.rating-page-buttons{display:flex;gap:1.75rem;margin-top:.25rem}.rating-page-btn{width:78px;height:78px;border-radius:50%;border:2px solid rgba(255,255,255,.22);background:#ffffff24;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);font-size:2.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease;box-shadow:0 4px 18px #0000002e}.rating-page-btn:hover{transform:scale(1.14);box-shadow:0 8px 30px #00000047}.rating-page-btn:active{transform:scale(.97)}.rating-page-btn--like:hover{background:#4ade8052;border-color:#4ade80a6}.rating-page-btn--dislike:hover{background:#f8717152;border-color:#f87171a6}.rating-page-skip{background:none;border:none;color:#fff6;cursor:pointer;font-family:Inter,sans-serif;font-size:.78rem;padding:.3rem .5rem;transition:color .15s;letter-spacing:.02em;margin-top:.1rem}.rating-page-skip:hover{color:#ffffffb8}@media(max-width:480px){.rating-page{min-height:44vh}.rating-page-btn{width:68px;height:68px;font-size:1.9rem}}.debug-toggle-btn{font-family:monospace;font-size:.8rem;font-weight:700;letter-spacing:0;color:var(--text-muted)}.debug-toggle-btn--active{background:#e74c3c!important;color:#fff!important;border-radius:6px}.word--debug-target{color:#e74c3c!important;font-weight:700}.debug-panel{flex-shrink:0;margin:0 0 .5rem;padding:.75rem 1rem;background:#e74c3c14;border:1px solid rgba(231,76,60,.3);border-radius:8px;font-size:.78rem;font-family:monospace;line-height:1.5;color:var(--text-primary);overflow-y:auto;max-height:280px}.debug-panel__header{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.6rem}.debug-panel__title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#e74c3c}.debug-panel__meta{color:var(--text-muted);font-size:.75rem}.debug-panel__section{margin-top:.5rem}.debug-panel__section-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:.25rem}.debug-panel__word{display:flex;align-items:baseline;gap:.3rem;padding:.1rem 0}.debug-panel__word-status{width:1rem;flex-shrink:0}.debug-panel__word--hit .debug-panel__word-status{color:#2ecc71}.debug-panel__word--miss .debug-panel__word-status{color:#888}.debug-panel__word--miss .debug-panel__word-lemma{color:#888;text-decoration:line-through}.debug-panel__word-hint,.debug-panel__word-forms{color:var(--text-muted);font-size:.72rem}.debug-panel__uncomfortable{color:#e67e22;font-size:.75rem;word-break:break-all}.debug-panel__prompt-toggle{background:none;border:none;color:var(--text-muted);font-family:monospace;font-size:.75rem;cursor:pointer;padding:.2rem 0}.debug-panel__prompt-toggle:hover{color:var(--text-primary)}.debug-panel__prompt{margin-top:.4rem;padding:.5rem .75rem;background:#0003;border-radius:4px;font-size:.72rem;white-space:pre-wrap;word-break:break-word;color:var(--text-primary);max-height:200px;overflow-y:auto}.settings-view{display:flex;flex-direction:column;height:100%;overflow-y:auto;padding:1.5rem 1.5rem 2rem;max-width:600px;width:100%;margin:0 auto;box-sizing:border-box}.settings-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:2rem;flex-shrink:0}.settings-title{font-family:Playfair Display,Georgia,serif;font-size:1.6rem;font-weight:700;color:var(--text-primary);margin:0}.settings-back-btn{background:none;border:none;color:var(--accent);font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;padding:.5rem 0;min-height:44px;display:flex;align-items:center;white-space:nowrap}.settings-back-btn:hover{opacity:.75}.settings-content{display:flex;flex-direction:column;gap:1.75rem}.settings-section{display:flex;flex-direction:column;gap:.5rem}.settings-section-label{font-family:Inter,sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin:0 0 .25rem .25rem}.settings-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1rem;gap:1rem;min-height:52px}.settings-row--btn{background:none;border:none;width:100%;cursor:pointer;text-align:left;color:var(--text-primary);font-family:Inter,sans-serif;transition:background .12s}.settings-row--btn:hover{background:var(--surface-3)}.settings-row--goal{flex-wrap:wrap;gap:.75rem}.settings-row-label{font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap}.settings-row-value{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-dim);display:flex;align-items:center;gap:.4rem}.settings-row-chevron{font-size:1.2rem;color:var(--text-dim);line-height:1}.settings-feedback{font-family:Inter,sans-serif;font-size:.78rem;margin:0;padding:0 1rem .6rem}.settings-feedback--ok{color:var(--accent-3)}.settings-feedback--err{color:#f87171}.theme-selector{display:flex;border:1px solid var(--border);border-radius:calc(var(--radius) - 2px);overflow:hidden;flex-shrink:0}.theme-btn{background:none;border:none;padding:.45rem .8rem;font-family:Inter,sans-serif;font-size:.78rem;font-weight:500;color:var(--text-dim);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;min-height:36px}.theme-btn+.theme-btn{border-left:1px solid var(--border)}.theme-btn:hover{background:var(--surface-3);color:var(--text-primary)}.theme-btn--active{background:var(--accent);color:#fff;font-weight:700}.theme-btn--active:hover{background:var(--accent);opacity:.9}.goal-input-group{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.goal-input{width:90px;padding:.45rem .65rem;background:var(--surface-1);border:1px solid var(--border);border-radius:calc(var(--radius) - 2px);color:var(--text-primary);font-family:Inter,sans-serif;font-size:.9rem;text-align:center;-moz-appearance:textfield}.goal-input::-webkit-outer-spin-button,.goal-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.goal-input:focus{outline:none;border-color:var(--accent)}.goal-save-btn{background:var(--accent);border:none;border-radius:calc(var(--radius) - 2px);color:#fff;font-family:Inter,sans-serif;font-size:.8rem;font-weight:700;padding:.45rem .9rem;cursor:pointer;min-height:36px;transition:opacity .15s}.goal-save-btn:hover{opacity:.85}.settings-slider-row{display:flex;align-items:center;gap:.75rem;padding:0 .25rem}.settings-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;background:var(--border);outline:none;cursor:pointer}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 1px 4px #0000004d}.settings-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;box-shadow:0 1px 4px #0000004d}.settings-slider-bound{font-family:Lora,Georgia,serif;color:var(--text-dim);font-size:.85rem;flex-shrink:0;width:18px;text-align:center}.settings-slider-bound--lg{font-size:1.3rem}.settings-spacing-icon{font-family:Inter,sans-serif;font-size:1rem;letter-spacing:-.1em}.settings-spacing-icon--lg{font-size:1.4rem;letter-spacing:.05em}.settings-slider-label{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-dim);text-align:center;margin:.25rem 0 0}.font-preview{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-1);padding:1.25rem;max-width:480px}.font-preview-text{font-family:Lora,Georgia,serif;color:var(--text-primary);text-align:justify;margin:0;-webkit-hyphens:auto;hyphens:auto}@media(max-width:640px){.settings-view{padding:1.25rem 1rem 2rem}.settings-title{font-size:1.3rem}.theme-btn{padding:.45rem .6rem;font-size:.72rem}.goal-input{width:80px}.font-preview{max-width:100%}.settings-row--goal{flex-direction:column;align-items:flex-start}}.resume-banner{display:flex;align-items:center;gap:.75rem;background:linear-gradient(120deg,#4f46e5,#7c3aed 60%,#a855f7);border-radius:var(--radius);padding:.85rem 1rem;margin-bottom:1.25rem;animation:fade-up .3s ease both;box-shadow:0 4px 18px #633cdc59}.resume-banner-icon{font-size:1.4rem;flex-shrink:0}.resume-banner-text{display:flex;flex-direction:column;flex:1;min-width:0}.resume-banner-title{font-family:Inter,sans-serif;font-size:.88rem;font-weight:600;color:#fff}.resume-banner-time{font-family:Inter,sans-serif;font-size:.75rem;color:#ffffffb3}.resume-banner-btn{flex-shrink:0;background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:calc(var(--radius) - 2px);padding:.45rem .9rem;font-family:Inter,sans-serif;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease}.resume-banner-btn:hover{background:#ffffff47}.resume-banner-btn--ghost{background:transparent;color:#ffffffa6;border-color:#fff3}.resume-banner-btn--ghost:hover{background:#ffffff1a;color:#fff}.resume-banner-discard{flex-shrink:0;width:36px;height:36px;background:#c0392bbf;color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease;line-height:1}.resume-banner-discard:hover{background:#c0392b}.resume-banner-x{flex-shrink:0;background:#dc2626d9;color:#fff;border:none;border-radius:calc(var(--radius) - 2px);width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s ease}.resume-banner-x:hover{background:#dc2626}.resume-banner-confirm{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.resume-banner-confirm-label{font-family:Inter,sans-serif;font-size:.78rem;color:#ffffffe6;white-space:nowrap}.resume-banner-confirm-yes,.resume-banner-confirm-no{border:1px solid rgba(255,255,255,.4);border-radius:calc(var(--radius) - 2px);padding:.3rem .6rem;font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;cursor:pointer;color:#fff;transition:background .15s ease}.resume-banner-confirm-yes{background:#dc2626cc}.resume-banner-confirm-yes:hover{background:#dc2626}.resume-banner-confirm-no{background:#ffffff26}.resume-banner-confirm-no:hover{background:#ffffff40}.abandon-overlay{position:fixed;inset:0;z-index:1000;background:#0009;display:flex;align-items:center;justify-content:center;padding:1.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fade-in .2s ease both}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.abandon-card{background:var(--surface-raised);border-radius:calc(var(--radius) * 1.5);padding:2rem 1.75rem 1.75rem;max-width:400px;width:100%;box-shadow:0 24px 64px #00000080;animation:slide-up .25s cubic-bezier(.34,1.2,.64,1) both}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.abandon-title{font-family:Playfair Display,Georgia,serif;font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0 0 .4rem}.abandon-subtitle{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.5}.abandon-actions{display:flex;flex-direction:column;gap:.6rem}.abandon-btn{background:transparent;color:var(--text-primary);border:2px solid #7c3aed;border-radius:var(--radius);padding:.75rem 1rem;font-family:Inter,sans-serif;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease;text-align:center}.abandon-btn:hover{background:#7c3aed1a}.abandon-btn--back{border-color:var(--text-secondary);color:var(--text-secondary);font-weight:500;margin-top:.15rem}.abandon-btn--back:hover{background:transparent;border-color:var(--text-primary);color:var(--text-primary)}.sb-page{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem 1.25rem 3rem;max-width:680px;margin:0 auto;width:100%}.sb-header{display:flex;align-items:center;gap:1rem}.sb-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;flex:1}.sb-back-btn{background:none;border:none;color:var(--accent);font-size:.95rem;font-weight:600;cursor:pointer;padding:.25rem 0;flex-shrink:0}.sb-back-btn:hover{text-decoration:underline}.sb-btn-primary{display:block;width:100%;padding:.8rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s;text-align:center}.sb-btn-primary:hover:not(:disabled){opacity:.88}.sb-btn-primary:disabled{opacity:.4;cursor:not-allowed}.sb-btn-secondary{display:block;width:100%;padding:.75rem 1.25rem;background:transparent;color:var(--text-primary);border:1.5px solid var(--border);border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s;text-align:center}.sb-btn-secondary:hover{background:var(--surface-raised)}.sb-btn-danger{padding:.6rem 1.1rem;background:#c0392b;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.sb-btn-danger:hover{opacity:.85}.sb-btn-danger-sm{padding:.35rem .75rem;background:transparent;color:#c0392b;border:1.5px solid #c0392b;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.sb-btn-danger-sm:hover{background:#c0392b14}.sb-btn-create{padding:.55rem 1.1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s;flex-shrink:0}.sb-btn-create:hover:not(:disabled){opacity:.88}.sb-btn-create:disabled{opacity:.4;cursor:not-allowed}.sb-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:sb-spin .8s linear infinite;margin:1rem auto}.sb-spinner--sm{width:18px;height:18px;border-width:2px;margin:0;display:inline-block}@keyframes sb-spin{to{transform:rotate(360deg)}}.sb-list-loading{display:flex;justify-content:center;padding:2rem 0}.sb-empty{text-align:center;padding:2.5rem 1rem;color:var(--text-secondary);font-size:.95rem}.sb-error{color:#c0392b;font-size:.9rem;margin:0}.sb-list{display:flex;flex-direction:column;gap:.75rem}.sb-card{background:var(--surface-raised);border:1.5px solid var(--border);border-radius:12px;padding:1rem 1.1rem;cursor:pointer;transition:border-color .15s,box-shadow .15s}.sb-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px #7c3aed14}.sb-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.sb-card-title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 .2rem}.sb-card-seed{font-size:.85rem;color:var(--text-secondary);font-style:italic;margin:0 0 .75rem;line-height:1.4}.sb-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sb-genre-pill{display:inline-block;padding:.2rem .65rem;background:#7c3aed1f;color:var(--accent);border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.sb-completed-badge{display:inline-block;padding:.2rem .65rem;background:#27ae601f;color:#27ae60;border-radius:20px;font-size:.75rem;font-weight:600}.sb-generating-badge{display:inline-block;padding:.2rem .65rem;background:#f39c121f;color:#e67e22;border-radius:20px;font-size:.75rem;font-weight:600}.sb-progress-label{font-size:.85rem;color:var(--text-secondary)}.sb-detail-meta{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.sb-plot-seed{font-size:.9rem;color:var(--text-secondary);font-style:italic;margin:0;line-height:1.5}.sb-generating-notice{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary);padding:.5rem 0}.sb-chapter-list{display:flex;flex-direction:column;gap:.4rem}.sb-chapter-row{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:var(--surface-raised);border:1.5px solid var(--border);border-radius:8px;font-size:.9rem}.sb-chapter-num{font-weight:700;color:var(--text-primary);min-width:3.5rem}.sb-chapter-stage{flex:1;color:var(--text-secondary)}.sb-chapter-status{font-size:.8rem;font-weight:600}.sb-confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.sb-confirm-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:1.5rem 1.25rem;max-width:340px;width:90%;text-align:center}.sb-confirm-card p{color:var(--text-primary);margin:0 0 1rem;font-size:.95rem}.sb-confirm-btns{display:flex;gap:.75rem;justify-content:center}.sb-confirm-inline{display:flex;gap:.5rem;margin-top:.5rem}.sb-limit-notice{font-size:.85rem;color:var(--text-secondary);background:var(--surface-raised);border:1.5px solid var(--border);border-radius:8px;padding:.65rem .9rem;margin:0}.sb-form{display:flex;flex-direction:column;gap:1.25rem}.sb-section{display:flex;flex-direction:column;gap:.5rem}.sb-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.sb-optional{font-weight:400;text-transform:none;letter-spacing:0;font-size:.8rem}.sb-chip-row{display:flex;flex-wrap:wrap;gap:.4rem}.sb-chip{padding:.4rem .85rem;border:1.5px solid var(--border);border-radius:20px;background:transparent;color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.sb-chip:hover{border-color:var(--accent)}.sb-chip--active{border-color:var(--accent);background:var(--accent);color:#fff}.sb-length-btn{display:flex;flex-direction:column;align-items:center;padding:.55rem 1rem;border:1.5px solid var(--border);border-radius:10px;background:transparent;cursor:pointer;transition:border-color .15s,background .15s;min-width:80px}.sb-length-btn:hover{border-color:var(--accent)}.sb-length-btn--active{border-color:var(--accent);background:#7c3aed14}.sb-length-label{font-size:.9rem;font-weight:700;color:var(--text-primary)}.sb-length-desc{font-size:.75rem;color:var(--text-secondary)}.sb-seeds-loading{display:flex;justify-content:center;padding:2rem 0}.sb-seeds-list{display:flex;flex-direction:column;gap:.6rem}.sb-seed-card{display:flex;align-items:flex-start;gap:.75rem;padding:.85rem 1rem;background:var(--surface-raised);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s;width:100%}.sb-seed-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px #7c3aed14}.sb-seed-card--surprise{border-style:dashed}.sb-seed-num{font-size:.85rem;font-weight:700;color:var(--accent);min-width:1.25rem;padding-top:.05rem;flex-shrink:0}.sb-seed-text{font-size:.95rem;color:var(--text-primary);line-height:1.45}.sb-creating{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:.75rem;text-align:center;padding:2rem 1.25rem}.sb-creating-icon{font-size:3rem;margin-bottom:.5rem}.sb-creating-title{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0}.sb-creating-subtitle{font-size:.9rem;color:var(--text-secondary);margin:0}.chapter-complete-page{display:flex;align-items:center;justify-content:center;min-height:100%;padding:2rem 1.25rem}.cc-heading{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .4rem;text-align:center}.cc-subheading{font-size:.9rem;color:var(--text-secondary);margin:0 0 1.5rem;text-align:center;line-height:1.5}.cc-error{color:#c0392b;font-size:.85rem;margin:.75rem 0 0;text-align:center}.cc-choices-wrap{width:100%;max-width:540px;display:flex;flex-direction:column;align-items:stretch}.cc-choices{display:flex;flex-direction:column;gap:.75rem}.cc-choice-card{display:flex;align-items:flex-start;gap:.9rem;padding:1rem 1.1rem;background:var(--surface-raised);border:2px solid var(--border);border-radius:12px;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s;width:100%}.cc-choice-card:hover:not(:disabled){border-color:var(--accent);box-shadow:0 0 0 3px #7c3aed14}.cc-choice-card:disabled{opacity:.5;cursor:not-allowed}.cc-choice-label{font-size:.75rem;font-weight:800;color:var(--accent);background:#7c3aed1a;border-radius:4px;padding:.15rem .45rem;flex-shrink:0;align-self:flex-start;margin-top:.1rem;letter-spacing:.05em}.cc-choice-text{font-size:.95rem;color:var(--text-primary);line-height:1.5;font-style:italic}.cc-interstitial,.cc-generating{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;max-width:400px;width:100%}.cc-complete-icon{font-size:3.5rem;margin-bottom:.25rem}.cc-interstitial-btns{display:flex;flex-direction:column;gap:.6rem;width:100%;margin-top:.5rem}.cc-btn-primary{display:block;width:100%;padding:.8rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s;text-align:center}.cc-btn-primary:hover{opacity:.88}.cc-btn-secondary{display:block;width:100%;padding:.75rem 1.25rem;background:transparent;color:var(--text-primary);border:1.5px solid var(--border);border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s;text-align:center}.cc-btn-secondary:hover{background:var(--surface-raised)}.sb-chip--wide{padding:.4rem 1.25rem}.sb-btn-generate{display:block;width:100%;padding:.8rem 1.25rem;background:transparent;color:var(--accent);border:2px dashed var(--accent);border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s;text-align:center}.sb-btn-generate:hover{background:#7c3aed14}.sb-chapter-row--read{opacity:.6}.sb-chapter-row--generating{border-color:#e67e22}.sb-chapter-row--ready{border-color:var(--accent)}.sb-chapter-row--tappable{border-color:var(--accent);border-style:dashed;cursor:pointer}.sb-chapter-row--tappable:hover{background:#7c3aed0f}.sb-ch-icon{font-size:.8rem;font-weight:600}.sb-ch-icon--read{color:#27ae60}.sb-ch-icon--ready{color:var(--accent)}.sb-ch-icon--gen{color:#e67e22}.sb-ch-icon--pending{color:var(--accent);font-style:italic}.ob-shell--center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:2rem 1.25rem}.ob-welcome{display:flex;flex-direction:column;align-items:center;gap:1.25rem;max-width:480px;text-align:center}.ob-welcome-body{display:flex;flex-direction:column;gap:.6rem;color:var(--text-secondary);font-size:1rem;line-height:1.6}.ob-welcome-body strong{color:var(--text-primary)}.ob-transition{display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:ob-fade-up .4s ease both}.ob-transition-label{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.ob-transition-dim{font-size:2rem;font-weight:700;color:var(--text-primary)}@keyframes ob-fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ob-progress-bar{display:flex;gap:4px;padding:.75rem 1.25rem 0}.ob-progress-seg{flex:1;height:4px;border-radius:2px;background:var(--surface-raised);overflow:hidden;opacity:.45;transition:opacity .25s}.ob-progress-seg--active{opacity:1}.ob-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .35s ease}.ob-quiz-area{flex:1;display:flex;align-items:center;justify-content:center;padding:1.5rem 1.25rem}.ob-quiz-loading{display:flex;align-items:center;justify-content:center;min-height:260px}.ob-quiz-card{display:flex;flex-direction:column;gap:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem 1.5rem;max-width:560px;width:100%;box-shadow:var(--shadow-card);animation:ob-fade-up .3s ease both}.ob-quiz-prompt{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em}.ob-quiz-sentence{font-family:Lora,Georgia,Times New Roman,serif;font-size:1.2rem;line-height:1.75;color:var(--text-primary)}.ob-infinitive-hint{font-size:.85rem;color:var(--text-secondary);font-style:italic;margin-top:-.5rem;margin-bottom:.75rem}.ob-quiz-target{color:var(--accent);font-weight:600;text-decoration:underline;text-underline-offset:3px}.ob-quiz-counter{font-size:.75rem;color:var(--text-muted);text-align:right}.ob-choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}.ob-choice-btn{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.95rem;font-family:inherit;padding:.75rem .5rem;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;text-align:center}.ob-choice-btn:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-strong);transform:translateY(-1px)}.ob-choice-btn:disabled{cursor:default}.ob-choice-btn--correct{border-color:var(--accent-3)!important;background:var(--accent-3-dim)!important;color:var(--accent-3)}.ob-choice-btn--wrong{border-color:#ef4444!important;background:#ef44441a!important;color:#ef4444}.ob-not-sure-btn{display:block;width:100%;margin-top:.75rem;padding:.55rem 1rem;background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);font-size:.82rem;cursor:pointer;transition:color .15s,border-color .15s}.ob-not-sure-btn:hover:not(:disabled){color:var(--text-primary);border-color:var(--border-strong)}.ob-not-sure-btn:disabled{opacity:.35;cursor:default}.ob-step-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em}.sb-ch-icon--locked{color:var(--text-secondary)}.ob-tense-eval{display:flex;flex-direction:column;align-items:center;gap:1.1rem;max-width:440px;text-align:center}.ob-tense-eval-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary)}.ob-tense-eval-name{font-family:Playfair Display,serif;font-size:1.8rem;color:var(--text-primary);margin:0}.ob-tense-eval-forms{font-family:Lora,serif;font-size:.9rem;color:var(--text-secondary);font-style:italic}.ob-tense-eval-sentence{font-family:Lora,serif;font-size:1rem;color:var(--text-primary)}.ob-tense-eval-btns{display:flex;flex-direction:column;gap:.6rem;width:100%;margin-top:.5rem}.ob-tense-eval-btn{width:100%;padding:.8rem 1.25rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:background .15s}.ob-tense-eval-btn:hover{background:var(--surface-hover)}.ob-tense-eval-btn--no{color:var(--text-secondary)}.bootstrap-screen{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:2rem;background:#0a0e16c2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.bootstrap-screen__card{width:min(100%,460px);padding:1.5rem 1.35rem;border-radius:20px;border:1px solid rgba(255,255,255,.06);background:#121824f0;box-shadow:0 16px 48px #0000004d;display:flex;flex-direction:column;align-items:stretch;text-align:left}.bootstrap-screen__visual{position:relative;width:72px;height:72px;margin:0 0 .9rem}.bootstrap-screen__spinner{position:absolute;inset:15px;border-radius:50%;border:3px solid rgba(255,255,255,.1);border-top-color:#7ba4f5;animation:ob-spin .8s linear infinite}.bootstrap-screen__pulse{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(123,164,245,.18);animation:bootstrap-pulse 2.4s ease-out infinite}.bootstrap-screen__pulse--two{animation-delay:1.2s}@keyframes bootstrap-pulse{0%{transform:scale(.78);opacity:0}18%{opacity:.42}to{transform:scale(1.16);opacity:0}}.bootstrap-screen__eyebrow{margin:0;font-size:.78rem;font-weight:600;letter-spacing:.03em;color:#adbad3c7}.bootstrap-screen__title{margin:.45rem 0 0;font-size:clamp(1.2rem,1.8vw,1.5rem);line-height:1.2;color:#fffffffa;letter-spacing:-.02em}.bootstrap-screen__subtitle{margin:.7rem 0 0;max-width:38ch;font-size:.94rem;line-height:1.55;color:#dae2f2b3}.bootstrap-screen__note{margin:1rem 0 0;font-size:.82rem;color:#bdc7db94}.auth-shell,.auth-loading{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:2rem 1.25rem;background:radial-gradient(circle at top left,rgba(78,128,238,.18),transparent 32%),radial-gradient(circle at bottom right,rgba(52,211,153,.12),transparent 28%),var(--bg)}.auth-loading{color:var(--text-secondary);font-size:.95rem}.auth-card{width:min(440px,100%);padding:1.75rem;border-radius:18px;background:color-mix(in srgb,var(--surface) 92%,transparent);border:1px solid var(--border);box-shadow:var(--shadow-lg)}.auth-brand{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;text-align:center}.auth-subtitle{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.auth-tab{padding:.7rem .85rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-raised);color:var(--text-secondary);font:inherit;font-weight:600;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease}.auth-tab:hover{border-color:var(--border-strong);color:var(--text-primary)}.auth-tab--active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.auth-form{display:flex;flex-direction:column;gap:.95rem}.auth-label{display:flex;flex-direction:column;gap:.45rem;color:var(--text-secondary);font-size:.86rem;font-weight:600}.auth-input{width:100%;padding:.8rem .9rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-raised);color:var(--text-primary);font:inherit}.auth-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.auth-error{color:#f87171;font-size:.86rem;line-height:1.5}.auth-submit{width:100%;margin-top:.4rem}.limit-notice-overlay{position:fixed;inset:0;z-index:1400;display:grid;place-items:center;padding:1.25rem;background:#10182870;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.limit-notice-card{width:min(420px,100%);padding:1.3rem 1.2rem 1.1rem;border-radius:20px;border:1px solid rgba(148,163,184,.18);background:#fffffff5;box-shadow:0 24px 60px #0f172a2e}html[data-theme=dark] .limit-notice-card{background:#111827f5;border-color:#94a3b82e}.limit-notice-title{margin:0 0 .45rem;color:var(--text-primary);font-size:1.05rem;font-weight:700}.limit-notice-body{margin:0;color:var(--text-secondary);line-height:1.6}.limit-notice-btn{margin-top:1rem;padding:.72rem .95rem;border:1px solid var(--border);border-radius:12px;background:var(--surface-raised);color:var(--text-primary);font:inherit;font-weight:600;cursor:pointer}
