/* The Bookish Flame — design tokens & shared styles */
:root{
  --ink:#15100b; --ink2:#1e1710; --ink3:#27201733;
  --parchment:#efe4ce; --dim:#c4b69b; --faint:#8f836c;
  --glow:#e9a458; --glow-bright:#f6c989; --ember:#c75b2e; --moss:#74805e;
  --hair:rgba(239,228,206,.13);
  --serif:"Newsreader",Georgia,serif;
  --disp:"Fraunces",Georgia,serif;
  --max:72rem; --measure:42rem;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
body{background:var(--ink);color:var(--parchment);font-family:var(--serif);font-size:1.0625rem;line-height:1.72;-webkit-font-smoothing:antialiased}
::selection{background:var(--glow);color:var(--ink)}
a{color:var(--glow);text-decoration-color:rgba(233,164,88,.35);text-underline-offset:3px}
a:hover{color:var(--glow-bright)}
a:focus-visible,button:focus-visible{outline:2px solid var(--glow);outline-offset:3px;border-radius:2px}
img{max-width:100%;display:block}

.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)}
.eyebrow{font-family:var(--serif);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--glow);font-weight:500}
h1,h2,h3{font-family:var(--disp);font-weight:480;line-height:1.12;letter-spacing:-.01em;text-wrap:balance}
h1{font-size:clamp(2.4rem,6vw,4.2rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.5rem);margin:0 0 1rem}
h3{font-size:1.35rem;margin:0 0 .5rem}
p,li{max-width:var(--measure)}
.lede{font-size:clamp(1.15rem,2vw,1.35rem);line-height:1.6;color:var(--dim)}
em{font-style:italic}
strong{color:var(--glow-bright);font-weight:600}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--ink) 86%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--hair)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:4rem}
.brand{font-family:var(--disp);font-size:1.15rem;color:var(--parchment);text-decoration:none;display:flex;align-items:center;gap:.55rem}
.brand .spark{width:.5rem;height:.5rem;border-radius:50%;background:var(--glow);box-shadow:0 0 12px 3px rgba(233,164,88,.65)}
.navlinks{display:flex;gap:1.6rem;font-size:.9rem}
.navlinks a{color:var(--dim);text-decoration:none}
.navlinks a:hover{color:var(--glow-bright)}
@media(max-width:680px){.navlinks{display:none}}
.nav .shopcta{font-size:.85rem;border:1px solid var(--glow);color:var(--glow);padding:.45rem 1rem;border-radius:999px;text-decoration:none;white-space:nowrap}
.nav .shopcta:hover{background:var(--glow);color:var(--ink)}

/* article layout */
.article-head{padding:5.5rem 0 3rem;border-bottom:1px solid var(--hair);background:radial-gradient(80rem 40rem at 70% -20%,rgba(233,164,88,.08),transparent 60%)}
.article-head .meta{color:var(--faint);font-size:.88rem;margin-top:1.4rem}
.article-body{padding:3.5rem 0 5rem}
.article-body h2{margin-top:3rem}
.article-body h3{margin-top:2.2rem}
.article-body p{margin:1.1rem 0}
.article-body ul,.article-body ol{margin:1.1rem 0 1.1rem 1.3rem}
.article-body li{margin:.45rem 0}
.answer-box{border:1px solid var(--hair);border-left:3px solid var(--glow);background:var(--ink2);padding:1.4rem 1.6rem;margin:2rem 0;border-radius:0 8px 8px 0}
.answer-box p{margin:.4rem 0;color:var(--parchment)}
.answer-box .eyebrow{display:block;margin-bottom:.5rem}

/* pick cards */
.pick{border:1px solid var(--hair);border-radius:10px;background:linear-gradient(180deg,var(--ink2),transparent);padding:1.6rem 1.7rem;margin:1.8rem 0}
.pick .rank{font-family:var(--disp);color:var(--glow);font-size:.95rem;letter-spacing:.08em}
.pick h3{margin-top:.3rem}
.pick .notes{color:var(--moss);font-size:.92rem;letter-spacing:.04em;margin:.2rem 0 .8rem;font-style:italic}
.pick .specs{display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;font-size:.85rem;color:var(--faint);margin:1rem 0 0;border-top:1px solid var(--hair);padding-top:.9rem}
.pick a.buy{display:inline-block;margin-top:1rem;font-size:.9rem;border:1px solid var(--glow);color:var(--glow);padding:.5rem 1.1rem;border-radius:999px;text-decoration:none}
.pick a.buy:hover{background:var(--glow);color:var(--ink)}

/* comparison table */
.cmp{width:100%;border-collapse:collapse;margin:1.6rem 0;font-size:.94rem}
.cmp th{text-align:left;font-family:var(--serif);font-weight:600;color:var(--glow);border-bottom:1px solid var(--glow);padding:.6rem .8rem;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
.cmp td{border-bottom:1px solid var(--hair);padding:.75rem .8rem;vertical-align:top;color:var(--dim)}
.cmp td:first-child{color:var(--parchment)}
.cmp-scroll{overflow-x:auto}

/* FAQ */
.faq details{border-bottom:1px solid var(--hair);padding:1.1rem 0}
.faq summary{cursor:pointer;font-family:var(--disp);font-size:1.18rem;color:var(--parchment);list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::after{content:"+";color:var(--glow);font-size:1.3rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details p{margin-top:.7rem;color:var(--dim)}

/* footer */
.footer{border-top:1px solid var(--hair);padding:3rem 0 4rem;color:var(--faint);font-size:.9rem}
.footer .cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(14rem,1fr));gap:2rem}
.footer a{color:var(--dim)}
.footer .fineprint{margin-top:2.5rem;font-size:.8rem;max-width:none}
