@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,700&family=IBM+Plex+Sans:wght@400;500;600&family=Patrick+Hand&display=swap";:root{font-family:IBM Plex Sans,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2b221a;background-color:#f4ede2;--display: "Fraunces", serif;--paper: #f4ede2;--paper-warm: #f8f1e5;--ink: #2b221a;--muted: #6b5c50;--accent: #d1773c;--accent-strong: #b5582f;--wood: #6a4325;--wood-deep: #4b2d18;--glow: #f2b95b;--card: rgba(255, 255, 255, .72);--handwriting: "Patrick Hand", "Bradley Hand", "Segoe Print", "Comic Sans MS", cursive}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(1200px 800px at 5% -20%,#fff8ec 0%,transparent 70%),radial-gradient(900px 600px at 95% 0%,#f6e4cf 0%,transparent 65%),linear-gradient(160deg,#f9f1e6,#f2e5d5 48%,#efe1cd);color:var(--ink)}#root{min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.page{--page-gutter: clamp(16px, 4vw, 52px);min-height:100vh;padding:0 var(--page-gutter);display:flex;flex-direction:column;gap:40px}.landing-shell{--page-gutter: clamp(16px, 4vw, 52px);min-height:100vh;display:flex;flex-direction:column}.home-landing{color:#f5ead8;background:radial-gradient(900px 540px at 12% -8%,#f7a9463d,#f7a94600 72%),radial-gradient(900px 620px at 100% 0%,#6099eb38,#6099eb00 68%),linear-gradient(165deg,#131923,#0e1521 52%,#131b2c)}.landing{flex:1;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:48px;align-items:center;padding:56px clamp(18px,6vw,72px) 64px;position:relative;overflow:hidden}.landing:before{content:"";position:absolute;width:520px;height:520px;background:radial-gradient(circle,rgba(242,185,91,.35),transparent 70%);top:-180px;left:-140px;filter:blur(10px);pointer-events:none}.landing:after{content:"";position:absolute;width:420px;height:420px;background:radial-gradient(circle,rgba(209,119,60,.28),transparent 70%);bottom:-180px;right:-120px;filter:blur(12px);pointer-events:none}.landing-hero{display:grid;gap:20px;max-width:680px;position:relative;z-index:1;animation:riseIn .8s ease both}.landing-logo{width:min(420px,76vw);height:auto;width:min(320px,62vw)}.landing-logo-frame{width:fit-content;padding:0;border-radius:24px;border:1px solid rgba(255,255,255,.26);background:#1118279e;box-shadow:0 14px 26px #00000052;margin-bottom:4px;overflow:hidden}.landing-kicker{text-transform:uppercase;letter-spacing:.32em;font-size:.7rem;color:var(--muted);font-weight:600}.landing-title{margin:0;font-family:var(--display);font-size:clamp(2.4rem,5vw,3.6rem)}.landing-copy{margin:0;color:var(--muted);max-width:32rem;font-size:1.05rem}.landing-highlights{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px}.landing-highlight{background:#ffffffb3;border-radius:18px;padding:16px;border:1px solid rgba(86,60,36,.12);box-shadow:0 16px 32px #3424141f}.landing-highlight h3{margin:0 0 6px;font-size:1rem}.landing-highlight p{margin:0;color:var(--muted);font-size:.9rem}.landing-preview{background:#ffffffd9;border-radius:22px;padding:18px 20px;border:1px solid rgba(86,60,36,.15);box-shadow:0 22px 46px #34241433;display:grid;gap:12px;animation:riseIn .8s ease .15s both}.landing-preview-head{display:flex;align-items:center;justify-content:space-between;text-transform:uppercase;letter-spacing:.2em;font-size:.65rem;font-weight:700;color:var(--muted)}.landing-preview-meta{background:#f2b95b47;color:var(--ink);padding:.25rem .6rem;border-radius:999px}.landing-preview-shelf{padding:0;border-radius:16px;background:#1a1410;overflow:hidden}.landing-preview-image{display:block;width:100%;height:auto}.home-landing .landing:before{background:radial-gradient(circle,rgba(247,170,73,.42),transparent 70%)}.home-landing .landing:after{background:radial-gradient(circle,rgba(95,153,237,.36),transparent 70%)}.home-landing .landing-logo{filter:drop-shadow(0 18px 36px rgba(0,0,0,.42))}.home-landing .landing-logo-frame{border-color:#7ea1d66b;background:#0c121ebd;box-shadow:0 16px 30px #0000005c}.home-landing .landing-kicker{color:#dac4aceb}.home-landing .landing-title{color:#fff3df;text-shadow:0 6px 20px rgba(0,0,0,.45)}.home-landing .landing-copy{color:#eadecde0}.home-landing .landing-highlight{background:#0c111db8;border:1px solid rgba(126,161,214,.32);box-shadow:0 22px 36px #0000006b}.home-landing .landing-highlight h3{color:#f8ebd7}.home-landing .landing-highlight p{color:#e1d6c6d6}.home-landing .landing-preview{background:#0b111ecc;border:1px solid rgba(126,161,214,.34);box-shadow:0 28px 46px #00000075}.home-landing .landing-preview-head{color:#dac4ace6}.home-landing .landing-preview-meta{background:#5f99ed3d;border:1px solid rgba(126,161,214,.34);color:#d9ecff}.home-landing .landing-preview-shelf{background:#0e1521}.sign-in-panel{display:grid;gap:22px;position:relative;z-index:1;justify-items:end;align-items:start}.sign-in-card{width:min(420px,100%);background:#ffffffe6;border-radius:26px;padding:26px;border:1px solid rgba(86,60,36,.15);box-shadow:0 26px 50px #34241440;display:grid;gap:18px;animation:riseIn .8s ease .25s both}.sign-up-card{background:#ffffffd1}.home-landing .sign-in-card{background:#090f1adb;border:1px solid rgba(126,161,214,.32);box-shadow:0 30px 52px #0000007a}.home-landing .sign-up-card{background:#0a101cc2}.sign-in-head h2{margin:0 0 6px;font-family:var(--display);font-size:1.8rem}.sign-in-head p{margin:0;color:var(--muted)}.home-landing .sign-in-head h2{color:#fff3df}.home-landing .sign-in-head p{color:#eadecdd1}.sign-in-form{display:grid;gap:12px}.auth-error{font-size:.85rem;color:#7a2f1d;background:#d1773c1f;border-radius:12px;padding:.6rem .75rem}.sign-in-label{text-transform:uppercase;letter-spacing:.18em;font-size:.65rem;font-weight:700;color:var(--muted)}.home-landing .sign-in-label{color:#d4c1aad1}.sign-in-form input{border-radius:14px;border:1px solid rgba(86,60,36,.2);padding:.8rem 1rem;font-size:.95rem;background:#ffffffe6;color:var(--ink);transition:border .2s ease,box-shadow .2s ease}.home-landing .sign-in-form input{border-color:#7ea1d657;background:#131c2ee6;color:#f8efdf}.home-landing .sign-in-form input::placeholder{color:#d0c1aea3}.sign-in-form input:focus{outline:none;border-color:#d1773c99;box-shadow:0 0 0 3px #f2b95b4d}.home-landing .sign-in-form input:focus{border-color:#8cb7f2b8;box-shadow:0 0 0 3px #5f99ed4d}.primary{background:var(--accent);color:#1c1814;box-shadow:0 16px 30px #d1773c4d}.primary:hover{transform:translateY(-2px);background:var(--accent-strong)}.sign-in-submit{width:100%;margin-top:6px}.session-loading{min-height:100vh;display:grid;place-items:center;font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.2em}.reserved-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2.5rem 1.5rem 0;text-align:center}.reserved-card{width:min(520px,100%);background:#ffffffeb;border-radius:28px;padding:32px;border:1px solid rgba(86,60,36,.15);box-shadow:0 22px 40px #34241433;display:grid;gap:12px}.reserved-kicker{text-transform:uppercase;letter-spacing:.22em;font-size:.65rem;color:var(--muted);font-weight:700}.reserved-card h1{margin:0;font-family:var(--display);font-size:2rem;color:var(--ink)}.reserved-card p{margin:0;color:var(--muted)}.reserved-meta{font-size:.75rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}.site-footer{margin:0;padding:10px 16px 12px;border-top:1px solid rgba(86,60,36,.14);background:#ffffff80;white-space:normal;font-size:.68rem;line-height:1.45;color:#563c24d1}.site-footer-separator{white-space:pre}.site-footer a{color:var(--ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.site-footer-landing{padding-left:clamp(18px,6vw,72px);padding-right:clamp(18px,6vw,72px)}.page .site-footer{margin:auto calc(-1 * var(--page-gutter)) 0;padding-left:var(--page-gutter);padding-right:var(--page-gutter)}.reserved-page .site-footer{width:auto;margin-top:auto;margin-left:-1.5rem;margin-right:-1.5rem;padding-left:1.5rem;padding-right:1.5rem;justify-self:stretch}.sign-in-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);font-size:.9rem}.home-landing .sign-in-foot{color:#dcccb9cc}.text-link{background:none;border:none;padding:0;font:inherit;color:inherit;text-transform:uppercase;letter-spacing:.18em;font-size:.65rem;font-weight:700;cursor:pointer}.text-link:hover{color:var(--ink)}.home-landing .text-link:hover{color:#f7ebd5}.text-link:disabled{cursor:default;opacity:.6}.auth-note{font-size:.82rem;color:var(--muted);background:#ffffffb3;border-radius:12px;padding:.55rem .75rem;border:1px solid rgba(86,60,36,.12)}.home-landing .auth-note{color:#ddcbb6d6;background:#0f1626b8;border:1px solid rgba(126,161,214,.28)}.sign-in-note{font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:.18em;text-align:right}.home-landing .auth-error{color:#ffc8bc;background:#ab46383d}.home-landing .sign-in-note{color:#d0c0adcc}.masthead{display:flex;align-items:center;justify-content:space-between;gap:24px;margin:0 calc(-1 * var(--page-gutter));padding:16px var(--page-gutter);background:#ffffffd9;border-top:0;border-bottom:1px solid rgba(86,60,36,.12);box-shadow:0 10px 28px #3424141f}.masthead-left{display:flex;align-items:center;gap:22px;min-width:0}.masthead-brand{display:flex;align-items:center;gap:12px}.masthead-brand-link{color:inherit;text-decoration:none}.masthead-brand-link:hover{color:inherit}.masthead-logo{width:clamp(42px,4vw,52px);height:clamp(42px,4vw,52px);object-fit:contain}.masthead-wordmark{font-family:var(--display);font-size:1.35rem;line-height:1;white-space:nowrap}.masthead-nav{display:flex;gap:18px;font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;white-space:nowrap}.masthead-link{color:var(--muted);transition:color .2s ease}.masthead-link:hover{color:var(--ink)}.masthead-actions{display:flex;gap:12px;align-items:center}.masthead-share,.masthead-view-library{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:.8rem 1.5rem;border-radius:999px;text-decoration:none}.masthead-menu{position:relative}.masthead-burger{min-width:48px;width:48px;height:48px;padding:0;font-size:1.1rem}.masthead-dropdown{position:absolute;right:0;top:calc(100% + 8px);z-index:8;min-width:152px;background:#fffffff5;border:1px solid rgba(86,60,36,.16);border-radius:14px;padding:8px;box-shadow:0 20px 36px #28180c33}.masthead-account{font-size:.72rem;text-transform:uppercase;letter-spacing:.11em;color:var(--muted);padding:.3rem .45rem .55rem}.masthead-dropdown-item{width:100%;text-align:left;border-radius:10px}button{border:none;border-radius:999px;padding:.8rem 1.5rem;font-size:.95rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease}button:focus-visible{outline:3px solid var(--glow);outline-offset:3px}.ghost{background:#fffc;color:var(--ink);border:1px solid rgba(100,70,40,.18)}.ghost:hover{transform:translateY(-2px)}.current-reading{display:flex;justify-content:center}.current-reading-card{width:min(980px,100%);display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.9fr);gap:24px;align-items:center;background:#ffffffd9;border-radius:28px;padding:28px;border:1px solid rgba(86,60,36,.12);box-shadow:0 24px 50px #3424142e;position:relative;overflow:hidden}.current-reading-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 0% 0%,rgba(242,185,91,.18),transparent 45%);pointer-events:none}.current-reading-content{display:grid;gap:12px;position:relative;z-index:1}.current-reading-label{text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:var(--muted);font-weight:600}.current-reading-title{margin:0;font-family:var(--display);font-size:clamp(1.8rem,3vw,2.6rem)}.current-reading-author{margin:0;font-weight:600;color:var(--muted)}.current-reading-note{margin:0;color:var(--muted);max-width:28rem}.current-reading-book{position:relative;min-height:260px;padding:32px 28px;color:#1c1814;background-image:var(--book-cover, none),linear-gradient(140deg,var(--book-color),rgba(255,255,255,.75));background-size:cover,auto;background-position:center,center;background-blend-mode:soft-light;border:4px solid #2b221a;box-shadow:0 32px 60px #1e120873;clip-path:polygon(0% 6%,6% 0%,14% 6%,22% 0%,30% 6%,38% 0%,46% 6%,54% 0%,62% 6%,70% 0%,78% 6%,86% 0%,94% 6%,100% 0%,100% 94%,94% 100%,86% 94%,78% 100%,70% 94%,62% 100%,54% 94%,46% 100%,38% 94%,30% 100%,22% 94%,14% 100%,6% 94%,0% 100%);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;z-index:1}.current-reading-book.has-cover:before{content:"";position:absolute;inset:0;background:linear-gradient(150deg,#140e088c,#140e0814);z-index:0}.current-reading-book:hover{transform:translateY(-4px);box-shadow:0 40px 70px #1e120880}.current-reading-book:focus-visible{outline:3px solid var(--glow);outline-offset:6px}.current-reading-sheen{display:none}.current-reading-meta{text-transform:uppercase;letter-spacing:.2em;font-size:.65rem;font-weight:700;position:relative;z-index:1}.current-reading-book-title{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.4rem);margin-top:14px;position:relative;z-index:1}.current-reading-book-author{text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;margin-top:6px;position:relative;z-index:1}.book-search{background:#ffffffbf;border-radius:24px;padding:24px;border:1px solid rgba(86,60,36,.12);box-shadow:0 20px 40px #3424141f;display:grid;gap:18px}.book-search-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.book-search-title{margin:0 0 6px;font-family:var(--display);font-size:1.6rem}.book-search-copy{margin:0;color:var(--muted);max-width:32rem}.book-search-meta{text-transform:uppercase;letter-spacing:.2em;font-size:.65rem;font-weight:700;color:var(--muted)}.book-search-form{display:grid;gap:12px}.book-search-label{text-transform:uppercase;letter-spacing:.18em;font-size:.65rem;font-weight:700;color:var(--muted)}.book-search-inputs{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr) minmax(0,1fr) auto;gap:12px;align-items:end}.book-search-inputs input,.book-search-inputs select{border-radius:14px;border:1px solid rgba(86,60,36,.2);padding:.8rem 1rem;font-size:.95rem;background:#fffffff2;color:var(--ink);transition:border .2s ease,box-shadow .2s ease}.book-search-inputs input:focus,.book-search-inputs select:focus{outline:none;border-color:#d1773c99;box-shadow:0 0 0 3px #f2b95b4d}.book-search-source,.book-search-shelf{display:grid;gap:8px}.book-search-error{font-size:.85rem;color:#7a2f1d;background:#d1773c1f;border-radius:12px;padding:.6rem .75rem}.book-search-empty{color:var(--muted);font-size:.95rem}.book-search-results{display:grid;gap:12px}.search-result{display:grid;grid-template-columns:84px minmax(0,1fr) auto;gap:16px;align-items:center;padding:12px;border-radius:18px;border:1px solid rgba(86,60,36,.15);background:#ffffffd9;box-shadow:0 14px 28px #3424141f}.search-result-cover{width:84px;height:110px;border-radius:12px;overflow:hidden;background:#3022161a;display:grid;place-items:center}.search-result-cover img{width:100%;height:100%;object-fit:cover;display:block}.search-result-fallback{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.search-result-body{display:grid;gap:6px}.search-result-title{font-weight:700;font-size:1rem}.search-result-author{color:var(--muted);font-size:.9rem}.search-result-meta{color:var(--muted);font-size:.8rem;letter-spacing:.02em}.shelves{display:grid;gap:28px}.everyone-page{gap:28px}.everyone-intro{width:min(1040px,100%);margin:0 auto;display:grid;gap:8px}.everyone-kicker{text-transform:uppercase;letter-spacing:.2em;font-size:.68rem;font-weight:700;color:var(--muted)}.everyone-title{margin:0;font-family:var(--display);font-size:clamp(1.8rem,3vw,2.6rem)}.everyone-copy{margin:0;color:var(--muted)}.everyone-users{width:min(1040px,100%);margin:0 auto;display:grid;gap:24px}.everyone-user-shelves{display:grid;gap:12px}.everyone-user-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.everyone-user-title{margin:0;font-size:1rem;text-transform:uppercase;letter-spacing:.16em}.everyone-user-link{color:inherit;text-decoration:none}.everyone-user-link:hover{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}.everyone-user-tag{border-radius:999px;border:1px solid rgba(86,60,36,.18);background:#ffffffb8;color:var(--muted);font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;padding:.24rem .7rem}.everyone-user-shelves .shelves{gap:0}.everyone-status{width:min(1040px,100%);margin:0 auto;border-radius:20px;border:1px solid rgba(86,60,36,.16);background:#ffffffb3;padding:24px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem}.shelves-actions{display:flex;justify-content:flex-end}.shelf{background:#fff9;border-radius:24px;padding:24px;border:1px solid rgba(86,60,36,.12);box-shadow:0 18px 40px #3424141f;min-width:0}.shelf-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.shelf-title{font-family:var(--display);font-size:1.6rem;margin:0}.shelf-title.untitled{color:var(--muted);font-style:italic}.shelf-title-wrap{min-width:0}.shelf-title-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.library-privacy-notice{display:inline-block;color:#bf1010;border:2px solid #ff2a2a;border-radius:999px;background:#ffebebe6;font-weight:700;padding:.2rem .7rem}.shelf-edit{position:relative;display:inline-flex}.shelf-edit-trigger{padding:.3rem .7rem;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;opacity:0;transform:translateY(2px);pointer-events:none;transition:opacity .18s ease,transform .18s ease}.shelf-title-wrap:hover .shelf-edit-trigger,.shelf-title-wrap:focus-within .shelf-edit-trigger{opacity:1;transform:translateY(0);pointer-events:auto}.shelf-meta{background:#ffffffb3;border-radius:999px;padding:.35rem .9rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border:1px solid rgba(86,60,36,.12)}.shelf-meta.library-privacy-notice{background:#ffebebe6;text-transform:none;letter-spacing:normal;font-size:.92rem}.shelf-board{position:relative;border-radius:20px;background:linear-gradient(180deg,#4a2d19,#2a170c 68%,#1b0f08);padding:18px 18px 86px;overflow:hidden;isolation:isolate;box-shadow:inset 0 16px 28px #0a050280,inset 0 -12px 20px #0603018c;min-width:0;width:100%}.shelf-board:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,rgba(255,255,255,.06) 0,rgba(255,255,255,.06) 2px,transparent 2px,transparent 6px);mix-blend-mode:soft-light;opacity:.5;z-index:0;pointer-events:none}.shelf-books{position:relative;z-index:1;display:flex;align-items:flex-end;gap:12px;height:var(--shelf-height, 170px);padding:8px 6px 18px;min-width:0;width:100%}.shelf-books-stack{display:grid;gap:0;min-width:0;width:100%}.shelf-books-stack.split{gap:18px}.book-drop-slot{flex:0 0 var(--drop-slot-width, 32px);width:var(--drop-slot-width, 32px);height:calc(var(--shelf-height, 170px) - 18px);border-radius:8px;border:2px dashed rgba(242,185,91,.9);background:#f2b95b2e;box-shadow:inset 0 0 0 1px #120a0673,0 0 14px #f2b95b59;pointer-events:none;align-self:flex-end}.shelf-books:after{content:"";position:absolute;left:0;right:0;bottom:0;height:14px;border-radius:8px;background:linear-gradient(180deg,#8a5a35,#5f3a21);box-shadow:inset 0 1px #ffffff2e,0 6px 12px #120a0559;pointer-events:none;z-index:0}.shelf-add-book{position:absolute;right:18px;bottom:16px;width:44px;height:44px;border-radius:999px;border:1px solid rgba(255,255,255,.28);background:#ffffffe6;color:#2b221a;font-size:1.5rem;line-height:1;padding:0;display:grid;place-items:center;box-shadow:0 12px 24px #1a10094d;z-index:2}.shelf-add-book:hover{background:#fff}.shelf.dusty .shelf-board:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 20%,rgba(255,255,255,.25),transparent 40%),radial-gradient(circle at 80% 30%,rgba(255,255,255,.15),transparent 45%);opacity:.6;z-index:0;pointer-events:none}.shelf.library{border-color:#d1773c4d}.book{position:relative;z-index:1;flex:0 0 auto;--book-shadow-side: black;--book-shadow-down: black;width:var(--book-width);height:var(--book-height);border-radius:4px;border:1px solid rgba(12,8,5,.95);background:linear-gradient(130deg,var(--book-color),rgba(255,255,255,.4));box-shadow:-8px 0 12px -4px var(--book-shadow-side),8px 0 12px -4px var(--book-shadow-side),0 6px 10px -7px var(--book-shadow-down);color:#1c1814;overflow:visible;transform:translate(var(--book-shift, 0px));transform-origin:center bottom;transition:width .3s ease,transform .3s ease,box-shadow .25s ease;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;outline:none;will-change:width,transform}.book.spine.has-cover{background:none}.book.spine.has-cover .book-inner{background:none;transform-style:flat}.book.spine.has-cover .book-cover{opacity:1;filter:none;mix-blend-mode:normal}.book.revealed{width:var(--book-face-width);z-index:4;transform:translate(var(--book-shift, 0px)) translateY(-8px)}.book-inner{position:relative;width:100%;height:100%;border-radius:inherit;overflow:hidden;transform-origin:center center;transform-style:preserve-3d}.book.revealed .book-inner{animation:book-reveal-spin .32s cubic-bezier(.2,.8,.2,1) both}.book-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.85}.book.has-cover .book-body{color:#fdf6ee;text-shadow:0 1px 2px rgba(20,12,6,.7)}.book.spine.has-cover .book-title,.book.spine.has-cover .book-author{text-shadow:1.5px 0 0 rgba(20,12,6,.9),-1.5px 0 0 rgba(20,12,6,.9),0 1.5px 0 rgba(20,12,6,.9),0 -1.5px 0 rgba(20,12,6,.9)}.book.revealed .book-body{opacity:0}.book:hover{box-shadow:-10px 0 14px -4px var(--book-shadow-side),10px 0 14px -4px var(--book-shadow-side),0 8px 12px -7px var(--book-shadow-down)}.book[draggable=true]{cursor:grab}.book.dragging{opacity:.55;cursor:grabbing}.book:focus-visible{box-shadow:0 0 0 3px #f2b95bcc,-10px 0 14px -4px var(--book-shadow-side),10px 0 14px -4px var(--book-shadow-side),0 8px 12px -7px var(--book-shadow-down)}.book.selected{box-shadow:0 0 0 2px #fffc,0 0 0 6px #d1773c73,-10px 0 14px -4px var(--book-shadow-side),10px 0 14px -4px var(--book-shadow-side),0 8px 12px -7px var(--book-shadow-down)}.book:active{cursor:pointer}.book-body{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;gap:6px;height:100%;padding:12px}.book-media-icon{display:inline-flex;width:14px;height:14px;color:#ffffff3d;opacity:.52}.book-media-icon svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}.book-media-icon-overlay{position:absolute;left:50%;top:-18px;z-index:5;transform:translate(-50%);pointer-events:none}.book-note-postit{position:absolute;left:50%;bottom:calc(100% + 16px);width:clamp(72px,calc(var(--book-face-width, 160px) * .42),98px);min-height:58px;max-height:58px;padding:8px 8px 7px;border-radius:3px;border:1px solid rgba(80,64,20,.38);background:linear-gradient(150deg,var(--book-note-start, #fff6a8) 0%,var(--book-note-end, #f0df74) 100%);box-shadow:0 7px 18px #06040159;transform:translate(-50%) rotate(var(--book-note-tilt, -3deg));transform-origin:center bottom;overflow:visible;pointer-events:none;z-index:6;transition:transform .2s ease,width .2s ease,max-height .2s ease}.book-note-postit:before{content:"";position:absolute;top:-7px;left:50%;width:28px;height:11px;border-radius:2px;border:1px solid rgba(255,255,255,.22);background:#ffffff5c;transform:translate(-50%) rotate(-2deg)}.book-note-text{margin:0;max-height:43px;overflow:hidden;font-family:var(--handwriting);font-size:.9rem;line-height:1.15;letter-spacing:.01em;font-weight:400;color:var(--book-note-ink, rgba(64, 49, 15, .8));white-space:pre-wrap;overflow-wrap:anywhere;filter:blur(4px);opacity:.78;transition:filter .16s ease,opacity .16s ease}.book.spine .book-body{padding:10px 8px;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);gap:12px}.book.spine.revealed .book-body{padding:12px;writing-mode:horizontal-tb;text-orientation:mixed;transform:none;gap:6px}.book.spine .book-title{position:relative;z-index:0;font-size:.7rem;font-weight:700;letter-spacing:.08em}.book .book-title.book-title-music{font-weight:500;letter-spacing:.01em}.book .book-title.book-title-music .music-artist{font-weight:800;text-transform:uppercase}.book .book-title.book-title-music .music-album{font-weight:500;text-transform:none}.book.spine .book-author{position:relative;z-index:0;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em}.book.spine.revealed .book-title{font-size:.95rem;letter-spacing:.02em}.book.spine.revealed .book-author{font-size:.72rem}.book.spine .book-title:before,.book.spine .book-author:before{display:none}.book.current{box-shadow:-10px 0 14px -4px var(--book-shadow-side),10px 0 14px -4px var(--book-shadow-side),0 8px 12px -7px var(--book-shadow-down),0 0 20px #f2b95b99}.book.current:after{content:"";position:absolute;inset:-8px;border-radius:8px;border:2px solid rgba(242,185,91,.8);box-shadow:0 0 18px #f2b95b99;pointer-events:none}.book-badge{position:absolute;top:8px;right:8px;background:#ffffffe6;padding:.2rem .5rem;border-radius:999px;font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;z-index:3}.book-meta-card{position:absolute;left:50%;bottom:-70px;width:min(100%,220px);transform:translate(-50%) translateY(10px);opacity:0;pointer-events:none;background:#160e09eb;color:#f8efe3;border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:.55rem .65rem .6rem;box-shadow:0 10px 24px #08040273;transition:opacity .2s ease,transform .2s ease}.book.revealed .book-meta-card{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.book.revealed .book-note-postit{transform:translate(-50%) translateY(-4px) rotate(var(--book-note-tilt, -3deg));width:var(--book-face-width, 160px);max-height:min(220px,calc(var(--shelf-height, 408px) - 130px));pointer-events:auto}.book.revealed .book-note-text{max-height:min(205px,calc(var(--shelf-height, 408px) - 145px));overflow-y:auto;filter:none;opacity:1}.book-meta-actions{margin-top:.45rem;display:flex;justify-content:flex-end}.book-add-note{border:1px solid rgba(255,255,255,.35);border-radius:999px;background:#ffffff1f;color:inherit;font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;padding:.25rem .56rem;line-height:1.1;cursor:pointer}.book-add-note:hover{background:#ffffff38}.book-meta-title{font-weight:700;font-size:1rem;line-height:1.1;white-space:normal;overflow-wrap:anywhere;word-break:break-word}.book-meta-author{margin-top:.28rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-meta-type{margin-bottom:.32rem;font-size:.58rem;text-transform:uppercase;letter-spacing:.14em;color:#f8efe394}@keyframes book-reveal-spin{0%{transform:perspective(900px) rotateY(-85deg)}to{transform:perspective(900px) rotateY(0)}}.modal-backdrop{position:fixed;inset:0;background:#160e0999;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:clamp(16px,4vw,40px);z-index:20}.modal-sheet{width:min(980px,100%);max-height:92vh;overflow:auto;position:relative}.shelf-edit-sheet,.book-note-sheet{width:min(620px,100%)}.shelf-edit-modal{background:#fffffff2;border:1px solid rgba(86,60,36,.16);border-radius:24px;padding:clamp(18px,3vw,26px);box-shadow:0 24px 44px #1a100942;display:grid;gap:18px}.book-note-modal{background:#fffffff2;border:1px solid rgba(86,60,36,.16);border-radius:24px;padding:clamp(18px,3vw,26px);box-shadow:0 24px 44px #1a100942;display:grid;gap:16px}.shelf-edit-head,.book-note-head{display:grid;gap:6px}.shelf-edit-title,.book-note-title{margin:0;font-family:var(--display);font-size:clamp(1.6rem,3vw,2rem)}.shelf-edit-copy,.book-note-copy{margin:0;color:var(--muted);font-size:.92rem}.shelf-edit-form,.book-note-form{display:grid;gap:10px}.shelf-edit-form input{border-radius:14px;border:1px solid rgba(86,60,36,.2);padding:.8rem 1rem;font-size:.95rem;background:#ffffffe6;color:var(--ink);transition:border .2s ease,box-shadow .2s ease}.book-note-form textarea{border-radius:14px;border:1px solid rgba(86,60,36,.2);padding:.8rem 1rem;min-height:160px;resize:vertical;font-size:.95rem;line-height:1.38;background:#ffffffe6;color:var(--ink);transition:border .2s ease,box-shadow .2s ease}.shelf-edit-form input:focus{outline:none;border-color:#d1773c99;box-shadow:0 0 0 3px #f2b95b4d}.book-note-form textarea:focus{outline:none;border-color:#d1773c99;box-shadow:0 0 0 3px #f2b95b4d}.book-note-meta-row{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:.8rem}.book-note-hint{overflow-wrap:anywhere}.book-note-count{flex:0 0 auto;font-variant-numeric:tabular-nums}.book-note-colors{margin:0;padding:0;border:0;display:grid;gap:8px}.book-note-colors-label{padding:0;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.book-note-color-grid{display:flex;gap:8px;flex-wrap:wrap}.book-note-color-swatch{width:28px;height:28px;border-radius:999px;border:1px solid rgba(86,60,36,.25);background:linear-gradient(150deg,var(--note-swatch-start) 0%,var(--note-swatch-end) 100%);box-shadow:inset 0 0 0 1px #ffffff57;cursor:pointer}.book-note-color-swatch.selected{box-shadow:0 0 0 2px #d1773c8c,inset 0 0 0 1px #ffffff57}.book-note-color-swatch:focus-visible{outline:none;box-shadow:0 0 0 3px #f2b95b8c,inset 0 0 0 1px #ffffff57}.shelf-edit-actions-row,.book-note-actions{display:flex;justify-content:flex-end;gap:10px}.shelf-edit-danger{border-top:1px solid rgba(86,60,36,.14);padding-top:14px;display:flex;align-items:center;justify-content:space-between;gap:14px}.shelf-edit-danger-copy{margin:0;color:var(--muted);font-size:.84rem}.shelf-edit-delete{color:#8a241b;border-color:#8a241b40;background:#fff2f1e6}.shelf-edit-delete:hover{background:#ffeceafa}.modal-close{position:sticky;top:12px;margin-left:auto;display:block;z-index:2}@keyframes riseIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@media(max-width:960px){.landing{grid-template-columns:1fr;padding-top:40px}.sign-in-panel{justify-items:start}.masthead{flex-direction:column;align-items:flex-start}.masthead-left{flex-direction:column;align-items:flex-start;gap:12px}.book-search-head{flex-direction:column;align-items:flex-start}.book-search-inputs{grid-template-columns:1fr}.search-result{grid-template-columns:1fr;justify-items:start}.site-footer-landing{margin-bottom:0}}@media(max-width:720px){.page{--page-gutter: 18px;padding:0 var(--page-gutter)}.landing-shell{--page-gutter: 18px}.landing{padding:32px 18px 24px}.landing-title{font-size:clamp(2rem,8vw,2.8rem)}.sign-in-note{text-align:left}.current-reading-card{grid-template-columns:1fr}.shelf-head{flex-direction:column}.everyone-user-head{flex-direction:column;align-items:flex-start}.shelf-edit-trigger{opacity:1;transform:none;pointer-events:auto}.shelf-edit-actions-row,.book-note-actions{flex-direction:column-reverse}.shelf-edit-danger{flex-direction:column;align-items:stretch}.shelf-books{transform:scale(.92);transform-origin:left bottom}.shelf-add-book{right:12px;bottom:12px;width:40px;height:40px;font-size:1.3rem}.site-footer{font-size:.66rem}.site-footer-landing{margin-bottom:0}}@media(prefers-reduced-motion:reduce){.book,.book.revealed{transition:none;animation:none}.book.revealed .book-inner,.current-reading-sheen,.landing-hero,.landing-preview,.sign-in-card{animation:none}}
