/* the spins · site stylesheet · v1.0 */

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--ink);
  color:var(--spin);
  line-height:1.55;
  font-weight:400;
  overflow-x:hidden;
  position:relative;
  min-height:100vh;
}

/* film grain */
body::before{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:200;
  opacity:.07;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='320' height='320'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/></filter><rect width='320' height='320' filter='url(%23n)' opacity='1'/></svg>");
  mix-blend-mode:overlay;
}
/* vignette */
body::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:199;
  background:radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.5) 100%);
}
::selection{background:var(--red);color:var(--spin)}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit}

/* ============ LAYOUT ============ */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 1.5rem}
.wrap-narrow{max-width:var(--wrap-narrow);margin:0 auto;padding:0 1.5rem}
section{padding:5rem 0;position:relative;z-index:1}
@media(min-width:768px){section{padding:7rem 0}}
.divider-red{height:6px;background:var(--red);width:100%}
.rule{height:1px;background:#222;margin:0}

/* ============ TYPE ============ */
h1{font-family:var(--display);font-size:clamp(3rem,12vw,8rem);line-height:.88;letter-spacing:-.015em;text-transform:lowercase}
h2{font-family:var(--display);font-size:clamp(2.25rem,6.5vw,4.5rem);line-height:.95;letter-spacing:-.01em;text-transform:lowercase;margin-bottom:1.5rem}
h3{font-family:var(--display);font-size:clamp(1.5rem,3.5vw,2.25rem);line-height:1;letter-spacing:-.005em;text-transform:lowercase;margin-bottom:.75rem}
h4{font-family:var(--display);font-size:1.25rem;line-height:1;letter-spacing:-.005em;text-transform:lowercase;margin-bottom:.5rem}
p{font-size:1rem;line-height:1.65;max-width:62ch}
@media(min-width:768px){p{font-size:1.0625rem}}
.lead{font-size:1.1875rem;line-height:1.55}
.eyebrow{
  font-family:var(--body);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.7rem;
  font-weight:700;
  color:var(--red);
  display:inline-block;
  margin-bottom:1.25rem;
}
.scribble{font-family:var(--hand);color:var(--red);display:inline-block;transform:rotate(-2.5deg);font-weight:400}
.hand-blue{font-family:var(--hand);color:var(--steel);display:inline-block;transform:rotate(-2deg)}
.hand-ink{font-family:var(--hand);color:var(--ink);display:inline-block;transform:rotate(-1.5deg)}
.mono{font-family:var(--mono)}
.section-flag{
  display:inline-block;
  background:var(--red);
  color:var(--spin);
  font-family:var(--display);
  text-transform:lowercase;
  padding:.35rem .85rem;
  font-size:.875rem;
  margin-bottom:1.25rem;
  letter-spacing:.005em;
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  background:var(--red);
  color:var(--spin);
  font-family:var(--display);
  font-size:1.0625rem;
  text-transform:lowercase;
  padding:1rem 1.75rem;
  text-decoration:none;
  border:none;
  cursor:pointer;
  position:relative;
  letter-spacing:.005em;
  transition:transform var(--t-fast) ease-out, box-shadow var(--t-fast) ease-out;
  box-shadow:6px 6px 0 var(--spin);
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--spin)}
.btn:active{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--spin)}
.btn-light{background:var(--spin);color:var(--ink);box-shadow:6px 6px 0 var(--red)}
.btn-light:hover{box-shadow:8px 8px 0 var(--red)}
.btn-light:active{box-shadow:3px 3px 0 var(--red)}
.btn-ghost{background:transparent;color:var(--spin);box-shadow:inset 0 0 0 2px var(--spin)}
.btn-ghost:hover{background:var(--spin);color:var(--ink);box-shadow:6px 6px 0 var(--red), inset 0 0 0 2px var(--spin)}
.btn .arrow{transition:transform .15s}
.btn:hover .arrow{transform:translateX(4px)}
.btn-sm{font-size:.9rem;padding:.65rem 1.1rem;box-shadow:4px 4px 0 var(--spin)}
.btn-sm:hover{box-shadow:6px 6px 0 var(--spin)}

/* secondary inline link — 44px tappable on touch devices */
.link-secondary{
  font-family:var(--body);
  color:var(--spin-2);
  text-decoration:none;
  transition:color var(--t-fast), border-color var(--t-fast);
  font-size:.95rem;
  display:inline-block;
  padding:.85rem 0;
  border-bottom:1px dashed var(--grey);
  line-height:1.2;
  min-height:44px;
}
.link-secondary:hover{color:var(--red);border-color:var(--red)}

/* ============ STICKY CTA + TOPBAR ============ */
.sticky-cta{
  position:fixed;
  bottom:1.25rem;
  right:1.25rem;
  z-index:150;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
}
.sticky-cta.show{opacity:1;pointer-events:auto}
@media(max-width:640px){.sticky-cta{bottom:.75rem;right:.75rem;font-size:.95rem}.sticky-cta.btn{padding:.875rem 1.25rem}}

.topbar{
  position:absolute;
  top:0;left:0;right:0;
  z-index:10;
  padding:1rem 1.25rem;
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  font-family:var(--body);
  font-size:.6rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--grey);
  gap:.4rem .75rem;
}
@media(min-width:640px){.topbar{font-size:.65rem;letter-spacing:.18em}}
@media(min-width:768px){.topbar{padding:1.25rem 1.5rem;font-size:.7rem;letter-spacing:.2em;gap:.75rem;flex-wrap:nowrap}}
.topbar .est{display:flex;align-items:center;gap:.5rem;white-space:nowrap}
/* short deadline on mobile, full on desktop */
.topbar .deadline-short{display:inline}
.topbar .deadline-full{display:none}
@media(min-width:768px){
  .topbar .deadline-short{display:none}
  .topbar .deadline-full{display:inline}
}
.topbar .dot{width:6px;height:6px;background:var(--red);border-radius:50%}
.topbar a{color:var(--spin-2);text-decoration:none;border-bottom:1px dashed transparent;transition:color var(--t-fast),border-color var(--t-fast)}
.topbar a:hover{color:var(--red);border-color:var(--red)}
.topbar .deadline{color:var(--red);font-weight:700}

/* ============ HERO ============ */
.hero{
  min-height:100vh;
  padding-top:5rem;
  padding-bottom:4rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.hero-bg-spiral{
  position:absolute;
  right:-15%;
  top:50%;
  transform:translateY(-50%);
  width:min(110vw,860px);
  height:min(110vw,860px);
  opacity:.10;
  pointer-events:none;
  z-index:0;
}
@media(min-width:1024px){.hero-bg-spiral{opacity:.14;right:-5%}}
.hero-content{position:relative;z-index:2}
.wordmark{
  font-family:var(--display);
  font-size:clamp(4.5rem,21vw,16rem);
  line-height:.82;
  letter-spacing:-.025em;
  text-transform:lowercase;
  color:var(--spin);
  margin:.5rem 0 1rem;
}
.tagline-block{margin-top:1.5rem;max-width:540px}
.tagline-block .tag-red{
  font-family:var(--display);
  font-size:clamp(1.125rem,2.4vw,1.5rem);
  color:var(--red);
  text-transform:lowercase;
  letter-spacing:-.005em;
  line-height:1.15;
}
.tagline-block .tag-sub{
  font-family:var(--body);
  font-size:1rem;
  color:var(--spin-2);
  margin-top:.75rem;
  max-width:42ch;
  line-height:1.55;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.25rem;align-items:center}
.hero-secondary{margin-top:1rem;display:flex;flex-wrap:wrap;gap:1.25rem;align-items:center}

/* counter + countdown */
.counter{
  display:inline-flex;
  align-items:center;
  gap:.75rem;
  background:transparent;
  border:1.5px dashed var(--grey);
  padding:.65rem 1rem;
  font-family:var(--body);
  font-size:.875rem;
  color:var(--spin-2);
}
.counter strong{font-family:var(--display);color:var(--red);font-size:1rem;letter-spacing:0}
.counter .live-dot{width:8px;height:8px;background:var(--red);border-radius:50%;animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}

.countdown{
  font-family:var(--mono);
  font-size:.875rem;
  color:var(--grey);
  letter-spacing:.05em;
}
.countdown strong{color:var(--red);font-family:var(--mono);font-weight:400}
.countdown-big{font-family:var(--display);font-size:clamp(1.5rem,4vw,2.5rem);line-height:1;color:var(--spin);text-transform:lowercase}
.countdown-big strong{color:var(--ink);background:var(--spin);padding:0 .35rem;display:inline-block}

/* ============ PITCH + RECEIPT ============ */
.pitch{padding:5rem 0;background:var(--ink-2);position:relative}
.pitch-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:start}
@media(min-width:900px){.pitch-grid{grid-template-columns:1.2fr 1fr;gap:5rem}}
.pitch-bullets{list-style:none;margin-top:2rem}
.pitch-bullets li{
  padding:1rem 0;
  border-bottom:1px solid #2a2a2a;
  display:flex;
  gap:1.25rem;
  align-items:flex-start;
}
.pitch-bullets li:last-child{border-bottom:none}
.pitch-bullets .num{font-family:var(--display);color:var(--red);font-size:1.5rem;line-height:1;min-width:2rem}
.pitch-bullets .text strong{color:var(--spin);display:block;margin-bottom:.25rem;font-weight:700}
.pitch-bullets .text{font-size:.95rem;color:var(--spin-2);line-height:1.55}

.receipt{
  background:var(--spin);
  color:var(--ink);
  max-width:380px;
  padding:1.75rem 1.5rem;
  font-family:var(--mono);
  font-size:.875rem;
  line-height:1.6;
  box-shadow:14px 14px 0 var(--red);
  position:relative;
  transform:rotate(1.5deg);
}
@media(min-width:900px){.receipt{margin-left:auto;transform:rotate(2deg)}}
.receipt.is-stamped{animation:stampIn .6s cubic-bezier(.16,1,.3,1) both}
@keyframes stampIn{
  0%{transform:rotate(0deg) scale(.95);opacity:0}
  60%{transform:rotate(3deg) scale(1.02)}
  100%{transform:rotate(2deg) scale(1);opacity:1}
}
.receipt::before{
  content:'';position:absolute;top:-12px;left:0;right:0;height:14px;
  background:linear-gradient(135deg, var(--spin) 25%, transparent 25%) 0 0/14px 14px, linear-gradient(225deg, var(--spin) 25%, transparent 25%) 0 0/14px 14px;
}
.receipt::after{
  content:'';position:absolute;bottom:-12px;left:0;right:0;height:14px;
  background:linear-gradient(45deg, var(--spin) 25%, transparent 25%) 0 0/14px 14px, linear-gradient(-45deg, var(--spin) 25%, transparent 25%) 0 0/14px 14px;
}
.receipt-header{font-family:var(--display);font-size:1.75rem;text-transform:lowercase;line-height:.95;margin-bottom:.5rem}
.receipt-sub{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.25rem;color:var(--ink)}
.receipt-row{display:flex;justify-content:space-between;align-items:baseline;padding:.15rem 0}
.receipt-row span:first-child{flex:1;padding-right:.5rem}
.receipt-row .val{white-space:nowrap}
.receipt-rule{border-top:1px dashed var(--ink);margin:.75rem 0}
.receipt-total{
  font-family:var(--display);font-size:1.125rem;text-transform:lowercase;
  display:flex;justify-content:space-between;padding-top:.5rem;
  border-top:2px solid var(--ink);margin-top:.5rem;
}
.receipt-strike{text-decoration:line-through;color:#8a8780}
.receipt-now{color:var(--red);font-size:2rem;font-family:var(--display);line-height:1;display:block;margin-top:.25rem}
.receipt-barcode{margin-top:1.25rem;font-size:.65rem;letter-spacing:0;text-align:center;color:var(--ink)}
.barcode-bars{display:flex;gap:1.5px;justify-content:center;margin-top:.5rem;height:32px}
.barcode-bars span{display:block;background:var(--ink)}
.receipt-cta{margin-top:1.5rem;text-align:center}
.receipt-cta a{
  font-family:var(--display);font-size:1rem;text-transform:lowercase;
  color:var(--ink);text-decoration:none;
  background:var(--red);color:var(--spin);
  padding:.75rem 1.25rem;display:inline-block;
  transition:transform var(--t-fast), box-shadow var(--t-fast);
  box-shadow:4px 4px 0 var(--ink);
}
.receipt-cta a:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}

/* ============ STEPS ============ */
.steps{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-top:3rem}
@media(min-width:640px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.steps{grid-template-columns:repeat(4,1fr);gap:2rem}}
.step{position:relative;padding-top:1rem}
.step-num{font-family:var(--display);color:var(--red);font-size:3.75rem;line-height:.85;margin-bottom:.5rem;display:block}
.step h3{margin-bottom:.5rem}
.step p{font-size:.95rem;color:var(--spin-2);max-width:30ch}
.steps-coda{margin-top:2.5rem;font-family:var(--hand);color:var(--spin-2);font-size:1.25rem;transform:rotate(-1deg);display:inline-block}

/* ============ TIERS ============ */
.tiers{background:var(--ink-2);position:relative}
.tier-ladder{
  display:grid;
  grid-template-columns:1fr;
  gap:1rem;
  margin-top:2.5rem;
}
@media(min-width:768px){
  .tier-ladder{grid-template-columns:repeat(5,1fr);gap:.75rem;align-items:stretch}
}
.tier{
  background:var(--ink);
  border:1px solid #2a2a2a;
  padding:1.5rem 1.25rem;
  display:flex;
  flex-direction:column;
  gap:.5rem;
  position:relative;
  transition:transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
}
.tier-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;height:44px;
  font-family:var(--display);
  font-size:.875rem;
  text-transform:lowercase;
  letter-spacing:.02em;
  background:var(--spin);
  color:var(--ink);
}
.tier--std .tier-badge{background:var(--spin);color:var(--ink)}
.tier--cp .tier-badge{background:var(--spin);color:var(--ink);border-bottom:3px solid var(--red)}
.tier--spn .tier-badge{background:var(--navy);color:var(--spin)}
.tier--res .tier-badge{background:var(--red);color:var(--spin)}
.tier--lgd{
  background:linear-gradient(180deg, var(--ink-2) 0%, var(--ink) 100%);
  border:1px solid rgba(212,175,55,.35);
  box-shadow:
    inset 0 1px 0 rgba(212,175,55,.15),
    0 0 0 1px rgba(212,175,55,.08),
    0 14px 30px rgba(0,0,0,.4);
  position:relative;
}
.tier--lgd::before{
  content:'★ earned';
  position:absolute;
  top:-10px;left:1.25rem;
  background:var(--gold);
  color:var(--ink);
  font-family:var(--mono);
  font-size:.55rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  padding:.25rem .5rem;
  font-weight:700;
}
.tier--lgd .tier-badge{
  background:var(--ink);
  color:var(--gold);
  border:1px solid var(--gold);
  box-shadow:0 0 0 3px rgba(212,175,55,.12);
  width:52px;height:52px;
  font-size:1rem;
}
.tier:hover{transform:translateY(-3px)}
.tier--lgd:hover{transform:translateY(-5px);border-color:var(--gold);box-shadow:
    inset 0 1px 0 rgba(212,175,55,.25),
    0 0 0 1px var(--gold),
    0 18px 36px rgba(0,0,0,.5)}
.tier-name{font-family:var(--display);font-size:1.5rem;line-height:1;text-transform:lowercase;color:var(--spin)}
.tier--lgd .tier-name{color:var(--gold);font-size:1.65rem}
.tier-spins{font-family:var(--mono);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--grey)}
.tier--lgd .tier-spins{color:rgba(212,175,55,.7)}
.tier-arrow{
  display:none;
}
@media(min-width:768px){
  .tier-arrow{display:flex;align-items:center;justify-content:center;color:var(--red);font-family:var(--hand);font-size:1.5rem}
}
.tier-note{
  margin-top:2.5rem;
  font-family:var(--body);
  color:var(--spin-2);
  font-size:.95rem;
  max-width:54ch;
}

/* ============ GUARANTEE ============ */
.guarantee{background:var(--navy);text-align:center;position:relative;overflow:hidden}
.guarantee::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.5' numOctaves='2' stitchTiles='stitch'/></filter><rect width='140' height='140' filter='url(%23n)' opacity='1'/></svg>");
  mix-blend-mode:overlay;opacity:.04;pointer-events:none;
}
.stamp{width:220px;height:220px;margin:0 auto 2.25rem;position:relative}
@media(min-width:768px){.stamp{width:260px;height:260px}}

/* ============ PARENTS BLOCK (interwoven) ============ */
.parents-block{background:var(--spin);color:var(--ink);position:relative}
.parents-block::before{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 30px, rgba(0,0,0,0.025) 30px 32px);
  pointer-events:none;
}
.parents-block .section-flag{background:var(--ink);color:var(--spin)}
.parents-block h2{color:var(--ink)}
.parents-grid{
  display:grid;grid-template-columns:1fr;gap:2rem;margin-top:2.5rem;
}
@media(min-width:900px){.parents-grid{grid-template-columns:1.1fr 1fr;gap:4rem;align-items:center}}
.parents-card{
  background:var(--ink);color:var(--spin);
  padding:1.75rem;position:relative;
  box-shadow:10px 10px 0 var(--red);
}
.parents-card h4{color:var(--spin);margin-bottom:.5rem}
.parents-card p{color:var(--spin-2);font-size:.95rem}
.parents-list{list-style:none;margin-top:1.5rem;display:grid;gap:1.25rem}
.parents-list li{display:flex;gap:1rem;align-items:flex-start}
.parents-list .pl-icon{
  width:36px;height:36px;flex-shrink:0;
  background:var(--ink);color:var(--spin);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:1.125rem;
}
.parents-list .pl-text strong{display:block;color:var(--ink);font-weight:700;margin-bottom:.15rem}
.parents-list .pl-text{font-size:.95rem;color:var(--grey-2);line-height:1.5}
.parents-cta{margin-top:2rem}

/* SMS mock bubble */
.sms{
  background:var(--ink);
  border-radius:18px;
  padding:1rem 1.25rem;
  max-width:280px;
  color:var(--spin);
  font-family:var(--body);
  font-size:.9rem;
  line-height:1.45;
  position:relative;
  margin:.5rem 0;
}
.sms.sms-out{background:var(--steel);color:var(--spin);margin-left:auto}
.sms small{display:block;font-size:.65rem;color:var(--grey);margin-top:.4rem;letter-spacing:.05em}

/* ============ ABOUT (founder polaroid) ============ */
.about-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:768px){.about-grid{grid-template-columns:1fr 1.4fr;gap:4rem}}
.polaroid{
  background:var(--spin);
  padding:1rem 1rem 3.5rem;
  box-shadow:14px 14px 0 var(--red), 0 0 0 1px #d0ccc0 inset;
  transform:rotate(-2deg);
  position:relative;
  max-width:380px;
  transition:transform var(--t-med) ease-out, box-shadow var(--t-med) ease-out;
}
.polaroid:hover{transform:rotate(0deg);box-shadow:16px 16px 0 var(--red), 0 0 0 1px #d0ccc0 inset}
.polaroid-img{
  background:linear-gradient(135deg, var(--steel), var(--navy));
  aspect-ratio:3/3.6;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.polaroid-img::before{
  content:'[ founder polaroid · placeholder ]';
  font-family:var(--mono);color:var(--spin);font-size:.7rem;
  letter-spacing:.2em;text-transform:uppercase;opacity:.6;
}
.polaroid-cap{margin-top:.85rem;font-family:var(--hand);color:var(--ink);font-size:1rem;text-align:center;transform:rotate(-1deg)}
.about-copy h2 span{display:block}
.signature{font-family:var(--hand);font-size:1.5rem;color:var(--red);display:inline-block;transform:rotate(-2deg);margin-top:1.5rem}

/* ============ CULTURAL (curry/mixtape/party) ============ */
.culture{position:relative}
.culture-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:2.5rem;
  margin-top:3rem;
  position:relative;
}
@media(min-width:768px){
  .culture-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}
}
.culture-card{
  background:var(--spin);
  color:var(--ink);
  padding:1rem 1rem 2.5rem;
  position:relative;
  box-shadow:10px 10px 0 var(--red);
  transition:transform var(--t-med) ease-out, box-shadow var(--t-med) ease-out;
}
.culture-card:nth-child(1){transform:rotate(-2deg)}
.culture-card:nth-child(2){transform:rotate(1.5deg);margin-top:2rem}
.culture-card:nth-child(3){transform:rotate(-1deg)}
.culture-card:hover{transform:rotate(0deg);box-shadow:12px 12px 0 var(--red)}
.culture-card::before{
  content:'';position:absolute;top:-12px;left:50%;
  transform:translateX(-50%) rotate(-3deg);
  width:90px;height:24px;background:rgba(229,57,53,.6);
}
.culture-img{
  aspect-ratio:1/1;
  background:linear-gradient(135deg, var(--steel), var(--navy));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);color:var(--spin);font-size:.7rem;
  letter-spacing:.2em;text-transform:uppercase;
  position:relative;overflow:hidden;
}
.culture-img::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(45deg, transparent 0 8px, rgba(255,255,255,.04) 8px 9px);
}
.culture-cap{margin-top:.9rem;font-family:var(--hand);color:var(--ink);font-size:1.05rem;text-align:center;transform:rotate(-1deg)}
.culture-meta{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey-2);text-align:center;margin-top:.4rem}

/* ============ PRICING COMPARISON ============ */
.compare{background:var(--ink-2)}
.compare-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1rem;
  margin-top:2.5rem;
}
@media(min-width:768px){
  .compare-grid{grid-template-columns:repeat(4,1fr);gap:0}
}
.compare-col{
  background:var(--ink);
  padding:1.5rem 1.25rem 1.75rem;
  border:1px solid #2a2a2a;
  position:relative;
  display:flex;flex-direction:column;gap:.5rem;
}
.compare-col--us{background:var(--red);color:var(--spin);border-color:var(--red);transform:scale(1)}
@media(min-width:768px){.compare-col--us{transform:scale(1.04);z-index:2;box-shadow:0 14px 30px rgba(0,0,0,.35)}}
.compare-name{font-family:var(--display);font-size:1.25rem;line-height:1;text-transform:lowercase}
.compare-price{font-family:var(--display);font-size:2rem;line-height:1;color:var(--red);margin-top:.5rem}
.compare-col--us .compare-price{color:var(--spin)}
.compare-unit{font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--grey)}
.compare-col--us .compare-unit{color:var(--spin-2)}
.compare-verdict{
  margin-top:.85rem;
  font-family:var(--body);
  font-size:.875rem;
  color:var(--spin-2);
  line-height:1.5;
}
.compare-col--us .compare-verdict{color:var(--spin)}
.compare-coda{
  margin-top:2rem;
  font-family:var(--hand);
  color:var(--red);
  font-size:1.5rem;
  transform:rotate(-2deg);
  display:inline-block;
}

/* ============ FAQ ============ */
.faq-list{margin-top:2.5rem;border-top:1px solid #2a2a2a}
.faq-item{border-bottom:1px solid #2a2a2a;padding:0}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:1.25rem 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  font-family:var(--display);
  font-size:1.125rem;
  text-transform:lowercase;
  color:var(--spin);
  line-height:1.2;
  transition:color var(--t-fast);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--red)}
.faq-item summary::after{
  content:'+';
  font-family:var(--display);
  font-size:1.5rem;
  color:var(--red);
  transition:transform var(--t-med);
  flex-shrink:0;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item-body{padding:0 0 1.5rem;font-size:1rem;line-height:1.65;color:var(--spin-2);max-width:62ch}

/* ============ LEAD MAGNET ============ */
.leadmag{background:var(--ink-2);position:relative}
.leadmag-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:768px){.leadmag-grid{grid-template-columns:1fr 1.2fr;gap:4rem}}
.leadmag-form{
  display:grid;gap:.75rem;max-width:420px;margin-top:1.5rem;
}
.leadmag-form input{
  background:var(--ink);
  color:var(--spin);
  border:none;
  padding:1rem;
  font-family:var(--body);
  font-size:1rem;
  outline:2px solid #2a2a2a;
  outline-offset:-2px;
  transition:outline-color var(--t-fast);
}
.leadmag-form input:focus{outline-color:var(--red)}
.leadmag-form input::placeholder{color:var(--grey)}
.leadmag-form .leadmag-meta{font-size:.8rem;color:var(--grey);margin-top:.4rem}

/* ============ SIGNUP ============ */
.signup{
  background:var(--red);color:var(--spin);text-align:center;
  position:relative;overflow:hidden;
}
.signup::before{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 30px, rgba(0,0,0,0.08) 30px 32px);
  pointer-events:none;
}
.signup-inner{position:relative;z-index:1}
.signup h2{color:var(--spin)}

/* ============ FINAL CTA (last call · brand-dominant) ============ */
.final-cta{
  background:var(--ink-2);color:var(--spin);text-align:center;
  position:relative;overflow:hidden;
}
.final-cta::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(ellipse at 50% 0%, rgba(229,57,53,.15) 0%, transparent 55%),
    repeating-linear-gradient(45deg, transparent 0 60px, rgba(229,57,53,.04) 60px 62px);
  pointer-events:none;
}
.final-cta::after{
  content:'';position:absolute;left:0;right:0;top:0;height:6px;
  background:var(--red);
}
.final-inner{position:relative;z-index:1}
.final-cta h2{color:var(--spin)}
.final-cta .signup-eyebrow{background:var(--red);color:var(--spin)}
.signup-eyebrow{
  display:inline-block;font-family:var(--body);
  text-transform:uppercase;letter-spacing:.2em;
  font-size:.7rem;font-weight:700;
  background:var(--ink);color:var(--spin);
  padding:.45rem .75rem;margin-bottom:1.5rem;
}
.signup-form{
  max-width:480px;margin:2.5rem auto 0;
  display:grid;gap:.875rem;text-align:left;
}
.signup-form label{
  font-family:var(--body);font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;
  font-weight:700;color:var(--spin);
  display:block;margin-bottom:.4rem;
}
.signup-form input,.signup-form select{
  background:var(--ink);color:var(--spin);
  border:none;padding:1rem;
  font-family:var(--body);font-size:1rem;width:100%;
  appearance:none;border-radius:0;
  outline:2px solid transparent;outline-offset:-2px;
  transition:outline-color var(--t-fast);
}
.signup-form input:focus,.signup-form select:focus{outline-color:var(--spin)}
.signup-form input::placeholder{color:var(--grey)}
.signup-form button{
  background:var(--spin);color:var(--ink);
  border:none;padding:1.25rem;
  font-family:var(--display);font-size:1.25rem;
  cursor:pointer;text-transform:lowercase;
  margin-top:.5rem;transition:transform var(--t-fast);
}
.signup-form button:hover{transform:translateY(-2px)}
.signup-meta{margin-top:1.5rem;font-size:.8rem;color:var(--spin-2);opacity:.85}

.final-cta-row{
  margin-top:2.5rem;display:flex;flex-wrap:wrap;gap:1rem;
  justify-content:center;align-items:center;
}
.final-cta-warning{
  margin-top:2rem;font-family:var(--mono);
  font-size:.875rem;letter-spacing:.05em;color:var(--grey);
  max-width:46ch;margin-left:auto;margin-right:auto;
}

/* ============ FOOTER ============ */
footer{
  padding:3rem 1.5rem 5rem;background:var(--ink);text-align:center;
  font-family:var(--body);font-size:.875rem;color:var(--grey);
  border-top:1px solid #1f1f1f;
}
.footer-mark{
  font-family:var(--display);color:var(--spin);
  font-size:2.25rem;text-transform:lowercase;
  letter-spacing:-.01em;margin-bottom:.5rem;display:block;
}
.footer-tag{font-family:var(--display);color:var(--red);font-size:1rem;text-transform:lowercase;margin-bottom:1.5rem}
.footer-links{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}
.footer-links a{color:var(--spin-2);text-decoration:none;letter-spacing:.05em}
.footer-links a:hover{color:var(--red)}
.footer-fine{font-size:.75rem;color:#666;line-height:1.6;max-width:62ch;margin:0 auto}

/* ============ MOTION ============ */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease, transform .6s cubic-bezier(.16,1,.3,1)}
.reveal.is-in{opacity:1;transform:translateY(0)}
.reveal-1{transition-delay:.05s}
.reveal-2{transition-delay:.15s}
.reveal-3{transition-delay:.25s}
.reveal-4{transition-delay:.35s}
.reveal-5{transition-delay:.45s}
.reveal-6{transition-delay:.55s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
}

/* ============ UTILITY ============ */
.tape{
  position:absolute;background:rgba(229,57,53,.65);
  width:80px;height:22px;transform:rotate(-3deg);z-index:2;
}
.desktop-only{display:none}
@media(min-width:768px){.desktop-only{display:block}.desktop-only-inline{display:inline}}
.mobile-only{display:block}
@media(min-width:768px){.mobile-only{display:none}}

/* skip link for a11y */
.skip{position:absolute;left:-9999px;top:0}
.skip:focus{left:0;top:0;background:var(--spin);color:var(--ink);padding:.75rem 1rem;z-index:500;font-family:var(--body)}
