@import url(https://fonts.googleapis.com/css2?family=Homemade+Apple&display=swap);@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Homemade+Apple&family=Playfair+Display:wght@400;600;700;800&display=swap);body{background:var(--pt-cream);background-repeat:repeat;background-size:cover;padding:0}.sidebar{background-color:#fffaf0;border-right:2px solid #b7b7a4;box-shadow:2px 0 8px #0000000d;box-sizing:border-box;color:#6b705c;font-family:Playfair Display,serif;height:100vh;left:0;overflow-y:auto;padding:2rem 1rem;position:fixed;top:0;transform:translateX(-100%);transition:transform .3s ease;width:250px;z-index:1000}.sidebar.open{transform:translateX(0)}.sidebar-toggle{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:30px;justify-content:space-between;left:1rem;padding:0;position:fixed;top:1rem;width:35px;z-index:1100}.sidebar-toggle .bar{background-color:#cb997e;border-radius:2px;height:4px;transition:all .3s ease}.sidebar-toggle.open .bar:first-child{transform:rotate(45deg) translate(6px,6px)}.sidebar-toggle.open .bar:nth-child(2){opacity:0}.sidebar-toggle.open .bar:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.sidebar a{border-radius:8px;color:#6b705c;display:block;font-family:Playfair Display,serif;font-weight:600;margin-bottom:.5rem;padding:.75rem 1rem;text-decoration:none;transition:background-color .3s ease}.sidebar a:hover{background-color:#ffe8d6;color:#cb997e}body.sidebar-open #main-content{margin-left:250px;transition:margin-left .3s ease}@media (max-width:720px){.sidebar{transform:translateX(-100%);width:200px}.sidebar.open{transform:translateX(0)}body.sidebar-open #main-content{margin-left:200px}}.sidebar-logo{margin-bottom:1.5rem;text-align:center}.sidebar-logo img{border-radius:2px;height:auto;max-width:100px;opacity:.95;width:100px}.nav-overlay,.sidebar-backdrop,.sidebar:not(.open){pointer-events:none!important;z-index:0!important}.fb-backdrop{background:#00000059;inset:0;position:fixed;z-index:10000}.fb-modal{background:#ffe8d6;border:2px solid #ddbea9;border-radius:16px;box-shadow:0 12px 30px #0003;color:#6b705c;font-family:Playfair Display,serif;inset:50% auto auto 50%;padding:1.25rem 1.25rem 1rem;position:fixed;transform:translate(-50%,-50%);width:min(580px,92vw);z-index:10001}.fb-close{background:#0000;border:none;color:#6b705c;cursor:pointer;font-size:1.5rem;position:absolute;right:12px;top:8px}.fb-title{color:#6b705c;font-size:1.4rem;margin:0 0 .25rem}.fb-sub{margin:0 0 .75rem;opacity:.85}.fb-form{grid-gap:.75rem;display:grid;gap:.75rem}.fb-field{grid-gap:.35rem;display:grid;gap:.35rem}.fb-field>span{font-weight:600}.fb-field input,.fb-field select,.fb-field textarea{background:#fffaf0;border:2px solid #b7b7a4;border-radius:10px;color:#6b705c;font-family:Playfair Display,serif;padding:.55rem .7rem;width:90%}.fb-field textarea{min-height:110px;resize:vertical}.fb-error{background:#ffe0e0;border:1px solid #ffb3b3;border-radius:8px;color:#8b0000;padding:6px 10px}.fb-success{background:#e4ffe6;border:1px solid #b7f5c0;border-radius:8px;color:#1b5e20;padding:6px 10px}.fb-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.25rem}.fb-btn{background:#cb997e;border:2px solid #cb997e;border-radius:10px;color:#fff;cursor:pointer;padding:.5rem .9rem}.fb-btn.secondary{background:#fff;border-color:#b7b7a4;color:#6b705c}.fb-btn:disabled{cursor:not-allowed;opacity:.7}.home{background:#fffaf0!important;background-image:none!important;color:#6b705c;color:var(--pt-green);font-family:Playfair Display,serif;min-height:100vh;padding:clamp(16px,3vw,28px)}.home-header{margin-bottom:clamp(16px,3vw,28px);text-align:center}.home-brand{font-family:Homemade Apple,cursive;font-size:clamp(2.2rem,6vw,3.8rem);letter-spacing:.3px;margin:0 0 6px}.home-tag{margin:0;opacity:.9}.streak-pill{align-items:center;background:#f7efe3;border:1px solid #e3d6c5;border-radius:999px;color:#6b705c;color:var(--pt-green);display:inline-flex;font-weight:600;gap:8px;margin-top:12px;padding:6px 12px}.streak-dot{background:#cb997e;background:var(--pt-terracotta);border-radius:50%;display:inline-block;height:8px;width:8px}.icon-grid{grid-gap:clamp(14px,2vw,22px);display:grid;gap:clamp(14px,2vw,22px);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin:0 auto;max-width:980px}.icon-tile{color:#6b705c;color:var(--pt-green);flex-direction:column;gap:10px;text-decoration:none}.icon-face,.icon-tile{align-items:center;display:flex}.icon-face{background:#0000;border-radius:22px;height:160px;justify-content:center;transition:transform .25s ease,box-shadow .25s ease;width:160px}.icon-face img{filter:drop-shadow(0 4px 6px rgba(0,0,0,.1));height:78%;object-fit:contain;transition:transform .25s ease;width:78%}.icon-tile:hover .icon-face{box-shadow:0 16px 36px #0000001f;transform:translateY(-2px)}.icon-tile:hover .icon-face img{transform:scale(1.04)}@media (max-width:520px){.icon-face{height:120px;width:120px}}.panel{background:#fffaf0;border:1px solid #e9dccb;border-radius:14px;box-shadow:0 6px 16px #0000000f;max-height:320px;overflow:auto;padding:12px}.panel-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(84px,1fr))}.book-card{aspect-ratio:2/3;background:#f7f3ed;border:1px solid #e6e0d6;border-radius:10px;box-shadow:0 2px 6px #0000000f;overflow:hidden;width:100%}.book-card img{height:100%;object-fit:cover;width:100%}.book-ph{align-items:center;color:#a9a39a;display:flex;font-size:.85rem;height:100%;justify-content:center;width:100%}.home-section{margin:20px auto 0;max-width:980px}.home-sec-title{color:#6b705c;color:var(--pt-green);font-family:Playfair Display,serif;font-size:1.2rem;margin:0 0 8px 4px}.panel::-webkit-scrollbar{width:10px}.panel::-webkit-scrollbar-track{background:#f4efe6;border-radius:12px}.panel::-webkit-scrollbar-thumb{background:#d7c7b5;border:2px solid #f4efe6;border-radius:12px}.panel:hover::-webkit-scrollbar-thumb{background:#cb997e}.panel{scrollbar-color:#d7c7b5 #f4efe6;scrollbar-width:thin}@media (max-width:560px){.panel{max-height:260px}.panel-grid{gap:8px}}.book{display:inline-block;position:relative;transition:transform .2s ease,box-shadow .2s ease}.book-remove-btn{background-color:#fffc;border:none;border-radius:50%;color:#6b705c;cursor:pointer;font-size:14px;height:20px;line-height:18px;opacity:0;padding:0;position:absolute;right:4px;text-align:center;top:4px;transition:opacity .2s ease;width:20px}.book:hover .book-remove-btn{opacity:1}.book-remove-btn:hover{background-color:#fff}.bookshelf-page{background:#fffaf0;background-size:cover;color:#6b705c;font-family:Playfair Display,serif;padding:2rem}.library-hero{margin-bottom:1.5rem;text-align:center}.library-title{color:#596e52;font-family:Homemade Apple,cursive;font-size:2.5rem;margin:0 0 .5rem}.library-actions{display:flex;justify-content:center}.add-book-button{background-color:#ddbea9;border:2px solid #b7b7a4;border-radius:10px;color:#6b705c;display:inline-block;font-family:Playfair Display,serif;font-size:1rem;padding:.6rem 1.2rem;text-decoration:none;transition:all .3s ease}.add-book-button:hover{background-color:#ffe8d6;border-color:#cb997e}.shelf-container{margin-bottom:3rem}.shelf-label{background-color:hsla(23,92%,86%,.467);border-radius:8px;box-shadow:0 1px 3px #0000000d;font-size:1.5rem;font-weight:700;margin-bottom:1rem;padding:.5rem 1rem;text-align:center;width:100%}.shelf{background-image:url(/static/media/wood-shelf-texture.e17d462e181a69c2cf27.png);background-size:cover;border-radius:10px;box-shadow:inset 0 2px 8px #0000000f;gap:.5rem;height:180px;justify-content:flex-start;overflow-x:auto;padding:0 1rem;position:relative;z-index:10}.book,.shelf{align-items:center;display:flex}.book{cursor:pointer;justify-content:center;margin:0 .5rem;transition:transform .2s ease}.book:hover{transform:translateY(-4px)}.book-cover{background:#fff;border-radius:4px;box-shadow:2px 4px 6px #0003;display:block;height:150px;width:auto}.empty-shelf{color:#f4f4f4;font-style:italic;margin:auto 0}.book-cover.dnf,.book-cover[data-shelf=dnf],.book.dnf .book-cover,.book[data-shelf=dnf] .book-cover{filter:grayscale(100%) contrast(.9) brightness(.95)}.book-modal-backdrop{background:#6b705c59;inset:0;position:fixed;z-index:5000}.book-modal{background:#fffaf0;border:2px solid #b7b7a4;border-radius:12px;box-shadow:0 18px 40px #0000002e;color:#6b705c;font-family:Playfair Display,serif;left:50%;padding:1rem;position:fixed;top:8%;transform:translateX(-50%);width:min(900px,96vw);z-index:5010}.modal-close{background:#ffffffe6;border:1px solid #b7b7a4;border-radius:50%;color:#6b705c;cursor:pointer;font-size:18px;height:28px;line-height:26px;position:absolute;right:12px;text-align:center;top:10px;width:28px}.modal-close:hover{background:#ffe8d6;color:#cb997e}.book-modal-header{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:220px 1fr}@media (max-width:720px){.book-modal-header{grid-template-columns:1fr}}.cover-col{align-items:center;display:flex;flex-direction:column;gap:.75rem}.book-modal-cover{background:#fff;border:1px solid #e7e1d7;border-radius:8px;box-shadow:2px 4px 12px #0000001f;height:auto;width:220px}.book-modal-main{grid-gap:.6rem;display:grid;gap:.6rem}.title-row{align-items:center;display:flex;gap:.5rem}.book-modal-title{color:#cb997e;margin:0}.book-modal-author{opacity:.9}.modal-series{opacity:.85}.fav-toggle{align-items:center;background:#fffaf0;border:2px solid #b7b7a4;border-radius:999px;color:#3f3a35;cursor:pointer;display:inline-flex;font-family:Playfair Display,serif;gap:.5rem;justify-content:center;padding:.35rem .7rem}.fav-toggle .heart{font-size:1rem;transform:translateY(-1px)}.fav-toggle.is-fav{background:#ffe8d6;border-color:#cb997e;color:#6b705c}.remove-inline-button{background:#0000;border:1px solid #cb6d6d;border-radius:8px;color:#cb6d6d;cursor:pointer;display:block;font-family:Playfair Display,serif;font-size:.9rem;margin:.6rem auto 0;padding:.35rem .75rem;text-align:center}.remove-inline-button:hover{background:#cb6d6d;color:#fff}.dates-row{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:1fr 1fr}.date-field{grid-gap:.25rem;display:grid;gap:.25rem}.date-field input{background:#fff;border:1.5px solid #b7b7a4;border-radius:10px;font-family:Playfair Display,serif;padding:.5rem .7rem}.reading-block{grid-gap:.45rem;display:grid;gap:.45rem;margin-top:.25rem}.reading-label{font-weight:600}.reading-row{align-items:center;display:flex;gap:.5rem}.page-input{background:#fff;border:1.5px solid #b7b7a4;border-radius:10px;font-family:Playfair Display,serif;padding:.5rem .7rem;width:120px}.of{opacity:.85}.progress-bar{background:#efe7dc;border:1px solid #dfd6c8;border-radius:999px;height:8px;overflow:hidden;width:100%}.progress-fill{background:#cb997e;height:100%}.progress-small{font-size:.9rem;opacity:.9}.rating-row{align-items:center;display:flex;gap:.25rem}.star-btn{background:#0000;border:none;cursor:pointer;display:inline-block;height:24px;padding:0;position:relative;width:24px}.star-empty,.star-fill{font-size:24px;left:0;line-height:24px;pointer-events:none;position:absolute;top:0;-webkit-user-select:none;user-select:none}.star-empty{color:#b7b7a4}.star-fill{color:#cb997e;overflow:hidden;white-space:nowrap;width:0;width:var(--fill,0)}.rating-row .star-btn:hover .star-empty{filter:brightness(.95)}.bm-field{grid-gap:.4rem;display:grid;gap:.4rem;margin-top:.75rem}.bm-label{color:#6b705c;font-family:Playfair Display,serif;font-size:1.05rem}.bm-genre-row{align-items:center;display:flex;flex-wrap:wrap;gap:.6rem}.bm-select{appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;utf8,<svg fill=%27%236b705c%27 height=%2720%27 viewBox=%270 0 20 20%27 width=%2720%27 xmlns=%27http://www.w3.org/2000/svg%27><path d=%27M5.25 7.5l4.5 4.5 4.5-4.5H5.25z%27/></svg>");background-position:right .8rem center;background-repeat:no-repeat;background-size:1rem;border:2px solid #b7b7a4;border-radius:12px;color:#6b705c;cursor:pointer;font-family:Playfair Display,serif;font-size:1rem;min-width:220px;padding:.5rem 2rem .5rem 1rem;transition:border-color .2s,box-shadow .2s}.bm-select:focus,.bm-select:hover{border-color:#cb997e}.bm-select:focus{box-shadow:0 0 0 3px #cb997e4d;outline:none}.bm-select option{background-color:#fffaf0;color:#6b705c;padding:.5rem}.bm-input,.bm-select option{font-family:Playfair Display,serif}.bm-input{background:#fff;border:1.5px solid #b7b7a4;border-radius:10px;color:#3f3a35;font-size:1rem;min-width:220px;outline:none;padding:.55rem .75rem}.bm-input:focus{border-color:#6b705c}.review-card{align-items:flex-start;background:none;border:none;display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem}.review-card-head{align-items:baseline;display:flex;gap:.5rem}.review-card-title{color:#6b705c;font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700}.edit-btn{background:none;border:none;color:#cb997e;font-size:.95rem;margin-top:-2px;padding:0}.edit-btn:hover{text-decoration:underline}.review-display{background:none;border:none;padding:0}.review-display,.review-textarea{color:#6b705c;font-family:Playfair Display,serif;font-size:1rem}.review-textarea{background-color:#fffaf0;border:2px solid #b7b7a4;border-radius:12px;box-sizing:border-box;max-width:500px;min-height:100px;padding:.75rem;resize:vertical;width:100%}.review-textarea:focus{border-color:#cb997e;box-shadow:0 0 0 3px #cb997e4d;outline:none}.bottom-actions{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:.4rem}.bottom-actions button{background:#fbebe0;border:1px solid #b7b7a4;border-radius:12px;color:#6b705c;cursor:pointer;font-family:Playfair Display,serif;font-weight:600;padding:.55rem 1.15rem}.bottom-actions button:hover{background:#ffe8d6;border-color:#cb997e}.book-modal .bm-select{appearance:none;appearance:none!important;background-color:#fff;background-color:#fff!important;background-image:url("data:image/svg+xml;utf8,<svg fill=%27%236b705c%27 height=%2720%27 viewBox=%270 0 20 20%27 width=%2720%27 xmlns=%27http://www.w3.org/2000/svg%27><path d=%27M5.25 7.5l4.5 4.5 4.5-4.5H5.25z%27/></svg>");background-image:url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 width=%2720%27 height=%2720%27 viewBox=%270 0 20 20%27 fill=%27%236b705c%27><path d=%27M5.25 7.5l4.5 4.5 4.5-4.5H5.25z%27/></svg>")!important;background-position:right .8rem center;background-position:right .8rem center!important;background-repeat:no-repeat;background-repeat:no-repeat!important;background-size:1rem;background-size:1rem!important;border:2px solid #b7b7a4;border:2px solid #b7b7a4!important;border-radius:12px;border-radius:12px!important;color:#6b705c;color:#6b705c!important;cursor:pointer;cursor:pointer!important;font-family:Playfair Display,serif;font-family:Playfair Display,serif!important;font-size:1rem;font-size:1rem!important;line-height:1.2!important;min-width:220px;min-width:220px!important;padding:.5rem 2rem .5rem 1rem;padding:.5rem 2rem .5rem 1rem!important;transition:border-color .2s,box-shadow .2s;transition:border-color .2s ease,box-shadow .2s ease!important}.book-modal .bm-select:focus,.book-modal .bm-select:hover{border-color:#cb997e!important}.book-modal .bm-select:focus{box-shadow:0 0 0 3px #cb997e4d!important;outline:none!important}.book-modal .bm-select option{background-color:#fffaf0;color:#6b705c;font-family:Playfair Display,serif;padding:.5rem}.pretty-select{display:inline-block;font-family:Playfair Display,serif;min-width:220px;position:relative}.pretty-select .ps-trigger{align-items:center;background:#fff;border:2px solid #b7b7a4;border-radius:12px;color:#6b705c;cursor:pointer;display:flex;justify-content:space-between;padding:.5rem 2rem .5rem 1rem;text-align:left;transition:border-color .2s,box-shadow .2s;width:100%}.pretty-select .ps-trigger:hover{border-color:#cb997e}.pretty-select .ps-trigger:focus,.pretty-select[aria-expanded=true] .ps-trigger{border-color:#cb997e;box-shadow:0 0 0 3px #cb997e4d;outline:none}.pretty-select .ps-value.ps-placeholder{opacity:.8}.pretty-select .ps-chevron{color:#6b705c;font-size:1rem;line-height:1;margin-left:.5rem}.pretty-select .ps-list{background:#fffaf0;border:2px solid #ddbea9;border-radius:12px;box-shadow:0 14px 28px #00000026;left:0;list-style:none;margin:0;max-height:320px;overflow:auto;padding:.35rem 0;position:absolute;right:0;top:calc(100% + 6px);z-index:6000}.pretty-select .ps-option{color:#3f3a35;cursor:pointer;padding:.6rem .9rem;transition:background .15s}.pretty-select .ps-option.is-active,.pretty-select .ps-option:hover{background:#ffe8d6}.pretty-select .ps-option.is-selected{color:#6b705c;font-weight:700}.book-modal .bm-select{background:#0000!important;background-image:none!important;border:0!important;box-shadow:none!important;padding:0!important}.book-modal .bm-select .ps-trigger{align-items:center;background:#fff;border:2px solid #b7b7a4;border-radius:12px;color:#6b705c;cursor:pointer;display:flex;justify-content:space-between;padding:.5rem 2rem .5rem 1rem;text-align:left;transition:border-color .2s,box-shadow .2s;width:100%}.book-modal .bm-select .ps-trigger:hover{border-color:#cb997e}.book-modal .bm-select .ps-trigger:focus,.book-modal .bm-select[aria-expanded=true] .ps-trigger{border-color:#cb997e;box-shadow:0 0 0 3px #cb997e4d;outline:none}.book-modal .bm-select .ps-chevron{color:#6b705c;margin-left:.5rem}.book-modal .bm-select .ps-list{background:#fffaf0;border:2px solid #ddbea9;border-radius:12px;box-shadow:0 14px 28px #00000026;left:0;list-style:none;margin:0;max-height:320px;overflow:auto;padding:.35rem 0;position:absolute;right:0;top:calc(100% + 6px);z-index:6000}.book-modal .bm-select .ps-option{color:#3f3a35;cursor:pointer;padding:.6rem .9rem;transition:background .15s}.book-modal .bm-select .ps-option.is-active,.book-modal .bm-select .ps-option:hover{background:#ffe8d6}.book-modal .bm-select .ps-option.is-selected{color:#6b705c;font-weight:700}.book-modal .bm-select .ps-option,.book-modal .bm-select .ps-trigger{font-family:Playfair Display,serif!important;font-size:1rem}.meta-row{grid-gap:1rem 1.25rem;gap:1rem 1.25rem;margin-top:.5rem}.meta-field{grid-gap:.4rem;display:grid;gap:.4rem}@media (max-width:820px){.meta-row{grid-template-columns:1fr}}.pretty-multi{font-family:Playfair Display,serif;position:relative}.pm-trigger{align-items:center;background:#fff;border:2px solid #b7b7a4;border-radius:12px;cursor:pointer;display:flex;gap:.75rem;justify-content:space-between;padding:.5rem .9rem;transition:border-color .2s,box-shadow .2s}.pm-trigger:hover{border-color:#cb997e}.pm-trigger:focus,.pretty-multi[aria-expanded=true] .pm-trigger{border-color:#cb997e;box-shadow:0 0 0 3px #cb997e4d;outline:none}.pm-pills{display:flex;flex-wrap:wrap;gap:.4rem}.pm-placeholder{color:#6b705c;opacity:.85}.pm-pill{align-items:center;background:#ffe8d6;border:1px solid #cb997e;border-radius:999px;box-shadow:0 1px 2px #0000000f;color:#3f3a35;display:inline-flex;font-size:.95rem;gap:.35rem;padding:.15rem .55rem}.pm-x{background:#0000;border:none;color:#6b705c;cursor:pointer;font-size:1rem;line-height:1;padding:0}.pm-x:hover{color:#cb6d6d}.pm-chevron{color:#6b705c}.pm-pop{background:#fffaf0;border:2px solid #ddbea9;border-radius:12px;box-shadow:0 14px 28px #00000026;left:0;padding:.5rem;position:absolute;right:0;top:calc(100% + 6px);z-index:6000}.pm-input{background:#fff;border:1.5px solid #b7b7a4;border-radius:10px;color:#3f3a35;font-family:Playfair Display,serif;margin-bottom:.5rem;padding:.45rem .6rem;width:100%}.pm-list{list-style:none;margin:0;max-height:260px;overflow:auto;padding:.25rem 0}.pm-opt{border-radius:8px;color:#3f3a35;cursor:pointer;margin:0 .25rem;padding:.55rem .7rem}.pm-opt:hover{background:#ffe8d6}.pm-opt.is-selected{background:#fbebe0;border:1px solid #cb997e}.pm-empty{color:#6b705c;opacity:.85;padding:.6rem .75rem}.meta-row{grid-gap:1rem;align-items:start;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-top:.25rem}.meta-field{min-width:0}.bm-multi,.bm-multi .pms-control{box-sizing:border-box;width:100%}.bm-multi .pms-control,.bm-multi .pms-menu,.bm-select{max-width:520px}@media (max-width:900px){.meta-row{grid-template-columns:1fr}}.bm-multi{max-width:300px;width:auto!important}.bm-multi .pms-control{width:50%!important}.bm-multi .pms-control,.bm-multi .pms-menu{max-width:300px!important}.add-book-page{background:#fffaf0;background-size:cover;font-family:Homemade Apple,cursive;min-height:100vh;padding:40px 20px;text-align:center}.add-book-page label{color:#465444;display:block;font-size:20px;margin:10px 0}.add-book-page select{background-color:#596e52;border:2px solid #596e52;border-radius:3px;color:#fff;font-family:Playfair Display,serif;font-size:18px;margin-bottom:25px;outline:#fff;padding:2px 10px}.add-book-page input[type=text]{background-color:#f8f8f8;border:2px solid #596e52;border-radius:6px;font-family:Playfair Display,serif;font-size:18px;margin-bottom:20px;max-width:80%;outline:none;padding:10px;width:300px}.suggestions-list{align-items:center;display:flex;flex-direction:column;font-family:Playfair Display,serif;gap:10px;list-style:none;margin-top:15px;padding:0}.suggestions-list li{align-items:center;background-color:#ffe8d6;border-radius:6px;box-shadow:2px 2px 8px #0000001a;cursor:pointer;display:flex;padding:5px 10px;transition:transform .2s ease;width:320px}.suggestions-list li:hover{transform:scale(1.02)}.suggestions-list img{border-radius:6px;height:100px;margin-right:15px}.suggestions-list div{color:#596e52;font-size:16px;text-align:left}.suggestions-list strong{display:block;font-size:18px;margin-bottom:5px}.select-input-container{gap:2rem}.shelf-picker{align-items:flex-start;display:flex;flex-direction:column;margin-right:20px}.shelf-label{font-size:18px;margin-bottom:6px}.select-input-container{align-items:flex-start}.shelf-label{color:#6b705c;font-size:20px;margin-bottom:10px}.select-input-wrapper{align-items:center;display:flex;flex-direction:column;margin-bottom:30px}.select-input-container{align-items:flex-end;gap:20px;margin-bottom:30px}.shelf-select-group{align-items:flex-start;display:flex;flex-direction:column}.shelf-label{color:#5f7a64;font-size:22px;margin-bottom:8px}.dropdown-wrapper{font-family:Playfair Display,serif;margin:1rem 0}.dropdown-wrapper label{color:#6b705c;display:block;font-size:1rem;margin-bottom:6px}.dropdown-wrapper select{appearance:none;background-color:#ffe8d6;background-image:url("data:image/svg+xml;utf8,<svg fill=%27gray%27 height=%2720%27 viewBox=%270 0 24 24%27 width=%2720%27 xmlns=%27http://www.w3.org/2000/svg%27><path d=%27M7 10l5 5 5-5z%27/></svg>");background-position-x:calc(100% - 12px);background-position-y:center;background-repeat:no-repeat;background-size:16px;border:2px solid #b7b7a4;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#596e52;cursor:pointer;font-family:Playfair Display,serif;font-size:1rem;padding:10px 12px}.dropdown-wrapper select:focus{border-color:#cb997e;outline:none}.shelf-selection{margin-bottom:1.5rem}.shelf-label{display:block}select{appearance:none;background-color:#ffe8d6;border:1px solid #b7b7a4;border-radius:8px;box-shadow:1px 1px 4px #0000001a;color:#333;cursor:pointer;font-family:Playfair Display,serif;font-size:1rem;padding:8px 12px;transition:all .3s ease}select:focus{background-color:#fff;border-color:#cb997e;outline:none}option{color:#333}.shelf-selection,option{font-family:Playfair Display,serif}.shelf-selection{margin-right:1rem}.shelf-selection select{background-position:right .75rem center;border-radius:8px;padding:.6rem 1rem}.select-input-container{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-top:2rem}.shelf-selection{align-items:center;display:flex;flex-direction:column}.shelf-label{font-size:1.1rem;margin-bottom:.4rem}.shelf-label,.shelf-selection select{color:#596e52;font-family:Playfair Display,serif}.shelf-selection select{appearance:none;background-color:#fff8f0;background-image:url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="%236b705c" viewBox="0 0 16 16"><path d="M4 6l4 4 4-4z"/></svg>');background-position:right 1rem center;background-repeat:no-repeat;background-size:1rem;border:2px solid #ddbea9;border-radius:10px;box-shadow:0 2px 4px #0000000d;font-size:1rem;padding:.6rem 1.2rem;transition:border-color .2s,box-shadow .2s}.shelf-selection select:focus{border-color:#cb997e;box-shadow:0 0 0 3px #cb997e33;outline:none}input[type=text]{border:2px solid #333;border-radius:10px;font-family:Playfair Display,serif;font-size:1.1rem;padding:.7rem 1.2rem;width:300px}.add-book-page h1{color:#596e52;font-size:3rem;margin-bottom:2rem}.add-book-page h1,.spinner-container{font-family:Homemade Apple,cursive;text-align:center}.spinner-container{background:#fffaf0;background-size:cover;color:#6b705c;min-height:100vh;padding:3rem 1rem}.spinner-title{color:#6b705c;font-size:2.5rem;margin-bottom:2rem}.wheel-wrapper{height:420px;margin:0 auto 2rem;position:relative;width:420px}.wheel{transition:transform 3s ease-out}.wheel,.wheel-img{height:100%;width:100%}.pointer-img{left:50%;position:absolute;top:-5px;transform:translateX(-50%) rotate(180deg);width:100px;z-index:2}.spin-button{background-color:#ddbea9;border:none;border-radius:10px;cursor:pointer;font-family:Playfair Display,serif;font-size:1.2rem;padding:.75rem 1.5rem;transition:background-color .3s ease}.spin-button:hover{background-color:#ffe8d6}.prompt-result{background-color:#fffaf0;border:2px dashed #b7b7a4;border-radius:12px;display:inline-block;font-size:1.3rem;font-style:italic;margin-top:2rem;max-width:80%;padding:1.5rem}.sa-wrap{background:#fffaf0;border:2px solid #ddbea9;border-radius:14px;box-shadow:2px 4px 8px #0000000a;margin:1rem auto 1.25rem;max-width:1100px}.sa-header{align-items:center;background:#0000;border:0;color:#6b705c;cursor:pointer;display:flex;font-family:Playfair Display,serif;font-size:1.25rem;gap:.75rem;justify-content:space-between;padding:.9rem 1.1rem;width:100%}.sa-name{font-weight:700}.sa-chevron{transition:transform .15s ease}.sa-chevron.open{transform:rotate(180deg)}.sa-body{padding:.5rem 1rem .25rem}.sa-row{grid-gap:1rem;align-items:start;border-top:1px solid #eee4d9;display:grid;gap:1rem;grid-template-columns:120px 1fr;padding:.9rem 0}.sa-row:first-child{border-top:0}.sa-cover{background:#f4efe8;border-radius:10px;box-shadow:0 3px 8px #00000014;height:180px!important;object-fit:cover;width:120px!important}.sa-main{min-width:0}.sa-title{color:#3f3a35;font-size:1.1rem;line-height:1.2;margin-bottom:2px}.sa-author,.sa-title{font-family:Playfair Display,serif}.sa-author{color:#6b705c;font-size:.95rem;margin-bottom:.5rem;opacity:.9}.sa-controls{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem 1.25rem}.sa-field{grid-gap:.4rem;display:grid;gap:.4rem}.sa-small-label{color:#3f3a35;font-family:Playfair Display,serif;font-size:.95rem}.sa-pill-row{display:flex;flex-wrap:wrap;gap:.5rem}.sa-pill{background:#ffe8d6;border:2px solid #ddbea9;border-radius:999px;color:#3f3a35;cursor:pointer;font-family:Playfair Display,serif;padding:.35rem .75rem}.sa-pill.active{background:#cb997e;border-color:#cb997e;color:#fffaf0}.sa-pages-block{grid-gap:.35rem;display:grid;gap:.35rem}.sa-pages-label{color:#3f3a35;font-family:Playfair Display,serif;font-size:.95rem}.sa-range-row{align-items:center;display:flex;gap:.6rem}.sa-range{accent-color:#cb997e;width:280px}.sa-page-chip{background:#fff;border:2px solid #ddbea9;border-radius:999px;color:#6b705c;font-family:Playfair Display,serif;font-size:.9rem;padding:.2rem .5rem}.sa-readout-row{align-items:center;display:flex;gap:.35rem}.sa-input,.sa-select{background:#ffe8d6;border:2px solid #ddbea9;border-radius:10px;color:#3f3a35;font-family:Playfair Display,serif;outline:none;padding:.45rem .6rem}.sa-input{width:84px}.sa-slash{color:#6b705c;opacity:.8}.sa-total{color:#6b705c;font-family:Playfair Display,serif}.sa-footer{display:flex;justify-content:flex-end;padding:.6rem 1rem 1rem}.sa-remove{background:#fff;border:2px solid #b7b7a4;border-radius:10px;color:#6b705c;cursor:pointer;font-family:Playfair Display,serif;padding:.45rem .75rem}.sa-remove:hover{background:#ffe8d6;border-color:#cb997e}@media (max-width:640px){.sa-row{grid-template-columns:88px 1fr}.sa-cover{height:132px!important;width:88px!important}.sa-range{width:180px}}.series-tracker{background:#0000;font-family:Homemade Apple,cursive;padding:2rem 3rem}.tracker-header{align-items:center;display:flex;justify-content:center;margin:1rem 0 2rem}.tracker-title{color:#6b705c;font-size:2.2rem;letter-spacing:.5px}.add-series-form{display:flex;gap:.75rem;justify-content:center;margin-bottom:1.25rem;position:relative}.series-search-input{background:#ffe8d6;border:2px solid #ddbea9;color:#6b705c;font-size:1rem;outline:none;width:min(700px,90vw)}.confirm-add-button,.series-search-input{border-radius:999px;font-family:Playfair Display,serif;padding:.9rem 1.1rem}.confirm-add-button{background:#cb997e;border:2px solid #cb997e;color:#fffaf0;cursor:pointer}.suggestions-dropdown{background:#fffaf0;border:2px solid #ddbea9;border-radius:12px;list-style:none;margin:0;max-height:320px;overflow:auto;padding:.5rem 0;position:absolute;top:110%;width:min(700px,90vw)}.suggestions-dropdown li{cursor:pointer;padding:.6rem 1rem}.suggestions-dropdown li:hover{background:#ffe8d6}.manual-add-card{background:#fffaf0;border:2px solid #b7b7a4;border-radius:12px;margin:1rem auto 2rem;max-width:900px;padding:1rem}.manual-add-header{color:#6b705c;font-weight:600;margin-bottom:.75rem}.manual-book-row{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:2fr 1.5fr 2fr 1fr;margin-bottom:.6rem}.manual-book-row input{background:#ffe8d6;border:2px solid #ddbea9;border-radius:10px;color:#6b705c;font-family:Playfair Display,serif;padding:.6rem .75rem}.manual-buttons{display:flex;gap:.6rem;justify-content:flex-end;margin-top:.5rem}.manual-buttons button{background:#cb997e;border:2px solid #cb997e;border-radius:10px;color:#fffaf0;cursor:pointer;font-family:Playfair Display,serif;padding:.6rem .9rem}.suggestions-dropdown{font-size:1.2rem;line-height:1.4}.suggestions-dropdown,.suggestions-dropdown li{font-family:Playfair Display,serif!important}.calendar-page{background:#fffaf0;font-family:Playfair Display,serif;min-height:100vh;padding:1.5rem}.calendar-header{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:.75rem;padding-left:0}.calendar-month{font-size:1.2rem;text-align:center}.cal-nav{border-radius:10px;font-size:1.1rem;padding:.35rem .6rem}.cal-nav--prev{margin-left:.25rem}.cal-nav--next{justify-self:end}.calendar-title{color:#6b705c;color:var(--pt-green);font-size:1.1rem;grid-column:2/3;letter-spacing:.5px;margin:0;text-align:center}.calendar-month{color:#cb997e;color:var(--pt-terracotta);font-weight:600;grid-column:3/4;justify-self:center}.cal-nav{background:#0000;border:1px solid #b7b7a4;border:1px solid var(--pt-sage);border-radius:8px;color:#6b705c;color:var(--pt-green);cursor:pointer;font-size:1.2rem;line-height:1;padding:.25rem .5rem}.cal-nav:hover{background:#ffe8d6;background:var(--pt-peach)}.calendar-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr)}.cal-dow{background:#f7efe3;border:1px solid #e9dccb;border-radius:10px;color:#6b705c;color:var(--pt-green);font-weight:600;padding:.4rem 0;text-align:center}.cal-cell{background:#fff;border:1px solid #e9dccb;border-radius:12px;box-shadow:0 1px 3px #0000000a;min-height:130px;overflow:hidden;padding:8px 8px 14px;position:relative;transition:transform .12s ease,box-shadow .12s ease}.cal-cell:hover{box-shadow:0 3px 10px #0000000f;transform:translateY(-1px)}.cal-cell--faded{opacity:.55}.cal-cell--today{box-shadow:0 0 0 3px #cb997e26;outline:2px solid #cb997e;outline:2px solid var(--pt-terracotta);outline-offset:-2px}.cal-date{color:#6b705c;color:var(--pt-green);font-size:.9rem;opacity:.9;position:absolute;right:8px;top:6px}.cover-stack{cursor:pointer;height:96px;margin:26px auto 0;position:relative;transform-origin:top center;width:64px}.cover-thumb{background:#f7f3ed;border:2px solid #fff;border-radius:6px;box-shadow:0 3px 6px #0000001f;height:96px;left:0;object-fit:cover;position:absolute;top:0;transition:transform .12s ease,box-shadow .12s ease;width:64px}.cover-thumb--g1{opacity:.92;transform:translate(6px,6px) scale(.96);z-index:1}.cover-thumb--g2{opacity:.88;transform:translate(12px,12px) scale(.92);z-index:0}.cover-thumb:hover{transform:translateY(-1px) scale(1.01)}.cover-count{background:#cb997e;background:var(--pt-terracotta);border:1px solid #c18f78;border-radius:999px;bottom:4px;box-shadow:0 2px 4px #cb997e59;color:#fff;font-size:.7rem;font-weight:700;padding:2px 7px;position:absolute;right:4px}@media (max-width:540px){.cal-cell{min-height:120px}.cover-stack,.cover-thumb{height:84px;width:56px}.cover-thumb--g1{transform:translate(5px,5px) scale(.96)}.cover-thumb--g2{transform:translate(10px,10px) scale(.92)}}.bp-backdrop{align-items:center;background:#00000040;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.bp-modal{background:#fffaf0;border:1px solid #e9dccb;border-radius:14px;box-shadow:0 10px 30px #00000026;font-family:Playfair Display,serif;max-height:85vh;overflow:auto;width:min(900px,100%)}.bp-header{align-items:center;border-bottom:1px solid #e9dccb;display:flex;justify-content:space-between;padding:.9rem 1rem}.bp-close,.bp-header{color:#6b705c;color:var(--pt-green)}.bp-close{background:#0000;border:none;cursor:pointer;font-size:1.5rem}.bp-empty{color:#6b705c;padding:1rem}.bp-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));padding:1rem}.bp-card{background:none;border:none;box-shadow:none;margin:0;padding:0;transition:transform .15s ease;-webkit-user-select:none;user-select:none}.bp-card:hover{transform:translateY(-1px)}.bp-card input{display:none}.bp-card--checked .bp-cover-wrap:before{background-color:#cb997e99;border-radius:8px;content:"";inset:0;position:absolute;z-index:1}.bp-card--checked .bp-cover-wrap:after{color:#fff;content:"✔";font-size:2.2rem;font-weight:700;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:2}.bp-cover-wrap{aspect-ratio:2/3;background:none;border-radius:8px;width:100%}.bp-cover{display:block;height:100%;object-fit:cover;width:100%}.bp-cover--placeholder{align-items:center;border:1px dashed #ddd;color:#999;display:flex;justify-content:center}.bp-author,.bp-meta,.bp-title{display:none!important}.bp-actions{background:#fffaf0;border-top:1px solid #e9dccb;display:flex;gap:.6rem;justify-content:flex-end;padding:.9rem 1rem}.bp-btn{background:#cb997e;background:var(--pt-terracotta);border:1px solid #c18f78;border-radius:10px;color:#fff;cursor:pointer;font-family:Playfair Display,serif;font-weight:600;padding:.5rem .9rem}.bp-btn:disabled{cursor:not-allowed;opacity:.6}.bp-btn--ghost{background:#fff;border:1px solid #b7b7a4;border:1px solid var(--pt-sage);color:#6b705c;color:var(--pt-green);font-family:Playfair Display,serif}:root{--pt-terracotta:#cb997e;--pt-beige:#ddbea9;--pt-peach:#ffe8d6;--pt-sage:#b7b7a4;--pt-green:#6b705c;--pt-cream:#fffaf0}.ch-page{background:#fffaf0;background:var(--pt-cream);color:#6b705c;color:var(--pt-green);font-family:Playfair Display,serif;min-height:100vh;padding:1.5rem}.ch-header h1{font-family:Homemade Apple,cursive;font-size:2rem;letter-spacing:.3px;margin:0;text-align:center}.ch-sub{font-size:1rem;margin-top:.25rem;opacity:.9;text-align:center}.ch-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));margin-top:1rem}.ch-card{background:linear-gradient(180deg,#fff,#fffaf2);border:1px solid #e9dccb;border-radius:16px;box-shadow:0 3px 14px #0000000f;cursor:pointer;padding:14px;position:relative;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.ch-card:hover{box-shadow:0 10px 24px #0000001a;transform:translateY(-2px)}.ch-card--done{border-color:#cfe6cf;box-shadow:inset 0 0 0 4px #8cb48c24}.ch-head{align-items:center;display:flex;gap:16px}.ch-head__meta{flex:1 1;min-width:0}.ch-title{color:#6b705c;color:var(--pt-green);font-size:1.25rem;font-weight:800;line-height:1.1;margin-bottom:.25rem}.ch-desc{font-size:1rem;margin-bottom:.5rem;opacity:.9}.ch-card>.wreath{display:none!important}.ch-modal .wreath{display:grid!important}.ch-card button[aria-label="Delete challenge"]{background:#0000;border:none;color:#cb997e;cursor:pointer;font-size:20px;font-weight:700;height:24px;line-height:1;opacity:0;padding:0;position:absolute;right:8px;text-align:center;top:8px;transition:opacity .2s ease;-webkit-user-select:none;user-select:none;width:24px;z-index:10}.ch-card:hover button[aria-label="Delete challenge"]{opacity:1}.ch-card button[aria-label="Delete challenge"]:before{content:"×";display:inline-block;font-family:Playfair Display,serif;font-size:24px;font-weight:700;line-height:24px;-webkit-user-select:none;user-select:none}.ch-modal-overlay{align-items:center;background:#00000040;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.ch-modal{background:#fffdf8;border-radius:16px;box-shadow:0 20px 60px #00000040;max-height:90vh;overflow-y:auto;padding:16px;width:min(900px,92vw)}.ch-modal__close{align-self:flex-end;background:#0000;border:none;cursor:pointer;font-size:1.5rem;margin-bottom:8px;padding:0}.ch-modal__close,.ch-modal__title{color:#6b705c;color:var(--pt-green)}.ch-modal__title{font-family:Homemade Apple,cursive;font-size:1.8rem;font-weight:800;margin-bottom:12px;text-align:center}.ch-modal__desc{font-size:1rem;margin-bottom:16px;opacity:.9}@media (max-width:720px){.ch-grid{grid-template-columns:1fr}}.ch-book img{border:1px solid #e6e0d6;border-radius:8px;box-shadow:0 2px 6px #0000001a;height:120px;object-fit:cover;width:80px}.ch-shelf{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.ch-book figcaption{display:none}.book-slot{align-items:center;background-color:#ddbea9;background-color:var(--pt-beige);border:2px dashed #b7b7a4;border:2px dashed var(--pt-sage);border-radius:12px;cursor:pointer;display:flex;height:120px;justify-content:center;overflow:hidden;position:relative;width:80px}.book-slot.has-cover img{border-radius:12px;height:100%;object-fit:contain;transition:filter .3s ease;width:100%}.book-slot.has-cover:hover img{filter:blur(2px)}.book-slot .overlay{background:#fffc;border-radius:8px;color:#6b705c;color:var(--pt-green);font-family:Playfair Display,serif;font-size:14px;font-weight:700;left:50%;opacity:0;padding:4px 8px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity .3s ease;z-index:2}.book-slot.has-cover:hover .overlay{opacity:1!important;pointer-events:auto!important}.remove-btn{background:#cb997ed9;border:none;border-radius:12px;bottom:6px;color:#fff;cursor:pointer;font-size:.75rem;left:50%;opacity:0;padding:4px 10px;position:absolute;transform:translateX(-50%);transition:opacity .3s ease;-webkit-user-select:none;user-select:none;z-index:2}.book-slot.has-cover:hover .remove-btn{opacity:1!important}.bp-card input[type=checkbox]{display:none}.bp-card{cursor:pointer;display:inline-block;position:relative}.bp-cover-wrap{border-radius:10px;box-shadow:0 2px 8px #0000001a;height:120px;overflow:hidden;position:relative;width:80px}.bp-card.bp-card--checked .bp-cover-wrap:before{background-color:#cb997e99;border-radius:10px;content:"";inset:0;position:absolute;z-index:1}.bp-card.bp-card--checked .bp-cover-wrap:after{color:#fff;content:"✔";font-size:2.2rem;font-weight:700;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:2}.ch-card--active{box-shadow:0 8px 20px #0000001f;display:flex;flex-direction:column;justify-content:center;transform:translateY(-4px);transition:all .25s ease}.ch-card--active .ch-head{align-items:center;flex-direction:column;text-align:center}.ch-card--active .ch-desc{margin-top:.3rem}.ch-modal,.ch-modal-body{align-items:center;display:flex;flex-direction:column}.ch-modal-body{box-sizing:border-box;max-width:760px;padding:4px 8px 16px;text-align:center;width:100%}.ch-modal__title{margin:0 0 6px}.ch-modal__desc{margin:0 0 16px}.ch-slot-grid{flex-wrap:wrap;justify-content:center}.ch-card-row,.ch-slot-grid{align-items:center;display:flex;gap:16px}.ch-head--left{flex:1 1;text-align:left}.ch-progress{align-items:center;display:flex;flex:1 1;gap:10px;min-width:0}.ch-progress__label{color:#6b705c;color:var(--pt-green);font-size:.95rem;white-space:nowrap}.ch-pbar{background:#eee3d2;border:1px solid #e0d4c4;border-radius:999px;box-shadow:inset 0 2px 6px #0000000f;flex:1 1;height:12px;overflow:hidden;position:relative}.ch-pbar__fill{background:linear-gradient(90deg,#cb997e,#c18f78);background:linear-gradient(90deg,var(--pt-terracotta),#c18f78);height:100%;left:0;position:absolute;top:0;transition:width .22s ease;width:0}.auth-wrap{background:#fffaf0;font-family:Playfair Display,serif;justify-content:flex-start;padding-top:-1rem}.auth-card{border:2px solid #b7b7a4;border-radius:16px;box-shadow:2px 6px 14px #0000000f;width:min(500px,92vw)}.auth-title{color:#3f3a35;font-size:2rem;margin:0 0 1rem}.auth-label{color:#3f3a35;display:block;margin:.6rem 0}.req{color:#cb997e}.auth-input{appearance:none;background:#fffef8;border:2px solid #b7b7a4!important;border-radius:12px;box-sizing:border-box;color:#3f3a35;font-family:Playfair Display,serif;font-size:1rem;margin-top:.35rem;padding:.6rem .8rem;width:100%}.auth-input::placeholder{color:#9aa08f}.auth-input:focus{background:#fffdfa;border-color:#cb997e;box-shadow:0 0 0 3px #cb997e2e;outline:none}.auth-grid{grid-gap:.75rem 1rem;display:grid;gap:.75rem 1rem;grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.with-prefix{position:relative;width:100%}.prefix{color:#6b705c;left:12px;opacity:.8;position:absolute;top:50%;transform:translateY(-50%)}.with-prefix .auth-input{padding-left:28px}.hint{color:#6b705c;font-size:.9rem;max-width:40%;overflow:hidden;position:absolute;right:12px;text-overflow:ellipsis;top:50%;transform:translateY(-50%);white-space:nowrap}.auth-button{background:#cb997e;border:1px solid #c18f78;border-radius:12px;color:#fff;cursor:pointer;font-family:Playfair Display,serif;font-weight:700;margin-top:.8rem;padding:.7rem;transition:background .2s ease,transform .05s ease;width:100%}.auth-button:hover{background:#b58872}.auth-button:disabled{cursor:default;opacity:.6}.auth-error{color:#a23;margin-top:.4rem}.auth-switch{margin-top:.75rem;text-align:center}.linky{background:#0000;border:none;color:#6b705c;cursor:pointer;font-family:Playfair Display,serif;font-size:1rem;text-decoration:underline}.auth-card,.auth-card *{box-sizing:border-box;max-width:100%}@media (max-width:560px){.auth-grid{grid-template-columns:1fr}}.auth-logo{display:block;height:auto;margin-bottom:1.5rem;margin-left:auto;margin-right:auto;max-width:400px}.auth-wrap{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;padding-top:2rem}.auth-logo{margin-bottom:1rem;width:200px}.auth-card{background:#fffaf0;border:1px solid #b7b7a4;border-radius:12px;box-shadow:0 4px 8px #0000000d;max-width:420px;padding:1.5rem;width:100%}.delete-modal-backdrop{background:#00000073;inset:0;position:fixed;z-index:6000}.delete-modal{background:#fffaf0;border:2px solid #b7b7a4;border-radius:14px;box-shadow:0 18px 40px #00000038;color:#3f3a35;font-family:Playfair Display,serif;left:50%;padding:1.1rem 1.2rem 1rem;position:fixed;top:12%;transform:translateX(-50%);width:min(560px,92vw);z-index:6010}.delete-modal h2{font-size:1.35rem;margin:0 0 .35rem}.delete-modal p{color:#6b705c;margin:0 0 .65rem}.delete-error{background:#ffecec;border:1px solid #f3c1c1;border-radius:8px;color:#8b0000;font-family:Playfair Display,serif;margin:.5rem 0;padding:.5rem .6rem}.delete-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.75rem}.delete-btn{background:#c05746;border:1px solid #b04c3b;color:#fff;font-weight:700}.cancel-btn,.delete-btn{font-family:Playfair Display,serif;padding:.55rem .9rem}.cancel-btn{border:1px solid #b7b7a4;border-radius:10px;cursor:pointer}.badge-toast{align-items:center;background:#ffe8d6;border:2px solid #ddbea9;border-radius:14px;bottom:24px;box-shadow:0 6px 18px #0000001f;color:#6b705c;display:flex;font-family:Playfair Display,serif;gap:12px;max-width:320px;padding:12px 16px;position:fixed;right:20px;z-index:9999}.badge-icon{background:#cb997e;border-radius:10px;box-shadow:inset 0 0 0 3px #b7b7a4;height:40px;width:40px}.badge-text{display:flex;flex-direction:column}.badge-title{font-size:1.05rem;font-weight:700}.badge-desc{font-size:.9rem;opacity:.9}.badge-toast{cursor:pointer}.ach-section{padding:1rem 0}.ach-heading-row{align-items:baseline;display:inline-flex;gap:12px;margin-bottom:.75rem}.ach-reset-link{background:none;border:none;color:#9aa099;cursor:pointer;font-family:Playfair Display,serif;font-size:.95rem;padding:0}.ach-reset-link:hover{color:#6b705c;text-decoration:underline}.ach-grid.circles{grid-gap:28px 32px;align-items:start;display:grid;gap:28px 32px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));justify-items:center}.ach-card{align-items:center;background:#f5f3ef;border:2px solid #e7ddd1;border-radius:50%;box-shadow:0 2px 6px #0000000d;color:#8c9186;display:flex;font-family:Playfair Display,serif;height:120px;justify-content:center;padding:0;text-align:center;transition:background-color .25s ease,border-color .25s ease,color .25s ease,transform .12s ease,box-shadow .2s ease;width:120px}.ach-title{font-size:.9rem;font-weight:800;line-height:1.15;padding:0 8px}.ach-card.locked{background:#dcdcd6;border-color:#b7b7a4}.ach-card.locked .ach-title{color:#a4a89f}.ach-card.locked:hover{cursor:default;filter:brightness(.995)}.ach-card.earned{background:#ffe8d6;border-color:#ddbea9;color:#6b705c;cursor:pointer}.ach-card.earned:hover{box-shadow:0 6px 16px #0000001f;transform:translateY(-2px) scale(1.03)}.ach-card.clicked{animation:ach-pop .26s ease-out}@keyframes ach-pop{0%{transform:scale(1)}60%{transform:scale(1.08)}to{transform:scale(1)}}.ach-backdrop{animation:ach-fade .18s ease-out;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#00000040;inset:0;position:fixed;z-index:3000}.ach-modal{left:50%;max-width:520px;opacity:0;position:fixed!important;top:50%;transform:translate(-50%,-50%) scale(.96);transition:transform .18s ease,opacity .18s ease;width:min(92vw,520px);z-index:3001}.ach-modal[data-open=true]{opacity:1;transform:translate(-50%,-50%) scale(1)}@keyframes ach-fade{0%{opacity:0}to{opacity:1}}@keyframes ach-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.rgc-wrap{align-items:center;display:flex;flex-direction:column;text-align:center}.rgc-title{color:#6b705c;font-family:Playfair Display,serif;font-size:1.2rem;line-height:1.05;margin:0 0 6px}.rgc-candleBox{align-items:flex-end;display:flex;justify-content:center;padding:0}.rgc-candle{display:block;height:100%;max-height:inherit;pointer-events:none;-webkit-user-select:none;user-select:none;width:auto}.rgc-text{color:#6b705c;font-size:1rem;line-height:1.1;margin-top:6px}.profile-page,.rgc-text{font-family:Playfair Display,serif}.profile-page{background:#fffaf0;color:#2d2a26;min-height:100vh;padding:2rem 1rem 3rem}.profile-header{grid-gap:2rem;gap:2rem;grid-template-columns:1fr 300px;margin:0 auto 1.5rem;max-width:1100px}.profile-header,.profile-left{align-items:center;display:grid}.profile-left{grid-gap:1rem;gap:1rem;grid-template-columns:96px 1fr}.profile-right{display:flex;justify-content:center}.avatar{background:#e8e1d6;border-radius:999px;box-shadow:inset 0 0 0 3px #b7b7a4;height:100px;width:100px}.identity .name{color:#3f3a35;font-size:2.1rem;line-height:1.1;margin:0}.identity .username{color:#6b705c;font-size:.95rem;margin-top:.25rem}.identity .bio{color:#6b705c;font-size:1rem;margin-top:.35rem;opacity:.95}.edit-btn{background:#ffe8d6;border:1.5px solid #cb997e;border-radius:10px;color:#6b705c;cursor:pointer;font-family:Playfair Display,serif;margin-top:.5rem;padding:.4rem .7rem}.edit-btn:hover{background:#f7dcc5}.profile-section{margin:0 auto;max-width:1100px}.section-title{color:#3f3a35;font-size:1.4rem;margin:0 0 .75rem}.reader-stats{margin-top:1rem}.stats-bubbles{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,minmax(160px,1fr))}.stat-bubble{background:#ffe8d6;border:2px solid #b7b7a4;border-radius:999px;box-shadow:2px 4px 10px #0000000f;display:grid;height:140px;place-items:center;text-align:center}.stat-bubble .label{color:#6b705c;font-size:.95rem}.stat-bubble .value{color:#6b705c;font-size:1.6rem;font-weight:700;line-height:1.1;margin-top:.15rem}.profile-modal-backdrop{background:#00000059;inset:0;position:fixed;z-index:5000}.profile-modal{background:#fffaf0;border:2px solid #b7b7a4;border-radius:14px;box-shadow:0 18px 40px #0000002e;color:#3f3a35;display:grid;font-family:Playfair Display,serif;grid-template-rows:auto 1fr auto;left:50%;max-height:90vh;overflow:hidden;position:fixed;top:8%;transform:translateX(-50%);width:min(720px,94vw);z-index:5010}.profile-modal-head{align-items:center;border-bottom:1px solid #e7e1d7;display:flex;justify-content:space-between;padding:.9rem 1rem .4rem}.profile-modal-head h3{font-size:1.4rem;margin:0}.modal-x{background:#0000;border:1px solid #b7b7a4;border-radius:999px;cursor:pointer;height:28px;width:28px}.profile-modal-body{grid-gap:.65rem;display:grid;gap:.65rem;overflow:auto;padding:.9rem 1rem 0}.profile-modal-foot{border-top:1px solid #e7e1d7;display:flex;gap:.5rem;justify-content:flex-end;padding:.9rem 1rem 1rem}.edit-label{color:#6b705c}.edit-input,.edit-textarea{background:#fffef8;border:2px solid #b7b7a4;border-radius:12px;color:#3f3a35;font-family:Playfair Display,serif;font-size:1rem;padding:.6rem .8rem;width:90%}.edit-textarea{resize:vertical}.cancel-btn,.save-btn{border:1px solid #b7b7a4;border-radius:10px;font-family:Playfair Display,serif;padding:.55rem .9rem}.cancel-btn{background:#fffaf0;color:#6b705c}.save-btn{background:#cb997e;border-color:#c18f78;color:#fff;font-weight:700}@media (max-width:900px){.profile-header{grid-template-columns:1fr}.profile-right{margin-top:10px}.stats-bubbles{grid-template-columns:repeat(2,1fr)}}.profile-page .section-title{color:#3f3a35!important;font-family:Playfair Display,serif!important;font-size:1.4rem!important;margin:0 0 .75rem!important}.achievements-section .section-title{font-family:Homemade Apple,cursive!important}.profile-page .reader-stats{margin:0 auto 2rem!important;max-width:1100px!important}.profile-page .reader-stats-grid,.profile-page .stats-bubbles{grid-gap:1rem!important;display:grid!important;gap:1rem!important;grid-template-columns:repeat(4,minmax(160px,1fr))!important}.profile-page .rs-card,.profile-page .stat-bubble{background:#ffe8d6!important;border:2px solid #b7b7a4!important;border-radius:999px!important;box-shadow:2px 4px 10px #0000000f!important;display:grid!important;height:140px!important;place-items:center!important;text-align:center!important}.profile-page .rs-label,.profile-page .stat-bubble .label{color:#6b705c!important;font-size:.95rem!important}.profile-page .rs-value,.profile-page .stat-bubble .value{color:#6b705c!important;font-size:1.6rem!important;font-weight:700!important}@media (max-width:900px){.profile-page .reader-stats-grid,.profile-page .stats-bubbles{grid-template-columns:repeat(2,1fr)!important}}.profile-page .profile-header{grid-template-columns:minmax(520px,1fr) 300px!important}.profile-page .identity .name{font-size:2.4rem!important;line-height:1.1!important}.profile-page .identity .username{color:#6b705c!important;font-size:1.05rem!important;letter-spacing:.2px!important;margin-top:.3rem!important}.profile-page .identity .bio{color:#6b705c!important;font-size:1.05rem!important;margin-top:.5rem!important;opacity:.95!important}.profile-page .edit-btn{margin-top:.55rem!important}.profile-page .favorites{margin:0 auto 1.25rem!important;max-width:1100px!important}.profile-page .fav-shelf-wrap{padding-bottom:28px!important;position:relative!important}.profile-page .fav-shelf-rail{grid-gap:.9rem!important;display:grid!important;gap:.9rem!important;grid-auto-columns:max-content!important;grid-auto-flow:column!important;overflow-x:auto!important;padding:.25rem .25rem .75rem!important;scroll-snap-type:x proximity!important}.profile-page .fav-book{scroll-snap-align:start!important}.profile-page .wood-shelf{background:url(/static/media/wood-shelf-texture.e17d462e181a69c2cf27.png) 50%/cover no-repeat;border-radius:4px!important;bottom:0;box-shadow:0 6px 8px #00000014!important;height:26px!important;left:0;pointer-events:none!important;position:absolute!important;right:0}@supports (background:linear-gradient(#000,#000)){.profile-page .wood-shelf{background:linear-gradient(180deg,#0000000f,#0000) 0 0/100% 100%,repeating-linear-gradient(90deg,#c49a7a,#c49a7a 6px,#b68666 0,#b68666 10px,#cfa081 0,#cfa081 14px)}}.profile-page .achievements-section,.profile-page .favorites,.profile-page .reader-stats{margin:0 auto 1.5rem!important;max-width:1100px!important;padding-left:0!important;padding-right:0!important}.profile-page .achievements-section .section-title,.profile-page .favorites .section-title,.profile-page .reader-stats .section-title{margin:0 0 .75rem!important}.profile-page .achievements-section .section-title,.profile-page .favorites .section-title,.profile-page .reader-stats .section-title{font-family:Homemade Apple,cursive!important;font-weight:400!important}.profile-modal .username-field{position:relative}.profile-modal .username-field .at{color:#6b705c;font-size:1rem;left:10px;opacity:.7;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.profile-modal .username-field .username-input{padding-left:26px!important;padding-right:96px!important}.profile-modal .status-pill{border:1px solid #0000;border-radius:999px;font-size:.95rem;line-height:1.1;padding:.15rem .55rem;position:absolute;right:10px;top:50%;transform:translateY(-50%);white-space:nowrap}.profile-modal .status-pill.ok{background:#eaf7ea;border-color:#a8d5b1;color:#2f7d32}.profile-modal .status-pill.bad{background:#fdecec;border-color:#f1b5b5;color:#a33}.profile-modal .status-pill.checking{background:#f3efe6;border-color:#d9d3c4;color:#6b705c}.profile-modal .pill-editor{align-items:center;display:flex;gap:.5rem}.profile-modal .pill-add-btn{background:#ffe8d6;border:1px solid #cb997e;border-radius:10px;color:#6b705c;cursor:pointer;font-family:Playfair Display,serif;padding:.45rem .8rem}.profile-modal .pill-add-btn:hover{background:#f7dcc5}.profile-modal .pill-list{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.5rem}.profile-modal .pill.removable{align-items:center;background:#ffe8d6;border:1px solid #cb997e;border-radius:999px;box-shadow:0 2px 4px #0000000d;color:#6b705c;display:inline-flex;font-size:.9rem;gap:.35rem;padding:.3rem .6rem}.profile-modal .pill.removable .pill-x{background:#0000;border:none;color:#6b705c;cursor:pointer;font-size:1rem;line-height:1;padding:0 .1rem}.profile-modal .pill.removable .pill-x:hover{color:#3f3a35}.username-field{align-items:center;display:flex;gap:6px;max-width:320px;position:relative}.username-field .at{color:#6b705c;font-size:1rem;left:10px;pointer-events:none;position:absolute}.username-input{flex:1 1;max-width:200px;min-width:120px;padding-left:22px}.status-pill{border-radius:12px;font-family:Playfair Display,serif;font-size:.85rem;padding:2px 8px;white-space:nowrap}.username-field.ok .status-pill{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.username-field.bad .status-pill{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.username-field.checking .status-pill{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404}.friend-btn{background:#fbebe0;border:1px solid #b7b7a4;border-radius:12px;color:#6b705c;cursor:pointer;font-family:Playfair Display,serif;font-weight:600;padding:.45rem .8rem}.friend-btn:hover{background:#ffe8d6;border-color:#cb997e}.friend-btn:disabled{cursor:default;opacity:.75}.friend-secondary{background:#fff;border:1px solid #e7e1d7}.friend-secondary:hover{background:#fffaf0}:root{--ink:#2f2a24;--sage:#6b705c;--sage-2:#8c927f;--beige:#e7e1d7;--beige-2:#ddbea9;--paper:#fffaf2}.predictions-page{color:#2f2a24;color:var(--ink);font-family:Playfair Display,serif;margin:24px auto 56px;max-width:980px;padding:0 16px}.predictions-title{color:#6b705c;color:var(--sage);font-size:clamp(28px,2.4vw + 12px,40px);margin:0 0 12px}.predictions-form{background:#fffaf2;background:var(--paper);border:1px solid #ddbea9;border:1px solid var(--beige-2);border-radius:16px;box-shadow:0 10px 26px #0000000f;margin-bottom:22px;overflow:hidden;padding:18px 18px 16px}.row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 180px 180px;margin-bottom:14px}@media (max-width:860px){.row{grid-template-columns:1fr}}.field{display:block}.field--sm .input{height:44px}.label{color:#6b705c;color:var(--sage);display:block;font-weight:800;margin:6px 0 8px}.input,.textarea{background:#fff;border:1.5px solid #ddbea9;border:1.5px solid var(--beige-2);border-radius:12px;box-shadow:inset 0 1px 0 #cb997e24;box-sizing:border-box;color:#2f2a24;color:var(--ink);outline:none;padding:12px 14px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.input{height:44px}.input:focus,.textarea:focus{border-color:#cb997e;border-color:var(--terracotta);box-shadow:0 0 0 3px #cb997e38}.textarea{min-height:150px;resize:vertical}.form-actions{margin-top:10px}.btn{background:#cb997e;background:var(--terracotta);border:0;border-radius:999px;box-shadow:0 6px 18px #cb997e59,inset 0 -2px 0 #00000014;color:#fff;font-weight:800;padding:.78rem 1.15rem;transition:transform .05s ease-in-out,filter .15s ease}.btn:hover{filter:brightness(1.04)}.btn[disabled]{cursor:default;opacity:.7}.btn.ghost{background:#fff;border:2px solid #e7e1d7;border:2px solid var(--beige);box-shadow:none;color:#6b705c;color:var(--sage)}.btn.ghost.danger-outline,.btn.ghost.subtle{border-radius:14px;padding:.6rem 1rem}.btn.ghost.danger-outline{border-color:#b26b65;color:#b26b65}.btn.ghost.subtle:hover{border-color:#cfc7bc}.btn.ghost.danger-outline:hover{border-color:#a15d58}.section-head{color:#6b705c;color:var(--sage);font-size:22px;margin:22px 0 10px}.muted{color:#8c927f;color:var(--sage-2)}.cards{grid-gap:12px;display:grid;gap:12px;list-style:none;margin:0;padding:0}.card{background:#fffdf8;border:1px solid #e7e1d7;border:1px solid var(--beige);border-radius:16px;box-shadow:0 6px 20px #0000000a;padding:12px 14px}.card.correct{border-color:#bdd8bf;box-shadow:0 6px 18px #5082500f}.card.incorrect{border-color:#e4bcbc;box-shadow:0 6px 18px #a050500d}.card-head{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:6px}.card-title{align-items:baseline;display:flex;flex-wrap:wrap;gap:10px}.card .book{font-weight:800}.card .meta{color:#8c927f;color:var(--sage-2)}.pred{line-height:1.5;margin:.45rem 0 .7rem}.badge{--pad-y:.28rem;--pad-x:.8rem;border:1px solid #0000;border-radius:999px;display:inline-block;font-weight:800;letter-spacing:.2px;padding:var(--pad-y) var(--pad-x)}.badge.pending{background:#f0f2eb;border-color:#d3d8c8;color:#5b5f52}.badge.correct{background:#e9f3ea;border-color:#bdd8bf;color:#315a35}.badge.incorrect{background:#f8eaea;border-color:#e4bcbc;color:#7b3b3b}.actions{flex-wrap:wrap;gap:10px}.people-wrap{color:#3f3a35;font-family:Playfair Display,serif;margin:24px auto;max-width:1100px;padding:0 16px 56px}.search-hero{margin-bottom:14px;text-align:left}.search-title{font-size:clamp(28px,4.2vw,48px);margin:0 0 10px}.search-pill{align-items:center;background:#ffe8d6;border:2px solid #ddbea9;border-radius:999px;box-shadow:0 2px 12px #0000000a;display:inline-flex;gap:10px;padding:10px 12px 10px 16px}.ps-input{background:#0000;border:none;color:#3f3a35;font-family:inherit;font-size:18px;outline:none;width:min(720px,78vw)}.ps-input::placeholder{color:#6b705c;opacity:.75}.ps-button{background:#cb997e;border:1.5px solid #b7b7a4;border-radius:999px;color:#fff;cursor:pointer;font-family:inherit;padding:8px 16px}.ps-button:hover{filter:brightness(1.03)}.result-title{color:#6b705c;margin-top:10px}.ps-list{grid-gap:12px;display:grid;gap:12px;list-style:none;margin:16px 0 0;padding:0}.ps-card{grid-gap:14px;align-items:center;background:#fffaf0;border:2px solid #ddbea9;border-radius:14px;box-shadow:0 2px 8px #0000000a;display:grid;gap:14px;grid-template-columns:64px 1fr auto;padding:12px 14px}.ps-card:hover{box-shadow:0 6px 18px #0000000f}.avatar{background:#fff;border:1px solid #b7b7a4;border-radius:50%;height:64px;object-fit:cover;width:64px}.meta{min-width:0}.name{color:#3f3a35;font-size:20px;font-weight:700;text-decoration:none}.name:hover{text-decoration:underline}.bio,.username{color:#6b705c}.bio{margin-top:2px;max-width:56ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.actions{align-items:center;display:flex;gap:8px}.confirm-btn,.soft-btn{border-radius:12px;font-family:inherit;font-weight:600;padding:.45rem .9rem;text-decoration:none;white-space:nowrap}.soft-btn{background:#fbebe0;border:1px solid #b7b7a4;color:#6b705c}.soft-btn:hover{background:#ffe8d6}.confirm-btn{background:#cb997e;border:1px solid #b7b7a4;color:#fff}.confirm-btn:hover{filter:brightness(1.04)}.lock-pill{background:#fff;border:1px solid #e7e1d7;border-radius:12px;color:#6b705c;padding:.45rem .9rem}.ps-empty{color:#6b705c;margin-top:20px}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.ps-error{background:#fff2f2;border:1px solid #f0c9c9;border-radius:10px;color:#8b3a3a;margin-top:16px;padding:10px 12px}.skeleton{overflow:hidden;position:relative}.shimmer{background:#eee1d6;position:relative}.shimmer:after{animation:shimmer 1.25s infinite;background:linear-gradient(90deg,#0000,#ffffff8c,#0000);content:"";inset:0;position:absolute;transform:translateX(-100%)}@keyframes shimmer{to{transform:translateX(100%)}}.skeleton .avatar{background:#eee1d6;border:none}.skeleton .line{border-radius:6px;height:14px;margin:6px 0;width:38ch}.skeleton .line.short{width:16ch}.skeleton .btn{border-radius:12px;height:36px;width:110px}.friends-page{color:#3f3a35;font-family:Playfair Display,serif;margin:28px auto;max-width:980px;padding:0 16px 40px}.friends-hero{grid-gap:16px;align-items:end;display:grid;gap:16px;grid-template-columns:1fr auto;margin-bottom:20px}.friends-title{font-size:clamp(28px,4vw,42px);margin:0}.friends-sub{color:#6b705c;margin:6px 0 0;opacity:.95}.friends-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.chip{align-items:center;background:#ffe8d6;border:1px solid #ddbea9;border-radius:999px;color:#6b705c;display:inline-flex;font-weight:600;gap:6px;padding:.3rem .7rem;white-space:nowrap}.friends-error{background:#fff2f2;border:1px solid #f0c9c9;border-radius:12px;color:#8b3a3a;margin:12px 0 18px;padding:10px 12px}.friend-section{background:#fffbf6;border:2px solid #ddbea9;border-radius:14px;box-shadow:0 2px 8px #0000000a;margin-top:18px}.friend-section-head{align-items:center;border-bottom:1px dashed #e7e1d7;display:flex;gap:10px;padding:12px 14px 8px}.friend-section-title{font-size:22px;margin:0}.friend-section-head .linky{background:#fffaf0;border:1px solid #b7b7a4;border-radius:10px;color:#596e52;margin-left:auto;padding:.35rem .6rem;text-decoration:none}.friend-section-head .linky:hover{background:#ffe8d6;border-color:#cb997e}.friend-section-body{padding:12px 14px 14px}.friend-list{grid-gap:10px;display:grid;gap:10px;list-style:none;margin:0;padding:0}.friend-row{grid-gap:12px;align-items:center;background:#fff;border:1px solid #e7e1d7;border-radius:12px;display:grid;gap:12px;grid-template-columns:1fr auto;padding:10px 12px}.friend-person{align-items:center;display:flex;gap:10px;min-width:0}.friend-avatar{border:1px solid #b7b7a4;border-radius:50%;height:44px;object-fit:cover;width:44px}.friend-person-meta{min-width:0}.friend-name{color:#3f3a35;text-decoration:none}.friend-name:hover{text-decoration:underline}.friend-handle{color:#6b705c;font-size:14px}.row-actions{display:flex;gap:8px}.btn{border-radius:10px;cursor:pointer;font-family:Playfair Display,serif;font-weight:600;padding:.45rem .9rem;transition:transform .02s ease,background .2s ease,border-color .2s ease}.btn:active{transform:translateY(1px)}.btn-primary{background:#cb997e;border:1px solid #b7b7a4;color:#fff}.btn-primary:hover{background:#c1886b}.btn-ghost{background:#fff;border:1px solid #e7e1d7;color:#6b705c}.btn-ghost:hover{background:#ffe8d6;border-color:#cb997e}.muted{color:#6b705c;opacity:.95}:root{--font-serif:"Playfair Display",Georgia,serif;--font-ui:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}.post-card{background:#fffaf0;background:var(--cream);box-shadow:0 12px 40px #cb997e1a;padding:12px 14px}.post-head{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:44px 1fr auto}.post-avatar{background:#fff;border:1px solid #b7b7a4;border:1px solid var(--sage);border-radius:50%;height:44px;object-fit:cover;width:44px}.post-head-meta{display:grid}.post-name{color:#3f3a35;color:var(--ink);font-family:Playfair Display,Georgia,serif;font-family:var(--font-serif)}.post-meta{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-family:var(--font-ui);font-size:.95rem}.post-del{background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:10px;color:#6b705c;color:var(--sage-deep);cursor:pointer;padding:.34rem .7rem}.post-del:hover{background:#ffe8d6;border-color:#cb997e;border-color:var(--terracotta)}.post-body{margin:12px 2px 6px}.post-text{font-family:Playfair Display,Georgia,serif;font-family:var(--font-serif);line-height:1.45;white-space:pre-wrap}.book-inline{grid-gap:10px;align-items:center;background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:12px;display:grid;gap:10px;grid-template-columns:auto 1fr;margin:10px 0;padding:8px 10px}.post-book-cover{border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:8px;height:84px;object-fit:cover;width:56px}.book-inline-meta{grid-gap:2px;display:grid;gap:2px}.book-title{color:#3f3a35;color:var(--ink);font-family:Playfair Display,Georgia,serif;font-family:var(--font-serif);font-weight:800}.book-note{color:#6b705c;color:var(--sage-deep);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-family:var(--font-ui)}.poll{grid-gap:8px;display:grid;gap:8px;margin:10px 0 6px}.poll-title{font-weight:800;margin-bottom:2px}.poll-opt,.poll-title{font-family:Playfair Display,Georgia,serif;font-family:var(--font-serif)}.poll-opt{background:#fff;border:1px solid #cb997e;border:1px solid var(--terracotta);border-radius:12px;cursor:pointer;overflow:hidden;padding:10px 12px;position:relative;text-align:left}.poll-opt.you{box-shadow:inset 0 0 0 3px #cb997e24,inset 0 0 0 1px #cb997e;box-shadow:0 0 0 3px #cb997e24 inset,0 0 0 1px var(--terracotta) inset}.poll-opt:hover{background:#fff9f3}.poll-fill{background:linear-gradient(90deg,#f0d7c7,#fff1e8);inset:0;opacity:.65;pointer-events:none;position:absolute;width:0;width:var(--w,0)}.poll-label{align-items:center;display:flex;font-weight:600;justify-content:space-between;position:relative;z-index:1}.poll-option{padding-right:10px}.poll-pct{color:#7a6a5e;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-family:var(--font-ui)}.post-actions{display:flex;gap:10px;margin:10px 2px 6px}.action{align-items:center;background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:999px;color:#3f3a35;color:var(--ink);cursor:pointer;display:inline-flex;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-family:var(--font-ui);gap:8px;padding:.4rem .8rem}.action:hover{background:#fff7ef}.action.active{background:#fff7f0;border-color:#cb997e;border-color:var(--terracotta);color:#9b6c57}.action svg{display:block;height:18px;width:18px}.action .count{min-width:1ch}.action .label{font-family:Playfair Display,Georgia,serif;font-family:var(--font-serif)}.comment-new{grid-template-columns:auto auto;margin-top:6px;max-width:100%;width:fit-content}.comment-input{font-family:var(--font-serif);width:min(640px,82vw)}.comment-send{margin-left:2px}.pc-modal{align-items:center;background:#00000047;display:flex;inset:0;justify-content:center;padding:18px;position:fixed;z-index:200}.pc-modal-card{background:#fff;border:2px solid #e7e1d7;border:2px solid var(--line);border-radius:18px;box-shadow:0 22px 70px #00000040;max-height:90vh;overflow:auto;padding:14px;width:min(640px,92vw)}.pc-modal-card *{box-sizing:border-box;font-family:Playfair Display,Georgia,serif;font-family:var(--font-serif)}.pc-modal-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.pc-modal-title{color:#3f3a35;color:var(--ink);font-size:1.55rem;font-weight:800}.pc-modal-sub{margin:6px 0 10px}.pc-modal-sub,.pc-x{color:#6b705c;color:var(--sage-deep)}.pc-x{align-items:center;background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:50%;cursor:pointer;display:flex;height:32px;justify-content:center;width:32px}.pc-x:hover{background:#fff0e7;border-color:#cb997e;border-color:var(--terracotta)}.pc-chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}.pc-chip{background:#fff;border:2px solid #b7b7a4;border:2px solid var(--sage);border-radius:999px;color:#6b705c;color:var(--sage-deep);cursor:pointer;font-size:1.05rem;padding:.42rem .9rem;transition:.15s}.pc-chip:hover{background:#f7f5f0}.pc-chip.active{background:#e9efe2;border-color:#a9b399;color:#445240}.pc-note-label{color:#6b705c;color:var(--sage-deep);margin:0 0 6px}.pc-note{background:#fffdf8;border:2px solid #ddbea9;border-radius:12px;min-height:110px;padding:.7rem .8rem;resize:vertical;width:100%}.pc-note:focus{border-color:#cdb8a9;box-shadow:0 0 0 3px #fff1e8;outline:none}.pc-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}.pc-btn{background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:12px;cursor:pointer;font-weight:800;padding:.52rem 1rem}.pc-btn.ghost:hover{background:#fff0e7;border-color:#cb997e;border-color:var(--terracotta)}.pc-btn.primary{background:#cb997e;background:var(--terracotta);border-color:#c18f78;color:#fff}.pc-btn.primary:disabled{cursor:not-allowed;opacity:.55}.comments{grid-gap:8px;display:grid;gap:8px;margin-top:10px}.comment{grid-gap:10px;align-items:start;display:grid;gap:10px;grid-template-columns:36px 1fr}.comment-ava{background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:999px;height:36px;object-fit:cover;width:36px}.comment-bubble{grid-gap:6px;background:#fff;border:0;border-radius:12px;box-shadow:inset 0 1px 0 #00000008;display:grid;gap:6px;padding:8px 10px}.comment-head{align-items:baseline;display:flex;gap:8px}.comment-name{color:#3f3a35;color:var(--ink);font-family:Playfair Display,Georgia,serif;font-weight:800}.comment-meta{color:#6b705c;color:var(--sage-deep);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:.92rem}.comment-text{font-family:Playfair Display,Georgia,serif;white-space:pre-wrap}.comment-new{grid-gap:8px;display:grid;grid-template-columns:1fr auto;margin-top:10px}.comment-input{background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:12px;font-family:Playfair Display,Georgia,serif;padding:.6rem .75rem}.comment-input:focus{border-color:#cdb8a9;box-shadow:0 0 0 3px #fff1e8;outline:none}.comment-send{align-items:center;background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:12px;color:#55624f;cursor:pointer;display:flex;height:38px;justify-content:center;width:38px}.comment-send:hover{background:#fff7ef}.comment-new{align-items:center;display:flex;gap:8px}.comment-input{max-width:100%;width:100%}.comment-send{margin:0!important;position:static!important}:root{--cream:#fffaf0;--paper:#fdfaf6;--terracotta:#cb997e;--terracotta-deep:#c18f78;--sage:#b7b7a4;--sage-deep:#6b705c;--ink:#3f3a35;--line:#e7e1d7;--shadow:0 10px 36px #cb997e1f}.community-page *{box-sizing:border-box;color:#3f3a35;color:var(--ink);font-family:Playfair Display,Georgia,serif}.community-title{color:#6b705c;color:var(--sage-deep);font-family:Homemade Apple,cursive;font-size:clamp(32px,4.5vw,56px);margin:8px 0 20px;text-align:center}.community-grid{grid-gap:28px;align-items:start;display:grid;gap:28px;grid-template-columns:minmax(0,680px) 340px;margin:0 auto 64px;max-width:1120px;padding:0 16px}@media (max-width:980px){.community-grid{gap:22px;grid-template-columns:1fr}}.np-composer{background:#fdfaf6;background:var(--paper);border:2px solid #ddbea9;border-radius:16px;box-shadow:0 10px 36px #cb997e1f;box-shadow:var(--shadow);padding:12px}.np-composer .np-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.np-composer .np-title{font-size:1.1rem;font-weight:800}.np-composer .np-share{background:#cb997e;background:var(--terracotta);border:1px solid #c18f78;border:1px solid var(--terracotta-deep);border-radius:12px;color:#fff;cursor:pointer;font-weight:800;padding:.45rem .9rem}.np-composer .np-share:disabled{cursor:not-allowed;opacity:.6}.np-textarea{background:#fffdf8;border:2px solid #ddbea9;border-radius:12px;color:#3f3a35;color:var(--ink);min-height:96px;padding:12px 14px;resize:vertical;width:100%}.np-tools{align-items:center;border-top:1px dashed #e7e1d7;border-top:1px dashed var(--line);display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;padding-top:8px}.np-tags-label{color:#6b705c;color:var(--sage-deep)}.np-chips{display:flex;gap:8px}.np-chip{background:#fff;border:2px solid #b7b7a4;border:2px solid var(--sage);border-radius:999px;color:#6b705c;color:var(--sage-deep);padding:.38rem .8rem}.np-icons{display:flex;gap:6px;margin-left:auto}.np-icon{align-items:center;background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:10px;color:#6b705c;color:var(--sage-deep);display:flex;height:34px;justify-content:center;width:34px}.feed-tabs{display:flex;gap:12px;margin:16px 0 6px}.tab{background:#fff;border:2px solid #b7b7a4;border:2px solid var(--sage);border-radius:999px;color:#6b705c;color:var(--sage-deep);cursor:pointer;padding:.42rem 1rem}.tab.active{background:#fff7f0;border-color:#cb997e;border-color:var(--terracotta);color:#9b6c57}.feed-list{margin-top:12px}.feed-list>*+*{margin-top:18px}.post-card{background:#fdfaf6;background:var(--paper);border:2px solid #ddbea9;border-radius:16px;box-shadow:0 10px 36px #cb997e1f;box-shadow:var(--shadow);padding:14px 14px 16px}.post-name{font-weight:800}.post-meta{color:#6b705c;color:var(--sage-deep)}.feed-head{align-items:center;display:flex;gap:10px}.feed-ava{border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:999px;height:44px;object-fit:cover;width:44px}.feed-meta{line-height:1.15}.feed-name{font-weight:800}.feed-sub{font-size:.95rem}.delete-btn,.feed-sub{color:#6b705c;color:var(--sage-deep)}.delete-btn{background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:10px;cursor:pointer;margin-left:auto;padding:.25rem .6rem}.feed-body{margin-top:10px}.feed-book{align-items:center;background:#fff;border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:12px;display:flex;gap:10px;margin-top:10px;padding:8px 10px}.feed-book-cover{border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:8px;height:84px;object-fit:cover;width:56px}.feed-book-title{font-weight:700}.feed-book-author{color:#6b705c;color:var(--sage-deep)}.post-image{border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:14px;display:block;height:auto;max-height:480px;object-fit:cover;width:100%}.side-col{height:fit-content;position:sticky;top:76px}@media (max-width:980px){.side-col{position:static}}.side-card{background:#fdfaf6;background:var(--paper);border:2px solid #ddbea9;border-radius:16px;box-shadow:0 10px 36px #cb997e1f;box-shadow:var(--shadow);padding:12px}.side-card+.side-card{margin-top:16px}.side-title{font-weight:800;margin-bottom:6px}.friends-list{grid-gap:8px;display:grid;gap:8px;list-style:none;margin:0;padding:0}.friends-list li{align-items:center;display:flex;gap:10px}.friend-ava{border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:999px;height:36px;object-fit:cover;width:36px}.friend-meta{line-height:1.05}.friend-name{font-weight:700}.friend-user{color:#6b705c;color:var(--sage-deep);font-size:.95rem}.status-dot{background:#94c08b;border-radius:999px;height:8px;margin-left:auto;width:8px}.side-muted{color:#6b705c;color:var(--sage-deep)}.trend-list{grid-gap:6px;display:grid;gap:6px;list-style:none;margin:0;padding:0}.trend-list .dot{background:#7f9b72;border-radius:999px;display:inline-block;height:6px;margin-right:8px;transform:translateY(-1px);width:6px}.trend-text{color:#6b705c;color:var(--sage-deep)}.reading-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,56px)}.reading-cover{border:1px solid #e7e1d7;border:1px solid var(--line);border-radius:8px;height:84px;object-fit:cover;width:56px}.feed-empty{color:#6b705c;color:var(--sage-deep);margin:8px 2px 0}button,input,textarea{font-family:Playfair Display,Georgia,serif}.post-card img{border-radius:12px;display:block;height:auto;max-width:100%}.poll .poll-fill{width:0;width:var(--w,0)}body{background-color:#fdfaf6;font-family:Playfair Display,serif;margin:0}
/*# sourceMappingURL=main.fa13381d.css.map*/