:root{--bg1:#1c1640;--bg2:#2c1f55;--glow:#4a2f7a;--accent:#f4b740;--accent2:#ec6a45;--leaf:#74c79a;--ink:#3a2a18;--ink-soft:#6a5740;--paper:#f8f1df;--paper-edge:#ecdcb8;--cream:#f6ecd8;--cream-dim:#f6ecd8a8;--plate-base:#efe2c4;--read-size:26px;--r-lg:26px;--r-md:16px;--r-sm:11px;--shadow-card:0 24px 60px -28px #0009;--display:"Fredoka",system-ui,sans-serif;--read:"Lexend",system-ui,sans-serif}*{box-sizing:border-box}html,body{height:100%;margin:0}body{font-family:var(--read);color:var(--cream);background:radial-gradient(120% 80% at 50% -10%, var(--glow) 0%, transparent 55%), radial-gradient(90% 70% at 85% 110%, color-mix(in oklch, var(--accent2) 30%, transparent), transparent 60%), linear-gradient(160deg, var(--bg1), var(--bg2));-webkit-font-smoothing:antialiased;background-attachment:fixed}#approot,#appstage{min-height:100vh}button{cursor:pointer;font-family:inherit}.link-btn{color:var(--cream-dim);font-size:15px;font-family:var(--read);background:0 0;border:none;padding:6px 4px}.link-btn:hover{color:var(--accent)}.mini-label{letter-spacing:.02em;color:var(--cream-dim);margin-bottom:7px;font-size:13px;font-weight:500;display:block}.mini-label em{opacity:.7;font-style:normal}.motes{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.motes span{background:radial-gradient(circle at 40% 35%, #fff, var(--accent));filter:blur(.3px);border-radius:50%;animation:linear infinite float;position:absolute;bottom:-12px}@keyframes float{0%{opacity:0;transform:translate(0)scale(.7)}10%{opacity:.7}90%{opacity:.5}to{transform:translate(var(--drift),-104vh) scale(1);opacity:0}}@media (prefers-reduced-motion:reduce){.motes span{animation:none;display:none}}.logo{font-family:var(--display);color:var(--cream);align-items:center;gap:12px;font-weight:600;display:inline-flex}.logo-lamp{filter:drop-shadow(0 0 14px color-mix(in oklch,var(--accent) 60%,transparent));display:inline-flex}.logo-text em{color:var(--accent);font-style:normal}.btn{font-family:var(--display);white-space:nowrap;border:none;border-radius:999px;font-weight:600;transition:transform .12s,box-shadow .2s,filter .2s}.btn:active{transform:translateY(1px)scale(.99)}.btn-primary{color:#3a2300;background:linear-gradient(180deg, color-mix(in oklch,var(--accent) 88%,white), var(--accent));box-shadow:0 10px 24px -10px color-mix(in oklch,var(--accent) 80%,transparent), inset 0 1px 0 #fff9}.btn-primary:hover{filter:brightness(1.05);box-shadow:0 14px 30px -10px color-mix(in oklch,var(--accent) 85%,transparent)}.btn-soft{color:var(--cream);background:#ffffff14;border:1px solid #ffffff29}.btn-soft:hover{background:#ffffff24}.btn-sm{padding:9px 16px;font-size:15px}.btn-md{padding:12px 22px;font-size:16px}.btn-lg{padding:16px 30px;font-size:19px}.btn-full{width:100%}.btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.3)}.screen{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}.home{text-align:center;justify-content:center;align-items:center;padding:40px 24px}.home-inner{z-index:2;flex-direction:column;align-items:center;gap:6px;width:100%;max-width:760px;display:flex;position:relative}.home-title{font-family:var(--display);color:var(--cream);text-wrap:balance;margin:22px 0 6px;font-size:clamp(34px,5.4vw,58px);font-weight:600;line-height:1.04}.home-sub{max-width:560px;color:var(--cream-dim);text-wrap:pretty;margin:0 0 14px;font-size:17px;line-height:1.6}.home-cards{grid-template-columns:1fr 1fr;gap:18px;width:100%;margin-top:18px;display:grid}.home-card{text-align:left;border-radius:var(--r-lg);color:var(--cream);background:#ffffff0e;border:1px solid #ffffff1f;flex-direction:column;align-items:flex-start;gap:6px;padding:24px 22px;transition:transform .15s,border-color .2s,background .2s;display:flex}button.home-card:hover{border-color:color-mix(in oklch,var(--accent) 60%,transparent);transform:translateY(-3px)}.home-card-primary{background:linear-gradient(165deg, color-mix(in oklch,var(--accent) 26%,transparent), #ffffff0d);border-color:color-mix(in oklch,var(--accent) 45%,transparent)}.hc-icon{color:var(--accent);font-size:26px}.hc-title{font-family:var(--display);font-size:21px;font-weight:600}.hc-sub{color:var(--cream-dim);font-size:14px;line-height:1.4}.hc-actions{align-items:center;gap:10px;margin-top:10px;display:flex}.roomcode{font-family:var(--display);letter-spacing:.08em;color:var(--accent);background:#00000047;border-radius:10px;padding:7px 14px;font-size:17px;font-weight:600}.code-input{font-family:var(--display);letter-spacing:.1em;text-transform:uppercase;color:var(--cream);background:#0000004d;border:1px solid #fff3;border-radius:10px;width:120px;padding:9px 12px;font-size:16px;font-weight:600}.home-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;width:100%;margin-top:26px;display:flex}.home-foot-right{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.readers{align-items:center;gap:10px;display:flex}.readers-label{color:var(--cream-dim);font-size:14px}.avatar{width:34px;height:34px;font-family:var(--display);color:#2a1a04;border-radius:50%;place-items:center;margin-left:-8px;font-size:15px;font-weight:600;display:grid;box-shadow:0 0 0 2px #ffffff2e}.avatar:first-child{margin-left:0}.create,.history{align-items:center;padding:0}.create-scroll,.history-scroll{z-index:2;width:100%;max-width:780px;margin:0 auto;padding:34px 24px 60px;position:relative}.create-head,.history-head{text-align:center;margin-bottom:26px}.back{position:absolute;top:30px;left:24px}.create-h2{font-family:var(--display);color:var(--cream);margin:6px 0 4px;font-size:clamp(28px,4vw,40px);font-weight:600}.create-tag{color:var(--cream-dim);margin:0;font-size:16px}.field{margin-bottom:26px}.field-label{font-family:var(--display);color:var(--cream);align-items:center;gap:10px;margin-bottom:14px;font-size:19px;font-weight:600;display:flex}.step-n{background:color-mix(in oklch,var(--accent) 30%,transparent);width:28px;height:28px;color:var(--accent);border:1px solid color-mix(in oklch,var(--accent) 55%,transparent);border-radius:50%;place-items:center;font-size:15px;display:grid}.theme-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.theme-card{text-align:left;border-radius:var(--r-md);color:var(--cream);background:#ffffff0d;border:1.5px solid #ffffff1a;flex-direction:column;align-items:flex-start;gap:4px;padding:15px;transition:transform .14s,border-color .2s,background .2s;display:flex}.theme-card:hover{background:#ffffff17;transform:translateY(-2px)}.theme-card.on{border-color:var(--accent);background:color-mix(in oklch,var(--accent) 16%,transparent);box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 22%,transparent)}.theme-ico{font-size:24px}.theme-name{font-family:var(--display);font-size:15.5px;font-weight:600;line-height:1.15}.theme-blurb{color:var(--cream-dim);font-size:12.5px;line-height:1.3}.dream-fields{grid-template-columns:1fr 1.3fr;gap:16px;display:grid}.text-input,.text-area{width:100%;color:var(--cream);font-size:15.5px;font-family:var(--read);resize:none;background:#0000003d;border:1.5px solid #ffffff29;border-radius:12px;padding:12px 14px}.text-input:focus,.text-area:focus,.code-input:focus{border-color:var(--accent);background:#00000057;outline:none}.text-area::placeholder,.text-input::placeholder{color:#f6ecd866}.toggle-row{border-radius:var(--r-md);color:var(--cream);background:#ffffff0d;border:1px solid #ffffff1a;align-items:center;gap:12px;padding:14px 18px;font-size:16px;display:flex}.toggle-row.small{color:var(--cream-dim);margin-bottom:14px;padding:11px 14px;font-size:14.5px}.toggle-row input{width:20px;height:20px;accent-color:var(--accent)}.toggle-pill{font-family:var(--display);background:#ffffff1f;border-radius:999px;margin-left:auto;padding:4px 12px;font-size:13px;font-weight:600}.toggle-pill.on{background:var(--accent);color:#3a2300}.two-up{grid-template-columns:1fr 1fr;gap:26px;display:grid}.seg{background:#0000003d;border:1px solid #ffffff1f;border-radius:999px;gap:4px;padding:5px;display:flex}.seg-btn{color:var(--cream-dim);font-family:var(--display);background:0 0;border:none;border-radius:999px;flex:1;padding:9px 6px;font-size:14.5px;font-weight:600;transition:all .18s}.seg-btn.seg-on{background:var(--accent);color:#3a2300;box-shadow:0 4px 12px -4px color-mix(in oklch,var(--accent) 70%,transparent)}.level-sample{color:var(--cream-dim);margin:11px 2px 0;font-size:14px;font-style:italic;line-height:1.4}.ls-tag{letter-spacing:.04em;text-transform:uppercase;color:var(--accent);background:color-mix(in oklch,var(--accent) 16%,transparent);border-radius:6px;margin-right:8px;padding:2px 8px;font-size:11.5px;font-style:normal;display:inline-block}.create-cta{text-align:center;margin-top:34px}.cta-note{color:var(--cream-dim);margin-top:12px;font-size:13.5px;display:block}.generating{text-align:center;justify-content:center;align-items:center}.gen-inner{z-index:2;flex-direction:column;align-items:center;gap:8px;display:flex;position:relative}.gen-lamp{filter:drop-shadow(0 0 30px color-mix(in oklch,var(--accent) 70%,transparent))}.gen-glow{animation:2.4s ease-in-out infinite pulse}.gen-flame{transform-origin:50%;animation:1.6s ease-in-out infinite flame}@keyframes pulse{0%,to{opacity:.16}50%{opacity:.32}}@keyframes flame{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.gen-title{font-family:var(--display);margin:14px 0 2px;font-size:30px;font-weight:600}.gen-line{color:var(--cream-dim);min-height:1.4em;font-size:17px}.gen-bar{background:#ffffff1f;border-radius:999px;width:240px;height:8px;margin-top:14px;overflow:hidden}.gen-bar span{background:var(--accent);border-radius:999px;width:40%;height:100%;animation:1.5s ease-in-out infinite slide;display:block}@keyframes slide{0%{margin-left:-40%}to{margin-left:100%}}.reader{padding:0}.presence{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:3;background:#00000042;border-bottom:1px solid #ffffff14;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding:14px 22px;display:flex;position:relative}.presence-room{color:var(--cream-dim);align-items:center;gap:8px;font-size:14.5px;display:flex}.presence-room strong{color:var(--accent);font-family:var(--display);letter-spacing:.06em}.dot-live{background:var(--leaf);width:9px;height:9px;box-shadow:0 0 0 0 var(--leaf);border-radius:50%;animation:2s infinite live}@keyframes live{0%{box-shadow:0 0 0 0 color-mix(in oklch,var(--leaf) 70%,transparent)}70%{box-shadow:0 0 0 7px #0000}to{box-shadow:0 0 #0000}}.presence-people{align-items:center;gap:0;display:flex}.presence-people .avatar{width:30px;height:30px;font-size:13px}.presence-count{color:var(--cream-dim);margin-left:14px;font-size:13.5px}.presence-sync{color:var(--leaf);align-items:center;gap:6px;font-size:13.5px;font-weight:500;display:flex}.sync-tick{font-size:16px}.reader-stage{z-index:2;flex:1;justify-content:center;align-items:center;gap:8px;padding:26px 14px;display:flex;position:relative}.page-arrow{width:54px;height:54px;color:var(--cream);background:#ffffff12;border:1px solid #ffffff29;border-radius:50%;flex:none;place-items:center;font-size:30px;line-height:1;transition:all .16s;display:grid}.page-arrow:hover:not(:disabled){background:var(--accent);color:#3a2300;transform:scale(1.06)}.page-arrow:disabled{opacity:.25;cursor:not-allowed}.book{width:min(860px,94vw)}.book.animate[data-dir="1"]{animation:.42s turnNext}.book.animate[data-dir="-1"]{animation:.42s turnPrev}@keyframes turnNext{0%{opacity:0;transform:translate(26px)rotateY(-6deg)}to{opacity:1;transform:none}}@keyframes turnPrev{0%{opacity:0;transform:translate(-26px)rotateY(6deg)}to{opacity:1;transform:none}}.cover,.spread{background:linear-gradient(180deg,var(--paper),var(--paper) 70%,var(--paper-edge));border-radius:var(--r-lg);box-shadow:var(--shadow-card);border:1px solid #00000014;position:relative;overflow:hidden}.cover:after,.spread:after{content:"";pointer-events:none;border-radius:inherit;position:absolute;inset:0;box-shadow:inset 0 0 60px #7850141f,inset 0 2px #ffffff80}.cover{text-align:center;grid-template-columns:1fr;gap:18px;padding:26px;display:grid}.cover-text{flex-direction:column;align-items:center;gap:12px;padding:6px 18px 14px;display:flex}.cover-kicker{letter-spacing:.16em;text-transform:uppercase;color:var(--accent2);font-size:13px;font-weight:600}.cover-title{font-family:var(--display);color:var(--ink);text-wrap:balance;margin:0;font-size:clamp(30px,4.6vw,46px);font-weight:600;line-height:1.05}.cover-ded{color:var(--ink-soft);max-width:520px;margin:0;font-size:16px;font-style:italic}.spread{grid-template-columns:1fr 1fr;align-items:center;gap:24px;min-height:min(64vh,520px);padding:22px;display:grid}.spread.text-only{grid-template-columns:1fr;max-width:680px;margin:0 auto}.spread-text{flex-direction:column;justify-content:center;gap:18px;display:flex}.readable{font-family:var(--read);font-size:var(--read-size);color:var(--ink);text-wrap:pretty;margin:0;font-weight:400;line-height:1.62}.text-only .readable{font-size:calc(var(--read-size) + 3px);text-align:center}.word{cursor:pointer;border-radius:6px;padding:0 1px;transition:background .12s,color .12s}.word:hover{background:color-mix(in oklch,var(--accent) 34%,transparent)}.word-hit{background:var(--accent);color:#3a2300;animation:.5s pop}@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.14)}to{transform:scale(1)}}.hear-page{border:1px solid color-mix(in oklch,var(--ink) 22%,transparent);color:var(--ink);font-family:var(--display);background:#ffffff80;border-radius:999px;align-self:flex-start;align-items:center;gap:8px;padding:9px 16px;font-size:15px;font-weight:600;transition:all .16s;display:inline-flex}.hear-page:hover{background:var(--accent);border-color:var(--accent)}.hp-ico{color:var(--accent2)}.text-only .hear-page{align-self:center}.page-num{font-family:var(--display);color:var(--ink-soft);font-size:15px;font-weight:600;position:absolute;bottom:14px;right:20px}.page-num i{opacity:.6;font-style:normal}.plate{border-radius:var(--r-md);border:2.5px dashed color-mix(in oklch,var(--accent) 60%,#9b7d3a);align-items:flex-end;min-height:240px;padding:16px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 40px #78501424}.plate-tall{min-height:300px}.cover .plate{min-height:clamp(220px,34vh,330px)}.plate-grain{opacity:.5;pointer-events:none;background-image:radial-gradient(#ffffff80 .5px,#0000 .5px);background-size:7px 7px;position:absolute;inset:0}.plate-badge{letter-spacing:.12em;text-transform:uppercase;color:color-mix(in oklch,var(--ink) 70%,#7a5a20);background:#ffffff8c;border-radius:999px;align-items:center;gap:6px;padding:4px 9px 4px 7px;font-size:11px;font-weight:600;display:flex;position:absolute;top:12px;left:12px}.plate-cap{z-index:1;color:#43331c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#ffffffa8;border-radius:10px;max-width:100%;padding:10px 13px;font-size:14.5px;font-style:italic;line-height:1.45;position:relative;box-shadow:0 6px 18px -10px #0006}.reader-foot{z-index:2;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:14px 24px 20px;display:flex;position:relative}.pagedots{flex-wrap:wrap;flex:1;justify-content:center;gap:7px;display:flex}.pd{cursor:pointer;background:#fff3;border-radius:50%;width:9px;height:9px;transition:all .18s}.pd.done{background:color-mix(in oklch,var(--accent) 55%,transparent)}.pd.on{background:var(--accent);transform:scale(1.5)}.tap-hint{color:var(--cream-dim);font-size:14px}.sync-toast{z-index:6;color:var(--cream);border:1px solid color-mix(in oklch,var(--leaf) 50%,transparent);background:#000000d1;border-radius:999px;align-items:center;gap:8px;padding:11px 20px;font-size:14.5px;animation:.3s toastIn;display:flex;position:fixed;bottom:84px;left:50%;transform:translate(-50%)}.sync-toast:before{content:"⤿";color:var(--leaf)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.finish{justify-content:center;align-items:center;padding:40px 20px}.finish-card{z-index:2;border-radius:var(--r-lg);text-align:center;width:min(560px,94vw);box-shadow:var(--shadow-card);background:#ffffff0f;border:1px solid #ffffff21;padding:30px 30px 26px;position:relative}.finish-badge{place-items:center;width:96px;height:96px;margin:0 auto 8px;display:grid;position:relative}.fb-burst{background:radial-gradient(circle,color-mix(in oklch,var(--accent) 60%,transparent),transparent 70%);border-radius:50%;animation:2.2s infinite pulse;position:absolute;inset:-10px}.fb-sticker{font-size:60px;animation:.6s badgePop}@keyframes badgePop{0%{transform:scale(0)rotate(-30deg)}60%{transform:scale(1.2)rotate(8deg)}to{transform:scale(1)rotate(0)}}.finish-h2{font-family:var(--display);color:var(--cream);margin:6px 0 2px;font-size:30px;font-weight:600}.finish-title{color:var(--accent);margin:0 0 20px;font-size:17px;font-style:italic}.rate-grid{grid-template-columns:1fr 1fr;gap:18px;margin-bottom:20px;display:grid}.rating-block{border-radius:var(--r-md);background:#0000002e;padding:14px 12px}.rating-label{color:var(--cream-dim);margin-bottom:8px;font-size:14px;font-weight:500}.stars{justify-content:center;gap:4px;display:flex}.star{color:#ffffff38;background:0 0;border:none;padding:0;line-height:1;transition:transform .12s,color .15s}.star:hover{transform:scale(1.18)}.star.on{color:var(--accent);filter:drop-shadow(0 0 8px color-mix(in oklch,var(--accent) 60%,transparent))}.sticker-pick{text-align:left;margin-bottom:18px}.sticker-row{flex-wrap:wrap;gap:8px;display:flex}.sticker-opt{background:#ffffff0f;border:1.5px solid #ffffff1f;border-radius:14px;padding:6px 10px;font-size:26px;line-height:1;transition:all .14s}.sticker-opt:hover{transform:translateY(-2px)}.sticker-opt.on{border-color:var(--accent);background:color-mix(in oklch,var(--accent) 18%,transparent);transform:translateY(-2px)}.note-field{text-align:left;margin-bottom:22px}.finish-actions{justify-content:center;gap:12px;display:flex}.stat-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px;display:grid}.stat{border-radius:var(--r-md);text-align:center;background:#ffffff0e;border:1px solid #ffffff1c;padding:18px 12px}.stat-num{font-family:var(--display);color:var(--accent);font-size:34px;font-weight:600;line-height:1;display:block}.stat-num i{font-size:20px;font-style:normal}.stat-lbl{color:var(--cream-dim);margin-top:6px;font-size:13px;display:block}.shelf{flex-direction:column;gap:12px;display:flex}.shelf-row{border-radius:var(--r-md);background:#ffffff0d;border:1px solid #ffffff1a;align-items:center;gap:16px;padding:14px 16px;transition:all .15s;display:flex}.shelf-row:hover{background:#ffffff14;transform:translateY(-2px)}.shelf-spine{background:color-mix(in oklch,var(--accent) 18%,transparent);border:1px solid color-mix(in oklch,var(--accent) 40%,transparent);border-radius:12px;flex:none;place-items:center;width:46px;height:46px;font-size:24px;display:grid}.shelf-main{flex:1;min-width:0}.shelf-top{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.shelf-title{font-family:var(--display);color:var(--cream);font-size:18px;font-weight:600}.shelf-date{color:var(--cream-dim);flex:none;font-size:13px}.shelf-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;display:flex}.tag{color:var(--accent);background:color-mix(in oklch,var(--accent) 14%,transparent);border-radius:7px;padding:3px 9px;font-size:12.5px}.tag.ghost{color:var(--cream-dim);background:#ffffff12}.shelf-stars{color:var(--accent);letter-spacing:1px;font-size:14px}.shelf-stars i{color:#fff3;font-style:normal}.shelf-note{color:var(--cream-dim);margin:8px 0 0;font-size:14px;font-style:italic;line-height:1.4}.reread{color:var(--cream);font-family:var(--display);background:0 0;border:1px solid #ffffff2e;border-radius:999px;flex:none;align-self:center;padding:8px 14px;font-size:14px;font-weight:600;transition:all .15s}.reread:hover{background:var(--accent);color:#3a2300;border-color:var(--accent)}.empty{color:var(--cream-dim);text-align:center;padding:30px}.history-cta{text-align:center;margin-top:30px}.mode-pick{grid-template-columns:1fr 1fr;gap:12px;display:grid}.mode-card{text-align:left;border-radius:var(--r-md);color:var(--cream);background:#ffffff0d;border:1.5px solid #ffffff1a;align-items:center;gap:13px;padding:15px 16px;transition:transform .14s,border-color .2s,background .2s;display:flex}.mode-card:hover{background:#ffffff17;transform:translateY(-2px)}.mode-card.on{border-color:var(--accent);background:color-mix(in oklch,var(--accent) 16%,transparent);box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 22%,transparent)}.mode-ico{flex:none;font-size:26px}.mode-col{flex-direction:column;gap:2px;display:flex}.mode-name{font-family:var(--display);font-size:16px;font-weight:600;line-height:1.1}.mode-sub{color:var(--cream-dim);font-size:12.5px;line-height:1.3}.truth-note{color:var(--leaf);margin:14px 2px 0;font-size:13.5px;font-weight:500}.tag.true-tag{color:var(--leaf);background:color-mix(in oklch,var(--leaf) 16%,transparent)}.name-edit{align-items:center;gap:8px;display:flex}.name-input{font-family:var(--read);color:var(--cream);background:#00000042;border:1px solid #ffffff2e;border-radius:9px;width:130px;padding:7px 11px;font-size:14.5px}.name-input:focus{border-color:var(--accent);outline:none}.share-hint{color:var(--cream-dim);margin-top:10px;font-size:13px}.share-hint b{color:var(--accent);font-family:var(--display);letter-spacing:.05em}.foot-nav{gap:10px;width:100%;display:none}.foot-nav-btn{min-height:50px;color:var(--cream);font-family:var(--display);background:#ffffff12;border:1px solid #ffffff2e;border-radius:14px;flex:1;font-size:17px;font-weight:600}.foot-nav-btn.primary{background:var(--accent);color:#3a2300;border-color:var(--accent)}.foot-nav-btn:disabled{opacity:.4}@media (width<=820px){.reader-stage{padding:18px 10px}.book{width:96vw}}@media (width<=680px){.home{padding:30px 18px}.home-title{margin-top:16px}.home-cards,.dream-fields,.two-up,.rate-grid,.mode-pick{grid-template-columns:1fr}.home-foot{flex-direction:column;align-items:flex-start;gap:14px}.theme-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-row{grid-template-columns:1fr 1fr}.create-scroll,.history-scroll{padding:26px 16px 70px}.back{margin-bottom:8px;display:inline-block;position:static}.create-head,.history-head{text-align:left}.page-arrow{display:none}.reader-stage{padding:14px 12px 6px}.book{width:100%}.spread{grid-template-columns:1fr;gap:16px;min-height:0;padding:16px}.spread-art{order:-1}.plate{min-height:180px}.cover{padding:18px}.reader-foot{padding:12px 16px calc(16px + env(safe-area-inset-bottom));flex-wrap:wrap;justify-content:center;gap:10px}.reader-foot .link-btn{order:2}.pagedots{flex:none;order:1;width:100%}.tap-hint,.reader-foot>.btn{order:2}.foot-nav{order:0;display:flex}.presence{gap:8px;padding:11px 14px}.presence-count{display:none}.shelf-row{flex-wrap:wrap}.reread{order:3;width:100%;margin-top:4px}.finish-card{padding:22px 18px}.rate-grid{gap:12px}}@media (width<=430px){.theme-grid{grid-template-columns:1fr}.stat-row{grid-template-columns:1fr 1fr}.home-title{font-size:30px}.readable{line-height:1.55}}.word{transition:background .12s,color .12s}.word-active{background:color-mix(in oklch,var(--accent) 80%,transparent);color:#2a1c06;box-shadow:0 0 0 2px color-mix(in oklch,var(--accent) 45%,transparent);border-radius:6px}@media (prefers-reduced-motion:reduce){.word{transition:none}}.hear-page.playing{background:color-mix(in oklch,var(--accent) 26%,transparent);border-color:color-mix(in oklch,var(--accent) 60%,transparent);color:var(--cream)}.plate-img{border-style:solid;border-color:color-mix(in oklch,var(--accent) 40%,transparent);padding:0;display:block;position:relative;overflow:hidden}.plate-img img{object-fit:cover;width:100%;height:100%;display:block}.plate-cap-img{color:#fff;background:linear-gradient(#0000,#0000008c);margin:0;padding:10px 12px;font-size:12.5px;line-height:1.3;position:absolute;bottom:0;left:0;right:0}.plate-loading{animation:1.4s ease-in-out infinite plate-pulse}@keyframes plate-pulse{0%,to{filter:brightness()}50%{filter:brightness(1.12)}}@media (prefers-reduced-motion:reduce){.plate-loading{animation:none}}.settings-fab{z-index:40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:44px;height:44px;color:var(--cream);box-shadow:var(--shadow-card);background:#141028b3;border:1px solid #ffffff2e;border-radius:50%;font-size:19px;line-height:1;position:fixed;top:14px;right:14px}.settings-fab:hover{color:var(--accent);border-color:color-mix(in oklch,var(--accent) 50%,transparent)}.reader .presence{padding-right:62px}.settings-scrim{z-index:39;background:#0000002e;position:fixed;inset:0}.settings-panel{z-index:41;background:color-mix(in oklch,var(--bg2) 92%,black);border-radius:var(--r-md);width:min(300px,100vw - 28px);max-height:calc(100vh - 84px);box-shadow:var(--shadow-card);border:1px solid #ffffff24;padding:14px 16px 18px;position:fixed;top:66px;right:14px;overflow:auto}.settings-head{font-family:var(--display);justify-content:space-between;align-items:center;margin-bottom:6px;font-size:16px;font-weight:600;display:flex}.settings-close{color:var(--cream-dim);background:0 0;border:none;padding:4px;font-size:15px}.settings-close:hover{color:var(--accent)}.settings-group{margin-top:14px}.settings-label{color:var(--cream-dim);margin-bottom:8px;font-size:13px;display:block}.settings-themes{gap:8px;display:flex}.theme-swatch{border:2px solid #0000;border-radius:8px;width:46px;height:30px;padding:0;display:flex;overflow:hidden}.theme-swatch span{flex:1}.theme-swatch.on{border-color:var(--accent)}.settings-group input[type=range]{width:100%;accent-color:var(--accent)}.settings-voice{align-items:center;gap:8px;display:flex}.voice-select{min-width:0;font-family:var(--read);color:var(--cream);background:#00000047;border:1.5px solid #ffffff29;border-radius:10px;flex:1;padding:9px 10px;font-size:14px}.voice-select:focus{border-color:var(--accent);outline:none}.voice-select option{color:#111}.voice-preview{background:color-mix(in oklch,var(--accent) 18%,transparent);width:38px;height:38px;color:var(--cream);border:1.5px solid #ffffff29;border-radius:10px;flex:none;font-size:13px}.voice-preview:hover{border-color:var(--accent);color:var(--accent)}.name-gate{z-index:60;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0806149e;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.name-gate-card{background:color-mix(in oklch,var(--bg2) 92%,black);border-radius:var(--r-lg);width:min(380px,100%);box-shadow:var(--shadow-card);text-align:center;border:1px solid #ffffff24;padding:26px 24px}.name-gate-title{font-family:var(--display);color:var(--cream);margin:0 0 6px;font-size:21px;font-weight:600}.name-gate-sub{color:var(--cream-dim);margin:0 0 16px;font-size:14px}.name-gate-sub b{color:var(--accent);font-family:var(--display);letter-spacing:.04em}.name-gate-input{width:100%;font-family:var(--read);text-align:center;color:var(--cream);background:#00000042;border:1.5px solid #ffffff2e;border-radius:12px;padding:13px 14px;font-size:18px}.name-gate-input:focus{border-color:var(--accent);outline:none}.name-gate-actions{justify-content:center;gap:10px;margin-top:18px;display:flex}.mode-pick-3{grid-template-columns:repeat(3,1fr)}.fact-headline .readable{font-family:var(--display);font-weight:600;font-size:calc(var(--read-size) + 6px);color:var(--ink);line-height:1.2}.text-only .fact-headline .readable{text-align:center}.spread-text.has-headline{gap:12px}.tag.fact-tag{color:var(--accent);background:color-mix(in oklch,var(--accent) 16%,transparent)}@media (width<=680px){.mode-pick-3{grid-template-columns:1fr}}.family-code{font-family:var(--display);letter-spacing:.06em;color:var(--accent);text-align:center;background:#0000003d;border:1.5px solid #ffffff24;border-radius:10px;padding:9px 12px;font-size:20px;font-weight:600}.family-hint{color:var(--cream-dim);margin:8px 0 10px;font-size:12px;line-height:1.4}.shelf-row.unread{border-left:3px solid color-mix(in oklch,var(--accent) 55%,transparent)}.shelf-new{font-family:var(--display);color:#2a1c06;background:var(--accent);white-space:nowrap;border-radius:999px;padding:2px 9px;font-size:12px;font-weight:600}.shelf-section{margin-top:22px}.shelf-section-label{font-family:var(--display);color:var(--cream);text-align:left;opacity:.92;margin:0 0 4px;padding:0 4px;font-size:16px;font-weight:600}.bookshelf{grid-template-columns:repeat(auto-fill,132px);justify-content:center;gap:24px 16px;padding:6px 2px 0;display:grid}.book-cover{background:0 0;border:none;flex-direction:column;gap:9px;width:132px;padding:0;display:flex}.cover-art{border-radius:8px;width:132px;height:166px;transition:transform .14s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 8px 16px -8px #00000080}.book-cover:hover .cover-art{transform:translateY(-4px);box-shadow:0 14px 22px -10px #0009}.cover-art img{object-fit:cover;width:100%;height:100%;display:block}.cover-ph{text-align:center;background:radial-gradient(120% 80% at 30% 18%, color-mix(in oklch,var(--c) 34%,transparent), transparent 60%), linear-gradient(160deg, var(--paper), var(--paper-edge));flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:100%;padding:10px;display:flex}.cover-ph-ico{filter:drop-shadow(0 2px 3px #00000040);font-size:34px}.cover-ph-title{font-family:var(--display);color:var(--ink);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:13px;font-weight:600;line-height:1.15;display:-webkit-box;overflow:hidden}.cover-new{font-family:var(--display);color:#2a1c06;background:var(--accent);border-radius:0 4px 4px 0;padding:2px 8px 2px 7px;font-size:10.5px;font-weight:600;position:absolute;top:6px;left:-4px;box-shadow:0 2px 4px #0006}.cover-label{font-family:var(--read);color:var(--cream);text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;height:30px;font-size:12px;line-height:1.25;display:-webkit-box;overflow:hidden}.pin-gate{justify-content:center;align-items:center}.pin-inner{z-index:1;text-align:center;flex-direction:column;align-items:center;gap:14px;max-width:360px;margin:auto;padding:30px;display:flex;position:relative}.pin-title{font-family:var(--display);color:var(--cream);margin:8px 0 0;font-size:26px;font-weight:600}.pin-sub{color:var(--cream-dim);margin:0;font-size:14px}.pin-input{width:200px;font-family:var(--display);letter-spacing:.32em;text-align:center;color:var(--cream);background:#00000047;border:1.5px solid #ffffff2e;border-radius:14px;padding:14px 10px;font-size:30px;font-weight:600}.pin-input:focus{border-color:var(--accent);outline:none}.pin-error{color:var(--accent2);margin:0;font-size:13.5px}.home-share{text-align:center;margin-top:6px}.share-link-btn{color:var(--cream-dim);font-family:var(--read);background:0 0;border:1px solid #ffffff2e;border-radius:999px;padding:8px 16px;font-size:13.5px}.share-link-btn:hover{color:var(--accent);border-color:color-mix(in oklch,var(--accent) 50%,transparent)}.presence-share{color:var(--cream-dim);background:0 0;border:none;margin-left:8px;padding:2px 6px;font-size:13px}.presence-share:hover{color:var(--accent)}
