@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400;1,600&family=EB+Garamond:ital,wght@0,400;0,500;1,400&family=Cinzel:wght@400;600&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-white:#fff;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.z-15{z-index:15}.mt-4{margin-top:calc(var(--spacing) * 4)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.block{display:block}.flex{display:flex}.hidden{display:none}.w-full{width:100%}.flex-1{flex:1}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.border-white\/10{border-color:color-mix(in oklab, var(--color-white) 10%, transparent)}}.pt-4{padding-top:calc(var(--spacing) * 4)}.italic{font-style:italic}.sepia{--tw-sepia:sepia(100%);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,)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--cream:#fdf8f0;--ink:#1a0e06;--brown:#4a2510;--gold:#c9973a;--rose:#b85050;--page-bg:#fffcf5;--page-line:#8c643c12;--fs:1rem;--lh:1.85}html,body{touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-webkit-touch-callout:none;background:#0c0806;width:100%;height:100%;font-family:EB Garamond,serif;overflow:hidden}#root{width:100%;height:100%}body:after{content:"";z-index:9998;pointer-events:none;opacity:.3;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");position:fixed;inset:0}.toast{color:var(--cream);letter-spacing:.04em;z-index:9997;opacity:0;pointer-events:none;white-space:nowrap;background:#140a04f5;border:1px solid #c9973a40;border-radius:32px;padding:10px 24px;font-size:.82rem;font-style:italic;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .3s;position:fixed;bottom:100px;left:50%;transform:translate(-50%)translateY(20px);box-shadow:0 8px 40px #0009}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.screen{flex-direction:column;align-items:center;display:none;position:fixed;inset:0}.screen.active{display:flex}.id-screen{background:radial-gradient(at 50% 35%,#2a1408,#0c0806);justify-content:center;padding:40px 24px;overflow:hidden}.id-screen:before{content:"";pointer-events:none;background:radial-gradient(at 50% 80%,#c9973a0f,#0000 60%);position:absolute;inset:0}.id-ornament{text-align:center;color:var(--gold);opacity:.4;letter-spacing:.4em;z-index:1;margin-bottom:6px;font-size:1rem;position:relative}.id-title{color:var(--gold);letter-spacing:.18em;text-align:center;text-shadow:0 0 80px #c9973a80;z-index:1;margin-bottom:8px;font-family:Cinzel,serif;font-size:clamp(1.6rem,6vw,2.8rem);position:relative}.id-sub{color:#7a5030;text-align:center;letter-spacing:.06em;z-index:1;margin-bottom:52px;font-size:.88rem;font-style:italic;position:relative}.id-cards{z-index:1;flex-wrap:wrap;justify-content:center;gap:24px;display:flex;position:relative}.id-card{cursor:pointer;border:1px solid #c9973a33;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:14px;width:clamp(130px,38vw,175px);height:clamp(170px,50vw,220px);transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 48px #00000080,inset 0 1px #ffffff0d}.id-card:before{content:"";background:radial-gradient(at 50% 20%,#ffffff14,#0000 60%);position:absolute;inset:0}.id-card:active{border-color:var(--gold);transform:translateY(-12px)scale(1.05)}.id-card-emoji{z-index:1;font-size:3rem;position:relative}.id-card-name{letter-spacing:.06em;z-index:1;font-family:Cormorant Garamond,serif;font-size:1.4rem;font-weight:600;position:relative}.id-card-hint{opacity:.45;letter-spacing:.18em;text-transform:uppercase;z-index:1;font-size:.6rem;position:relative}.shelf-screen{padding:max(56px,env(safe-area-inset-top) + 20px) 20px max(110px,env(safe-area-inset-bottom) + 90px);background:radial-gradient(at 50% 0,#261208,#0c0806);justify-content:flex-start;align-items:center;overflow-y:auto}.shelf-header{text-align:center;margin-bottom:24px}.shelf-greeting{color:var(--gold);letter-spacing:.2em;text-transform:uppercase;opacity:.7;margin-bottom:8px;font-family:Cormorant Garamond,serif;font-size:.78rem;font-style:italic}.shelf-title{color:var(--gold);letter-spacing:.12em;text-shadow:0 2px 30px #c9973a4d;margin-bottom:6px;font-family:Cinzel,serif;font-size:clamp(1.5rem,4.5vw,2.4rem)}.shelf-div{justify-content:center;align-items:center;gap:12px;margin-bottom:6px;display:flex}.shelf-div-line{background:linear-gradient(90deg,#0000,#c9973a4d,#0000);width:60px;height:1px}.shelf-div-diamond{background:var(--gold);opacity:.4;width:5px;height:5px;transform:rotate(45deg)}.shelf-sub{color:#6a4020;letter-spacing:.08em;font-size:.8rem;font-style:italic}.ann-widget{text-align:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#c9973a12;border:1px solid #c9973a2e;border-radius:18px;flex-shrink:0;width:calc(100% - 32px);max-width:360px;margin-bottom:24px;padding:16px 20px;position:relative;overflow:hidden}.ann-widget:before{content:"";pointer-events:none;background:radial-gradient(at 50% 0,#c9973a1a,#0000 70%);position:absolute;inset:0}.ann-days{color:var(--gold);z-index:1;text-shadow:0 0 30px #c9973a66;font-family:Cinzel,serif;font-size:clamp(1.8rem,8vw,2.8rem);line-height:1;position:relative}.ann-label{color:#7a5a30;z-index:1;letter-spacing:.06em;margin-top:5px;font-family:Cormorant Garamond,serif;font-size:clamp(.7rem,3vw,.85rem);font-style:italic;position:relative}.ann-set-btn{cursor:pointer;color:#c9973a73;letter-spacing:.08em;z-index:1;background:0 0;border:none;width:100%;min-height:28px;margin-top:6px;padding:4px 0;font-size:clamp(.58rem,2.5vw,.68rem);font-style:italic;display:block;position:relative}.shelf-actions{margin-bottom:32px}.new-book-btn{cursor:pointer;letter-spacing:.12em;color:var(--gold);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-tap-highlight-color:transparent;background:#c9973a14;border:1px solid #c9973a66;border-radius:28px;align-items:center;gap:8px;padding:11px 28px;font-family:Cormorant Garamond,serif;font-size:.92rem;font-weight:600;transition:all .25s;display:flex}.new-book-btn:active{background:#c9973a2e;transform:scale(.97)}.shelf-row{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:24px;width:100%;max-width:760px;display:flex}.book-card{cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .35s cubic-bezier(.34,1.56,.64,1);position:relative}.book-card:active{transform:translateY(-18px)scale(1.07)rotateY(-6deg)}.book-spine{border-radius:2px 12px 12px 2px;flex-direction:column;justify-content:center;align-items:center;width:96px;height:168px;display:flex;position:relative;overflow:hidden;box-shadow:-6px 0 #080402,-4px 0 #1a0e06,0 0 0 1px #ffffff0a,6px 12px 40px #0a05028c}.book-spine:before{content:"";background:linear-gradient(90deg,#000000a6,#0000000d);width:16px;position:absolute;top:0;bottom:0;left:0}.book-spine:after{content:"";background:#ffffff0f;width:3px;position:absolute;top:0;bottom:0;right:0}.bs-icon{z-index:1;opacity:.8;margin-bottom:6px;font-size:.9rem}.bs-title{writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.14em;text-align:center;z-index:1;text-shadow:0 1px 6px #00000080;padding:0 6px;font-family:Cinzel,serif;font-size:.62rem;font-weight:600;transform:rotate(180deg)}.bs-count{opacity:.5;z-index:1;letter-spacing:.08em;margin-top:5px;font-size:.5rem}.bs-badge{z-index:5;background:#ff4d6d;border-radius:50%;width:9px;height:9px;animation:2s ease-in-out infinite badgePulse;position:absolute;top:8px;right:6px;box-shadow:0 0 6px #ff4d6db3}@keyframes badgePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.35)}}.add-card{cursor:pointer;color:#c9973a59;-webkit-tap-highlight-color:transparent;border:1.5px dashed #c9973a33;border-radius:2px 12px 12px 2px;flex-direction:column;justify-content:center;align-items:center;gap:7px;width:96px;height:168px;transition:all .25s;display:flex}.add-card:active{border-color:var(--gold);color:var(--gold)}.add-lbl{letter-spacing:.14em;text-transform:uppercase;font-size:.55rem}.music-fab{cursor:pointer;z-index:50;width:48px;height:48px;color:var(--gold);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:manipulation;-webkit-touch-callout:none;background:#c9973a1a;border:1px solid #c9973a40;border-radius:50%;justify-content:center;align-items:center;transition:all .25s;display:flex;position:fixed;bottom:28px;right:22px}.music-fab.on{background:#c9973a33;animation:2.5s ease-in-out infinite fabPulse;box-shadow:0 0 20px #c9973a40}@keyframes fabPulse{0%,to{box-shadow:0 0 #c9973a4d}50%{box-shadow:0 0 0 10px #c9973a00}}.loading-wrap{color:#5a3818;text-align:center;flex-direction:column;align-items:center;gap:14px;width:100%;padding:60px 0;font-size:.86rem;font-style:italic;display:flex}.spinner{border:2px solid #c9973a33;border-top-color:var(--gold);border-radius:50%;width:28px;height:28px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.backdrop{z-index:500;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#000000bf;justify-content:center;align-items:flex-end;display:none;position:fixed;inset:0}.backdrop.open{animation:.2s bkIn;display:flex}@keyframes bkIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--cream);padding:20px 20px max(24px,env(safe-area-inset-bottom) + 12px);border-radius:24px 24px 0 0;flex-direction:column;width:100%;max-width:540px;max-height:96vh;animation:.38s cubic-bezier(.34,1.56,.64,1) modalUp;display:flex;box-shadow:0 -8px 60px #00000080}.modal:before{content:"";background:#4a25102e;border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:0 auto 18px;display:block}@keyframes modalUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:none}}.modal-scroll{flex:1;padding-right:4px;overflow-y:auto}.modal h2{color:var(--brown);letter-spacing:.1em;flex-shrink:0;margin-bottom:18px;font-family:Cinzel,serif;font-size:1.1rem}.modal label{color:#7a5030;letter-spacing:.06em;margin-bottom:5px;font-size:.78rem;font-style:italic;display:block}.modal input[type=text],.modal textarea{width:100%;color:var(--ink);-webkit-appearance:none;resize:none;background:#fffdf8;border:1.5px solid #4a251026;border-radius:10px;outline:none;margin-bottom:13px;padding:12px 14px;font-family:EB Garamond,serif;font-size:1rem;transition:border-color .2s}.modal input:focus,.modal textarea:focus{border-color:var(--gold)}.pal-row{flex-wrap:wrap;gap:9px;margin-bottom:16px;display:flex}.pal-sw{cursor:pointer;-webkit-tap-highlight-color:transparent;border:3px solid #0000;border-radius:50%;width:36px;height:36px;transition:transform .2s,border-color .2s}.pal-sw.on{border-color:var(--ink);transform:scale(1.25)}.btn-row{gap:10px;margin-top:6px;display:flex}.btn{letter-spacing:.08em;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:14px;flex:1;padding:15px 0;font-family:Cinzel,serif;font-size:.82rem;transition:all .2s}.btn-pri{background:var(--brown);color:var(--cream)}.btn-pri:disabled{opacity:.5;cursor:not-allowed}.btn-pri:not(:disabled):active{background:#2e1508;transform:scale(.97)}.btn-gh{color:var(--brown);background:0 0;border:1.5px solid #4a251033}.btn-gh:active{background:#4a25100f}.btn-danger{color:#fff;background:#c0392b;flex:.7}.btn-danger:active{background:#9a2a1f}.tab-row{border:1.5px solid #4a251026;border-radius:10px;margin-bottom:14px;display:flex;overflow:hidden}.tab-btn{color:var(--brown);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex:1;padding:13px 9px;font-family:EB Garamond,serif;font-size:.9rem;font-style:italic;transition:background .2s}.tab-btn.on{background:var(--brown);color:var(--cream)}.upload-zone{text-align:center;cursor:pointer;background:#fffdf8;border:2px dashed #4a251033;border-radius:12px;margin-bottom:12px;padding:22px 14px;transition:all .2s}.up-prev{border-radius:8px;max-width:100%;max-height:150px;margin:8px auto 0;display:block}.rec-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:12px;justify-content:center;align-items:center;gap:9px;width:100%;margin-bottom:11px;padding:13px;font-family:EB Garamond,serif;font-size:.88rem;font-style:italic;transition:all .2s;display:flex}.rec-idle{color:var(--brown);background:#4a251014}.rec-active{color:#fff;background:#c0392b;animation:1s ease-in-out infinite recPulse}@keyframes recPulse{0%,to{opacity:1}50%{opacity:.72}}.rec-bars{align-items:center;gap:3px;height:20px;display:flex}.rec-bar{background:currentColor;border-radius:2px;width:3px;animation:1s ease-in-out infinite barWave}.rec-bar:nth-child(2){animation-delay:.1s}.rec-bar:nth-child(3){animation-delay:.2s}.rec-bar:nth-child(4){animation-delay:.3s}.rec-bar:nth-child(5){animation-delay:.4s}@keyframes barWave{0%,to{height:3px}50%{height:18px}}.page-inner{background:var(--page-bg);background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 30px,var(--page-line) 30px,var(--page-line) 31px);flex-direction:column;width:100%;height:100%;transition:transform .5s;animation:.8s cubic-bezier(.16,1,.3,1) pageReveal;display:flex;position:relative;overflow:hidden}.page-inner.is-holding{background:#fcfcfc;transform:scale(.98)}@keyframes pageReveal{0%{opacity:.4;transform:scale(.99)translateY(4px)}to{opacity:1;transform:scale(1)translateY(0)}}.page-gutter{pointer-events:none;z-index:1;background:#d28c8c1f;width:1px;position:absolute;top:0;bottom:0;left:36px}.page-acts{z-index:6;gap:4px;display:flex;position:absolute;top:6px;right:6px}.pa-btn{cursor:pointer;color:var(--brown);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);-webkit-tap-highlight-color:transparent;background:#fffaf2eb;border:1px solid #b48c644d;border-radius:8px;min-height:30px;padding:5px 10px;font-size:.65rem;transition:background .15s}.pa-btn:active{background:#fff0dc}.pa-btn.del{color:#a02828;border-color:#b464644d}.page-body{z-index:2;flex-direction:column;flex:1;gap:5px;min-height:0;padding:10px 10px 6px 42px;display:flex;position:relative;overflow:hidden}.author-badge{letter-spacing:.08em;border-radius:9px;flex-shrink:0;align-items:center;gap:3px;width:fit-content;padding:2px 8px;font-size:.6rem;display:inline-flex}.badge-enuu{color:#4050b0;background:#f0f0ff;border:1px solid #c0c0f0}.badge-stupid,.badge-her{color:#b04040;background:#fff0f0;border:1px solid #f0c0c0}.badge-him,.badge-you{color:#4050b0;background:#f0f0ff;border:1px solid #c0c0f0}.page-date{color:var(--rose);flex-shrink:0;font-family:Cormorant Garamond,serif;font-size:.7rem;font-style:italic}.page-text{color:var(--ink);font-family:EB Garamond,serif;font-size:calc(var(--fs) * .9);line-height:var(--lh);white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;flex:1;overflow:hidden}.page-img{object-fit:cover;border-radius:5px;flex-shrink:0;width:100%;max-height:52%;box-shadow:0 2px 12px #0000001f}.page-caption{color:#8a6040;text-align:center;flex-shrink:0;font-size:.7rem;font-style:italic;line-height:1.45}.page-cover{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:relative;overflow:hidden}.cover-glow{pointer-events:none;background:radial-gradient(at 50% 30%,#ffffff2e,#0000 62%);position:absolute;inset:0}.cover-orn{letter-spacing:.4em;z-index:1;opacity:.7;margin-bottom:14px;font-family:Cinzel,serif;font-size:.7rem;position:relative}.cover-title{text-align:center;z-index:1;text-shadow:0 2px 12px #0000004d;font-family:Cormorant Garamond,serif;font-size:clamp(1rem,5vw,2rem);font-style:italic;font-weight:600;line-height:1.25;position:relative}.cover-sub{opacity:.6;text-align:center;z-index:1;letter-spacing:.1em;margin-top:12px;font-family:EB Garamond,serif;font-size:.68rem;font-style:italic;position:relative}.page-blank{background:#f7f0e4;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.blank-orn{opacity:.08;letter-spacing:.3em;color:var(--brown);font-family:Cinzel,serif;font-size:1.2rem}.rxn-strip{z-index:3;flex-wrap:wrap;flex-shrink:0;gap:4px;padding:4px 8px 6px 40px;display:flex;position:relative}.rxn-chip{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fffc;border:1px solid #00000012;border-radius:12px;align-items:center;gap:3px;min-height:28px;padding:5px 9px;font-size:.72rem;transition:transform .15s;display:flex}.rxn-chip:active{transform:scale(1.15)}.rxn-chip.mine{background:#ffc8c880;border-color:#c864644d}.rxn-count{color:#7a5040;font-size:.6rem}.rxn-detail-pop{color:#fff;white-space:nowrap;pointer-events:none;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#28140ae6;border-radius:8px;padding:5px 10px;font-size:.7rem;animation:.2s cubic-bezier(.17,.67,.83,.67) popIn;position:absolute;bottom:calc(100% + 8px);left:0;box-shadow:0 4px 12px #0000004d}@keyframes popIn{0%{opacity:0;transform:scale(.82)}to{opacity:1;transform:scale(1)}}.rxn-add{cursor:pointer;color:#9a7a5a;-webkit-tap-highlight-color:transparent;background:0 0;border:1px dashed #8c643c4d;border-radius:12px;justify-content:center;align-items:center;min-height:28px;padding:5px 9px;font-size:.72rem;transition:all .15s;display:flex}.rxn-add:active{border-color:var(--rose);color:var(--rose);background:#b850500d}.page-num-r{color:#c0a080;z-index:3;font-family:Cormorant Garamond,serif;font-size:.6rem;font-style:italic;position:absolute;bottom:5px;right:11px}.page-num-l{color:#c0a080;z-index:3;font-family:Cormorant Garamond,serif;font-size:.6rem;font-style:italic;position:absolute;bottom:5px;left:11px}.audio-wrap{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:12px;display:flex}.audio-icon-big{font-size:2.2rem;animation:3s ease-in-out infinite floatY}.audio-play{cursor:pointer;background:linear-gradient(135deg,var(--rose),#7a2020);color:#fff;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:1.1rem;transition:transform .15s;display:flex;box-shadow:0 4px 18px #b0505066}.audio-play:active{transform:scale(.93)}.audio-label{color:#9a7050;letter-spacing:.08em;font-size:.62rem;font-style:italic}.lp-rxn{z-index:600;pointer-events:auto;background:#fff;border:1px solid #0000000f;border-radius:22px;flex-wrap:wrap;gap:6px;max-width:240px;padding:10px 14px;animation:.2s cubic-bezier(.34,1.56,.64,1) popIn;display:flex;position:fixed;box-shadow:0 12px 48px #0000004d}.lp-rxn span{cursor:pointer;padding:4px;font-size:1.4rem;transition:transform .12s}.lp-rxn span:active{transform:scale(1.3)}@keyframes floatY{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.book-screen{background:#a08060;width:100%;height:100%;position:relative;overflow:hidden}.book-screen:before{content:"";pointer-events:none;background:radial-gradient(#c8a878,#8a6840);position:absolute;inset:0}.book-bar{z-index:200;transition:opacity .35s,transform .35s cubic-bezier(.4,0,.2,1);position:fixed;left:0;right:0}.book-bar-top{background:linear-gradient(#080402ed 0%,#080402a6 65%,#0000 100%);align-items:center;gap:10px;height:70px;padding:0 14px;display:flex;top:0}.book-bar-bot{background:linear-gradient(#0000 0%,#080402a6 35%,#080402ed 100%);justify-content:center;align-items:center;gap:16px;height:76px;padding:0 18px;display:flex;bottom:0}.book-bar.bar-hidden{opacity:0;pointer-events:none}.book-bar.bar-visible{opacity:1;pointer-events:auto}.bk-back{cursor:pointer;color:#fdf8f0d9;white-space:nowrap;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:20px;align-items:center;gap:6px;padding:8px 12px;font-family:EB Garamond,serif;font-size:.88rem;font-style:italic;transition:background .2s;display:flex}.bk-back:active{background:#ffffff1a}.bk-title{color:#fff;text-align:center;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.14em;flex:1;font-family:Cinzel,serif;font-size:.82rem;overflow:hidden}.bk-acts{flex-shrink:0;gap:7px;display:flex}.ic-btn{cursor:pointer;color:var(--cream);-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;background:#ffffff1f;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:1rem;transition:all .2s;display:flex}.ic-btn:hover{background:#ffffff3d;transform:scale(1.05)}.ic-btn:active{transform:scale(.9)}.nav-arr{cursor:pointer;color:var(--cream);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);-webkit-tap-highlight-color:transparent;background:#0000004d;border:1px solid #ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.1rem;transition:all .25s;display:flex}.nav-arr:hover:not(:disabled){background:#00000080;transform:scale(1.1)}.nav-arr:active:not(:disabled){transform:scale(.9)}.nav-arr:disabled{opacity:.1;cursor:default;transform:scale(.9)}.page-ind{color:#fdf8f0bf;text-align:center;letter-spacing:.06em;min-width:80px;font-family:Cormorant Garamond,serif;font-size:.88rem;font-style:italic}.book-stage-wrap{justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.book-stage{border-radius:4px;flex-shrink:0;position:relative;box-shadow:0 20px 60px #000000a6,0 4px 12px #0006}.stf__parent{overflow:visible!important}.spf-page{background:var(--page-bg);-webkit-user-select:none;user-select:none;overflow:hidden}.stf__parent>div>.stf__item:first-child,.stf__parent>div>.stf__item:last-child{background:#b89468!important}.mob-reader{z-index:100;flex-direction:column;transition:background .35s;display:flex;position:fixed;inset:0;overflow:hidden}.mob-hud{z-index:10;pointer-events:none;flex-direction:column;justify-content:space-between;transition:opacity .35s,transform .35s;display:flex;position:absolute;inset:0}.mob-hud.hud-off{opacity:0;pointer-events:none}.mob-hud.hud-on{opacity:1;pointer-events:none}.mob-hud.hud-off .mob-top-bar{transform:translateY(-100%)}.mob-hud.hud-off .mob-bot-bar{transform:translateY(100%)}.mob-hud.hud-on .mob-top-bar,.mob-hud.hud-on .mob-bot-bar{transform:translateY(0)}.mob-top-bar{padding:max(14px,env(safe-area-inset-top) + 8px) 16px 24px;pointer-events:auto;background:linear-gradient(#000c 0%,#0000 100%);align-items:center;gap:10px;transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex}.mob-bot-bar{padding:20px 16px max(22px,env(safe-area-inset-bottom) + 12px);pointer-events:auto;background:linear-gradient(#0000 0%,#000c 100%);flex-direction:column;gap:10px;transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex}.toc-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1100;background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.toc-modal{background:var(--page-bg);border:1px solid #ffffff1a;border-radius:24px;flex-direction:column;width:100%;max-width:500px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 12px 40px #0006}.toc-header{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.toc-header-left h3{color:#2a1408;font-family:Cormorant Garamond,serif;font-size:1.4rem}.toc-header-left p{color:#7a5a4a;margin-top:2px;font-size:.75rem}.toc-close{cursor:pointer;color:#7a5a4a;background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.toc-scroll{flex:1;padding:12px 16px;overflow-y:auto}.toc-grid{flex-direction:column;gap:8px;display:flex}.toc-item{cursor:grab;background:#fff6;border:1px solid #0000000a;border-radius:16px;align-items:center;gap:12px;padding:10px;transition:all .2s;display:flex;position:relative}.toc-item.dragging{z-index:10;cursor:grabbing;background:#fff;box-shadow:0 8px 24px #00000026}.toc-item-num{color:#d28c8c;min-width:20px;font-family:Cormorant Garamond,serif;font-size:1rem;font-weight:600}.toc-thumb{background:#0000000d;border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;display:flex;overflow:hidden}.toc-thumb img{object-fit:cover;width:100%;height:100%}.toc-thumb-icon{font-size:1.2rem}.toc-item-info{flex:1;min-width:0}.toc-item-date{color:#9a7a5a;margin-bottom:2px;font-size:.65rem;font-weight:600}.toc-item-preview{color:#4a3a2a;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-style:italic;overflow:hidden}.toc-drag-handle{color:#0003;padding:4px}.toc-footer{border-top:1px solid #0000000f;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.toc-hint{color:#9a7a5a;font-size:.7rem;font-style:italic}.mob-progress{background:#ffffff26;border-radius:1px;height:2px;overflow:hidden}.mob-progress-fill{background:var(--gold);border-radius:1px;height:100%;transition:width .4s}.mob-controls{justify-content:space-between;align-items:center;gap:8px;display:flex}.mob-btn{color:#fff;cursor:pointer;letter-spacing:.04em;-webkit-tap-highlight-color:transparent;background:#ffffff1f;border:1px solid #ffffff1a;border-radius:12px;min-height:38px;padding:8px 16px;font-family:EB Garamond,serif;font-size:.82rem;font-style:italic;transition:background .2s}.mob-btn:active{background:#ffffff38}.mob-btn:disabled{opacity:.25;cursor:default}.mob-icon-btn{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;background:#ffffff1f;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:.95rem;transition:background .2s;display:flex}.mob-icon-btn:active{background:#ffffff38}.mob-title{color:#fff;letter-spacing:.12em;text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:Cinzel,serif;font-size:.75rem;overflow:hidden}.mob-page-label{color:#ffffff8c;letter-spacing:.06em;text-align:center;min-width:60px;font-family:Cormorant Garamond,serif;font-size:.8rem;font-style:italic}.mob-page-area{flex:1;justify-content:center;align-items:center;padding:10px 8px;display:flex;position:relative;overflow:hidden}.mob-page-card{will-change:transform,opacity;border-radius:2px 10px 10px 2px;width:100%;max-width:500px;height:100%;position:relative;overflow:hidden;box-shadow:4px 6px 28px #00000061,0 0 0 1px #00000014}.mob-page-card.enter-left{animation:.3s cubic-bezier(.4,0,.2,1) both enterL}.mob-page-card.enter-right{animation:.3s cubic-bezier(.4,0,.2,1) both enterR}@keyframes enterL{0%{opacity:0;transform:translate(56px)}to{opacity:1;transform:none}}@keyframes enterR{0%{opacity:0;transform:translate(-56px)}to{opacity:1;transform:none}}.mob-page-card .page-text{font-size:calc(var(--fs) * 1.05)}.mob-page-card .cover-title{font-size:clamp(1.5rem,7vw,2.6rem)}.mob-page-card .page-body{padding:14px 12px 8px 46px}.mob-settings{z-index:20;padding:8px 20px max(32px,env(safe-area-inset-bottom) + 16px);background:#100a04f7;border-radius:24px 24px 0 0;animation:.3s cubic-bezier(.34,1.56,.64,1) modalUp;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -8px 40px #0009}.mob-settings:before{content:"";background:#ffffff26;border-radius:2px;width:40px;height:4px;margin:0 auto 16px;display:block}.z-15{z-index:15}.s-row{align-items:center;gap:12px;margin-bottom:16px;display:flex}.s-lbl{color:#ffffff80;letter-spacing:.06em;flex-shrink:0;min-width:60px;font-family:EB Garamond,serif;font-size:.82rem;font-style:italic}.theme-btns{gap:8px;display:flex}.th-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:2px solid #0000;border-radius:10px;padding:7px 14px;font-family:EB Garamond,serif;font-size:.78rem;font-style:italic;transition:all .2s}.th-btn.on{border-color:var(--gold)}.th-paper{color:#4a3f35;background:#fdfcf0}.th-dark{color:#d0c8b8;background:#1a1410}.th-sepia{color:#5d4037;background:#f4e0bc}.fs-row{align-items:center;gap:10px;display:flex}.fs-btn{color:#fffc;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:1.5px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:1rem;transition:all .2s;display:flex}.fs-btn:active{background:#ffffff1a}.fs-val{color:var(--gold);text-align:center;min-width:38px;font-family:Cinzel,serif;font-size:.9rem}.lh-slider{accent-color:var(--gold);cursor:pointer;flex:1}.ann-overlay{z-index:700;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000bf;justify-content:center;align-items:center;padding:24px;animation:.2s bkIn;display:flex;position:fixed;inset:0}.ann-modal{background:var(--cream);border-radius:20px;width:100%;max-width:340px;padding:26px;animation:.3s cubic-bezier(.34,1.56,.64,1) popIn;box-shadow:0 24px 80px #00000080}.ann-modal h3{color:var(--brown);letter-spacing:.1em;margin-bottom:18px;font-family:Cinzel,serif;font-size:1rem}.writer-overlay{z-index:800;flex-direction:column;transition:background .3s;display:flex;position:fixed;inset:0;overflow:hidden}.writer-top{padding:max(14px,env(safe-area-inset-top) + 8px) 16px 14px;z-index:10;background:linear-gradient(#000000b3 0%,#0000 100%);align-items:center;gap:10px;transition:opacity .3s,transform .3s;display:flex;position:absolute;top:0;left:0;right:0}.writer-top.chrome-off{opacity:0;pointer-events:none;transform:translateY(-100%)}.writer-title-input{letter-spacing:.12em;color:var(--gold);text-align:center;-webkit-appearance:none;background:0 0;border:none;outline:none;flex:1;font-family:Cinzel,serif;font-size:.82rem}.writer-title-input::placeholder{color:#c9973a66}.writer-done{color:var(--gold);cursor:pointer;letter-spacing:.08em;-webkit-tap-highlight-color:transparent;white-space:nowrap;background:#c9973a26;border:1px solid #c9973a59;border-radius:20px;padding:7px 18px;font-family:Cinzel,serif;font-size:.75rem;transition:background .2s}.shelf-greeting{color:#7a5030;justify-content:center;align-items:center;gap:12px;margin-bottom:8px;font-family:Cormorant Garamond,serif;font-size:1.1rem;font-style:italic;display:flex}.offline-pill{color:#7a5030;background:#7a50301a;border-radius:10px;align-items:center;gap:4px;padding:3px 8px;font-family:sans-serif;font-size:.7rem;font-style:normal;display:flex}@keyframes pulseStatus{0%,to{opacity:1}50%{opacity:.6}}.bk-top-left{align-items:center;gap:12px;display:flex}.music-modal{max-width:320px;padding:28px 22px}.music-list{flex-direction:column;gap:8px;margin:15px 0;display:flex}.music-item{cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:#fff9;border:1.5px solid #7a50301a;border-radius:12px;justify-content:space-between;align-items:center;padding:12px 14px;transition:all .2s;display:flex}.music-item-info{align-items:center;gap:12px;display:flex}.music-item-icon{color:var(--rose);opacity:.7;font-size:.9rem}.music-item-name{color:var(--ink);font-family:EB Garamond,serif;font-size:1rem;font-weight:500}.music-item-tag{color:#a08060;text-transform:uppercase;letter-spacing:.05em;background:#a080601a;border-radius:4px;padding:2px 6px;font-size:.6rem}.music-item:hover{border-color:var(--rose);background:#fff;transform:translate(4px)}.music-item.active{background:var(--rose);border-color:var(--rose)}.music-item.active .music-item-name,.music-item.active .music-item-icon{color:#fff}.music-item.active .music-item-tag{color:#ffffffb3;background:#fff3}.writer-back{color:#ffffffb3;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;transition:background .2s;display:flex}.writer-back:active{background:#ffffff1a}.writer-area{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;display:flex;position:relative;overflow-y:auto}.writer-textarea{resize:none;width:100%;min-height:100%;font-family:EB Garamond,serif;line-height:var(--lh);color:inherit;font-size:calc(var(--fs) * 1.1);word-break:break-word;overflow-wrap:break-word;-webkit-appearance:none;caret-color:var(--gold);box-sizing:border-box;background:0 0;border:none;outline:none;height:auto;padding:80px 28px 160px;transition:color .3s;overflow:visible}.writer-textarea::placeholder{opacity:.3;font-style:italic}.writer-bot{padding:0 20px max(16px,env(safe-area-inset-bottom) + 8px);background:linear-gradient(#0000 0%,#00000080 100%);justify-content:space-between;align-items:center;transition:opacity .3s,transform .3s;display:flex;position:absolute;bottom:0;left:0;right:0}.writer-bot.chrome-off{opacity:0;transform:translateY(100%)}.writer-wc{letter-spacing:.08em;opacity:.5;font-family:Cormorant Garamond,serif;font-size:.72rem;font-style:italic}.writer-save-ind{letter-spacing:.06em;opacity:.4;font-size:.65rem;font-style:italic;transition:opacity .3s}.writer-save-ind.saving{opacity:.9;color:var(--gold)}.writer-paper{color:#2a1408;background:#f5ead8}.writer-sepia{color:#3a2c10;background:#f0e6cc}.writer-dark{color:#d0c8b8;background:#141010}.writer-tap-hint{color:#ffffff26;letter-spacing:.12em;pointer-events:none;white-space:nowrap;font-size:.65rem;font-style:italic;transition:opacity .5s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.writer-attach-bar{padding:10px 16px max(14px,env(safe-area-inset-bottom) + 8px);background:inherit;z-index:5;border-top:1px solid #0000001a;flex-shrink:0;gap:10px;display:flex;position:sticky;bottom:0}.writer-attach-bar.chrome-off{opacity:1;transform:none}.attach-btn{cursor:pointer;color:inherit;opacity:.7;-webkit-tap-highlight-color:transparent;background:#0000000f;border:none;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:10px 16px;font-family:EB Garamond,serif;font-size:.65rem;font-style:italic;transition:all .2s;display:flex}.attach-btn:active{opacity:1;background:#0000001f}.attach-btn svg,.attach-btn span:first-child{font-size:1.2rem}.attach-thumb{cursor:pointer;border-radius:10px;flex-shrink:0;width:56px;height:56px;position:relative;overflow:hidden}.attach-thumb img{object-fit:cover;width:100%;height:100%}.attach-thumb .del-x{color:#fff;background:#0009;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.6rem;display:flex;position:absolute;top:2px;right:2px}.attach-voice{cursor:pointer;background:#b8505026;border:1px solid #b850504d;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:3px;width:56px;height:56px;display:flex}.attach-voice span{font-size:1.1rem}.attach-voice small{opacity:.6;font-size:.5rem;font-style:italic}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
