/* Party Box — Ideas (blog) theme. Shares the storefront tokens (home.css) but
   tuned for long-form reading: cream page, stone ink, gold accents, serif heads. */
:root{
  --gold:#e7c073; --gold-deep:#c79a45; --gold-light:#fff0d2;
  --stone-950:#120c08; --stone-900:#1a120c; --stone-850:#211711;
  --stone-800:#2a1d14; --stone-700:#3a2a1d;
  --parchment:#f3e6cf; --parchment-deep:#e7d3b1; --cream:#fff8ef;
  --ink:#2a1d12; --ink-soft:#6a553c; --rule:rgba(106,85,60,.16);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Nunito",system-ui,sans-serif;
  --script:"Caveat",cursive;
  --maxw:1180px; --readw:720px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);
  -webkit-font-smoothing:antialiased;line-height:1.65;overflow-x:clip}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.1;margin:0}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:800;margin-bottom:10px}
.btn{display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;
  font-family:var(--sans);font-weight:800;border-radius:999px;padding:14px 26px;
  font-size:15px;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:#3a2a10;
  box-shadow:0 10px 26px rgba(199,154,69,.4)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--rule)}
.btn-dark{background:var(--stone-900);color:var(--gold-light)}

/* ---------- nav (mirrors storefront) ---------- */
.nav{position:sticky;top:0;z-index:90;background:rgba(20,13,8,.94);
  backdrop-filter:blur(10px);border-bottom:1px solid rgba(231,192,115,.18)}
.nav-in{display:flex;align-items:center;gap:24px;height:68px;max-width:var(--maxw);
  margin:0 auto;padding:0 22px}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--cream)}
.brand img{height:42px;width:auto;display:block}
.navlinks{display:flex;gap:22px;list-style:none;margin:0 0 0 8px;padding:0;
  font-weight:700;font-size:14.5px}
.navlinks a{color:#efe2cf;text-decoration:none;opacity:.92;transition:color .15s}
.navlinks a:hover{color:var(--gold)}
.navlinks a[aria-current]{color:var(--gold)}
.navtools{margin-left:auto;display:flex;align-items:center;gap:12px}
.navtools .btn-primary{padding:10px 20px}
@media(max-width:860px){.navlinks{display:none}}

/* ---------- breadcrumb ---------- */
.crumbs{max-width:var(--readw);margin:26px auto 0;padding:0 22px;font-size:13px;
  color:var(--ink-soft);font-weight:700}
.crumbs a{color:var(--ink-soft);text-decoration:none}
.crumbs a:hover{color:var(--gold-deep)}
.crumbs span{opacity:.5;margin:0 7px}

/* ---------- article hero ---------- */
.post-hero{max-width:var(--readw);margin:0 auto;padding:30px 22px 10px;text-align:left}
.post-hero .eyebrow{margin-bottom:14px}
.post-hero h1{font-size:clamp(33px,5.4vw,52px);letter-spacing:-.01em}
.post-dek{font-family:var(--serif);font-size:clamp(19px,2.6vw,24px);font-style:italic;
  color:var(--ink-soft);margin:16px 0 0;line-height:1.4}
.post-meta{display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;margin-top:20px;
  padding-top:18px;border-top:1px solid var(--rule);font-size:13.5px;color:var(--ink-soft);font-weight:700}
.post-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--gold-deep);opacity:.6}
.post-emoji{font-size:30px;line-height:1}

/* ---------- article body ---------- */
.post{max-width:var(--readw);margin:0 auto;padding:18px 22px 10px;font-size:18px}
.post h2{font-size:clamp(25px,3.6vw,33px);margin:42px 0 4px;letter-spacing:-.01em}
.post h2::before{content:"✦";color:var(--gold-deep);font-size:.62em;margin-right:.5em;
  vertical-align:.18em}
.post h3{font-size:22px;margin:28px 0 2px;color:var(--stone-800)}
.post p{margin:16px 0}
.post a{color:var(--gold-deep);text-decoration:underline;text-underline-offset:2px;
  text-decoration-thickness:1px;font-weight:700}
.post a:hover{color:var(--ink)}
.post ul,.post ol{margin:16px 0;padding-left:4px;list-style:none}
.post ul li,.post ol li{position:relative;padding-left:30px;margin:10px 0}
.post ul li::before{content:"✦";position:absolute;left:4px;top:1px;color:var(--gold-deep);font-size:14px}
.post ol{counter-reset:step}
.post ol li{counter-increment:step}
.post ol li::before{content:counter(step);position:absolute;left:0;top:1px;
  width:21px;height:21px;border-radius:50%;background:var(--gold-light);color:var(--gold-deep);
  font-size:12px;font-weight:800;display:grid;place-items:center;font-family:var(--sans)}
.post strong{color:var(--stone-800)}

/* ---------- key takeaways box ---------- */
.takeaways{background:linear-gradient(180deg,#fff,var(--cream));border:1px solid var(--parchment-deep);
  border-radius:18px;padding:24px 26px;margin:26px 0;box-shadow:0 12px 30px rgba(106,85,60,.08)}
.takeaways h2{font-size:18px !important;margin:0 0 10px !important;letter-spacing:.04em;
  text-transform:uppercase;color:var(--gold-deep)}
.takeaways h2::before{display:none}
.takeaways ul{margin:0}
.takeaways li{font-size:16px}

/* ---------- inline CTA ---------- */
.cta-card{margin:38px 0;border-radius:22px;padding:30px 32px;text-align:center;
  background:radial-gradient(120% 140% at 50% 0%,var(--stone-800),var(--stone-950));
  color:var(--cream);box-shadow:0 18px 44px rgba(18,12,8,.28);position:relative;overflow:hidden}
.cta-card::after{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 80% at 80% 10%,rgba(231,192,115,.22),transparent 60%)}
.cta-card>*{position:relative;z-index:1}
.cta-card .eyebrow{color:var(--gold)}
.cta-card h3{font-size:26px;color:var(--gold-light);margin-bottom:6px}
.cta-card p{color:#d9c8ad;margin:0 0 18px;font-size:15.5px}

/* ---------- FAQ ---------- */
.faq{max-width:var(--readw);margin:10px auto 0;padding:0 22px}
.faq h2{font-size:clamp(25px,3.6vw,33px);margin:42px 0 14px}
.faq details{border-bottom:1px solid var(--rule);padding:4px 0}
.faq summary{cursor:pointer;list-style:none;padding:16px 30px 16px 2px;font-family:var(--serif);
  font-size:21px;font-weight:600;position:relative;color:var(--stone-800)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:14px;font-family:var(--sans);
  font-size:24px;color:var(--gold-deep);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:0 0 16px;color:var(--ink-soft);font-size:16.5px}

/* ---------- related ---------- */
.related{max-width:var(--maxw);margin:60px auto 0;padding:40px 22px;border-top:1px solid var(--rule)}
.related h2{font-size:28px;text-align:center;margin-bottom:24px}
.rel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.rel-card{display:block;text-decoration:none;color:inherit;background:#fff;border:1px solid var(--rule);
  border-radius:16px;padding:22px;transition:transform .15s,box-shadow .15s}
.rel-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(106,85,60,.12)}
.rel-card .rc-cat{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:800}
.rel-card h3{font-size:20px;margin:8px 0;line-height:1.2}
.rel-card p{margin:0;font-size:14px;color:var(--ink-soft)}

/* ---------- blog index ---------- */
.idx-hero{text-align:center;padding:60px 22px 34px;background:radial-gradient(120% 130% at 50% -10%,var(--parchment),var(--cream))}
.idx-hero h1{font-size:clamp(38px,6vw,62px);letter-spacing:-.015em}
.idx-hero .script{font-family:var(--script);color:var(--gold-deep);font-size:clamp(26px,4vw,38px);display:block;margin-bottom:-6px}
.idx-hero p{max-width:600px;margin:18px auto 0;color:var(--ink-soft);font-size:18px}
.idx-search{max-width:520px;margin:26px auto 0;display:flex;gap:10px}
.idx-search input{flex:1;border:1.5px solid var(--parchment-deep);background:#fff;border-radius:999px;
  padding:13px 20px;font-family:var(--sans);font-size:15px;color:var(--ink)}
.idx-search input:focus{outline:none;border-color:var(--gold)}
.cluster{max-width:var(--maxw);margin:50px auto 0;padding:0 22px}
.cluster-head{display:flex;align-items:baseline;gap:14px;margin-bottom:20px;
  border-bottom:2px solid var(--parchment-deep);padding-bottom:12px}
.cluster-head h2{font-size:30px}
.cluster-head .count{font-size:13px;color:var(--ink-soft);font-weight:700}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.bcard{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:#fff;
  border:1px solid var(--rule);border-radius:18px;padding:24px;transition:transform .15s,box-shadow .15s}
.bcard:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(106,85,60,.13)}
.bcard .b-emoji{font-size:26px;margin-bottom:10px}
.bcard .b-cat{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:800}
.bcard h3{font-size:21px;margin:7px 0 9px;line-height:1.18}
.bcard p{margin:0;font-size:14.5px;color:var(--ink-soft);flex:1}
.bcard .b-read{margin-top:14px;font-size:13px;font-weight:800;color:var(--gold-deep)}
.idx-empty{max-width:var(--maxw);margin:30px auto;padding:0 22px;color:var(--ink-soft);display:none}

/* ---------- footer ---------- */
footer{background:var(--stone-950);color:#cbb892;margin-top:70px;padding:50px 22px 26px}
.foot-in{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px}
.foot-in h4{color:var(--gold-light);font-size:16px;margin-bottom:12px}
.foot-in a{display:block;color:#bba883;text-decoration:none;font-size:14px;margin:7px 0}
.foot-in a:hover{color:var(--gold)}
.foot-in .brand img{height:46px}
.foot-motto{font-family:var(--script);color:var(--gold);font-size:24px;margin-top:8px}
.foot-bot{max-width:var(--maxw);margin:34px auto 0;padding-top:18px;border-top:1px solid rgba(231,192,115,.15);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#8c7a5c}
@media(max-width:760px){.foot-in{grid-template-columns:1fr 1fr;gap:24px}}
