/* Sort By Cravings — Book Page Shared Stylesheet */
/* Cached across all book pages for performance */

:root{--bg:#0f0e0c;--bg-warm:#161412;--bg-card:#1c1a17;--bg-card-hover:#242119;--gold:#c9a84c;--gold-dim:rgba(201,168,76,.15);--cream:#f0e6d3;--cream-dim:rgba(240,230,211,.7);--cream-faint:rgba(240,230,211,.4);--cream-ghost:rgba(240,230,211,.12);--burgundy:#8b2252;--forest:#3d5a3e;--sapphire:#2a4a7f;--plum:#6b4d7a;--storm:#4a5e6a;--honey:#d4a853;--rose:#c47a7a;--ember:#b8513b;--green:#5d8a5e;--red:#b84c4c;--heading:'Cormorant Garamond','Georgia',serif;--body:'Outfit',system-ui,sans-serif;--ease:cubic-bezier(.16,1,.3,1);--container:860px}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--body);background:var(--bg);color:var(--cream);line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
:focus:not(:focus-visible){outline:none}
.skip-link{position:absolute;top:-100px;left:0;background:var(--gold);color:var(--bg);padding:10px 20px;z-index:10000;font-weight:600;border-radius:0 0 8px 0}
.skip-link:focus{top:0}
body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");background-size:256px}

/* Nav */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 32px;display:flex;align-items:center;justify-content:space-between;transition:background .4s}
nav.scrolled{background:rgba(15,14,12,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.nav-logo{font-family:var(--heading);font-weight:600;font-size:1.35rem;color:var(--gold)}
.nav-right{display:flex;gap:32px;align-items:center}
.nav-right a{font-size:.85rem;font-weight:400;color:var(--cream-dim);letter-spacing:.06em;transition:color .2s}
.nav-right a:hover{color:var(--gold)}
.nav-quiz{background:var(--gold);color:var(--bg);padding:8px 24px;border-radius:100px;font-weight:600;font-size:.85rem;transition:transform .15s,box-shadow .3s}
.nav-quiz:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.25)}
.nav-ham{display:none;padding:8px}
.nav-ham span{display:block;width:22px;height:1.5px;background:var(--cream);margin:5px 0;transition:all .3s;border-radius:2px}
.nav-search{display:flex;align-items:center;color:var(--cream-dim);transition:color .2s}
.nav-search:hover{color:var(--gold)}
.nav-search svg{width:18px;height:18px}
@media(max-width:768px){.nav-right{display:none}.nav-ham{display:block}.nav-right.open{display:flex;flex-direction:column;position:fixed;inset:0;background:var(--bg);justify-content:center;align-items:center;gap:32px;z-index:101}.nav-right.open a{font-size:1.5rem}}

/* Layout */
.section-inner{max-width:var(--container);margin:0 auto}
.sec-label{font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.sec-h2{font-family:var(--heading);font-weight:400;font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.15;margin-bottom:8px}
.sec-h2 em{font-style:italic;color:var(--gold)}
.sec-sub{font-size:.9rem;color:var(--cream-faint);margin-bottom:28px;font-weight:300}

/* Hero */
.book-hero{padding:140px 24px 60px;position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(139,34,82,.08) 0%,var(--bg) 100%)}
.bh-glow{position:absolute;pointer-events:none;border-radius:50%;filter:blur(120px)}
.bh-g1{width:400px;height:400px;background:var(--burgundy);opacity:.06;top:-10%;right:10%}
.bh-g2{width:300px;height:300px;background:var(--plum);opacity:.04;bottom:5%;left:5%}
.hero-inner{max-width:var(--container);margin:0 auto}
.bread{font-size:.8rem;color:var(--cream-faint);margin-bottom:20px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bread a{color:var(--cream-faint);transition:color .2s}
.bread a:hover{color:var(--gold)}
.bread span{opacity:.3}

/* Series nav */
.series-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:24px;padding:12px 16px;background:var(--bg-card);border-radius:12px;border:1px solid var(--cream-ghost);font-size:.8rem}
.series-nav-label{color:var(--gold);font-weight:600}
.series-book{color:var(--cream-faint);transition:color .2s}
.series-book:hover{color:var(--gold)}
.series-book.current{color:var(--cream);font-weight:600;background:var(--cream-ghost);padding:2px 10px;border-radius:100px}
.series-arrow{color:var(--cream-ghost);font-size:.7rem}

/* Hero grid */
.hero-grid{display:grid;grid-template-columns:180px 1fr;gap:40px;align-items:start}
.cover{width:180px;height:264px;border-radius:12px;overflow:hidden;position:relative;box-shadow:0 16px 48px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,255,255,.08);flex-shrink:0;background:linear-gradient(160deg,#1a0e20,#2a1a38 50%,#3a2a50)}
.cover-inner{position:absolute;bottom:0;left:0;right:0;padding:14px;padding-top:70px;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.85),rgba(0,0,0,.3) 60%,transparent)}
.cover-t{font-family:var(--heading);font-weight:700;font-size:.9rem;color:white;line-height:1.2}
.cover-a{font-size:.75rem;color:rgba(255,255,255,.7);margin-top:2px}
.cover-badge{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);padding:3px 10px;border-radius:8px;font-size:.7rem;color:white;z-index:3}
.cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;border-radius:12px}

/* Meta */
.meta h1{font-family:var(--heading);font-weight:400;font-size:clamp(1.6rem,3.5vw,2.5rem);line-height:1.1;margin-bottom:6px}
.meta-author{font-size:.95rem;color:var(--cream-faint);margin-bottom:4px}
.meta-author a{color:var(--gold);font-weight:500}
.meta-details{font-size:.82rem;color:var(--cream-faint);margin-bottom:16px}
.vibe{font-family:var(--heading);font-style:italic;font-size:1rem;color:var(--honey);line-height:1.5;margin-bottom:16px;padding-left:16px;border-left:2px solid rgba(212,168,83,.3)}
.voice{font-family:var(--heading);font-style:italic;font-size:.95rem;color:var(--cream-dim);line-height:1.6;padding:14px 18px;border-left:2px solid var(--gold-dim);background:rgba(201,168,76,.03);border-radius:0 10px 10px 0;margin-bottom:20px}

/* Stats + tags */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}
.stat{padding:10px 12px;background:var(--bg-card);border-radius:10px;border:1px solid var(--cream-ghost)}
.stat-label{font-size:.6rem;color:var(--cream-faint);text-transform:uppercase;letter-spacing:.06em}
.stat-val{font-size:.82rem;font-weight:600;margin-top:1px}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.tag{background:var(--cream-ghost);color:var(--cream-dim);padding:4px 14px;border-radius:100px;font-size:.75rem;font-weight:500;transition:color .2s}
.tag:hover{color:var(--gold)}

/* CTAs */
.cta-group{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}
.cta-primary{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--gold);color:var(--bg);padding:14px 28px;border-radius:100px;font-weight:600;font-size:.95rem;transition:transform .15s,box-shadow .3s;box-shadow:0 4px 20px rgba(201,168,76,.2);text-align:center}
.cta-primary:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(201,168,76,.3)}
.cta-row{display:flex;gap:10px;justify-content:center}
.cta-alt{padding:10px 20px;border:1px solid var(--cream-ghost);border-radius:100px;font-size:.82rem;color:var(--cream-dim);transition:all .2s;text-align:center}
.cta-alt:hover{border-color:var(--gold);color:var(--gold)}
.aff-disc{font-size:.65rem;color:rgba(240,230,211,.2);text-align:center}

/* Content sections */
.content-section{padding:48px 24px;border-top:1px solid var(--cream-ghost)}
.content-section.alt{background:var(--bg-warm)}

/* Spice roadmap */
.roadmap{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.roadmap-row{display:flex;align-items:flex-start;gap:12px}
.roadmap-pct{width:48px;flex-shrink:0;font-size:.75rem;font-weight:600;color:var(--gold);text-align:right;padding-top:2px}
.roadmap-bar{flex:1;position:relative;padding-left:16px;border-left:2px solid var(--cream-ghost);font-size:.85rem;color:var(--cream-dim);line-height:1.5}
.roadmap-bar strong{color:var(--cream);font-weight:600}
.roadmap-tldr{font-size:.85rem;color:var(--cream-faint);font-style:italic;padding:10px 16px;background:rgba(201,168,76,.04);border-radius:10px;border-left:2px solid var(--gold-dim)}

/* Compatibility */
.compat-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.compat-col h3{font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.compat-col.yes h3{color:var(--green)}
.compat-col.no h3{color:var(--red)}
.compat-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:.85rem;color:var(--cream-dim);line-height:1.5}
.compat-icon{flex-shrink:0;width:18px;font-size:.75rem}

/* Content warnings */
.cw-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.cw{background:rgba(184,76,76,.08);color:var(--red);padding:6px 14px;border-radius:100px;font-size:.75rem;font-weight:500}

/* Real talk */
.real-talk{display:flex;flex-direction:column;gap:12px}
.rt-item{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--cream-dim);line-height:1.6}
.rt-arrow{color:var(--gold);flex-shrink:0;font-weight:700;font-size:.85rem;padding-top:2px}

/* Pacing */
.pace-bar{display:flex;height:12px;border-radius:100px;overflow:hidden;margin-bottom:10px;gap:2px}
.pace-seg{border-radius:100px}
.pace-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--cream-faint)}

/* Similar books */
.sim-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.sim-card{padding:20px;background:var(--bg-card);border-radius:14px;border:1px solid var(--cream-ghost);transition:all .3s var(--ease);display:flex;flex-direction:column;gap:8px}
.sim-card:hover{transform:translateY(-4px);border-color:rgba(201,168,76,.15);box-shadow:0 12px 36px rgba(0,0,0,.3)}
.sim-badge{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:4px}
.sim-title{font-family:var(--heading);font-weight:600;font-size:1rem;color:var(--cream)}
.sim-author{font-size:.75rem;color:var(--cream-faint)}
.sim-spice{font-size:.75rem}
.sim-pitch{font-size:.8rem;color:var(--cream-faint);line-height:1.5;font-weight:300}
.sim-cta{font-size:.78rem;color:var(--gold);font-weight:500;margin-top:auto;opacity:.6;transition:opacity .3s}
.sim-card:hover .sim-cta{opacity:1}

/* Audiobook + Book club */
.extras-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.extras-card{padding:20px;background:var(--bg-card);border-radius:14px;border:1px solid var(--cream-ghost)}
.extras-card h3{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.audio-row{display:flex;justify-content:space-between;font-size:.82rem;margin-bottom:6px}
.audio-label{color:var(--cream-faint)}
.audio-val{color:var(--cream);font-weight:500}
.audio-verdict{font-size:.82rem;color:var(--cream-dim);line-height:1.5;margin-top:10px;font-style:italic}
.club-q{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px;font-size:.82rem;color:var(--cream-dim);line-height:1.5}
.club-arrow{color:var(--gold);font-weight:700;flex-shrink:0}

/* Expandable */
details{margin-top:24px}
details summary{cursor:pointer;font-size:.85rem;font-weight:600;color:var(--cream-faint);padding:14px 18px;background:var(--bg-card);border:1px solid var(--cream-ghost);border-radius:12px;transition:all .2s;list-style:none}
details summary::-webkit-details-marker{display:none}
details summary::before{content:'▸ ';color:var(--gold)}
details[open] summary::before{content:'▾ '}
details[open] summary{border-radius:12px 12px 0 0;border-bottom:none}
details .spoiler-content{padding:20px;background:var(--bg-card);border:1px solid var(--cream-ghost);border-top:none;border-radius:0 0 12px 12px;font-size:.88rem;color:var(--cream-dim);line-height:1.8}

/* Timeline */
.timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:24px}
.timeline::before{content:'';position:absolute;left:6px;top:8px;bottom:8px;width:2px;background:var(--cream-ghost)}
.tl-item{display:flex;align-items:flex-start;gap:16px;padding:12px 0;position:relative}
.tl-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--gold);background:var(--bg);flex-shrink:0;margin-left:-24px;z-index:1;margin-top:3px}
.tl-content{flex:1}
.tl-time{font-size:.7rem;font-weight:600;color:var(--gold);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2px}
.tl-desc{font-size:.85rem;color:var(--cream-dim);line-height:1.5}

/* Before/After */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ba-card{padding:20px;background:var(--bg-card);border-radius:14px;border:1px solid var(--cream-ghost)}
.ba-card h3{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;text-align:center}
.ba-card.before h3{color:var(--cream-faint)}
.ba-card.after h3{color:var(--gold)}
.ba-item{font-size:.82rem;color:var(--cream-dim);line-height:1.5;padding:8px 0;border-bottom:1px solid var(--cream-ghost)}
.ba-item:last-child{border-bottom:none}

/* Emotional sparkline */
.sparkline{display:flex;align-items:flex-end;gap:4px;height:80px;margin-bottom:12px;padding:0 8px}
.spark-bar{flex:1;border-radius:6px 6px 0 0;min-width:0}
.spark-labels{display:flex;justify-content:space-between;font-size:.65rem;color:var(--cream-faint);padding:0 8px}

/* Quote cards */
.quote-grid{display:flex;flex-direction:column;gap:16px}
.quote-card{padding:20px 24px;background:var(--bg-card);border-radius:14px;border:1px solid var(--cream-ghost);border-left:3px solid var(--gold)}
.quote-text{font-family:var(--heading);font-style:italic;font-size:1.05rem;color:var(--cream);line-height:1.6;margin-bottom:8px}
.quote-context{font-size:.75rem;color:var(--cream-faint);font-weight:400}

/* Calculator */
.calc-wrap{max-width:400px}
.calc-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.calc-row label{font-size:.82rem;color:var(--cream-dim);flex-shrink:0;width:120px}
.calc-row select{padding:8px 14px;border:1px solid var(--cream-ghost);border-radius:10px;background:var(--bg-card);color:var(--cream);font-family:var(--body);font-size:.85rem;outline:none;flex:1;min-height:40px}
.calc-row select:focus{border-color:var(--gold)}
.calc-result{padding:16px;background:rgba(201,168,76,.06);border-radius:12px;border:1px solid var(--gold-dim);font-size:.9rem;color:var(--cream-dim);line-height:1.6}
.calc-result strong{color:var(--cream);font-weight:600}

/* Poll */
.poll-options{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.poll-btn{padding:14px 20px;background:var(--bg-card);border:1px solid var(--cream-ghost);border-radius:12px;font-size:.88rem;color:var(--cream-dim);text-align:left;transition:all .2s;cursor:pointer;position:relative;overflow:hidden}
.poll-btn:hover{border-color:rgba(201,168,76,.3);color:var(--cream)}
.poll-btn.voted{pointer-events:none}
.poll-bar{position:absolute;left:0;top:0;bottom:0;background:rgba(201,168,76,.08);border-radius:12px;width:0;transition:width .6s var(--ease)}
.poll-label{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center}
.poll-pct{font-weight:600;color:var(--gold);font-size:.82rem;opacity:0;transition:opacity .3s}
.poll-btn.voted .poll-pct{opacity:1}
.poll-total{font-size:.75rem;color:var(--cream-faint);text-align:center}

/* Email */
.email-section{padding:60px 24px;text-align:center;border-top:1px solid var(--cream-ghost)}
.email-inner{max-width:480px;margin:0 auto}
.email-form{display:flex;gap:10px;max-width:420px;margin:0 auto}
.email-form input{flex:1;padding:12px 20px;border:1px solid var(--cream-ghost);border-radius:100px;background:rgba(240,230,211,.04);color:var(--cream);font-size:.88rem;font-family:var(--body);outline:none;transition:border-color .3s;min-height:48px}
.email-form input::placeholder{color:rgba(240,230,211,.3)}
.email-form input:focus{border-color:var(--gold)}
.email-form button{background:var(--gold);color:var(--bg);padding:12px 24px;border-radius:100px;font-weight:600;font-size:.82rem;white-space:nowrap;transition:transform .15s,box-shadow .3s;min-height:48px}
.email-form button:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.25)}
.email-trust{margin-top:10px;font-size:.72rem;color:rgba(240,230,211,.2)}

/* Footer */
footer{padding:40px 24px 28px;border-top:1px solid rgba(240,230,211,.05)}
.footer-inner{max-width:var(--container);margin:0 auto}
.footer-quote{font-family:var(--heading);font-style:italic;font-size:.85rem;color:rgba(240,230,211,.2);text-align:center;margin-bottom:20px}
.footer-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;align-items:center}
.footer-logo{font-family:var(--heading);font-weight:600;font-size:1rem;color:var(--gold)}
.footer-links{display:flex;gap:20px;flex-wrap:wrap}
.footer-links a{font-size:.78rem;color:rgba(240,230,211,.3);transition:color .15s}
.footer-links a:hover{color:var(--gold)}
.footer-copy{font-size:.7rem;color:rgba(240,230,211,.12)}
.footer-update{text-align:center;margin-top:16px;font-size:.72rem;color:rgba(240,230,211,.2)}
.footer-update a{color:var(--gold);opacity:.5;transition:opacity .2s}
.footer-update a:hover{opacity:1}

/* Animations */
[data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-reveal].visible{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}[data-reveal]{opacity:1!important;transform:none!important}}

/* Editorial sections */
.ed-section{padding:48px 24px;border-top:1px solid var(--cream-ghost)}
.ed-section.alt-bg{background:var(--bg-warm)}
.ed-inner{max-width:var(--container);margin:0 auto}
.ed-h2{font-family:var(--heading);font-weight:400;font-size:clamp(1.4rem,3vw,2rem);margin-bottom:16px;line-height:1.2}
.ed-h2 em{font-style:italic;color:var(--gold)}
.ed-content{font-size:.92rem;color:var(--cream-dim);line-height:1.8;font-weight:300}
.ed-content p{margin-bottom:14px}
.ed-content a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.ed-trope-list{display:flex;flex-direction:column;gap:16px}
.ed-trope-item{padding:16px;background:var(--bg-card);border-radius:12px;border:1px solid var(--cream-ghost)}
.ed-trope-name{font-family:var(--heading);font-weight:600;font-size:1rem;margin-bottom:6px}
.ed-trope-name a{color:var(--gold);transition:color .2s}
.ed-trope-name a:hover{color:var(--cream)}
.ed-trope-desc{font-size:.85rem;color:var(--cream-dim);line-height:1.6;font-weight:300}
.ed-books-like{display:flex;flex-direction:column;gap:12px}
.ed-bl-item{display:flex;gap:12px;padding:14px;background:var(--bg-card);border-radius:12px;border:1px solid var(--cream-ghost);transition:all .2s}
.ed-bl-item:hover{border-color:rgba(201,168,76,.15)}
.ed-bl-mod{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);flex-shrink:0;width:90px;padding-top:2px}
.ed-bl-body{flex:1}
.ed-bl-title{font-family:var(--heading);font-weight:600;font-size:.95rem;margin-bottom:4px}
.ed-bl-title a{color:var(--cream);transition:color .2s}
.ed-bl-title a:hover{color:var(--gold)}
.ed-bl-pitch{font-size:.82rem;color:var(--cream-dim);line-height:1.5;font-weight:300}

/* Responsive */
@media(max-width:768px){
  .book-hero{padding:110px 20px 48px}
  .hero-grid{grid-template-columns:140px 1fr;gap:24px}
  .cover{width:140px;height:205px}
  .stats{grid-template-columns:1fr 1fr}
  .compat-grid{grid-template-columns:1fr}
  .sim-grid{grid-template-columns:1fr}
  .extras-grid{grid-template-columns:1fr}
  .email-form{flex-direction:column}
  .email-form button{width:100%}
  .cta-row{flex-direction:column;align-items:stretch}
  .ba-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .cover{margin:0 auto}
  .vibe{text-align:center;border-left:none;padding:0;border-bottom:2px solid rgba(212,168,83,.3);padding-bottom:12px}
}
