:root{--bg: #FBF8F2;--surface: #FFFFFF;--surface-2: #F4EFE6;--ink: #2C2A26;--ink-soft: #6E675C;--ink-faint: #9A9286;--line: rgba(44, 42, 38, .12);--line-soft: rgba(44, 42, 38, .07);--accent: #5B7553;--accent-ink: #3C5235;--tone-a-bg: #E7EFF7;--tone-a-ink: #2E5B8A;--tone-b-bg: #E5F1EA;--tone-b-ink: #2C7A57;--tone-c-bg: #F6E9DD;--tone-c-ink: #9A5A2C;--gold: #B08431;--radius: 10px;--radius-lg: 14px;--shadow: 0 1px 2px rgba(44, 42, 38, .06), 0 8px 24px rgba(44, 42, 38, .05);--serif: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, "Times New Roman", serif;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}:root[data-theme=dark]{--bg: #1A1916;--surface: #232220;--surface-2: #2E2C28;--ink: #ECE7DD;--ink-soft: #B0A99B;--ink-faint: #837C6F;--line: rgba(236, 231, 221, .14);--line-soft: rgba(236, 231, 221, .08);--accent: #8FAE84;--accent-ink: #C7DABE;--tone-a-bg: #1F3247;--tone-a-ink: #A9CBEC;--tone-b-bg: #1E3A2C;--tone-b-ink: #9FD9BC;--tone-c-bg: #3a2c1d;--tone-c-ink: #E0B387;--gold: #D6A951;--shadow: 0 1px 2px rgba(0, 0, 0, .3), 0 8px 24px rgba(0, 0, 0, .25)}*{box-sizing:border-box}html{color-scheme:light dark}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.25;margin:0}button{font-family:inherit;cursor:pointer}::selection{background:#5b755333}.app{max-width:1120px;margin:0 auto;padding:0 32px 80px}.reading{max-width:900px}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 0 16px;border-bottom:1px solid var(--line-soft);margin-bottom:30px}.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.brand-btn{border:none;background:none;padding:0;text-align:left;cursor:pointer}.brand-btn:hover .brand-mark{color:var(--accent-ink)}.brand-badge{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;background:var(--accent);color:#fbf8f2;flex-shrink:0;transition:background .18s ease}.brand-btn:hover .brand-badge{background:var(--accent-ink)}.brand-mark{font-family:var(--serif);font-size:22px;font-weight:600;letter-spacing:.2px;color:var(--ink)}.brand-tag{font-size:13px;color:var(--ink-faint);white-space:nowrap}.topbar-right{font-size:13px;color:var(--ink-soft)}.theme-toggle{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:999px;padding:6px 12px;font-size:13px;white-space:nowrap;flex-shrink:0}.theme-toggle:hover{background:var(--surface-2);color:var(--ink)}.theme-toggle svg{display:block}.back-link{border:none;background:none;color:var(--ink-soft);font-size:14px;padding:0;margin-bottom:18px}.back-link:hover{color:var(--accent-ink)}.lib-head{margin-bottom:26px}.lib-title{font-size:30px}.lib-sub{color:var(--ink-soft);font-size:15px;margin:4px 0 0}.shelf{margin-bottom:34px}.shelf-name{font-size:18px;margin-bottom:14px;display:flex;align-items:baseline;gap:8px}.shelf-count{font-size:13px;color:var(--ink-faint);font-family:var(--sans)}.shelf-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:24px 22px}.spine{border:none;background:none;padding:0;text-align:left;display:flex;flex-direction:column;gap:10px}.spine-cover{position:relative;aspect-ratio:7 / 9;border-radius:8px;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:flex-start;gap:6px;padding:14px 12px;color:#f3e7d6;transition:transform .18s ease,box-shadow .18s ease;transform:perspective(900px) rotateY(-7deg);transform-origin:center}.spine:not(.spine-soon):hover .spine-cover{transform:perspective(900px) rotateY(-4deg) translateY(-3px);box-shadow:0 12px 30px #00000042}.spine-cover .cover-img,.spine-cover .cover-scrim,.spine-cover .cover-art{border-radius:inherit}.spine-cover-title{font-family:var(--serif);font-size:16px;line-height:1.18}.spine-cover-author{font-size:11px;opacity:.82}.spine-badge{position:absolute;bottom:10px;left:12px;font-size:9.5px;letter-spacing:.4px;text-transform:uppercase;background:#ffffffeb;color:#3c5235;border-radius:4px;padding:1px 6px;font-weight:600}.spine-badge.soon{background:#00000059;color:#f3e7d6}.spine-soon{cursor:default}.spine-soon .spine-cover{opacity:.82}.spine-meta{display:flex;flex-direction:column;gap:1px}.spine-title{font-size:14px;line-height:1.3}.spine-author{font-size:12.5px;color:var(--ink-soft)}.spine-progress{display:flex;align-items:center;gap:7px;margin-top:5px}.spine-progress-bar{flex:1;height:5px;border-radius:3px;background:var(--surface-2);overflow:hidden}.spine-progress-bar>i{display:block;height:100%;background:var(--accent);border-radius:3px}.spine-progress-pct{font-size:11px;color:var(--ink-faint)}.fogmap{display:flex;flex-direction:column;gap:14px}.fog-vol{display:grid;grid-template-columns:78px 1fr;align-items:center;gap:12px}.fog-vol-unlabeled{grid-template-columns:1fr}.fog-vol-label{font-family:var(--serif);font-size:14px;color:var(--ink-soft);text-align:right}.fog-row{display:flex;gap:6px}.fog-cell{position:relative;flex-basis:0;height:44px;border-radius:7px;overflow:hidden;border:1px solid var(--line);background:var(--surface-2);min-width:30px}.fog-cell.fog{border-style:dashed;opacity:.5}.fog-cell.current{border-color:var(--accent);box-shadow:0 0 0 2px #8fae8459}.fog-fill{position:absolute;inset:0 auto 0 0;background:var(--accent);opacity:.32;transition:width .3s ease}.fog-cell.current .fog-fill{opacity:.5}.fog-cell-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--ink-soft);font-weight:500}.fog-cell.read .fog-cell-label{color:var(--accent-ink)}.fog-legend{display:flex;gap:20px;margin-top:18px;font-size:13px;color:var(--ink-soft)}.fog-legend span{display:inline-flex;align-items:center;gap:7px}.fog-legend .dot{width:12px;height:12px;border-radius:4px;display:inline-block}.fog-legend .dot.read{background:var(--accent);opacity:.5}.fog-legend .dot.current{background:var(--accent);box-shadow:0 0 0 2px #8fae8459}.fog-legend .dot.fog{background:var(--surface-2);border:1px dashed var(--line)}.now{display:grid;grid-template-columns:96px 1fr;gap:20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);margin-bottom:22px}.cover{width:96px;height:142px;border-radius:6px;overflow:hidden;background:linear-gradient(160deg,#6b3a2e,#8a5a3c);display:flex;flex-direction:column;justify-content:space-between;padding:12px 10px;color:#f3e7d6;box-shadow:var(--shadow)}.cover-title{font-family:var(--serif);font-size:15px;line-height:1.15}.cover-author{font-size:10px;opacity:.85;letter-spacing:.3px;text-transform:uppercase}.now-body{display:flex;flex-direction:column}.kicker{font-size:12px;letter-spacing:.8px;text-transform:uppercase;color:var(--accent);font-weight:600}.now-title{font-size:26px;margin:4px 0 2px}.now-author{color:var(--ink-soft);font-size:14px;margin-bottom:14px}.pos-label{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:6px}.pos-where{font-family:var(--serif);font-size:16px}.pos-pct{font-size:13px;color:var(--ink-soft)}.progress{height:7px;border-radius:4px;background:var(--surface-2);overflow:hidden}.progress>span{display:block;height:100%;background:var(--accent);border-radius:4px;transition:width .25s ease}.stepper{display:flex;align-items:center;gap:12px;margin-top:14px}.stepper input[type=range]{flex:1;accent-color:var(--accent)}.step-btn{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.step-btn:hover{background:var(--surface-2)}.step-btn:disabled{opacity:.4;cursor:default}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:26px 0 22px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{border:none;background:none;padding:10px 14px;font-size:15px;color:var(--ink-soft);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;flex-shrink:0}.tab.active{color:var(--ink);border-bottom-color:var(--accent);font-weight:500}.tab .count{font-size:12px;color:var(--ink-faint);margin-left:5px}.catchup-btn{margin-left:auto;align-self:center;border:1px solid var(--accent);color:var(--accent-ink);background:var(--tone-b-bg);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:500;white-space:nowrap;flex-shrink:0}.catchup-btn:hover{background:#d9ebe0}.section-hint{color:var(--ink-soft);font-size:14px;margin:0 0 18px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:14px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow)}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.fam-name{font-family:var(--serif);font-size:18px}.chip{font-size:11px;font-weight:600;padding:2px 9px;border-radius:999px;letter-spacing:.2px}.chip.tone-a{background:var(--tone-a-bg);color:var(--tone-a-ink)}.chip.tone-b{background:var(--tone-b-bg);color:var(--tone-b-ink)}.chip.tone-c{background:var(--tone-c-bg);color:var(--tone-c-ink)}.fam-blurb{font-size:12.5px;color:var(--ink-faint);margin-bottom:8px}.person{padding:9px 0;border-top:1px solid var(--line-soft);cursor:pointer}.person:hover .person-name{color:var(--accent-ink)}.person-name{font-size:15.5px}.person-alt{font-size:12.5px;color:var(--ink-faint);margin-left:6px}.person-role{font-size:13px;color:var(--ink-soft);margin-top:1px}.person.fresh .badge-new{font-size:10px;font-weight:600;color:var(--gold);border:1px solid var(--gold);border-radius:4px;padding:0 5px;margin-left:8px;vertical-align:middle}.notes{display:flex;flex-direction:column;gap:12px}.note{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);border-left:3px solid var(--accent);padding:14px 16px;box-shadow:var(--shadow)}.note h4{font-size:16px;margin-bottom:5px}.note p{margin:0;font-size:14.5px;color:var(--ink-soft)}.note .evergreen-tag{font-size:10px;color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:0 5px;margin-left:8px;vertical-align:middle}.empty{color:var(--ink-faint);font-size:14px;padding:26px;text-align:center;border:1px dashed var(--line);border-radius:var(--radius)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:56px 28px;margin:8px 0;border:1px dashed var(--line);border-radius:var(--radius);background:var(--surface)}.empty-title{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--ink);margin:0}.empty-body{font-size:15px;color:var(--ink-faint);max-width:42ch;margin:0;line-height:1.5}.empty-cta{margin-top:10px;display:inline-flex;align-items:center;padding:10px 20px;border-radius:999px;background:var(--accent);color:#fbf8f2;font-size:14px;font-weight:500;text-decoration:none;transition:background .18s ease}.empty-cta:hover{background:var(--accent-ink)}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c2a2652;display:flex;justify-content:flex-end;z-index:50}.drawer{width:min(380px,90vw);background:var(--bg);height:100%;padding:24px;box-shadow:-8px 0 30px #0000001f;overflow-y:auto;animation:slidein .18s ease}@keyframes slidein{0%{transform:translate(20px);opacity:.6}to{transform:none;opacity:1}}.drawer-close{float:right;border:none;background:none;font-size:22px;color:var(--ink-soft);line-height:1}.drawer h3{font-size:22px;margin-bottom:2px}.drawer .d-alt{color:var(--ink-soft);font-size:14px;margin-bottom:16px}.drawer .d-row{margin-bottom:14px}.drawer .d-row .d-key{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--ink-faint);margin-bottom:2px}.drawer .d-row .d-val{font-size:15px}.drawer .d-ask{width:100%;margin-top:8px;border:1px solid var(--accent);color:var(--accent-ink);background:var(--tone-b-bg);border-radius:8px;padding:9px;font-size:14px;font-weight:500}.drawer .d-note{font-size:12px;color:var(--ink-faint);margin-top:10px}.recap p{font-size:15px}.recap .recap-list{font-size:14.5px;color:var(--ink-soft);padding-left:18px}.recap .recap-list li{margin-bottom:3px}.book-toprow{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.book-toprow .back-link{margin-bottom:0}.reread{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.reread input{accent-color:var(--accent);width:15px;height:15px}.reread-banner,.stall-banner{border-radius:var(--radius);padding:10px 14px;font-size:14px;margin-bottom:16px}.reread-banner{background:var(--tone-c-bg);color:var(--tone-c-ink)}.stall-banner{background:var(--surface-2);color:var(--ink-soft);border-left:3px solid var(--gold);border-radius:0 var(--radius) var(--radius) 0}.stall-banner strong{color:var(--ink)}.search{position:relative;margin-bottom:4px}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--ink-faint);display:flex}.search-input{width:100%;box-sizing:border-box;padding:11px 14px 11px 40px;font-size:15px;font-family:inherit;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:999px;outline:none}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--ink-faint)}.search-results{position:absolute;z-index:20;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;max-height:320px;overflow-y:auto}.search-result{display:flex;flex-direction:column;gap:1px;width:100%;text-align:left;border:none;background:none;padding:9px 16px;border-top:1px solid var(--line-soft)}.search-result:first-child{border-top:none}.search-result:hover{background:var(--surface-2)}.search-result-title{font-size:15px;color:var(--ink)}.search-result-sub{font-size:12.5px;color:var(--ink-faint)}.search-empty{padding:12px 16px;font-size:13.5px;color:var(--ink-faint)}.seg-toggle{display:inline-flex;background:var(--surface-2);border-radius:999px;padding:3px;margin-bottom:16px}.seg-toggle button{border:none;background:none;padding:5px 16px;font-size:13px;color:var(--ink-soft);border-radius:999px}.seg-toggle button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}.web{display:block;width:100%;max-width:620px;height:auto;margin:8px auto 0}.web-edge{stroke:var(--ink-faint);stroke-width:1;opacity:.35}.web-edge.active{stroke:var(--accent);stroke-width:1.75;opacity:1}.web-edge-label{fill:var(--accent-ink);font-size:11px;font-family:var(--sans)}.web-node{cursor:pointer;transition:opacity .15s ease}.web-node.dim{opacity:.3}.web-node text.web-label{fill:var(--ink);font-size:12px;font-family:var(--sans)}.web-node circle{transition:r .12s ease}.web-node:hover circle{r:8}.fog-cell.stall{border-color:var(--gold)}.fog-stall-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--gold)}.fog-legend .dot.stall{background:var(--gold)}.rough{margin-top:20px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.rough-head{background:var(--surface-2);padding:9px 16px;font-family:var(--serif);font-size:15px}.rough-item{display:flex;flex-direction:column;gap:2px;padding:11px 16px;border-top:1px solid var(--line-soft)}.rough-where{font-size:13px;font-weight:500;color:var(--gold)}.rough-note{font-size:14px;color:var(--ink-soft)}.note-fore{border-left-color:var(--tone-c-ink)}.d-conns{display:flex;flex-direction:column;gap:6px;margin-top:2px}.d-conn{display:flex;align-items:baseline;justify-content:space-between;gap:10px;width:100%;text-align:left;border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:7px 11px}.d-conn:hover{border-color:var(--accent);background:var(--surface-2)}.d-conn-name{font-size:14px;color:var(--ink)}.d-conn-label{font-size:12px;color:var(--ink-faint)}.streak{display:flex;align-items:center;gap:18px;margin-top:16px;flex-wrap:wrap}.streak-count{display:inline-flex;align-items:center;gap:7px}.streak-flame{color:var(--gold);display:flex}.streak-num{font-family:var(--serif);font-size:22px;color:var(--ink)}.streak-label{font-size:14px;color:var(--ink-soft)}.streak-days{display:inline-flex;gap:6px}.streak-day{width:26px;height:26px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;color:var(--ink-faint);background:var(--surface-2);border:1px solid var(--line-soft)}.streak-day.on{background:var(--accent);color:#fff;border-color:var(--accent)}.journey{margin-top:16px}.journey-empty{font-size:14px;color:var(--ink-soft);max-width:560px}.journey-stats{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;font-size:15px;color:var(--ink-soft)}.journey-stat b{font-family:var(--serif);font-size:19px;font-weight:600;color:var(--ink);margin-right:4px}.journey-dot{color:var(--ink-faint)}.journey-lately{margin-top:6px;font-size:13.5px;color:var(--ink-faint)}.trail-rail{position:absolute;left:0;top:0;pointer-events:none}.trail-edge{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-linecap:round}.trail-pin{fill:var(--accent)}.trail-pin.gold{fill:var(--gold)}.trail-here-ring{fill:none;stroke:var(--accent);stroke-width:2;opacity:.5}.trail-row{display:flex;flex-direction:column;justify-content:center;padding-left:172px;box-sizing:border-box}.trail-row-title{font-size:16px;font-weight:500;color:var(--ink);line-height:1.3}.trail-row.here .trail-row-title{color:var(--accent-ink)}.trail-row-sub{font-size:13px;color:var(--ink-soft);margin-top:2px}.trail-tail{position:relative;padding:10px 0 6px 172px}.trail-tail:before{content:"";position:absolute;left:70px;top:-6px;width:0;height:34px;border-left:2px dotted var(--ink-faint);opacity:.6}.trail-tail-cap{font-size:13px;font-style:italic;color:var(--ink-faint)}.journey-road{display:block;width:100%;height:auto;margin-top:10px}.road{fill:none;stroke-linecap:round}.road.lit{stroke:var(--accent);stroke-width:3}.road.mist{stroke:var(--ink-faint);stroke-width:2.5;stroke-dasharray:1 9;opacity:.65}.road-start{fill:var(--gold)}.road-cap{fill:var(--ink-faint);font-size:13px;font-family:var(--sans)}.road-cap.horizon{font-style:italic}.stop{cursor:pointer}.stop-ring-track{fill:none;stroke:var(--line);stroke-width:3}.stop-ring{fill:none;stroke:var(--accent);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .3s ease}.stop-title{fill:var(--ink);font-size:15px;font-weight:500;font-family:var(--serif)}.stop:hover .stop-title{fill:var(--accent-ink)}.stop-sub{fill:var(--ink-soft);font-size:12px;font-family:var(--sans)}@media(max-width:1000px){.brand-tag{display:none}}@media(max-width:900px){.app{padding:0 22px 72px}}@media(max-width:640px){.app{padding:0 16px 56px}.topbar{padding:14px 0 12px;margin-bottom:20px}.brand-tag{display:none}.lib-title{font-size:25px}.now{grid-template-columns:64px 1fr;gap:14px;padding:16px}.cover{width:64px;height:90px}.now-title{font-size:22px}.tabs{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab,.catchup-btn{flex-shrink:0}.catchup-btn{margin-left:8px}.grid{grid-template-columns:1fr}.trail-row{padding-left:150px}.drawer{width:92vw}}@media(max-width:380px){.shelf-row{grid-template-columns:1fr 1fr;gap:16px}.stepper{gap:8px}}@media(max-width:640px){.now .cover-title,.now .cover-author{display:none}.pos-label{flex-direction:column;align-items:flex-start;gap:2px}.pos-where{font-size:15px}}.cover-art{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.cover{position:relative}.spine-cover-title,.spine-cover-author{position:relative;z-index:1}.spine-badge{z-index:1}.cover-title,.cover-author{position:relative;z-index:1}.cover-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.cover-scrim{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:linear-gradient(180deg,#120e0a9e,#120e0a1f 38%,#120e0a14 62%,#120e0a8c)}.credits{margin-top:28px;padding-top:18px;border-top:1px solid var(--line-soft)}.credits-head{font-size:12px;color:var(--ink-faint);margin-bottom:8px;letter-spacing:.2px}.credits-list{display:flex;flex-wrap:wrap;gap:4px 16px}.credit{font-size:12px;color:var(--ink-faint)}.credit em{font-style:italic;color:var(--ink-soft)}.lang-select{border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);font-size:13px;border-radius:999px;padding:6px 26px 6px 12px;cursor:pointer;flex-shrink:0;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239A9286' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.lang-select:hover{border-color:var(--accent);color:var(--ink)}.topbar{gap:16px}.topnav{display:flex;gap:4px;margin-right:auto;margin-left:12px;flex-shrink:0}.topnav-link{border:none;background:none;color:var(--ink-soft);font-size:14px;padding:6px 12px;border-radius:999px;white-space:nowrap}.topnav-link:hover{color:var(--ink);background:var(--surface-2)}.topnav-link.active{color:var(--ink);font-weight:500;background:var(--surface-2)}.detail-hero{display:grid;grid-template-columns:220px 1fr;gap:28px;margin-bottom:30px;align-items:start}.detail-cover{position:relative;aspect-ratio:7 / 9;border-radius:10px;overflow:hidden;box-shadow:var(--shadow);color:#f3e7d6;padding:16px 14px;display:flex;flex-direction:column;gap:6px}.detail-cover .spine-cover-title{font-size:19px}.detail-cover .spine-cover-author{font-size:12px}.detail-title{font-size:30px;line-height:1.15}.detail-byline{font-size:16px;color:var(--ink-soft);margin-top:4px}.detail-meta{font-size:13px;color:var(--ink-faint);margin-top:6px;letter-spacing:.2px}.detail-premise{font-size:16px;line-height:1.65;margin:16px 0 18px;color:var(--ink);max-width:56ch}.shelf-controls{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.shelf-btn{border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:999px;padding:7px 14px;font-size:13.5px}.shelf-btn:hover{border-color:var(--accent);color:var(--ink)}.shelf-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.detail-open{border:none;background:var(--accent);color:#fff;border-radius:10px;padding:11px 20px;font-size:15px;font-weight:500}.detail-open:hover{background:var(--accent-ink)}.detail-soon{font-size:14px;color:var(--ink-faint);font-style:italic}.detail-author{border-top:1px solid var(--line-soft);padding-top:20px;max-width:64ch}.detail-section-head{font-size:18px;margin-bottom:8px}.detail-author p{font-size:15.5px;line-height:1.7;color:var(--ink-soft);margin:0}@media(max-width:640px){.topbar{flex-wrap:wrap}.topnav{order:3;width:100%;margin:8px -16px 0;padding:2px 16px;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.topnav::-webkit-scrollbar{display:none}.topnav-link{flex-shrink:0}.detail-hero{grid-template-columns:120px 1fr;gap:18px}.detail-title{font-size:24px}}.page-intro{margin:2px 0 24px;color:var(--ink-soft);font-size:15.5px;max-width:60ch}.disc-cat{margin-bottom:30px}.disc-cat-head{font-size:18px;margin-bottom:14px}.disc-row{display:flex;gap:18px;overflow-x:auto;padding-bottom:10px;scroll-snap-type:x proximity;scrollbar-width:thin}.disc-row>.spine{flex:0 0 146px;width:146px;scroll-snap-align:start}.disc-row::-webkit-scrollbar{height:8px}.disc-row::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.disc-row::-webkit-scrollbar-track{background:transparent}.spine-cover,.detail-cover{position:relative;transform-style:preserve-3d}.detail-cover{transform:perspective(1100px) rotateY(-6deg);transform-origin:center}.spine-cover:after,.detail-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;border-radius:inherit;background:linear-gradient(90deg,#00000057 0,#00000014 9px,#0000 16px),linear-gradient(90deg,transparent 3px,rgba(255,255,255,.14) 4px,transparent 7px),linear-gradient(180deg,#ffffff12 0,#0000 40%)}.spine-cover:before,.detail-cover:before{content:"";position:absolute;z-index:-1;pointer-events:none;top:4px;bottom:4px;right:-6px;width:11px;border-radius:2px 4px 4px 2px;background:linear-gradient(90deg,#cbb98f 0,#cbb98f 1px,#f3e8cd 40%,#ece0c0 72%,#d6c499);box-shadow:1px 1px 2px #00000038}.spine-cover{box-shadow:6px 10px 18px -8px #2c2a2657,0 1px 2px #2c2a2629}.spine:not(.spine-soon):hover .spine-cover{box-shadow:8px 16px 28px -8px #0000005c,0 2px 4px #0000002e}.curtain{margin-top:18px;padding:14px 16px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--surface-2);display:flex;align-items:center;gap:16px;cursor:default;outline:none}.curtain-tiles{display:flex;gap:7px;flex-shrink:0}.curtain-tile{width:30px;height:40px;border-radius:6px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);color:var(--ink-faint)}.curtain-tile:nth-child(2){opacity:.7}.curtain-tile:nth-child(3){opacity:.45}.curtain-copy{display:flex;flex-direction:column;gap:2px;min-width:0}.curtain-count{font-size:14px;color:var(--ink-soft)}.curtain-next{font-size:12.5px;color:var(--accent-ink);font-weight:500;opacity:0;transform:translateY(-2px);transition:opacity .15s ease,transform .15s ease}.curtain:hover .curtain-next,.curtain:focus-within .curtain-next{opacity:1;transform:none}.app:has(.pos-dock){padding-bottom:92px}.pos-dock{position:fixed;bottom:18px;left:50%;transform:translate(-50%);width:min(540px,calc(100% - 32px));z-index:50;display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:8px 16px;box-shadow:0 6px 24px #00000029,0 1px 2px #00000014}.pos-dock-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-faint);flex-shrink:0}.pos-dock-btn{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-size:18px;line-height:1;display:grid;place-items:center}.pos-dock-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent-ink)}.pos-dock-btn:disabled{opacity:.35;cursor:default}.pos-dock-mid{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.pos-dock-where{font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pos-dock-bar{height:4px;border-radius:3px;background:var(--surface-2);overflow:hidden}.pos-dock-bar>span{display:block;height:100%;background:var(--accent);border-radius:3px;transition:width .2s ease}.pos-dock-pct{font-size:12px;color:var(--ink-faint);flex-shrink:0;min-width:30px;text-align:right}.why-read{border-left:3px solid var(--accent);padding:2px 0 2px 16px;margin:24px 0 0}.why-read-label{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--accent-ink);display:block;margin-bottom:5px}.why-read p{font-family:var(--serif);font-size:17px;line-height:1.5;margin:0;color:var(--ink);max-width:60ch}.detail-themes{margin:24px 0 0}.detail-themes-label{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:9px}.theme-chips{display:flex;gap:8px;flex-wrap:wrap}.theme-chip{font-size:13px;color:var(--ink-soft);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:5px 13px;text-decoration:none;transition:background .12s ease,color .12s ease,border-color .12s ease}.theme-chip:hover{border-color:var(--accent);color:var(--ink)}.theme-chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}.era-card{margin:24px 0 0;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}.era-head{display:flex;align-items:center;gap:9px}.era-pin{color:var(--gold);flex-shrink:0}.era-title{font-family:var(--serif);font-size:16px}.era-tag{margin-left:auto;font-size:11.5px;color:var(--gold);border:1px solid var(--line);border-radius:999px;padding:3px 10px;white-space:nowrap}.era-card p{font-size:14.5px;line-height:1.6;margin:10px 0 0;color:var(--ink-soft);max-width:64ch}.theme-bar{margin:0 0 26px}.theme-bar-label{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:10px}.theme-bar-chips{display:flex;gap:8px;flex-wrap:wrap}.disc-cat-head em{font-style:italic;color:var(--accent-ink)}@media(max-width:640px){.era-tag{margin-left:0}.era-head{flex-wrap:wrap}}.line-keep{margin:18px 0 22px}.line-keep-row{display:flex;align-items:center;margin-bottom:9px}.line-keep-label{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--ink-faint)}.line-keep-book{margin-left:auto;border:none;background:none;color:var(--accent-ink);font-size:12.5px;display:inline-flex;align-items:center;gap:5px;padding:2px 4px}.line-keep-book:hover{text-decoration:underline}.line-keep-quote{position:relative;margin:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px 14px}.line-keep-mark{position:absolute;top:6px;left:16px;font-family:var(--serif);font-size:40px;line-height:1;color:var(--gold);opacity:.5}.line-keep-quote p{font-family:var(--serif);font-size:18px;line-height:1.5;margin:4px 0 0;color:var(--ink);padding-left:22px}.line-keep-quote cite{display:block;font-style:normal;font-size:12px;color:var(--ink-faint);margin:10px 0 0;padding-left:22px}.line-keep-actions{display:flex;align-items:center;gap:14px;margin-top:10px}.line-keep-save{display:inline-flex;align-items:center;gap:6px;font-size:13px;border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:999px;padding:6px 13px}.line-keep-save:hover{border-color:var(--accent);color:var(--ink)}.line-keep-save.on{color:var(--accent-ink);border-color:var(--accent);background:var(--surface-2)}.line-keep-another{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;border:none;background:none;color:var(--ink-soft)}.line-keep-another:hover{color:var(--ink)}.line-keep-empty .line-keep-wait{font-size:13.5px;color:var(--ink-faint);font-style:italic;margin:0}.commonplace{margin-top:14px;display:flex;flex-direction:column;gap:10px}.cp-line{display:flex;gap:10px;align-items:flex-start;border-bottom:1px solid var(--line-soft);padding-bottom:10px}.cp-line p{font-family:var(--serif);font-size:15px;line-height:1.45;margin:0;color:var(--ink);flex:1}.cp-remove{border:none;background:none;color:var(--ink-faint);font-size:18px;line-height:1;flex-shrink:0}.cp-remove:hover{color:var(--ink)}.signin-btn{flex-shrink:0;white-space:nowrap;border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:999px;padding:6px 16px;font-size:13px;font-weight:500}.signin-btn:hover{background:var(--accent-ink);border-color:var(--accent-ink)}.acct-chip{flex-shrink:0;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-size:13px;font-weight:600;letter-spacing:.3px;display:grid;place-items:center}.acct-chip:hover{border-color:var(--accent);color:var(--accent-ink)}.auth{max-width:384px;margin:32px auto 0}.auth-title{font-size:27px;line-height:1.15;margin:0 0 6px}.auth-sub{font-size:15px;color:var(--ink-soft);line-height:1.5;margin:0 0 24px}.auth-social{display:flex;flex-direction:column;gap:10px}.auth-provider{display:flex;align-items:center;justify-content:center;gap:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:10px;padding:11px 14px;font-size:14.5px;font-weight:500}.auth-provider:hover{border-color:var(--ink-faint);background:var(--surface-2)}.auth-or{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--ink-faint);font-size:12.5px}.auth-or:before,.auth-or:after{content:"";flex:1;height:1px;background:var(--line)}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-field span{font-size:12.5px;color:var(--ink-soft)}.auth-field input{border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:10px;padding:11px 13px;font-size:15px;font-family:var(--sans);width:100%}.auth-field input:focus{outline:none;border-color:var(--accent)}.auth-submit{margin-top:6px;border:none;background:var(--accent);color:#fff;border-radius:10px;padding:12px 16px;font-size:15px;font-weight:500}.auth-submit:hover{background:var(--accent-ink)}.auth-submit:disabled{opacity:.6;cursor:default}.auth-error{font-size:13px;color:#b4453a;background:#b4453a14;border:1px solid rgba(180,69,58,.25);border-radius:8px;padding:8px 12px;margin:2px 0 0}.alongside{margin:22px 0;padding:16px 18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.alongside-head{font-size:13px;letter-spacing:.4px;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin:0 0 12px}.alongside-n{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;margin-left:6px;border-radius:999px;background:var(--accent);color:#fbf8f2;font-size:12px;vertical-align:middle}.alongside-list{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.alongside-reader{display:inline-flex;align-items:center;gap:7px;padding:5px 11px 5px 5px;border-radius:999px;background:var(--tone-b-bg);color:var(--ink);font-size:13px}.alongside-av{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fbf8f2;font-size:10px;font-weight:600}.alongside-more{font-size:13px;color:var(--ink-faint);padding-left:2px}.alongside-none{margin:0;font-size:14px;color:var(--ink-faint)}.alongside-guest{padding:14px 18px}.alongside-guest a{color:var(--accent-ink);font-weight:500;text-decoration:none;font-size:14px}.alongside-guest a:hover{text-decoration:underline}.alongside-follow{margin-left:4px;border:1px solid var(--accent);background:transparent;color:var(--accent-ink);border-radius:999px;font-size:11px;padding:2px 9px;cursor:pointer;font-weight:500}.alongside-follow:hover{background:var(--accent);color:#fbf8f2}.alongside-follow.on{background:var(--accent);color:#fbf8f2;border-color:var(--accent)}.feed-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.feed-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink-soft)}.feed-av{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;flex-shrink:0;border-radius:50%;background:var(--accent);color:#fbf8f2;font-size:10px;font-weight:600}.acct-toggle{cursor:pointer}.acct-toggle input{width:16px;height:16px;accent-color:var(--accent)}.caravan{margin:22px 0;padding:16px 18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.caravan-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.caravan-head .alongside-head{margin:0}.caravan-join{border:1px solid var(--accent);background:transparent;color:var(--accent-ink);border-radius:999px;font-size:12px;padding:5px 14px;cursor:pointer;font-weight:500;flex-shrink:0}.caravan-join:hover{background:var(--accent);color:#fbf8f2}.caravan-join:disabled{opacity:.6;cursor:default}.caravan-track{position:relative;height:30px;margin:18px 6px 6px;border-radius:999px;background:linear-gradient(90deg,var(--tone-b-bg),var(--surface-2, var(--tone-b-bg)))}.caravan-track:before{content:"";position:absolute;left:0;right:0;top:50%;height:2px;background:var(--line);border-radius:2px}.caravan-pin{position:absolute;top:50%;transform:translate(-50%,-50%);width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;background:var(--ink-faint);color:#fbf8f2;border:2px solid var(--surface)}.caravan-pin.me{background:var(--accent);width:30px;height:30px;font-size:10px;z-index:2}.reader-link{color:var(--ink);text-decoration:none;font-weight:500}.reader-link:hover{color:var(--accent-ink);text-decoration:underline}.reader-head{display:flex;align-items:center;gap:16px;margin:8px 0 28px}.reader-avatar{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fbf8f2;font-size:18px;font-weight:600;flex-shrink:0}.reader-id{flex:1;min-width:0}.reader-name{font-family:var(--serif);font-size:26px;font-weight:600;color:var(--ink);margin:0}.reader-handle{font-size:14px;color:var(--ink-faint)}.reader-follow{border:1px solid var(--accent);background:transparent;color:var(--accent-ink);border-radius:999px;font-size:13px;padding:7px 18px;cursor:pointer;font-weight:500;flex-shrink:0}.reader-follow:hover,.reader-follow.on{background:var(--accent);color:#fbf8f2}.reader-section{margin:24px 0}a.feed-av{text-decoration:none}.home-hero{position:relative;overflow:hidden;padding:38px 34px;margin-bottom:30px;border:1px solid var(--line);border-radius:16px;background:radial-gradient(130% 150% at 100% 0%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 62%),var(--surface)}.home-hero:after{content:"¶";position:absolute;right:22px;bottom:-46px;font-family:var(--serif);font-size:210px;line-height:1;font-weight:600;color:var(--accent);opacity:.08;pointer-events:none;-webkit-user-select:none;user-select:none}.home-hero-title{position:relative;z-index:1;font-family:var(--serif);font-size:33px;font-weight:600;color:var(--ink);margin:0 0 10px;line-height:1.15;letter-spacing:.2px;max-width:18ch}.home-hero-sub{position:relative;z-index:1;font-size:16px;color:var(--ink-soft);max-width:58ch;margin:0;line-height:1.55}.home-browse-head{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--ink);margin:34px 0 6px}.featured{flex:0 0 440px;max-width:440px;margin:0;padding:24px;border:none;border-radius:16px;position:relative;overflow:hidden;box-shadow:0 14px 40px #0003;color:#f3e7d6}.featured:after{content:"”";position:absolute;right:10px;bottom:-34px;font-family:var(--serif);font-size:150px;line-height:1;color:#ffffff17;pointer-events:none}.featured-kicker{display:inline-block;font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:#f3e7d6d1;font-weight:600;margin-bottom:18px}.featured-stage{display:flex;gap:22px;align-items:flex-start;margin-bottom:18px;position:relative;z-index:1}.featured-book{flex:0 0 132px;width:132px;perspective:1100px}.featured-book .spine-cover{transform:perspective(1100px) rotateY(-11deg);box-shadow:0 18px 38px #0006}.featured-book:hover .spine-cover{transform:perspective(1100px) rotateY(-6deg) translateY(-3px);box-shadow:0 22px 46px #00000075}.featured-book .spine-cover-title{font-size:17px}.featured-text{min-width:0;padding-top:2px}.featured-title{font-family:var(--serif);font-size:23px;font-weight:600;color:#fff;margin:0 0 4px;line-height:1.15}.featured-meta{font-size:13.5px;color:#f3e7d6c7;margin-bottom:13px}.featured-quote{font-family:var(--serif);font-size:16.5px;font-style:italic;color:#fff;line-height:1.5;margin:0;padding-left:15px;border-left:3px solid rgba(243,231,214,.55)}.featured-quote cite{display:block;font-size:12.5px;font-style:normal;color:#f3e7d6b8;margin-top:6px}.featured-note{position:relative;z-index:1;font-size:14.5px;color:#f3e7d6db;line-height:1.55;margin:0;padding-top:16px;border-top:1px solid rgba(243,231,214,.22)}@media(max-width:520px){.featured{flex-basis:auto;max-width:100%}}.home-masthead{padding:26px 0 20px;position:relative;border-bottom:1px solid var(--line-soft);margin-bottom:26px}.home-masthead:after{content:"¶";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-family:var(--serif);font-size:120px;line-height:1;color:var(--accent);opacity:.06;pointer-events:none;-webkit-user-select:none;user-select:none}.home-feature{display:flex;gap:24px;align-items:stretch;margin-bottom:14px}.home-aside{flex:1;min-width:0;display:flex;flex-direction:column;gap:16px}@media(max-width:860px){.home-feature{flex-direction:column}}.reveal{flex:1;display:flex;flex-direction:column;gap:12px;padding:18px 20px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}.reveal-head{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--accent);font-weight:600}.reveal-stage{display:flex;flex-direction:column;align-items:flex-start;gap:7px;flex:1;min-height:132px;align-content:flex-start}.reveal-chip{background:color-mix(in srgb,var(--accent) 13%,transparent);color:var(--ink);border:1px solid color-mix(in srgb,var(--accent) 32%,transparent);border-radius:999px;padding:5px 13px;font-size:13.5px;animation:revealIn .34s ease}.reveal-locked{color:var(--ink-faint);font-size:13px;border:1px dashed var(--line);border-radius:999px;padding:5px 13px}@keyframes revealIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.reveal-slider{width:100%;accent-color:var(--accent);cursor:pointer}.reveal-caption{font-size:13px;color:var(--ink-soft);line-height:1.45;margin:0}.pulse{display:flex;align-items:center;gap:9px;padding:12px 16px;border:1px solid var(--line);border-radius:12px;background:var(--surface);font-size:13.5px;color:var(--ink-soft)}.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:pulseDot 2.2s infinite}.pulse-title{font-weight:600;color:var(--ink)}.pulse-text{min-width:0}@keyframes pulseDot{0%{box-shadow:0 0 color-mix(in srgb,var(--accent) 55%,transparent)}70%{box-shadow:0 0 0 9px transparent}to{box-shadow:0 0 0 0 transparent}}.disc-live{font-size:9px;color:var(--accent);vertical-align:middle;margin-left:4px}.disc-cat-sub{font-size:14px;color:var(--ink-faint);margin:-2px 0 12px;line-height:1.45}.coll-presets{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:2px 0 22px}.coll-presets-label{font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin-right:4px}.coll-preset{border:1px solid var(--accent);background:transparent;color:var(--accent-ink);border-radius:999px;padding:7px 15px;font-size:13.5px;cursor:pointer;font-weight:500;transition:all .15s ease}.coll-preset:hover{background:var(--accent);color:#fbf8f2}.coll-dials{display:flex;flex-direction:column;gap:16px;padding:20px 22px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);margin-bottom:18px}.coll-group{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px 12px}.coll-group-head{display:inline-flex;align-items:center;gap:7px;flex:0 0 132px;padding-top:5px;font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-faint);font-weight:600}.coll-chips{display:flex;flex-wrap:wrap;gap:7px}.coll-chip{display:inline-flex;align-items:center;border:1px solid var(--line);background:var(--tone-b-bg);color:var(--ink-soft);border-radius:999px;padding:6px 14px;font-size:13px;cursor:pointer;transition:all .14s ease}.coll-chip:hover{border-color:var(--accent);color:var(--ink)}.coll-chip.on{background:var(--accent);color:#fbf8f2;border-color:var(--accent)}.coll-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px}.coll-chip.on .coll-dot{background:#ffffffeb!important}.coll-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:20px}.coll-result{display:flex;align-items:baseline;flex-wrap:wrap;gap:10px;min-width:0}.coll-count{font-family:var(--serif);font-size:19px;color:var(--ink);font-weight:600}.coll-trail{font-size:13px;color:var(--ink-faint)}.coll-clear{border:none;background:none;color:var(--accent-ink);font-size:13px;cursor:pointer;text-decoration:underline}.coll-add{border:none;background:var(--accent);color:#fbf8f2;border-radius:999px;padding:9px 18px;font-size:14px;font-weight:500;cursor:pointer}.coll-add:hover{background:var(--accent-ink)}.coll-add:disabled{opacity:.5;cursor:default}.coll-added{font-size:14px;color:var(--accent-ink);font-weight:600}@media(max-width:640px){.coll-group-head{flex-basis:100%;padding-top:0}}.ticker{margin:4px 0 30px;padding:18px 20px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.ticker-title{display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.8px;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin:0 0 12px}.ticker-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.ticker-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-top:1px solid var(--line-soft)}.ticker-item:first-child{border-top:none}.ticker-av{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;flex-shrink:0;border-radius:50%;background:var(--accent);color:#fbf8f2;font-size:10px;font-weight:600;text-decoration:none}.ticker-text{flex:1;min-width:0;font-size:14px;color:var(--ink-soft)}.ticker-time{flex-shrink:0;font-size:12px;color:var(--ink-faint)}.detail-adaptations{margin-top:26px}.adapt-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}.adapt-item{position:relative;padding-left:18px;font-size:15px;color:var(--ink-soft);line-height:1.5}.adapt-item:before{content:"▸";position:absolute;left:0;color:var(--accent);font-size:12px;top:2px}.why{max-width:680px}.why-title{font-family:var(--serif);font-size:34px;font-weight:600;color:var(--ink);margin:14px 0 6px}.why-lede{font-size:17px;color:var(--ink-soft);line-height:1.55;margin:0 0 28px}.why-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:22px}.why-item{display:flex;gap:16px;align-items:flex-start}.why-num{font-family:var(--serif);font-size:26px;line-height:1;color:var(--accent);flex-shrink:0;width:24px;text-align:center}.why-item-title{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--ink);margin:0 0 4px}.why-item-body{font-size:15.5px;color:var(--ink-soft);line-height:1.55;margin:0}.why-closer{font-family:var(--serif);font-size:18px;font-style:italic;color:var(--ink);margin:32px 0 0;padding-top:24px;border-top:1px solid var(--line)}.site-footer{display:flex;align-items:center;gap:10px;margin-top:56px;padding:22px 0 8px;border-top:1px solid var(--line-soft);font-size:13px;color:var(--ink-faint)}.site-footer-mark{font-family:var(--serif);color:var(--accent);font-size:15px}.site-footer-tag{flex:1}.site-footer-link{color:var(--accent-ink);text-decoration:none;font-weight:500}.site-footer-link:hover{text-decoration:underline}.booktags{margin:22px 0;padding:16px 18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.booktags .alongside-head{margin:0 0 12px}.booktags-row{display:flex;flex-wrap:wrap;gap:8px}.booktag{border:1px solid var(--line);background:var(--tone-b-bg);color:var(--ink-soft);border-radius:999px;font-size:13px;padding:6px 14px;cursor:pointer;transition:all .15s ease}.booktag:hover{border-color:var(--accent);color:var(--ink)}.booktag.on{background:var(--accent);color:#fbf8f2;border-color:var(--accent)}@media(max-width:640px){.home-hero{padding:26px 22px}.home-hero-title{font-size:26px}.home-hero:after{font-size:150px;bottom:-32px;right:14px}}.auth-switch{font-size:14px;color:var(--ink-soft);margin:20px 0 0}.auth-switch a{color:var(--accent-ink);font-weight:500;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.auth-note{font-size:12px;color:var(--ink-faint);margin:18px 0 0;line-height:1.5}.auth-hint{font-size:12px;color:var(--ink-faint);line-height:1.45}.account{max-width:560px}.acct-head{display:flex;align-items:center;gap:16px;margin-bottom:30px}.acct-avatar{width:64px;height:64px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;background:var(--accent);color:#fff;font-size:22px;font-weight:600;letter-spacing:.5px}.acct-name{font-size:24px;margin:0}.acct-handle{font-size:14px;color:var(--ink-faint);margin-top:3px}.acct-edit-btn{border:none;background:none;color:var(--accent-ink);font-size:13px}.acct-edit-btn:hover{text-decoration:underline}.acct-edit{display:flex;gap:8px;align-items:center}.acct-edit input{flex:1;max-width:320px;border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:8px;padding:8px 11px;font-size:14.5px;font-family:var(--sans)}.acct-edit input:focus{outline:none;border-color:var(--accent)}.acct-add-email{border:1px dashed var(--line);background:none;color:var(--accent-ink);border-radius:8px;padding:9px 14px;font-size:13.5px}.acct-add-email:hover{border-color:var(--accent)}.acct-hint{font-size:12.5px;color:var(--ink-faint);margin:8px 0 0;line-height:1.5;max-width:48ch}.acct-section{margin-bottom:28px}.acct-section-head{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-faint);margin:0 0 14px}.acct-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px}.acct-stat{background:var(--surface-2);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:4px}.acct-stat-n{font-family:var(--serif);font-size:28px;line-height:1}.acct-stat-label{font-size:13px;color:var(--ink-soft)}.acct-pref{display:flex;align-items:center;gap:12px}.acct-pref-label{font-size:14.5px;color:var(--ink)}.acct-signout{border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:999px;padding:9px 20px;font-size:14px}.acct-signout:hover{border-color:var(--accent);color:var(--ink)}
