*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.block{display:block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.underline{text-decoration-line:underline}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.\!outline{outline-style:solid!important}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--plume-purple: #7c5cff;--plume-pink: #ff689d;--plume-yellow: #ffd166;--plume-sky: #6bd4ff;--plume-green: #7ee787;--cream: #fff7e6;--bg: #f6f1ff;--surface: #ffffff;--surface-2: #f3eefb;--border: #ebe4f8;--text: #3d3656;--muted: #8b86a3;--accent: #7c5cff;--accent-hover: #6a48f0;--accent-soft: #ece8fd;--mint: #34c759;--peach: #f6a07a;--sky: #6bd4ff;--sunshine: #ffd166;--rose: #ff689d;--nav-bg: #3a2d6b;--nav-soft: #4a3a85;--nav-active: #7c5cff;--nav-text: #f3eefb;--nav-muted: #b9aee6;--ok: #25b394;--danger: #ef5f79;--radius: 20px;--radius-sm: 12px;--shadow: 0 10px 30px -12px rgba(91, 70, 160, .25);--shadow-sm: 0 4px 14px -6px rgba(91, 70, 160, .22);--font-body: "Nunito", system-ui, -apple-system, "Segoe UI", sans-serif;--font-display: "Baloo 2", "Nunito", system-ui, sans-serif}[data-theme=night]{--bg: #1b1730;--surface: #262138;--surface-2: #2f2947;--border: #3a3358;--text: #ece9f8;--muted: #aaa2c8;--cream: #2a2442;--accent: #9a82ff;--accent-hover: #ad97ff;--accent-soft: #2f2950;--mint: #2f9e6a;--peach: #cf7e5e;--sky: #4f93c4;--sunshine: #d8a94e;--shadow: 0 12px 34px -14px rgba(0, 0, 0, .55);--shadow-sm: 0 6px 16px -8px rgba(0, 0, 0, .5)}[data-theme=night] .skeleton:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}html[data-font="1"]{font-size:106.25%}html[data-font="2"]{font-size:112.5%}html[data-readable=on]{--font-body: "Lexend", "Nunito", system-ui, sans-serif;--font-display: "Lexend", "Baloo 2", system-ui, sans-serif}html[data-readable=on] body{letter-spacing:.02em;word-spacing:.08em;line-height:1.75}:where(a,button,select,input,textarea,[tabindex]):focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:8px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{color:var(--text);font-family:var(--font-body);line-height:1.6;background-color:var(--bg);background-image:radial-gradient(40rem 40rem at 8% -8%,rgba(139,124,240,.16),transparent 60%),radial-gradient(34rem 34rem at 105% 0%,rgba(102,182,232,.16),transparent 60%),radial-gradient(36rem 36rem at 50% 115%,rgba(246,160,122,.14),transparent 60%);background-attachment:fixed;min-height:100vh;transition:background-color .25s ease,color .25s ease}[data-theme=night] body{background-image:radial-gradient(40rem 40rem at 8% -8%,rgba(139,124,240,.1),transparent 60%),radial-gradient(34rem 34rem at 105% 0%,rgba(102,182,232,.08),transparent 60%),radial-gradient(36rem 36rem at 50% 115%,rgba(246,160,122,.07),transparent 60%)}h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:.01em;margin:0 0 .4rem}a{color:inherit;text-decoration:none}button{font:inherit;font-family:var(--font-display);font-weight:600;cursor:pointer;border:none;border-radius:999px;padding:.6rem 1.25rem;color:#fff;background:linear-gradient(135deg,var(--accent),var(--rose));box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease,background .15s ease,opacity .15s ease}button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 24px -10px #7b68ec8c}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed}.spinner{display:inline-block;width:1em;height:1em;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:sf-spin .6s linear infinite;vertical-align:-.15em;margin-right:.4em;flex-shrink:0}.spinner.spinner-lg{width:1.6rem;height:1.6rem;border-width:3px;margin:0}.loading-center{display:flex;align-items:center;justify-content:center;gap:.6rem;color:var(--muted);padding:1.4rem}button.is-loading:before{content:"";display:inline-block;width:1em;height:1em;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:sf-spin .6s linear infinite;vertical-align:-.15em;margin-right:.45em}button.is-loading{cursor:progress}@keyframes sf-spin{to{transform:rotate(360deg)}}.busy-chip{display:inline-flex;align-items:center;color:var(--accent);font-weight:700;font-size:.85rem;font-family:var(--font-display)}.cover-wrap{position:relative}.cover-placeholder{width:100%;aspect-ratio:3 / 2;max-height:360px;background:var(--surface-2);border-radius:var(--radius-sm);margin-bottom:1rem}.cover-overlay{position:absolute;inset:0;bottom:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;background:#ffffffb8;backdrop-filter:blur(2px);border-radius:var(--radius-sm);color:var(--accent);font-weight:700;font-family:var(--font-display)}.cover-play{position:absolute;left:50%;bottom:1.6rem;transform:translate(-50%);display:inline-flex;align-items:center;gap:.55rem;padding:.6rem 1.4rem .6rem .6rem;border-radius:999px;font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:#fff;background:linear-gradient(135deg,var(--accent),var(--rose));box-shadow:0 14px 28px -8px #7c5cffb3}.cover-play:hover:not(:disabled){transform:translate(-50%) translateY(-2px)}.cover-play:active:not(:disabled){transform:translate(-50%)}.cover-play-ico{display:grid;place-items:center;width:2.1rem;height:2.1rem;border-radius:50%;background:#ffffff40}.cover-mascot{position:absolute;top:.7rem;left:.7rem}.title-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.play-btn{width:2.2rem;height:2.2rem;padding:0;border-radius:50%;font-size:.85rem;display:inline-grid;place-items:center;flex-shrink:0}@media(prefers-reduced-motion:reduce){.spinner{animation-duration:1.4s}}.u-fade-in{animation:u-fade-in .4s ease both}.u-pop-in{animation:u-pop-in .35s cubic-bezier(.34,1.56,.64,1) both}@keyframes u-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes u-pop-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.u-fade-in,.u-pop-in{animation:none}}button.secondary{background:var(--surface-2);color:var(--accent);box-shadow:none;border:1.5px solid var(--border)}button.ghost{background:transparent;border:1.5px solid var(--border);color:var(--muted);box-shadow:none}button.ghost:hover:not(:disabled){color:var(--accent);border-color:var(--accent);box-shadow:none}button.link{background:transparent;color:var(--accent);padding:.5rem;box-shadow:none}button.danger{background:transparent;border:1.5px solid var(--danger);color:var(--danger);box-shadow:none}button.danger:hover:not(:disabled){background:var(--danger);color:#fff}.row-actions{display:flex;gap:.4rem;flex-wrap:wrap}tr.inactive{opacity:.5}input,textarea,select{width:100%;margin-top:.3rem;padding:.65rem .85rem;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);color:var(--text);font:inherit;resize:vertical;transition:border-color .15s ease,box-shadow .15s ease}input::placeholder,textarea::placeholder{color:#b6b1c6}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.topbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:1rem 2rem;background:#fffc;backdrop-filter:blur(10px);border-bottom:1px solid var(--border);box-shadow:0 6px 22px -18px #5b46a080;position:sticky;top:0;z-index:10}.topbar h1{font-size:1.5rem;margin:0;background:linear-gradient(120deg,var(--accent),var(--sky));-webkit-background-clip:text;background-clip:text;color:transparent}.brand{display:inline-flex;align-items:center;gap:.55rem}.brand .mark{display:grid;place-items:center;width:2.3rem;height:2.3rem;border-radius:14px;font-size:1.25rem;background:linear-gradient(135deg,var(--accent-soft),#e6f4fc);box-shadow:var(--shadow-sm)}.tagline{margin:0;color:var(--muted);font-size:.9rem}.topbar-link{color:var(--accent);font-size:.92rem;font-weight:700;font-family:var(--font-display);padding:.35rem .8rem;border-radius:999px;transition:background .15s ease}.topbar-link:hover{background:var(--accent-soft)}.topbar-nav{margin-left:auto;display:inline-flex;align-items:center;gap:.4rem;flex-wrap:wrap}.topbar-user{display:inline-flex;align-items:center;gap:.4rem;font-weight:700}.topbar-user button{padding:.35rem .9rem;font-size:.85rem}.container{max-width:880px;margin:0 auto;padding:2rem 1.1rem 5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem 1.5rem;margin-bottom:1.1rem;box-shadow:var(--shadow)}.grid{display:grid;gap:1rem;grid-template-columns:1fr}@media(min-width:680px){.grid{grid-template-columns:2fr 1fr}}.form-grid{display:grid;gap:0 1.1rem;grid-template-columns:1fr}@media(min-width:620px){.form-grid{grid-template-columns:1fr 1fr}}label{display:block;margin-bottom:.9rem;font-size:.92rem;font-weight:600}.banner{border-radius:var(--radius-sm);padding:.75rem 1.05rem;margin-bottom:1rem;font-weight:600}.banner.error{background:#ef5f791a;border:1px solid var(--danger);color:#c63a55}.banner.ok{background:#25b3941f;border:1px solid var(--ok);color:#18876e}.banner.warn{background:#f6c95f29;border:1px solid var(--sunshine);color:#9a7a16;font-weight:600}.generating-anim{display:flex;justify-content:center;margin-bottom:.5rem}.table-scroll{overflow-x:auto}table.budgets{border-collapse:collapse;width:100%;font-size:.85rem}table.budgets th,table.budgets td{border-bottom:1px solid var(--border);padding:.4rem .45rem;text-align:left}table.budgets th{color:var(--muted);font-weight:700;white-space:nowrap}table.budgets input{width:100%;min-width:4rem;margin:0;padding:.35rem .4rem}table.budgets input[type=text]{min-width:9rem}.nowrap{white-space:nowrap}.muted{color:var(--muted)}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem}.row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:.25rem;background:var(--accent-soft);border:1px solid transparent;border-radius:999px;padding:.15rem .7rem;font-size:.8rem;font-weight:700;color:var(--accent)}.chip.small{font-size:.74rem;background:var(--surface-2);color:var(--muted)}.list-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.list-head h2{font-size:1.9rem;background:linear-gradient(120deg,var(--accent),var(--rose));-webkit-background-clip:text;background-clip:text;color:transparent}.list-subtitle{margin:.1rem 0 0;color:var(--muted);font-size:.95rem}.series-thumb{width:100%;height:150px;object-fit:cover;border-radius:8px;display:block}.series-thumb-empty{display:flex;align-items:center;justify-content:center;font-size:2.6rem;background:var(--surface-2);color:var(--muted)}.clamp-2,.clamp-3{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.clamp-2{-webkit-line-clamp:2}.clamp-3{-webkit-line-clamp:3}.menu{position:relative;display:inline-block}.icon-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:1.3rem;line-height:1;padding:.4rem .7rem}.menu-panel{position:absolute;right:0;top:calc(100% + .3rem);z-index:20;min-width:14rem;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #00000059;padding:.3rem}.chapter-menu{margin-left:auto}.chapter-menu .icon-btn{font-size:1.05rem;padding:.2rem .55rem}.card-actions.menu{display:block;text-align:right}.card-actions.menu .icon-btn{font-size:1.05rem;padding:.15rem .5rem}.modal-backdrop{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;background:#281e4673;backdrop-filter:blur(2px);animation:sf-fade .12s ease}.modal{width:100%;max-width:30rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 20px 60px -15px #281e4680;padding:1.6rem 1.7rem}.modal h3{margin-top:0}.modal-actions{justify-content:flex-end;margin-top:1.2rem}@keyframes sf-fade{0%{opacity:0}}.finish-celebrate{position:fixed;inset:0;z-index:1200;display:grid;place-items:center;padding:1rem;background:#281e4680;backdrop-filter:blur(3px);animation:sf-fade .15s ease}.finish-card{text-align:center;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.8rem 2rem 2rem;max-width:min(90vw,22rem);display:flex;flex-direction:column;align-items:center;gap:.4rem}.finish-card h3{margin:.5rem 0 0;font-size:1.5rem}.finish-card button{margin-top:.9rem}.menu-panel button{background:transparent;color:var(--text);text-align:left;border-radius:6px;padding:.55rem .7rem;white-space:nowrap}.menu-panel button:hover:not(:disabled){background:var(--surface-2)}.menu-panel button.danger-item{color:var(--danger)}.menu-panel button.danger-item:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 15%,transparent)}.tome-pager{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap}.tome-series{font-weight:600;color:var(--accent);text-decoration:none;white-space:nowrap}.tome-nav{display:flex;align-items:center;gap:.6rem}.tome-pos{color:var(--muted);white-space:nowrap}.tome-select{width:auto;min-width:12rem;margin-top:0}.filters{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.2rem}.filters .search,.search{flex:1;min-width:12rem;margin:0}.story-list{list-style:none;margin:0;padding:0;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.chip-filters{display:flex;flex-direction:column;gap:.5rem;margin:0 0 1.3rem}.chip-row{display:flex;flex-wrap:wrap;gap:.45rem}.chip-toggle{padding:.4rem .95rem;border-radius:999px;font-family:var(--font-display);font-weight:700;font-size:.85rem;background:var(--surface);color:var(--muted);border:1.5px solid var(--border);box-shadow:none}.chip-toggle:hover:not(:disabled){transform:none;box-shadow:none;color:var(--accent);border-color:var(--accent)}.chip-toggle.on{background:linear-gradient(135deg,var(--accent),var(--rose));color:#fff;border-color:transparent}.story-item{display:flex;flex-direction:column;gap:.5rem;padding:1.1rem 1.2rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);border-top:5px solid var(--accent);cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .16s ease,box-shadow .16s ease}.story-item:nth-child(5n+1){border-top-color:var(--accent)}.story-item:nth-child(5n+2){border-top-color:var(--mint)}.story-item:nth-child(5n+3){border-top-color:var(--peach)}.story-item:nth-child(5n+4){border-top-color:var(--sky)}.story-item:nth-child(5n+5){border-top-color:var(--sunshine)}.story-item:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.story-item>strong,.story-item-main>strong{font-family:var(--font-display);font-size:1.12rem;line-height:1.3}.story-item .meta{display:flex;flex-wrap:wrap;gap:.35rem;margin:.1rem 0}.story-item .progress{font-size:.8rem}.open-hint{color:var(--accent);font-size:.88rem;font-weight:700;font-family:var(--font-display);margin-top:auto;align-self:flex-end}.card-actions{margin-top:.6rem;padding-top:.6rem;border-top:1px dashed var(--border)}.card-actions button{padding:.3rem .75rem;font-size:.8rem;box-shadow:none}.card-actions button:hover:not(:disabled){transform:none;box-shadow:none}.cover-thumb{display:block;width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:.6rem}.cover-hero{display:block;width:100%;max-height:360px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:1rem}.sentinel{height:1px}.loading-row{text-align:center;color:var(--muted);padding:.8rem;font-size:.85rem}.offline-bar{position:fixed;top:0;left:0;right:0;z-index:1400;text-align:center;padding:.35rem 1rem;font-size:.85rem;font-weight:700;color:#fff;background:var(--muted)}.continue-card{display:flex;align-items:center;gap:.9rem;padding:.7rem 1rem;margin-bottom:1.1rem;border-radius:var(--radius);background:linear-gradient(135deg,var(--accent-soft),var(--surface));border:1px solid var(--border);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease}.continue-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.continue-cover{display:grid;place-items:center;width:3.2rem;height:3.2rem;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-2)}.continue-cover img{width:100%;height:100%;object-fit:cover}.continue-meta{display:flex;flex-direction:column;min-width:0;flex:1}.continue-label{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:var(--accent);font-family:var(--font-display)}.continue-title,.continue-chapter{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.continue-title{font-family:var(--font-display);font-size:1.05rem}.continue-chapter{font-size:.85rem}.continue-go{display:grid;place-items:center;width:2.6rem;height:2.6rem;flex-shrink:0;border-radius:50%;color:#fff;background:linear-gradient(135deg,var(--accent),var(--rose));font-size:1.1rem}.shelf{list-style:none;margin:0;padding:0;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}.book-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .16s ease,box-shadow .16s ease}.book-card:hover{transform:translateY(-5px) rotate(-.4deg);box-shadow:var(--shadow)}.book-cover{position:relative;aspect-ratio:3 / 4;overflow:hidden}.book-cover-img{display:block;width:100%;height:100%;object-fit:cover}.book-cover-ph{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(150deg,var(--mint),var(--sky))}.book-card:nth-child(5n+1) .book-cover-ph{background:linear-gradient(150deg,var(--mint),var(--sky))}.book-card:nth-child(5n+2) .book-cover-ph{background:linear-gradient(150deg,var(--peach),var(--sunshine))}.book-card:nth-child(5n+3) .book-cover-ph{background:linear-gradient(150deg,var(--sky),var(--accent))}.book-card:nth-child(5n+4) .book-cover-ph{background:linear-gradient(150deg,var(--sunshine),var(--mint))}.book-card:nth-child(5n+5) .book-cover-ph{background:linear-gradient(150deg,var(--accent),var(--peach))}.book-status{position:absolute;top:.5rem;right:.5rem;box-shadow:var(--shadow-sm)}.fav-btn{position:absolute;top:.5rem;left:.5rem;width:2.1rem;height:2.1rem;padding:0;display:grid;place-items:center;border-radius:50%;color:#fff;background:#281e4659;backdrop-filter:blur(2px);box-shadow:none}.fav-btn app-icon svg{fill:none}.fav-btn:hover:not(:disabled){transform:scale(1.08);box-shadow:none}.fav-btn.on{color:var(--rose);background:#ffffffeb}.fav-btn.on app-icon svg{fill:currentColor}.book-body{display:flex;flex-direction:column;gap:.45rem;padding:.8rem .85rem .9rem}.book-title{font-family:var(--font-display);font-size:1.05rem;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-admin{margin-top:.4rem;padding-top:.55rem;border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:.4rem}.book-admin .progress{font-size:.78rem}.skeleton{position:relative;overflow:hidden;background:var(--surface-2, #f3eefb);border-radius:var(--radius-sm)}.skeleton:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:skeleton-shimmer 1.3s ease-in-out infinite}@keyframes skeleton-shimmer{to{transform:translate(100%)}}.skel-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface)}.skel-cover{aspect-ratio:3 / 4;border-radius:0}.skel-lines{display:flex;flex-direction:column;gap:.5rem;padding:.8rem .85rem .9rem}.skel-line{height:.8rem}.skel-line.short{width:55%}@media(prefers-reduced-motion:reduce){.skeleton:after{animation:none}}.story-head-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.story-head h2{font-size:1.7rem}.head-actions{display:flex;gap:.5rem;flex-shrink:0}.premise{margin:.6rem 0 0;font-style:italic;color:var(--muted)}.editor{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-top:.9rem;padding-top:.9rem;border-top:1px solid var(--border);font-size:.9rem}.editor input{width:7rem;margin:0}.editor select{min-width:12rem;margin:0}.editor .muted{flex-basis:100%;font-size:.8rem}.step-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}details.card>summary{cursor:pointer;list-style:none}details.card>summary::-webkit-details-marker{display:none}details.card:not([open])>summary.step-head{margin-bottom:0}details.card>summary h3{margin:0;font-size:1.15rem}details.card>summary h3:before{content:"\25b8";display:inline-block;margin-right:.45rem;color:var(--accent);transition:transform .15s ease}details.card[open]>summary h3:before{transform:rotate(90deg)}.status{font-size:.78rem;font-weight:700;color:var(--muted);background:var(--surface-2);border-radius:999px;padding:.15rem .7rem}.status.done{color:var(--ok);background:#25b3941f}.prose{white-space:pre-wrap;margin:0 0 .9rem}.characters,.outline,.chapters{margin:0 0 .9rem;padding-left:1.1rem}.characters{list-style:none;padding-left:0}.characters li{padding:.5rem 0;border-bottom:1px solid var(--border)}.characters li:last-child{border-bottom:none}.outline li{margin-bottom:.5rem}.chapters{list-style:none;padding-left:0}.chapter-readalong{display:block;margin-top:.7rem}.read-along{margin:0;padding:.9rem 1rem;background:var(--surface-2);border-radius:var(--radius-sm);line-height:2.1;font-size:1.05rem;white-space:pre-wrap}.read-along .ra-word{border-radius:6px;padding:0 2px;transition:background-color .12s ease,color .12s ease;scroll-margin-bottom:7.5rem;scroll-margin-top:1rem}.read-along .ra-active{background:var(--sunshine);color:#4a3a10;box-shadow:0 0 0 3px var(--sunshine)}@media(prefers-reduced-motion:reduce){.read-along .ra-word{transition:none}}.reader-tabs{display:flex;gap:.4rem;border-bottom:2px solid var(--border);margin:.2rem 0 1rem}.reader-tab{background:transparent;color:var(--muted);box-shadow:none;border:none;border-radius:0;padding:.55rem 1rem;margin-bottom:-2px;border-bottom:3px solid transparent;font-family:var(--font-display);font-weight:700}.reader-tab:hover:not(:disabled){transform:none;box-shadow:none;color:var(--accent)}.reader-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.reader-tab:disabled{opacity:.45}.link.is-current{color:var(--rose);font-weight:800}.audio-bandeau-spacer{height:7.5rem}.audio-bandeau{position:fixed;left:0;right:0;bottom:0;z-index:39;display:flex;flex-direction:column;gap:.45rem;padding:.6rem 1.1rem .7rem;color:#fff;background:radial-gradient(16rem 16rem at 100% -40%,rgba(255,209,102,.35),transparent 60%),linear-gradient(135deg,var(--nav-bg),var(--accent));box-shadow:0 -10px 30px -16px #281e46b3;border-top:1px solid rgba(255,255,255,.15)}.bandeau-row{display:flex;align-items:center;gap:.9rem}.bandeau-progress{display:flex;align-items:center;gap:.6rem}.bandeau-time{font-size:.72rem;font-variant-numeric:tabular-nums;opacity:.9;min-width:2.6rem;text-align:center;flex-shrink:0}.bandeau-seek{flex:1;-webkit-appearance:none;appearance:none;height:.4rem;border-radius:999px;background:#ffffff47;cursor:pointer}.bandeau-seek:disabled{opacity:.5;cursor:default}.bandeau-seek::-webkit-slider-thumb{-webkit-appearance:none;width:1rem;height:1rem;border:none;border-radius:50%;background:#fff;box-shadow:0 2px 6px -1px #0006;cursor:pointer}.bandeau-seek::-moz-range-thumb{width:1rem;height:1rem;border:none;border-radius:50%;background:#fff;cursor:pointer}.chapter-audio-el{display:none}.chapter-download{display:inline-flex;align-items:center;gap:.3rem;margin-top:.4rem;font-size:.85rem}@media(min-width:1024px){.audio-bandeau{left:250px}}.bandeau-play{width:2.8rem;height:2.8rem;padding:0;flex-shrink:0;border-radius:50%;font-size:1rem;display:inline-grid;place-items:center;background:#fff;color:var(--accent)}.bandeau-play:hover:not(:disabled){box-shadow:0 10px 24px -10px #00000080}.bandeau-meta{display:flex;flex-direction:column;min-width:0;margin-right:auto}.bandeau-now{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;opacity:.85}.bandeau-title{font-family:var(--font-display);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bandeau-title.muted{color:#ffffffbf;font-weight:600}.bandeau-rate{flex-shrink:0;min-width:3.2rem;padding:.35rem .7rem;font-size:.85rem;font-variant-numeric:tabular-nums;color:#fff;background:#ffffff2e;border:1px solid rgba(255,255,255,.28);box-shadow:none}.bandeau-rate:hover:not(:disabled){transform:none;background:#ffffff4d;box-shadow:none}.bandeau-toggle{color:#fff;font-size:1.2rem;flex-shrink:0}.bandeau-icon{flex-shrink:0;width:2.4rem;height:2.4rem;padding:0;display:grid;place-items:center;color:#fff;background:#ffffff24;border:1px solid rgba(255,255,255,.28);border-radius:50%;box-shadow:none}.bandeau-icon.on{background:#fff;color:var(--accent)}.bandeau-icon:hover:not(:disabled){transform:none;box-shadow:none;background:#ffffff4d}.bandeau-icon.on:hover:not(:disabled){background:#fff}.bandeau-vol{position:relative;flex-shrink:0}.vol-popover{position:absolute;right:0;bottom:calc(100% + .5rem);display:flex;flex-direction:column;gap:.6rem;padding:.8rem .9rem;border-radius:var(--radius-sm);background:var(--surface);color:var(--text);box-shadow:var(--shadow);z-index:46}.vol-row{display:flex;align-items:center;gap:.55rem;color:var(--accent)}.vol-row input[type=range]{width:9rem;accent-color:var(--accent);cursor:pointer}.admin-jump{position:sticky;top:0;z-index:30;display:flex;gap:.4rem;flex-wrap:nowrap;overflow-x:auto;padding:.5rem 0;margin-bottom:.8rem;background:var(--bg);border-bottom:1px solid var(--border);scrollbar-width:thin}.admin-jump .chip-toggle{flex-shrink:0;cursor:pointer}.switch{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:700}.switch input{position:absolute;opacity:0;width:0;height:0}.switch-track{position:relative;width:2.5rem;height:1.4rem;flex-shrink:0;border-radius:999px;background:var(--border);transition:background .15s ease}.switch-track:after{content:"";position:absolute;top:.15rem;left:.15rem;width:1.1rem;height:1.1rem;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0000004d;transition:transform .15s ease}.switch input:checked+.switch-track{background:var(--accent)}.switch input:checked+.switch-track:after{transform:translate(1.1rem)}.switch input:focus-visible+.switch-track{outline:3px solid var(--accent);outline-offset:2px}.switch-label{display:inline-flex;align-items:center;gap:.3rem}.audio-controls{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:.6rem}.continuous-toggle{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:700}.sleep-timer{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;margin-bottom:.6rem}.sleep-label{display:inline-flex;align-items:center;gap:.35rem;font-weight:700;margin-right:.2rem}.sleep-timer .chip-toggle{padding:.3rem .8rem;font-size:.82rem}.chapter-row{border-bottom:1px solid var(--border);padding:.7rem 0}.chapter-row.playing{background:var(--accent-soft);border-radius:var(--radius-sm);padding-left:.7rem;padding-right:.7rem}.chapter-row.playing .chapter-title{color:var(--accent)}.chapter-row:last-child{border-bottom:none}.moderation-flag{margin:.4rem 0 0;padding:.45rem .7rem;border-radius:var(--radius-sm);background:#fdecec;color:#9b1c1c;border:1px solid #f5c2c2;font-size:.85rem;font-weight:600}.chapter-row-head{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.idx{font-family:var(--font-display);font-weight:700;color:var(--accent)}.chapter-title{flex:1;min-width:8rem;font-weight:700}.chapter-content{margin-top:.7rem;padding:.9rem 1rem;background:var(--surface-2);border-radius:var(--radius-sm)}.auth-card,.login{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem 1.8rem}
