/* ============================================================
   FILEDMARK — section & component styles
   ============================================================ */

/* ---------- HERO ---------- */
.hero-grid {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hero-trust {
  margin-top: 26px; font-size: 12.5px; color: var(--ink-faint);
  letter-spacing: .02em; line-height: 1.7;
}

.hero-cert { position: relative; }
.cert--terms { max-width: 980px; margin: 0 auto; }

.cert-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.cert-title { font-family: var(--serif); font-weight: 600; font-size: clamp(24px, 3vw, 33px); letter-spacing: -.02em; margin-top: 6px; }
.cert-seal { flex: none; opacity: .85; }
.cert-fields { margin-top: 26px; display: flex; flex-direction: column; }
.cfield {
  display: grid; grid-template-columns: 108px 1fr; gap: 14px; align-items: baseline;
  padding: 11px 0; border-bottom: 1px solid var(--rule-soft);
}
.cfield:first-child { border-top: 1px solid var(--rule-soft); }
.cfk { font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em; color: var(--ink-faint); }
.cfv { font-size: 15px; color: var(--ink-soft); }
.cfv.mono { font-size: 14px; }
.cert-foot {
  margin-top: 22px; font-size: 11px; letter-spacing: .08em; color: var(--ink-faint);
  display: flex; gap: 8px; flex-wrap: wrap;
}

.hero-stamp {
  position: absolute;
  width: clamp(168px, 23vw, 232px);
  right: clamp(-14px, -1vw, -8px);
  bottom: clamp(-26px, -3vw, -34px);
  z-index: 5;
  pointer-events: none;
}

/* ---------- INK STRIP ---------- */
.strip-ink { background: var(--ink); color: var(--paper); }
.strip-ink::after, .strip-paperdeep::after { content: none; }
.strip-paperdeep { background: var(--paper-deep); }
.strip-ink .rule-line { border-color: var(--gold-light); }
.muted-p { color: var(--paper-deep); opacity: .7; }

/* ---------- S2 RACE ---------- */
.race-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px 56px; align-items: start; }
.tracks { margin-top: 70px; display: flex; flex-direction: column; gap: 30px; }
.track { display: grid; grid-template-columns: 200px 1fr; gap: 28px; align-items: center; }
.track-label { font-family: var(--mono); font-size: 13px; letter-spacing: .08em; color: var(--paper); display: flex; align-items: center; gap: 10px; }
.track-label b { font-weight: 600; }
.track-label--mute { color: var(--paper-deep); opacity: .62; }
.xglyph { color: var(--red); font-weight: 700; font-size: 16px; }
.track-bar { position: relative; height: 64px; }
.line { position: absolute; top: 50%; height: 2px; border-radius: 2px; }
.line--win { left: 6%; right: 12%; background: linear-gradient(90deg, var(--red) 0%, var(--gold-light) 100%); }
.line--lose { left: 0; right: 54%; background: repeating-linear-gradient(90deg, var(--paper-deep) 0 6px, transparent 6px 12px); opacity: .4; }
.node { position: absolute; top: 50%; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; gap: 4px; white-space: nowrap; }
.node b { font-family: var(--mono); font-size: 12px; letter-spacing: .06em; font-weight: 600; }
.node i { font-family: var(--sans); font-style: normal; font-size: 11.5px; color: var(--paper-deep); opacity: .75; }
.node::before { content: ""; width: 13px; height: 13px; border-radius: 50%; order: -1; margin-bottom: 4px; }
.node--stamp { color: var(--red); }
.node--stamp::before { background: var(--red); box-shadow: 0 0 0 4px rgba(178,58,46,.22); }
.node--win { color: var(--gold-light); }
.node--win::before { background: var(--gold-light); }
.node--lose { color: var(--paper-deep); }
.node--lose::before { content: "✕"; background: none; width: auto; height: auto; color: var(--red); font-weight: 700; font-size: 15px; margin-bottom: 2px; }
.node--lose b { color: var(--paper-deep); }

/* ---------- S3 DIAGRAM ---------- */
.diagram { margin-top: 56px; display: grid; grid-template-columns: auto 1fr auto 1fr auto; align-items: center; gap: 0; }
.dnode { display: flex; flex-direction: column; align-items: center; gap: 12px; color: var(--ink); }
.dnode-stamp { color: var(--red); width: 88px; }
.dnode-globe, .dnode-us { color: var(--ink); width: 78px; }
.dnum { font-size: 13px; letter-spacing: .2em; color: var(--ink-faint); border: 1.5px solid var(--rule); border-radius: 50%; width: 30px; height: 30px; display: grid; place-items: center; }
.dconn { position: relative; height: 2px; }
.dconn-line { position: absolute; inset: 0; background: repeating-linear-gradient(90deg, var(--rule) 0 7px, transparent 7px 14px); }
.dconn--clock { display: flex; align-items: center; justify-content: center; }
.clock-pill { position: relative; background: var(--red); color: var(--paper); font-size: 12px; font-weight: 600; letter-spacing: .12em; padding: 6px 13px; border-radius: 2px; z-index: 2; box-shadow: 0 6px 18px -10px rgba(178,58,46,.8); }
.steps { margin-top: 48px; display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px, 3vw, 48px); }
.step h3 { margin-bottom: 12px; }
.step p { color: var(--ink-soft); font-size: 16.5px; }

.citations { margin-top: 60px; padding-top: 26px; border-top: 1.5px solid var(--ink); display: grid; grid-template-columns: 180px 1fr; gap: 28px; }
.cite-list { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.cite-list--inline { flex-direction: row; flex-wrap: wrap; gap: 12px 26px; margin-top: 16px; }

/* ---------- S4 / S6 SLIPS ---------- */
.slips { display: grid; gap: clamp(18px, 2.2vw, 28px); }
.slips--audience { grid-template-columns: repeat(3, 1fr); }
.slips--price { grid-template-columns: repeat(3, 1fr); align-items: start; }
.slip { padding: 28px 26px 30px; }
.slip-tab { display: inline-block; font-size: 11px; letter-spacing: .14em; color: var(--red-ink); border: 1.2px solid var(--red); border-radius: 2px; padding: 4px 9px; margin-bottom: 18px; }
.slip h3 { margin-bottom: 10px; }
.slip p { color: var(--ink-soft); font-size: 16px; margin: 0; }

/* perforation tweak for slips on dark/light */
.perf { background: var(--paper-card); }
.strip-ink .perf { background: var(--paper-card); border-color: var(--rule); }

/* price slips */
.slip-price { position: relative; padding: 26px 24px 28px; display: flex; flex-direction: column; color: var(--ink); }
.slip .h3, .slip p { color: var(--ink-soft); }
.slip-price .sp-qty, .slip-price .sp-price { color: var(--ink); }
.slip-price--feat { border-style: solid; border-color: var(--red); box-shadow: 0 24px 50px -30px rgba(0,0,0,.6); }
.sp-ribbon { position: absolute; top: -11px; left: 24px; background: var(--red); color: var(--paper); font-size: 10.5px; letter-spacing: .14em; padding: 4px 10px; border-radius: 2px; }
.sp-head { font-size: 10.5px; letter-spacing: .16em; color: var(--ink-faint); }
.sp-qty { font-family: var(--serif); font-weight: 600; font-size: 23px; margin-top: 6px; }
.sp-price { font-size: clamp(44px, 5vw, 58px); font-weight: 600; letter-spacing: -.02em; line-height: 1; margin-top: 14px; }
.sp-slash { font-size: 22px; color: var(--ink-faint); font-weight: 500; }
.sp-each { font-size: 12.5px; margin-top: 4px; }
.sp-vs { font-size: 12px; color: var(--ink-faint); margin: 16px 0 22px; }
.sp-vs s { color: var(--red-ink); text-decoration-thickness: 1.5px; }
.slip-price .btn { margin-top: auto; }
.price-note { margin-top: 22px; font-size: 12.5px; color: var(--gold-light); letter-spacing: .04em; }

/* ---------- S5 TERMS ---------- */
.terms-head { display: flex; align-items: center; gap: 14px; }
.terms-grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: clamp(28px, 4vw, 56px); margin-top: 30px; }
.terms-rule { width: 1px; background: var(--rule); }
.terms-col-head { font-family: var(--serif); font-weight: 600; font-size: 20px; display: flex; align-items: center; gap: 11px; margin-bottom: 18px; }
.terms-mk { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; font-size: 14px; font-weight: 700; flex: none; }
.terms-mk--yes { background: color-mix(in oklab, var(--gold) 18%, var(--paper)); color: var(--gold-deep); border: 1.2px solid var(--gold-light); }
.terms-mk--no { background: color-mix(in oklab, var(--red) 12%, var(--paper)); color: var(--red); border: 1.2px solid var(--red); }
.terms-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.terms-list li { padding: 13px 0 13px 24px; border-bottom: 1px solid var(--rule-soft); font-size: 16px; color: var(--ink-soft); position: relative; }
.terms-list li::before { content: ""; position: absolute; left: 2px; top: 21px; width: 8px; height: 1.5px; background: var(--ink-faint); }
.terms-list li:last-child { border-bottom: 0; }
.terms-list b { color: var(--ink); font-weight: 600; }
.terms-callout { margin-top: 18px; padding: 16px 18px; background: color-mix(in oklab, var(--red) 7%, var(--paper)); border-left: 3px solid var(--red); font-size: 15px; line-height: 1.5; color: var(--ink); }

/* ---------- S7 CLOCK ---------- */
.clock-grid { display: grid; grid-template-columns: 0.86fr 1.14fr; gap: clamp(32px, 4vw, 64px); align-items: center; margin-top: 18px; }
.clock-card { align-self: stretch; }
.clock-row { display: flex; align-items: center; gap: 20px; }
.clock-cell { flex: 1; }
.cc-k { font-size: 11px; letter-spacing: .14em; color: var(--ink-faint); }
.cc-v { font-size: clamp(22px, 2.6vw, 30px); font-weight: 600; margin-top: 6px; letter-spacing: .01em; }
.clock-arrow { font-size: 24px; color: var(--gold); }
.clock-count { margin-top: 28px; padding-top: 24px; border-top: 1.5px solid var(--rule); display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap; }
.cc-num { font-size: clamp(48px, 7vw, 76px); font-weight: 600; color: var(--red); line-height: .9; letter-spacing: -.02em; }
.cc-lab { font-size: 12px; letter-spacing: .1em; color: var(--ink-faint); max-width: 18ch; }
.clock-progress { position: relative; height: 8px; background: var(--paper-deep); border: 1px solid var(--rule); border-radius: 4px; margin-top: 34px; }
.cp-fill { position: absolute; left: 0; top: 0; bottom: 0; width: 6%; background: var(--red); border-radius: 4px 0 0 4px; }
.cp-tick { position: absolute; top: 50%; transform: translate(-50%, -50%); }
.cp-tick i { display: block; width: 2px; height: 16px; background: var(--gold); margin: 0 auto; }
.cp-tick em { position: absolute; top: 16px; left: 50%; transform: translateX(-50%); font-size: 10px; color: var(--gold-deep); }
.clock-legend { margin-top: 34px; font-size: 11.5px; color: var(--ink-faint); letter-spacing: .04em; }

/* ---------- S8 FAQ ---------- */
.wrap--narrow { max-width: 860px; }
.faq { margin-top: 38px; border-top: 1.5px solid var(--ink); }
.faq-item { border-bottom: 1px solid var(--rule); }
.faq-q { width: 100%; background: none; border: 0; text-align: left; display: flex; align-items: center; gap: 20px; padding: 24px 4px; font-family: var(--serif); font-weight: 600; font-size: clamp(19px, 2.2vw, 24px); color: var(--ink); letter-spacing: -.01em; }
.faq-no { font-family: var(--mono); font-size: 12px; color: var(--red-ink); font-weight: 500; flex: none; padding-top: 6px; }
.faq-text { flex: 1; }
.faq-pm { position: relative; width: 18px; height: 18px; flex: none; }
.faq-pm::before, .faq-pm::after { content: ""; position: absolute; background: var(--ink); transition: transform .25s ease, opacity .2s; }
.faq-pm::before { left: 0; right: 0; top: 8px; height: 2px; }
.faq-pm::after { top: 0; bottom: 0; left: 8px; width: 2px; }
.faq-item.open .faq-pm::after { transform: scaleY(0); }
.faq-a { overflow: hidden; max-height: 0; transition: max-height .35s cubic-bezier(.2,.7,.2,1); }
.faq-a-in { padding: 0 42px 26px 46px; }
.faq-a-in p { font-size: 16.5px; color: var(--ink-soft); margin: 0; }

/* ---------- LEAD CAPTURE ---------- */
.leadcap { background: var(--ink); color: var(--paper); padding-block: clamp(40px, 5vw, 60px); position: relative; z-index: 2; }
.lead-line { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: end; border-bottom: 1.5px solid var(--gold-light); padding-bottom: 22px; }
.lead-copy .h3 { color: var(--paper); max-width: 22ch; }
.lead-form { display: flex; align-items: flex-end; gap: 16px; flex-wrap: wrap; }
.lead-field { display: flex; flex-direction: column; gap: 7px; }
.lead-lab { font-size: 10.5px; letter-spacing: .16em; color: var(--gold-light); }
.lead-input { background: transparent; border: 0; border-bottom: 1.5px solid var(--paper-deep); color: var(--paper); font-size: 16px; padding: 7px 2px; width: 260px; outline: none; }
.lead-input::placeholder { color: rgba(247,243,234,.42); }
.lead-input:focus { border-bottom-color: var(--red); }
.lead-btn { border-color: var(--paper); color: var(--paper); }
.lead-btn:hover { background: var(--paper); color: var(--ink); }
.lead-ok { color: var(--gold-light); align-self: center; }

/* ---------- FOOTER ---------- */
.footer { background: var(--ink); color: var(--paper); padding: clamp(48px, 6vw, 78px) 0 40px; position: relative; z-index: 2; }
.foot-top { display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.foot-entity { font-size: 11px; letter-spacing: .12em; color: var(--gold-light); margin-top: 8px; }
.foot-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: clamp(28px, 4vw, 64px); }
.foot-disc { font-size: 13px; line-height: 1.65; color: var(--paper-deep); margin: 0; }
.foot-disc b { color: var(--paper); }
.foot-links { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.foot-links a { font-family: var(--mono); font-size: 13px; letter-spacing: .04em; text-decoration: none; color: var(--paper); border-bottom: 1px solid transparent; }
.foot-links a:hover { border-bottom-color: var(--gold-light); color: var(--gold-light); }
.foot-cites { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 40px; font-size: 12px; color: var(--paper-deep); }
.foot-cites a { color: var(--paper-deep); text-decoration: none; border-bottom: 1px solid rgba(194,165,90,.4); }
.foot-cites a:hover { color: var(--gold-light); }
.foot-cites .dot { background: var(--gold-light); }
.foot-fine { margin-top: 26px; font-size: 10.5px; letter-spacing: .1em; color: rgba(247,243,234,.4); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 940px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-cert { max-width: 560px; }
  .hero-stamp { width: 190px; }
  .race-grid { grid-template-columns: 1fr; }
  .track { grid-template-columns: 1fr; gap: 12px; }
  .track-bar { height: 88px; }
  .clock-grid { grid-template-columns: 1fr; }
  .diagram { grid-template-columns: 1fr; gap: 6px; justify-items: center; }
  .dconn { width: 2px; height: 34px; }
  .dconn-line { background: repeating-linear-gradient(180deg, var(--rule) 0 7px, transparent 7px 14px); }
  .steps { grid-template-columns: 1fr; }
  .slips--audience, .slips--price { grid-template-columns: 1fr; }
  .terms-grid { grid-template-columns: 1fr; }
  .terms-rule { display: none; }
  .citations { grid-template-columns: 1fr; gap: 14px; }
  .foot-grid { grid-template-columns: 1fr; }
  .lead-line { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  body { font-size: 17px; }
  .hero-stamp { width: 150px; right: -6px; bottom: -22px; }
  .node i { display: none; }
  .lead-input { width: 100%; }
  .lead-form { width: 100%; }
}
