/* Event Heat Press — v8 "FESTIVAL CREDENTIAL / ALL-ACCESS BADGE"
   Bespoke design language: lanyard passes, ticket stubs, barcodes, ADMIT ONE chips.
   Palette: deep plum/indigo bg + lime + coral duotone. Display: Archivo Black. Mono: Space Mono. */

:root{
  color-scheme:dark;
  --plum:#221033;
  --plum-2:#170a26;
  --plum-card:#2c1646;
  --plum-line:#43275f;
  --lime:#c6f432;
  --coral:#ff5a5f;
  --ink:#f4ecff;
  --muted:#b7a4d4;
  --paper:#fdfbff;
  --display:"Archivo Black","Archivo",Impact,sans-serif;
  --grotesk:"Archivo",system-ui,-apple-system,sans-serif;
  --mono:"Space Mono",ui-monospace,Menlo,monospace;
  --notch:14px;
  --barcode:repeating-linear-gradient(90deg,#170a26 0,#170a26 2px,transparent 2px,transparent 4px,#170a26 4px,#170a26 9px,transparent 9px,transparent 11px,#170a26 11px,#170a26 12px,transparent 12px,transparent 16px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--grotesk);
  background:var(--plum);
  background-image:radial-gradient(120% 80% at 85% -10%,rgba(255,90,95,.22),transparent 55%),radial-gradient(90% 70% at 0% 0%,rgba(198,244,50,.12),transparent 50%);
  background-attachment:fixed;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,p{margin-top:0}
h1{font-family:var(--display);font-weight:900;font-size:clamp(2.5rem,6.4vw,5.6rem);line-height:.92;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:.45em}
h2{font-family:var(--display);font-weight:900;font-size:clamp(1.7rem,3.4vw,3.1rem);line-height:1;letter-spacing:-.01em;text-transform:uppercase}
h3{font-family:var(--grotesk);font-weight:900;font-size:1.12rem;letter-spacing:.005em}

/* ---------- scroll progress (lime credential bar) ---------- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:4px;background:var(--lime);transform-origin:left;transform:scaleX(0);z-index:30;box-shadow:0 0 14px rgba(198,244,50,.6)}

/* ---------- eyebrow / ADMIT ONE chip ---------- */
.eyebrow{font-family:var(--mono);text-transform:uppercase;font-size:.74rem;font-weight:700;letter-spacing:.18em;color:var(--lime);display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin-bottom:.9rem}
.admit{display:inline-block;background:var(--coral);color:#fff;font-family:var(--mono);font-weight:700;letter-spacing:.16em;font-size:.66rem;padding:.28rem .55rem;border-radius:3px;clip-path:polygon(7px 0,100% 0,calc(100% - 7px) 100%,0 100%);box-shadow:0 0 0 1px rgba(255,255,255,.15) inset}

/* ---------- header / nav ---------- */
.site-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem clamp(1rem,3.5vw,2.4rem);background:rgba(23,10,38,.82);border-bottom:1px solid var(--plum-line);backdrop-filter:blur(14px)}
.brand{display:flex;align-items:center;gap:.65rem;text-decoration:none;min-width:0}
.brand span:last-child{min-width:0;line-height:1.05}
.brand strong{font-family:var(--display);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56vw;text-transform:uppercase;letter-spacing:.01em;font-size:1.02rem}
.brand small{display:block;color:var(--muted);font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase}
.brand-mark{display:grid;place-items:center;flex:0 0 auto;width:44px;height:44px;background:var(--lime);color:var(--plum);font-family:var(--display);font-weight:900;font-size:1.1rem;letter-spacing:.02em;clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%);box-shadow:0 0 0 2px var(--plum) inset}
.site-nav{display:flex;align-items:center;gap:.2rem;font-family:var(--mono);font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}
.site-nav a{text-decoration:none;color:var(--muted);padding:.45rem .6rem;border-radius:4px;transition:color .15s,background .15s}
.site-nav a:hover{color:var(--plum);background:var(--lime)}
.site-nav a[href="#quote"]{color:var(--plum);background:var(--coral);font-weight:700}
.site-nav a[href="#quote"]:hover{background:var(--lime)}
.nav-toggle{display:none}

/* ---------- buttons (ticket-notched) ---------- */
.button,button.form-submit,.button-ghost{
  display:inline-block;border:0;cursor:pointer;text-decoration:none;text-align:center;
  font-family:var(--grotesk);font-weight:900;text-transform:uppercase;letter-spacing:.05em;font-size:.92rem;
  padding:.95rem 1.5rem;
  clip-path:polygon(0 0,calc(100% - var(--notch)) 0,100% 50%,calc(100% - var(--notch)) 100%,0 100%,var(--notch) 50%);
}
.button{background:var(--lime);color:var(--plum)}
.button:hover{background:#d6ff4f}
.button-ghost{background:var(--coral);color:#fff}
.button-ghost:hover{background:#ff7378}

/* ---------- HERO (lanyard badge) ---------- */
.hero{padding:clamp(2.5rem,6vw,5rem) clamp(1rem,4vw,4rem) clamp(3rem,6vw,5rem)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(330px,.7fr);gap:clamp(1.5rem,4vw,4rem);align-items:center;max-width:1280px;margin:0 auto}
.hero-copy{min-width:0}
.lede{font-size:clamp(1.06rem,1.9vw,1.32rem);line-height:1.55;max-width:46rem;color:var(--muted)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.6rem}
.hero-note{margin-top:1.4rem;font-family:var(--mono);font-size:.78rem;line-height:1.6;color:var(--muted);max-width:40rem;border-left:3px solid var(--lime);padding-left:.85rem}

/* the credential card */
.badge{position:relative;justify-self:center;width:100%;max-width:360px;padding-top:42px}
.badge-lanyard{position:absolute;top:0;left:50%;transform:translateX(-50%);width:54px;height:54px;background:linear-gradient(180deg,var(--coral),#d63d52);clip-path:polygon(0 0,100% 0,80% 100%,20% 100%);z-index:1}
.lanyard-clip{position:absolute;left:50%;bottom:-9px;transform:translateX(-50%);width:30px;height:16px;border:4px solid #d7d2dd;border-radius:0 0 9px 9px;border-top:0;background:transparent}
.badge-body{position:relative;background:var(--paper);color:var(--plum);border-radius:16px;padding:1.4rem 1.25rem 1.25rem;box-shadow:0 30px 60px -22px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.05);z-index:2}
.badge-body:before,.badge-body:after{content:"";position:absolute;width:14px;height:14px;border-radius:50%;background:var(--plum);top:64px}
.badge-body:before{left:-7px}
.badge-body:after{right:-7px}
/* perforation line */
.badge-perf{position:absolute;left:14px;right:14px;top:70px;height:2px;background:radial-gradient(circle,var(--plum) 1.4px,transparent 1.6px) 0 0/8px 2px repeat-x;opacity:.5}
.badge-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}
.badge-tag{background:var(--plum);color:var(--lime);font-family:var(--mono);font-weight:700;font-size:.66rem;letter-spacing:.18em;padding:.32rem .55rem;border-radius:3px}
.badge-no{font-family:var(--mono);font-weight:700;font-size:.78rem;color:var(--coral);letter-spacing:.06em}
.badge-photo{margin:0;border-radius:10px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 0 0 1px rgba(34,16,51,.12)}
.badge-photo img{width:100%;height:100%;object-fit:cover}
.badge-name{font-family:var(--display);text-transform:uppercase;font-size:1.4rem;line-height:1;margin:.95rem 0 .25rem;letter-spacing:.01em}
.badge-role{font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:#6a5a82;margin:0 0 1rem}
.badge-barcode{height:42px;background:var(--barcode);margin-bottom:.55rem;border-radius:2px}
.badge-code{font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;color:#6a5a82;display:block;text-align:center}

/* ---------- shared section frame ---------- */
main>section{padding:clamp(3rem,7vw,6rem) clamp(1rem,4vw,4rem);max-width:1280px;margin:0 auto}
main>section>.eyebrow{justify-content:flex-start}

/* ---------- trust bar (backstage) ---------- */
.trust-bar{text-align:center}
.trust-bar .eyebrow{justify-content:center}
.trust-logos{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin-top:1.4rem}
.trust-logos span{font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.84rem;color:var(--ink);padding:.6rem 1rem;border:1px solid var(--plum-line);border-radius:6px;background:rgba(255,255,255,.03)}

/* ---------- LINEUP (festival schedule) ---------- */
.lineup-head{max-width:46rem;margin-bottom:2rem}
.lineup-sub{color:var(--muted);font-size:1.02rem;line-height:1.5;margin-top:.7rem}
.lineup-list{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.lineup-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.1rem;background:var(--plum-card);border:1px solid var(--plum-line);border-radius:12px;padding:1.05rem 1.25rem;transition:transform .15s,border-color .15s}
.lineup-row:hover{transform:translateX(6px);border-color:var(--lime)}
.lineup-no{font-family:var(--display);font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1;color:var(--lime);min-width:1.8em}
.lineup-meta h3{margin:0 0 .25rem}
.lineup-meta p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.45;max-width:54ch}
.lineup-stage{justify-self:end;font-family:var(--mono);font-weight:700;font-size:.66rem;letter-spacing:.14em;color:var(--plum);background:var(--lime);padding:.34rem .55rem;border-radius:3px;white-space:nowrap}
.lineup-row:nth-child(even) .lineup-stage{background:var(--coral);color:#fff}

/* ---------- STUBS (ticket-stub flow cards) ---------- */
.stub-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-top:1.7rem}
.stub{position:relative;background:var(--paper);color:var(--plum);padding:1.4rem 1.15rem 1.25rem;border-radius:12px;overflow:hidden;clip-path:polygon(0 0,100% 0,100% calc(100% - 18px),calc(100% - 18px) 100%,0 100%)}
.stub:before{content:"";position:absolute;left:0;right:0;top:46px;height:2px;background:radial-gradient(circle,var(--plum) 1.3px,transparent 1.5px) 0 0/7px 2px repeat-x;opacity:.35}
.stub-no{display:inline-block;font-family:var(--mono);font-weight:700;font-size:.64rem;letter-spacing:.14em;color:#fff;background:var(--coral);padding:.28rem .5rem;border-radius:3px;margin-bottom:1.5rem}
.stub h3{margin:0 0 .45rem;font-family:var(--display);text-transform:uppercase;font-size:1.05rem}
.stub p{margin:0;color:#5a4b72;font-size:.92rem;line-height:1.5}

/* ---------- GALLERY ---------- */
.gallery-band .photo-grid,.photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:1.7rem}
.photo-grid figure{margin:0;background:var(--plum-card);border:1px solid var(--plum-line);border-radius:12px;overflow:hidden}
.photo-grid img{aspect-ratio:4/3;object-fit:cover;width:100%}
.photo-grid figcaption{padding:.75rem .85rem;color:var(--muted);font-family:var(--mono);font-size:.76rem;letter-spacing:.02em}

/* ---------- intent ribbon (barcode marquee) ---------- */
.intent-ribbon{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;padding:1.6rem clamp(1rem,4vw,4rem);background:var(--plum-2);border-top:1px solid var(--plum-line);border-bottom:1px solid var(--plum-line);max-width:none}
.intent-ribbon span{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--plum);background:var(--lime);padding:.4rem .7rem;border-radius:3px;clip-path:polygon(6px 0,100% 0,calc(100% - 6px) 100%,0 100%)}
.intent-ribbon span:nth-child(even){background:var(--coral);color:#fff}

/* ---------- FAQ (will call) ---------- */
.faq-list{display:grid;gap:.7rem;max-width:920px;margin-top:1.6rem}
.faq-list details{background:var(--plum-card);border:1px solid var(--plum-line);border-radius:10px;padding:1.05rem 1.2rem}
.faq-list summary{font-family:var(--grotesk);font-weight:900;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary:after{content:"+";font-family:var(--mono);color:var(--lime);font-size:1.3rem;line-height:1}
.faq-list details[open] summary:after{content:"–"}
.faq-list details p{margin:.85rem 0 0;color:var(--muted);line-height:1.6}

/* ---------- QUOTE BAND + form ---------- */
.quote-band{display:grid;grid-template-columns:minmax(260px,.7fr) minmax(0,1fr);gap:clamp(1.5rem,4vw,3rem);align-items:start;background:var(--plum-2);border:1px solid var(--plum-line);border-radius:18px}
.quote-intro p{color:var(--muted);line-height:1.55}
.quote-intro .eyebrow{justify-content:flex-start}
.lead-form{position:relative;background:var(--paper);color:var(--plum);border-radius:14px;padding:1.35rem;display:grid;gap:.95rem;box-shadow:0 28px 55px -25px rgba(0,0,0,.6)}
.lead-form:before{content:"PRESS PASS · MERCH TROOP";position:absolute;top:-11px;left:1.35rem;background:var(--coral);color:#fff;font-family:var(--mono);font-weight:700;font-size:.6rem;letter-spacing:.14em;padding:.3rem .55rem;border-radius:3px}
.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}
.lead-form label{display:grid;gap:.35rem;font-family:var(--mono);font-weight:700;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:#5a4b72}
.lead-form input,.lead-form textarea{width:100%;border:1.5px solid #d8cfe6;border-radius:8px;padding:.78rem;font-family:var(--grotesk);font-size:.98rem;background:#fff;color:var(--plum)}
.lead-form input::placeholder,.lead-form textarea::placeholder{color:#9a8cb2}
.lead-form input:focus,.lead-form textarea:focus{outline:0;border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,90,95,.18)}
.lead-form textarea{resize:vertical;min-height:6rem}
button.form-submit{margin-top:.2rem;justify-self:start;padding:1rem 1.8rem}
.form-note{margin:0;font-family:var(--mono);font-size:.72rem;line-height:1.5;color:#6a5a82}
.hp-wrap{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ---------- footer ---------- */
.site-footer{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1.5rem;align-items:center;padding:2.4rem clamp(1rem,4vw,4rem);background:var(--plum-2);border-top:2px solid var(--lime)}
.site-footer strong{font-family:var(--display);text-transform:uppercase;font-size:1.15rem;display:block;margin-bottom:.4rem}
.site-footer p{color:var(--muted);font-size:.9rem;line-height:1.55;max-width:46ch;margin:0}
.site-footer nav{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}
.site-footer a{text-decoration:none;font-family:var(--mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:.45rem .65rem;border:1px solid var(--plum-line);border-radius:5px}
.site-footer a:hover{color:var(--plum);background:var(--lime);border-color:var(--lime)}

/* ---------- subpage fallbacks (cohesion) ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:1.7rem}
.card{background:var(--plum-card);border:1px solid var(--plum-line);border-radius:12px;padding:1.25rem}
.card p{color:var(--muted);line-height:1.5}
.card a{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:700;color:var(--lime);text-decoration:none}
.article-body,.answer{max-width:880px}
.article-body p,.answer p{font-size:1.05rem;line-height:1.7;color:var(--muted)}
.product-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-top:1.7rem}
.product-strip figure{margin:0;background:var(--plum-card);border:1px solid var(--plum-line);border-radius:12px;overflow:hidden}
.product-strip img{aspect-ratio:1/1;object-fit:cover;width:100%}
.product-strip figcaption{padding:.7rem;color:var(--muted);font-family:var(--mono);font-size:.74rem}
/* legacy hero accessory/ticket bits from subpages — fold into badge styling */
.hero-accessory,.ticket-stamp,.ticket-title,.ticket-row,.ticket-cta,.hero-media,.hero-artifact,.hero-livebug,.hero-timestamp,.hero-ticker{font-family:var(--mono)}
.hero-media{margin:0;border-radius:14px;overflow:hidden;position:relative}
.hero-media img{width:100%;object-fit:cover}
.hero-media figcaption{position:absolute;left:.8rem;right:.8rem;bottom:.8rem;background:rgba(23,10,38,.85);color:var(--ink);padding:.55rem .7rem;border-radius:6px;font-size:.8rem}
.hero-accessory{background:var(--paper);color:var(--plum);border-radius:14px;padding:1.2rem;display:grid;gap:.4rem}
.ticket-stamp{display:inline-block;background:var(--coral);color:#fff;padding:.3rem .55rem;border-radius:3px;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;justify-self:start}
.ticket-title{display:flex;justify-content:space-between;font-family:var(--display);text-transform:uppercase;font-size:1.05rem;margin:.6rem 0}
.ticket-no{color:var(--coral)}
.ticket-row{display:flex;gap:.7rem;align-items:center;border-top:1px dashed #cbbfdd;padding:.45rem 0;font-size:.85rem}
.ticket-row span{font-family:var(--mono);font-weight:700;color:var(--coral)}
.ticket-cta{margin-top:.7rem;display:inline-block;background:var(--lime);color:var(--plum);text-decoration:none;text-align:center;font-weight:900;text-transform:uppercase;padding:.7rem;border-radius:6px;font-size:.85rem}
.hero-livebug,.hero-timestamp,.hero-ticker{display:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .badge{max-width:340px}
  .stub-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .photo-grid,.gallery-band .photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .product-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:860px){
  .nav-toggle{display:inline-flex;align-items:center;border:1px solid var(--plum-line);background:var(--lime);color:var(--plum);border-radius:6px;padding:.6rem .8rem;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}
  .site-nav{display:none;position:absolute;left:1rem;right:1rem;top:calc(100% + .4rem);background:var(--plum-2);border:1px solid var(--plum-line);border-radius:10px;padding:.8rem;flex-direction:column;align-items:stretch;gap:.3rem}
  .site-nav.is-open{display:flex}
  .site-nav a{padding:.7rem .8rem}
  .quote-band{grid-template-columns:1fr}
  .site-footer{grid-template-columns:1fr}
  .site-footer nav{justify-content:flex-start}
}
@media(max-width:560px){
  .site-header{padding:.65rem 1rem}
  .brand strong{font-size:.95rem;max-width:46vw}
  .lineup-row{grid-template-columns:auto 1fr;gap:.8rem}
  .lineup-stage{grid-column:1/-1;justify-self:start;margin-top:.2rem}
  .stub-grid{grid-template-columns:1fr}
  .photo-grid,.gallery-band .photo-grid{grid-template-columns:1fr}
  .field-grid{grid-template-columns:1fr}
  .card-grid,.product-strip{grid-template-columns:1fr}
  .hero-actions{display:grid}
  .button,.button-ghost{width:100%}
  h1{font-size:2.35rem}
}

/* === blog === */
/* Festival-credential blog system — readable long-form on the dark plum stage.
   Reuses --plum/--lime/--coral/--ink/--muted/--paper, Archivo Black display, Space Mono labels. */

/* ---- blog index landing ---- */
.blog-hero{max-width:1280px;margin:0 auto;padding:clamp(2.6rem,6vw,4.4rem) clamp(1rem,4vw,4rem) clamp(1.4rem,3vw,2.2rem)}
.blog-hero h1{font-size:clamp(2.2rem,5.2vw,4.2rem);margin-bottom:.4em}
.blog-hero .lede{max-width:48rem}
.blog-hero .eyebrow{justify-content:flex-start}

.post-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.15rem;margin-top:.4rem}
.post-card{display:flex;flex-direction:column;background:var(--plum-card);border:1px solid var(--plum-line);border-radius:14px;overflow:hidden;text-decoration:none;color:var(--ink);transition:transform .15s,border-color .15s,box-shadow .15s}
.post-card:hover{transform:translateY(-4px);border-color:var(--lime);box-shadow:0 22px 44px -26px rgba(0,0,0,.8)}
.post-card-figure{margin:0;aspect-ratio:16/10;overflow:hidden;position:relative}
.post-card-figure img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post-card:hover .post-card-figure img{transform:scale(1.05)}
.post-card-tag{position:absolute;top:.7rem;left:.7rem;font-family:var(--mono);font-weight:700;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--plum);background:var(--lime);padding:.3rem .5rem;border-radius:3px;clip-path:polygon(6px 0,100% 0,calc(100% - 6px) 100%,0 100%)}
.post-card:nth-child(even) .post-card-tag{background:var(--coral);color:#fff}
.post-card-body{padding:1.1rem 1.15rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.post-card-body h3{font-family:var(--display);text-transform:uppercase;font-size:1.12rem;line-height:1.05;margin:0;color:var(--ink)}
.post-card-body p{margin:0;color:var(--muted);font-size:.93rem;line-height:1.5}
.post-card-meta{margin-top:auto;font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--lime);display:flex;align-items:center;gap:.5rem;padding-top:.3rem}
.post-card-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--coral);display:inline-block}

/* ---- long-form article ---- */
.post-shell{max-width:1180px;margin:0 auto;padding:clamp(2.2rem,5vw,3.6rem) clamp(1rem,4vw,4rem) 0}
.post-header{max-width:54rem}
.post-header .eyebrow{justify-content:flex-start}
.post-crumbs{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:1.2rem}
.post-crumbs a{color:var(--lime);text-decoration:none}
.post-crumbs a:hover{text-decoration:underline}
.post-crumbs span{color:#6f5b8e;margin:0 .45rem}
.post-header h1{font-size:clamp(2.1rem,4.8vw,3.7rem);line-height:.96;margin-bottom:.45em}
.post-meta{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.55rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,.03);border:1px solid var(--plum-line);border-radius:30px;padding:.45rem .9rem}
.post-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--lime);display:inline-block}

.post-hero-figure{max-width:1180px;margin:1.8rem auto 0;padding:0 clamp(1rem,4vw,4rem)}
.post-hero-figure figure{margin:0;border-radius:16px;overflow:hidden;border:1px solid var(--plum-line);position:relative}
.post-hero-figure img{width:100%;aspect-ratio:16/8;object-fit:cover;display:block}
.post-hero-figure figcaption{font-family:var(--mono);font-size:.68rem;letter-spacing:.04em;color:var(--muted);padding:.7rem .2rem 0;text-transform:uppercase}

/* readable measure on dark: high-contrast body text ~68ch */
.post-body{max-width:68ch;margin:clamp(2rem,4vw,3rem) auto 0;padding:0 clamp(1rem,4vw,2rem);font-size:1.085rem;line-height:1.78;color:#e9def8}
.post-body>p{margin:0 0 1.25rem}
.post-body .post-lede{font-size:1.22rem;line-height:1.6;color:var(--ink);font-weight:600}
.post-body h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.45rem,2.6vw,2rem);line-height:1.04;color:var(--ink);margin:2.4rem 0 .9rem;letter-spacing:-.005em}
.post-body h2:before{content:"";display:block;width:46px;height:4px;background:var(--lime);margin-bottom:.85rem;border-radius:2px}
.post-body h3{font-family:var(--grotesk);font-weight:900;font-size:1.18rem;color:#f4ecff;margin:1.7rem 0 .55rem;letter-spacing:.005em}
.post-body a{color:var(--lime);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.post-body a:hover{color:#d6ff4f}
.post-body strong{color:var(--ink)}
.post-body ul,.post-body ol{margin:0 0 1.35rem;padding-left:0;list-style:none}
.post-body ul li,.post-body ol li{position:relative;padding-left:1.6rem;margin-bottom:.6rem;line-height:1.65}
.post-body ul li:before{content:"";position:absolute;left:0;top:.62em;width:9px;height:9px;background:var(--coral);clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%)}
.post-body ol{counter-reset:step}
.post-body ol li{counter-increment:step}
.post-body ol li:before{content:counter(step,decimal-leading-zero);position:absolute;left:0;top:.05em;font-family:var(--mono);font-weight:700;font-size:.78rem;color:var(--lime)}
.post-body blockquote{margin:1.8rem 0;padding:1.1rem 1.3rem;background:var(--plum-card);border-left:4px solid var(--lime);border-radius:0 10px 10px 0;font-family:var(--grotesk);font-style:normal;font-size:1.12rem;line-height:1.55;color:var(--ink)}
.post-body blockquote p:last-child{margin:0}

/* FAQ block inside article */
.post-faq{max-width:68ch;margin:1.5rem auto 0;padding:0 clamp(1rem,4vw,2rem)}
.post-faq h2{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.45rem,2.6vw,2rem);color:var(--ink);margin:2.4rem 0 1rem}
.post-faq details{background:var(--plum-card);border:1px solid var(--plum-line);border-radius:10px;padding:1rem 1.15rem;margin-bottom:.65rem}
.post-faq summary{font-family:var(--grotesk);font-weight:900;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center;color:var(--ink)}
.post-faq summary::-webkit-details-marker{display:none}
.post-faq summary:after{content:"+";font-family:var(--mono);color:var(--lime);font-size:1.3rem;line-height:1}
.post-faq details[open] summary:after{content:"–"}
.post-faq details p{margin:.85rem 0 0;color:#e9def8;line-height:1.7}

/* CTA band inside article */
.post-cta{max-width:1100px;margin:clamp(2.6rem,5vw,4rem) auto 0;padding:clamp(1.8rem,4vw,2.8rem) clamp(1.4rem,4vw,2.6rem);background:var(--plum-2);border:1px solid var(--plum-line);border-radius:18px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1.4rem;align-items:center;position:relative;overflow:hidden}
.post-cta:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--lime)}
.post-cta .eyebrow{justify-content:flex-start;margin-bottom:.6rem}
.post-cta h2{font-size:clamp(1.5rem,3vw,2.4rem);margin-bottom:.4rem}
.post-cta p{margin:0;color:var(--muted);line-height:1.55;max-width:46ch}
.post-cta-actions{display:flex;flex-wrap:wrap;gap:.7rem;justify-self:end}

/* related guides */
.related-posts{max-width:1180px;margin:clamp(2.4rem,5vw,3.4rem) auto 0;padding:0 clamp(1rem,4vw,4rem)}
.related-posts .eyebrow{justify-content:flex-start}
.related-posts h2{font-size:clamp(1.4rem,2.6vw,2rem);margin-bottom:1.3rem}
.related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.related-card{display:flex;flex-direction:column;gap:.45rem;background:var(--plum-card);border:1px solid var(--plum-line);border-radius:12px;padding:1.1rem 1.15rem;text-decoration:none;color:var(--ink);transition:border-color .15s,transform .15s}
.related-card:hover{border-color:var(--lime);transform:translateY(-3px)}
.related-card span{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--lime)}
.related-card h3{font-family:var(--display);text-transform:uppercase;font-size:1rem;line-height:1.05;color:var(--ink);margin:0}
.related-card p{margin:0;color:var(--muted);font-size:.88rem;line-height:1.45}

.post-shell+.related-posts,.post-cta+.related-posts{margin-top:clamp(2.4rem,5vw,3.4rem)}
main>.post-cta:last-child,main>.related-posts:last-child{margin-bottom:clamp(3rem,6vw,5rem)}

@media(max-width:980px){
  .post-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .related-grid{grid-template-columns:1fr}
  .post-cta{grid-template-columns:1fr}
  .post-cta-actions{justify-self:start}
}
@media(max-width:560px){
  .post-grid{grid-template-columns:1fr}
  .post-body{font-size:1.04rem}
  .post-cta-actions .button,.post-cta-actions .button-ghost{width:100%}
}
