.login-stage{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;overflow:hidden}.login-card{position:relative;width:min(420px,100%);padding:44px 40px 36px;background:radial-gradient(ellipse at top,#fff9ea 0%,var(--paper) 70%);border-radius:18px;box-shadow:0 2px #00000005,0 24px 40px -12px #78502840,0 60px 80px -30px #3c281433,inset 0 0 0 1px #e8dcc0cc;display:flex;flex-direction:column;align-items:stretch;animation:cardEnter .7s var(--ease-bounce) both}.login-card:before{content:"";position:absolute;top:-10px;left:50%;transform:translate(-50%) rotate(-3deg);width:72px;height:22px;background:#e9c8828c;border-radius:2px;box-shadow:0 2px 6px #7850282e}@keyframes cardEnter{0%{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.login-badge{align-self:center;display:grid;place-items:center;width:68px;height:68px;margin-bottom:10px;background:#fff;border-radius:50%;box-shadow:0 4px 10px #c88c4640,inset 0 0 0 3px #fff3e0;animation:badgeBob 4s ease-in-out infinite}@keyframes badgeBob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.login-title{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,4vw,36px);text-align:center;color:var(--ink);line-height:1.1;letter-spacing:-.01em}.login-subtitle{font-family:var(--font-display);font-style:italic;font-size:15px;text-align:center;color:var(--ink-soft);margin-top:6px;margin-bottom:20px}.divider{display:flex;align-items:center;gap:10px;margin:4px 0 22px}.divider-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--paper-edge),transparent)}.divider-icon{font-size:14px;color:var(--bloom)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field-label{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}.field input{width:100%;padding:12px 14px;font-size:15px;color:var(--ink);background:#fffdf6;border:1.5px solid var(--paper-edge);border-radius:10px;transition:border-color .2s,box-shadow .2s,background .2s;outline:none}.field input:focus{border-color:var(--leaf);background:#fff;box-shadow:0 0 0 4px #6a875926}.field input:disabled{opacity:.6}.login-error{margin:6px 0 14px;padding:10px 12px;background:#fdeadf;border-left:3px solid var(--bloom-deep);border-radius:6px;color:#7a3814;font-size:14px}.shake{animation:shake .45s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translate(-2px)}20%,80%{transform:translate(4px)}30%,50%,70%{transform:translate(-8px)}40%,60%{transform:translate(8px)}}.login-submit{margin-top:4px;padding:13px 18px;font-family:var(--font-body);font-size:15px;font-weight:700;letter-spacing:.02em;color:#fff;background:linear-gradient(180deg,var(--bloom) 0%,var(--bloom-deep) 100%);border-radius:10px;box-shadow:0 1px #ffffff59 inset,0 8px 16px -6px #c66f3399,0 2px 4px #3c1e0a26;transition:transform .15s var(--ease-soft),box-shadow .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 1px #ffffff59 inset,0 12px 20px -6px #c66f33b3,0 2px 4px #3c1e0a26}.login-submit:active:not(:disabled){transform:translateY(1px)}.login-submit:disabled{cursor:progress;opacity:.8}.busy-dots{display:inline-flex;gap:6px}.busy-dots span{width:6px;height:6px;border-radius:50%;background:#fff;animation:dotPulse 1s ease-in-out infinite}.busy-dots span:nth-child(2){animation-delay:.15s}.busy-dots span:nth-child(3){animation-delay:.3s}@keyframes dotPulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}.login-hint{margin-top:18px;font-size:12px;text-align:center;color:var(--ink-soft);opacity:.75}.login-hint code{font-family:Courier New,monospace;background:#6a87591f;padding:2px 6px;border-radius:4px;font-size:11.5px}.floating-leaves{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.floating-leaves .leaf{position:absolute;font-size:22px;opacity:.55;animation:floatLeaf linear infinite;filter:drop-shadow(0 2px 2px rgba(0,0,0,.08))}@keyframes floatLeaf{0%{transform:translateY(-10vh) translate(0) rotate(0);opacity:0}10%{opacity:.6}90%{opacity:.6}to{transform:translateY(110vh) translate(40px) rotate(360deg);opacity:0}}.leaf-0{left:5%;animation-duration:18s;animation-delay:0s}.leaf-1{left:14%;animation-duration:22s;animation-delay:3s}.leaf-2{left:25%;animation-duration:16s;animation-delay:6s;font-size:18px}.leaf-3{left:38%;animation-duration:24s;animation-delay:1s}.leaf-4{left:52%;animation-duration:20s;animation-delay:8s;font-size:26px}.leaf-5{left:63%;animation-duration:17s;animation-delay:4s}.leaf-6{left:74%;animation-duration:23s;animation-delay:2s;font-size:20px}.leaf-7{left:82%;animation-duration:19s;animation-delay:7s}.leaf-8{left:90%;animation-duration:21s;animation-delay:5s;font-size:24px}.leaf-9{left:46%;animation-duration:25s;animation-delay:10s;font-size:16px}@media (max-width: 480px){.login-card{padding:32px 24px 28px}.login-title{font-size:26px}}.library-shell{position:relative;min-height:100vh;display:flex;flex-direction:column}.library-header{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:#fffae68c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(184,153,104,.2);position:sticky;top:0;z-index:10}.library-brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:18px;color:var(--ink)}.library-brand .brand-mark{font-size:20px}.library-right{display:flex;align-items:center;gap:14px}.library-main{flex:1;padding:40px 24px 60px;max-width:1200px;width:100%;margin:0 auto}.library-title{font-family:var(--font-display);font-weight:700;font-size:clamp(24px,3.5vw,34px);color:var(--ink);text-align:center;margin-bottom:32px;line-height:1.25}.library-greeting{display:block;font-size:.8em;font-weight:600;color:var(--ink-soft);margin-bottom:6px}.library-error{text-align:center;color:var(--bloom-deep);font-family:var(--font-display);font-style:italic}.library-loading{display:flex;flex-direction:column;align-items:center;gap:12px;font-family:var(--font-display);font-style:italic;color:var(--ink-soft)}.library-loading .loading-flower{font-size:56px;animation:librarySpin 2.5s linear infinite}@keyframes librarySpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:28px;justify-content:center}.book-card{display:flex;flex-direction:column;text-align:left;padding:0;background:#fffae699;border:1.5px solid var(--paper-edge);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .25s var(--ease-soft),box-shadow .25s var(--ease-soft),border-color .25s var(--ease-soft);box-shadow:0 4px 14px #3c28141a}.book-card:hover:not(:disabled){transform:translateY(-4px);border-color:var(--leaf);box-shadow:0 12px 26px #3c281433}.book-card:active:not(:disabled){transform:translateY(-1px)}.book-card--locked{cursor:not-allowed;filter:grayscale(.85);opacity:.85}.book-card__cover{width:100%;aspect-ratio:1 / 1;background-size:cover;background-position:center;background-color:var(--paper);position:relative}.book-card__locked-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#3c281473;color:#fff;pointer-events:none}.book-card__lock{font-size:52px;text-shadow:0 2px 8px rgba(0,0,0,.55);display:inline-block;transform-origin:center}.book-card__coming{font-family:var(--font-display);font-style:italic;font-weight:600;font-size:clamp(16px,2.2vw,20px);letter-spacing:.03em;text-shadow:0 2px 6px rgba(0,0,0,.55);display:inline-block}.book-card__lock--wiggle{animation:lockWiggle .55s ease-in-out}.book-card__coming--wiggle{animation:comingWiggle .55s ease-in-out}@keyframes lockWiggle{0%,to{transform:rotate(0)}15%{transform:rotate(-14deg)}35%{transform:rotate(12deg)}55%{transform:rotate(-8deg)}75%{transform:rotate(5deg)}}@keyframes comingWiggle{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.book-card__meta{padding:14px 16px 18px;display:flex;flex-direction:column;gap:4px}.book-card__title{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--ink);line-height:1.2}.book-card__subtitle{font-family:var(--font-display);font-style:italic;font-size:13.5px;color:var(--ink-soft)}.book-card__count{margin-top:4px;font-size:12px;color:var(--ink-soft);opacity:.7}@media (max-width: 540px){.library-header{padding:10px 14px}.user-chip{display:none}.library-main{padding:24px 16px 40px}.library-grid{gap:18px}}.stf__parent{position:relative;display:block;box-sizing:border-box;transform:translateZ(0);-ms-touch-action:pan-y;touch-action:pan-y}.stf__wrapper{position:relative;width:100%;box-sizing:border-box}.stf__parent canvas{position:absolute;width:100%;height:100%;left:0;top:0}.stf__block{position:absolute;width:100%;height:100%;box-sizing:border-box;perspective:2000px}.stf__item{display:none;position:absolute;transform-style:preserve-3d}.stf__outerShadow,.stf__innerShadow,.stf__hardShadow,.stf__hardInnerShadow{position:absolute;left:0;top:0}.viewer-shell{position:relative;min-height:100vh;display:grid;grid-template-rows:auto 1fr;gap:8px;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:#fffae68c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(184,153,104,.2);position:sticky;top:0;z-index:10}.topbar-left{display:flex;align-items:center}.btn-back{display:inline-flex;align-items:center;gap:6px;padding:8px 14px 8px 10px;font-size:13px;font-weight:600;color:var(--ink);background:#ffffffb3;border:1.5px solid var(--paper-edge);border-radius:8px;transition:background .2s,border-color .2s,transform .1s}.btn-back:hover{background:#fff;border-color:var(--leaf)}.btn-back:active{transform:scale(.97)}.topbar-right{display:flex;align-items:center;gap:14px}.user-chip{font-size:13px;color:var(--ink-soft);padding:6px 12px;background:#6a87591a;border-radius:999px;border:1px solid rgba(106,135,89,.25)}.btn-logout{padding:8px 14px;font-size:13px;font-weight:600;color:var(--ink);background:#ffffffb3;border:1.5px solid var(--paper-edge);border-radius:8px;transition:background .2s,transform .1s}.btn-logout:hover{background:#fff;border-color:var(--leaf)}.btn-logout:active{transform:scale(.97)}.book-stage{display:grid;place-items:center;padding:24px 16px;position:relative}.nini-book{filter:drop-shadow(0 30px 40px rgba(60,40,20,.35)) drop-shadow(0 8px 12px rgba(60,40,20,.2))}.book-page{background-color:var(--paper);overflow:hidden;position:relative;backface-visibility:hidden;-webkit-backface-visibility:hidden;background-image:radial-gradient(ellipse at top left,rgba(255,245,210,.6),transparent 60%),radial-gradient(ellipse at bottom right,rgba(200,170,110,.15),transparent 70%),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='p'><feTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.3 0 0 0 0.1 0'/></filter><rect width='100%' height='100%' filter='url(%23p)'/></svg>");background-size:auto,auto,140px 140px}.book-page__inner{position:relative;width:100%;height:100%;padding:20px 22px;display:flex;flex-direction:column}.page-number{position:absolute;bottom:10px;left:50%;transform:translate(-50%);font-family:var(--font-display);font-style:italic;font-size:12px;color:var(--ink-soft);opacity:.7}.page-vignette{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;box-shadow:inset 0 0 60px #78502826,inset 0 0 8px #78502814}.book-cover{position:relative;background:#5d4a2e}.book-cover--front .cover-art{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;filter:saturate(.95) brightness(.92)}.book-cover--front .cover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#f5e6c8d9,#f5e6c866 40%,#64461e1a);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:40px 24px 0;text-align:center}.cover-title{font-family:var(--font-display);font-weight:700;font-size:clamp(24px,4.5vw,34px);color:#3d2e1f;line-height:1.05;letter-spacing:-.01em;text-shadow:0 1px 0 rgba(255,250,230,.7)}.cover-ornament{margin:14px 0 12px;color:var(--bloom);letter-spacing:.3em;font-size:11px}.cover-subtitle{font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--ink-soft)}.cover-corner{position:absolute;width:28px;height:28px;border:2px solid rgba(255,250,230,.6);pointer-events:none}.cover-corner--tl{top:14px;left:14px;border-right:none;border-bottom:none}.cover-corner--tr{top:14px;right:14px;border-left:none;border-bottom:none}.cover-corner--bl{bottom:14px;left:14px;border-right:none;border-top:none}.cover-corner--br{bottom:14px;right:14px;border-left:none;border-top:none}.book-cover--back{background:linear-gradient(135deg,#6b5640,#4a3a28)}.back-cover-content{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px;text-align:center;color:#f4e9d0}.back-ornament{font-size:42px;margin-bottom:20px;filter:drop-shadow(0 2px 3px rgba(0,0,0,.3))}.back-text{font-family:var(--font-display);font-style:italic;font-size:15px;line-height:1.6;opacity:.9}.story-illustration-full{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center}.story-text{flex:1;display:flex;flex-direction:column;justify-content:center;gap:4px;padding:8px 4px 22px}.story-text--center{justify-content:center;text-align:center;align-items:center}.story-text--end{justify-content:center;align-items:center;text-align:center}.story-text--end .story-line:first-child{font-size:28px;font-weight:700;color:var(--bloom-deep);margin-bottom:10px}.story-line{font-family:var(--font-display);font-size:clamp(14px,1.8vw,17px);line-height:1.4;color:var(--ink);opacity:0;animation:lineAppear .6s var(--ease-soft) both}@keyframes lineAppear{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.blank-page .book-page__inner{align-items:center;justify-content:center}.blank-ornament{font-size:28px;color:var(--paper-shadow);opacity:.4}.book-loading,.book-error{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;font-family:var(--font-display);color:var(--ink-soft);font-size:16px;font-style:italic}.loading-flower{font-size:56px;animation:loadSpin 2.5s linear infinite}@keyframes loadSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.book-error button{margin-top:12px}@media (max-width: 540px){.topbar{padding:10px 14px}.topbar-brand{font-size:15px}.user-chip{display:none}}:root{--paper: #fbf4e2;--paper-edge: #e8dcc0;--paper-shadow: #b89968;--ink: #3d2e1f;--ink-soft: #6b5640;--leaf: #6a8759;--leaf-deep: #4a6b44;--bloom: #e89451;--bloom-deep: #c66f33;--sky: #c9dcef;--field-1: #f4e9d0;--field-2: #e8d8b5;--font-display: "Fraunces", "Georgia", serif;--font-body: "Nunito", system-ui, sans-serif;--ease-soft: cubic-bezier(.65, .05, .36, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow-x:hidden}html{scrollbar-gutter:stable}body{font-family:var(--font-body);color:var(--ink);background:var(--field-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input{font-family:inherit}.garden-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 90% 60% at 80% 10%,rgba(255,240,180,.55),transparent 60%),radial-gradient(ellipse 70% 50% at 15% 85%,rgba(150,180,130,.35),transparent 65%),linear-gradient(180deg,#eaf4f1,#f4ecd2 55%,#d9cf9c);z-index:-2}.garden-backdrop:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.4 0 0 0 0 0.35 0 0 0 0 0.25 0 0 0 0.15 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");opacity:.4;mix-blend-mode:multiply;pointer-events:none}.garden-backdrop:after{content:"";position:absolute;top:-80px;right:-80px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,#ffdc8cd9,#ffdc8c00 70%);animation:sunPulse 8s var(--ease-soft) infinite;pointer-events:none}@keyframes sunPulse{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.08);opacity:1}}::selection{background:var(--bloom);color:#fff}
