/* ============================================================
   TINY PRINTS — cinematic scroll landing
   Act I   : the hero (the promise)
   Act II  : the run (scroll = running the race, route maps live)
   Act III : the transformation (route becomes a 3D print)
   Act IV  : the editions (one page per frame)
   ============================================================ */
:root{
  --porcelain:#F8F6F1;
  --coral:#E85D3F;
  --ink:#111111;
  --stone:#8a8276;
  --night:#0d0c0b;
  --line-dark:rgba(248,246,241,.12);
  --line-light:rgba(17,17,17,.1);
  --serif:"Instrument Serif",Georgia,serif;
  --mono:"Space Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--night)}
body{
  color:var(--ink);
  font-family:var(--serif);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--coral);color:#fff}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}

/* ---------- shared atoms ---------- */
.mono{
  font-family:var(--mono);font-size:11px;font-weight:400;
  letter-spacing:.22em;text-transform:uppercase;
}
.kicker{
  display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--stone);
}
.kicker::before{content:"";width:36px;height:1px;background:var(--coral)}
.wrap{width:min(1200px,calc(100% - 48px));margin:0 auto}
.line{display:block;overflow:hidden}
.line-inner{display:block;will-change:transform}
.fade-up{will-change:transform,opacity}
/* kinetic chars */
.char{display:inline-block;will-change:transform,opacity;transform-origin:center bottom}
/* custom cursor dot — desktop only */
.tp-cursor-inner{
  position:fixed;top:0;left:0;
  width:7px;height:7px;border-radius:50%;
  background:var(--coral);
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
}
@media(hover:none){.tp-cursor-inner{display:none}}
@media(hover:hover){body{cursor:none}}
.btn-coral{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  padding:18px 30px;border-radius:999px;border:none;
  background:var(--coral);color:#fff;
  transition:transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s;
}
.btn-coral:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(232,93,63,.4)}
.btn-coral .arr{transition:transform .3s}
.btn-coral:hover .arr{transform:translateX(4px)}
.btn-ghost{
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  padding:18px 26px;border-radius:999px;
  border:1px solid var(--line-dark);color:rgba(248,246,241,.75);
  transition:border-color .3s, color .3s;
}
.btn-ghost:hover{border-color:rgba(248,246,241,.45);color:var(--porcelain)}

/* grain overlay for dark sections */
.grain{position:relative}
.grain::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;z-index:6;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .035 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 32px;
  color:var(--porcelain);
  transition:color .4s, background .4s, padding .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav .brand{font-family:var(--serif);font-size:24px;letter-spacing:.01em}
.nav .brand .dot{color:var(--coral)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a.mono{color:inherit;opacity:.65;transition:opacity .25s}
.nav-links a.mono:hover{opacity:1}
.nav-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:11px 20px;border-radius:999px;
  background:var(--coral);color:#fff;
  transition:transform .25s, box-shadow .25s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(232,93,63,.35)}
.nav.solid{
  color:var(--ink);
  background:rgba(248,246,241,.85);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding:14px 32px;
  border-bottom-color:var(--line-light);
}
@media(max-width:768px){
  .nav{padding:16px 20px}
  .nav.solid{padding:12px 20px}
  .nav-links a.mono{display:none}
}

/* ============================================================
   ACT I · HERO
   ============================================================ */
.hero{
  position:relative;min-height:100vh;overflow:hidden;
  background:
    radial-gradient(ellipse 70% 55% at 70% 30%, rgba(232,93,63,.10), transparent 60%),
    var(--night);
  display:flex;align-items:center;justify-content:center;
}
.hero-glyph{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  z-index:1;pointer-events:none;
}
.hero-glyph svg{width:130vmin;height:97vmin;opacity:.9}
.hero-inner{position:relative;z-index:2;text-align:center;color:var(--porcelain);padding:0 24px}
.hero-inner .kicker{justify-content:center;color:rgba(248,246,241,.55);margin-bottom:36px}
.hero-inner .kicker::before{display:none}
.hero-h{
  font-weight:400;line-height:.98;letter-spacing:-.012em;
  font-size:clamp(56px,9vw,128px);
}
.hero-h em{font-style:italic;color:var(--coral)}
.hero-sub{
  font-family:var(--mono);font-size:13px;line-height:1.95;letter-spacing:.04em;
  color:rgba(248,246,241,.6);
  max-width:480px;margin:36px auto 0;
}
.hero-ctas{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:46px;flex-wrap:wrap}
.hero-scrollcue{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  color:rgba(248,246,241,.45);
  font-family:var(--mono);font-size:9.5px;letter-spacing:.34em;text-transform:uppercase;
}
.hero-scrollcue .stem{width:1px;height:44px;background:rgba(248,246,241,.25);overflow:hidden;position:relative}
.hero-scrollcue .stem::after{
  content:"";position:absolute;left:0;top:-100%;width:100%;height:100%;
  background:var(--coral);animation:cue 2.2s cubic-bezier(.65,0,.35,1) infinite;
}
@keyframes cue{0%{top:-100%}55%,100%{top:100%}}
@media(max-width:768px){
  .hero-h{font-size:clamp(46px,12vw,76px)}
}

/* ============================================================
   ACT II + III · THE RUN  (scroll = the race)
   ============================================================ */
.run{height:680vh;position:relative;background:var(--night);z-index:2}
.run-stick{
  position:sticky;top:0;height:100vh;overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 45%, rgba(232,93,63,.05), transparent 65%),
    var(--night);
}
#run-svg{position:absolute;inset:0;width:100%;height:100%;z-index:1}
#run-svg .ghost{stroke:rgba(248,246,241,.10)}
#run-svg .trace{stroke:#EC5BA1}   /* matches the pink route of the real print */
#runner .pulse{
  fill:rgba(236,91,161,.22);
  animation:rpulse 1.8s ease-out infinite;
  transform-origin:center;transform-box:fill-box;
}
@keyframes rpulse{0%{transform:scale(.35);opacity:.9}100%{transform:scale(1.5);opacity:0}}
#run-title{
  position:absolute;top:14vh;left:0;right:0;text-align:center;z-index:3;
  color:rgba(248,246,241,.55);opacity:0;
}
.run-hud{
  position:absolute;z-index:3;color:rgba(248,246,241,.8);opacity:0;
  font-family:var(--mono);text-transform:uppercase;
}
.hud-bl{left:36px;bottom:40px}
.hud-bl .hud-km{font-size:clamp(30px,4vw,52px);letter-spacing:.02em;color:var(--porcelain)}
.hud-bl .hud-km .unit{font-size:.42em;color:rgba(248,246,241,.5);letter-spacing:.18em}
.hud-bl .hud-mile{font-size:10px;letter-spacing:.26em;color:var(--coral);margin-top:10px;min-height:14px}
.hud-br{right:36px;bottom:44px;text-align:right}
.hud-br .hud-label{font-size:9px;letter-spacing:.3em;color:rgba(248,246,241,.4)}
.hud-br .hud-time{font-size:clamp(18px,2.4vw,28px);letter-spacing:.06em;color:var(--porcelain);margin-top:8px}
.map-attr{
  position:absolute;right:12px;bottom:10px;z-index:3;
  font-family:var(--mono);font-size:8px;letter-spacing:.06em;
  color:rgba(248,246,241,.35);
}
.run-cap{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;
  width:min(860px,calc(100% - 48px));text-align:center;
  color:var(--porcelain);opacity:0;pointer-events:none;
}
.run-cap .c-text{
  font-size:clamp(34px,5vw,66px);font-weight:400;line-height:1.08;letter-spacing:-.01em;
}
.run-cap .c-text em{font-style:italic;color:var(--coral)}
.disc-reveal{
  position:absolute;inset:0;z-index:4;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:36px;
  opacity:0;visibility:hidden;will-change:transform,opacity,filter;
}
#disc-art{width:min(54vmin,460px);aspect-ratio:1}
#disc-art svg{
  width:100%;height:auto;
  filter:drop-shadow(0 50px 80px rgba(0,0,0,.6)) drop-shadow(0 10px 24px rgba(0,0,0,.5));
}
.dr-cap{text-align:center;color:var(--porcelain);opacity:0}
.dr-cap .c-text{font-size:clamp(28px,3.6vw,48px);line-height:1.1}
.dr-cap .c-text em{font-style:italic;color:var(--coral)}
.dr-cap .c-sub{
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(248,246,241,.45);margin-top:16px;
}
@media(max-width:768px){
  .run{height:560vh}
  .hud-bl{left:20px;bottom:30px}
  .hud-br{right:20px;bottom:34px}
  #disc-art{width:min(74vw,320px)}
}

/* ============================================================
   ACT IV · THE EDITIONS  (one page per frame)
   ============================================================ */
.ed-intro{
  background:var(--porcelain);color:var(--ink);
  padding:150px 0 130px;position:relative;z-index:4;
  border-radius:28px 28px 0 0;margin-top:-24px;
  text-align:center;
}
.ed-intro .kicker{justify-content:center;margin-bottom:20px}
.ed-intro .kicker::before{display:none}
.ed-intro h2{font-size:clamp(42px,5.6vw,76px);font-weight:400;letter-spacing:-.01em;line-height:1.02}
.ed-intro h2 em{font-style:italic;color:var(--coral)}
.ed-intro p{
  font-family:var(--mono);font-size:12px;letter-spacing:.05em;line-height:2;
  color:var(--stone);margin:24px auto 0;max-width:480px;
}

.products{position:relative;z-index:4}
.p-page{
  position:sticky;top:0;height:100vh;overflow:hidden;
  display:flex;align-items:center;
}
.p-1{background:var(--porcelain)}
.p-2{background:#fffdf8}
.p-3{background:#f1ece1}
.p-4{background:var(--night);color:var(--porcelain)}
.p-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);
  align-items:center;
}
.p-page.alt .p-grid .p-art{order:2}
/* centre the copy block inside its column so editions 2 & 4 (copy on the
   left) sit balanced, exactly like 1 & 3 (copy on the right) */
.p-copy{justify-self:center;width:100%;max-width:500px}
.p-art{display:flex;justify-content:center}
.p-art svg{
  width:100%;height:auto;
  filter:drop-shadow(0 30px 60px rgba(17,17,17,.18)) drop-shadow(0 6px 14px rgba(17,17,17,.10));
}
.p-art.portrait svg{max-width:min(330px,70vw)}
.p-art.square svg{max-width:min(390px,74vw)}
.p-art.landscape svg{max-width:min(540px,86vw)}
.p-4 .p-art svg{filter:drop-shadow(0 36px 70px rgba(0,0,0,.65)) drop-shadow(0 8px 18px rgba(0,0,0,.5))}
.p-copy .p-kicker{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--coral);margin-bottom:24px;
}
.p-copy h3{font-size:clamp(38px,4.6vw,64px);font-weight:400;line-height:1.02;letter-spacing:-.01em}
.p-copy .p-price{
  font-family:var(--mono);font-size:15px;font-weight:700;letter-spacing:.06em;
  margin:18px 0 26px;display:flex;align-items:baseline;gap:10px;
}
.p-copy .p-price .cur{font-size:10px;font-weight:400;letter-spacing:.22em;color:var(--stone)}
.p-copy .p-desc{
  font-family:var(--mono);font-size:12.5px;line-height:2;letter-spacing:.03em;
  color:var(--stone);max-width:480px;
}
.p-4 .p-copy .p-desc{color:rgba(248,246,241,.6)}
.p-specs{
  list-style:none;display:flex;flex-direction:column;gap:10px;
  margin:30px 0 36px;
}
.p-specs li{
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--stone);
  padding-left:20px;position:relative;
}
.p-tagline{font-family:var(--serif);font-size:clamp(15px,1.2vw,18px);font-style:italic;color:var(--coral);margin:0 0 20px;line-height:1.5}
.p-section-label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin:24px 0 8px}
.p-specs.p-provide li::before{background:var(--stone)}
.p-made{font-family:var(--mono);font-size:11px;color:var(--stone);margin:20px 0 28px;letter-spacing:.03em}

.p-specs li::before{content:"";position:absolute;left:0;top:7px;width:8px;height:1.5px;background:var(--coral)}
.p-4 .p-specs li{color:rgba(248,246,241,.55)}
.p-cta-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.p-note{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--stone)}
.p-4 .p-note{color:rgba(248,246,241,.4)}
.p-index{
  position:absolute;top:50%;right:34px;transform:translateY(-50%);
  font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:var(--stone);
  writing-mode:vertical-rl;opacity:.6;
}
.p-4 .p-index{color:rgba(248,246,241,.35)}
@media(max-width:900px){
  .p-page{height:auto;min-height:100vh;padding:90px 0 70px}
  .p-grid{grid-template-columns:1fr;gap:44px}
  .p-page.alt .p-grid .p-art{order:0}
  .p-art svg{max-height:44vh}
  .p-index{display:none}
  /* centre all copy on single-column layout */
  .p-copy{text-align:center}
  .p-copy .p-desc{margin-left:auto;margin-right:auto}
  .p-cta-row{justify-content:center}
  .p-specs{align-items:center}
  .p-specs li{padding-left:0;padding-right:0}
  .p-specs li::before{display:none}
  .p-specs li::before{display:none}
}

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.how{
  background:var(--porcelain);color:var(--ink);
  padding:150px 0 150px;position:relative;z-index:4;
}
.how-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:84px}
.how-head h2{font-size:clamp(40px,5vw,68px);font-weight:400;line-height:1.02;letter-spacing:-.01em}
.how-head h2 em{font-style:italic;color:var(--coral)}
.how-head .kicker{margin-bottom:18px}
.how-head .aside{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;line-height:1.9;color:var(--stone);max-width:300px}
.steps{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.steps-rail{position:absolute;top:23px;left:0;right:0;height:1px;background:var(--line-light)}
.steps-rail .rail-fill{display:block;height:100%;width:100%;background:var(--coral);transform-origin:left;transform:scaleX(0)}
.step{position:relative;padding-top:58px}
.step .s-num{
  position:absolute;top:0;left:0;
  width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;
  background:var(--porcelain);border:1px solid var(--line-light);color:var(--stone);
  transition:background .4s,color .4s,border-color .4s;
}
.step.lit .s-num{background:var(--coral);border-color:var(--coral);color:#fff}
.step h3{font-size:clamp(26px,2.4vw,34px);font-weight:400;line-height:1.1;margin-bottom:14px}
.step p{font-family:var(--mono);font-size:12px;line-height:1.95;letter-spacing:.03em;color:var(--stone);max-width:300px}
.step .s-note{
  display:inline-block;margin-top:18px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--coral);
}
@media(max-width:768px){
  .how{padding:100px 0}
  .steps{grid-template-columns:1fr;gap:56px}
  .steps-rail{display:none}
  .how-head{margin-bottom:60px}
}

/* ============================================================
   THE DETAIL  (dark cinematic pin)
   ============================================================ */
.detail{height:380vh;position:relative;background:var(--night);z-index:3}
.detail-stick{
  position:sticky;top:0;height:100vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.detail-rings{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  z-index:1;will-change:transform;
}
.detail-rings svg{width:140vmin;height:140vmin;opacity:.85}
.detail-copy{
  position:relative;z-index:2;width:min(900px,calc(100% - 48px));
  text-align:center;color:var(--porcelain);
}
.d-block{
  position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);
  opacity:0;visibility:hidden;
}
.d-block .d-label{
  font-family:var(--mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--coral);margin-bottom:28px;
}
.d-block h3{font-size:clamp(44px,6.4vw,92px);font-weight:400;line-height:1.02;letter-spacing:-.01em}
.d-block h3 em{font-style:italic;color:var(--coral)}
.d-block p{
  font-family:var(--mono);font-size:12.5px;line-height:2;letter-spacing:.04em;
  color:rgba(248,246,241,.55);
  max-width:520px;margin:30px auto 0;
}
.detail-progress{
  position:absolute;bottom:44px;left:50%;transform:translateX(-50%);z-index:4;
  display:flex;gap:10px;
}
.detail-progress span{
  width:34px;height:2px;background:rgba(248,246,241,.18);
  border-radius:2px;overflow:hidden;position:relative;
}
.detail-progress span i{
  position:absolute;inset:0;background:var(--coral);
  transform:scaleX(0);transform-origin:left;display:block;
}

/* ============================================================
   PROOF / URGENCY
   ============================================================ */
.proof{
  background:var(--porcelain);padding:150px 0;position:relative;z-index:4;
  border-radius:28px 28px 0 0;margin-top:-24px;
}
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line-light)}
.proof-cell{padding:54px 36px 10px;border-left:1px solid var(--line-light)}
.proof-cell:first-child{border-left:none}
.proof-cell .p-big{font-size:clamp(34px,3.4vw,48px);font-weight:400;line-height:1.05}
.proof-cell .p-big em{font-style:italic;color:var(--coral)}
.proof-cell p{
  font-family:var(--mono);font-size:11.5px;line-height:1.95;letter-spacing:.04em;
  color:var(--stone);margin-top:18px;max-width:280px;
}
.proof-quote{margin-top:120px;text-align:center}
.proof-cta{text-align:center;margin-top:56px;padding-top:40px;border-top:1px solid var(--line-light)}

.proof-quote blockquote{
  font-size:clamp(26px,3.2vw,44px);font-weight:400;line-height:1.3;font-style:italic;
  max-width:820px;margin:0 auto;
}
.proof-quote blockquote .hl{color:var(--coral)}
.proof-quote cite{
  display:block;margin-top:28px;font-style:normal;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--stone);
}
@media(max-width:768px){
  .proof{padding:100px 0}
  .proof-grid{grid-template-columns:1fr}
  .proof-cell{border-left:none;border-top:1px solid var(--line-light);padding:40px 4px 8px}
  .proof-cell:first-child{border-top:none}
  .proof-quote{margin-top:88px}
}

/* ============================================================
   CTA + FOOTER
   ============================================================ */
.cta{
  background:var(--night);color:var(--porcelain);
  padding:170px 0 60px;position:relative;overflow:hidden;z-index:4;
  border-radius:28px 28px 0 0;margin-top:-24px;
}
.cta-glow{
  position:absolute;top:-30%;left:50%;transform:translateX(-50%);
  width:120vmin;height:90vmin;pointer-events:none;
  background:radial-gradient(ellipse, rgba(232,93,63,.16), transparent 62%);
}
.cta-inner{position:relative;z-index:2;text-align:center}
.cta .kicker{justify-content:center;color:rgba(248,246,241,.5);margin-bottom:30px}
.cta .kicker::before{display:none}
.cta h2{font-size:clamp(52px,8vw,124px);font-weight:400;line-height:.98;letter-spacing:-.015em}
.cta h2 em{font-style:italic;color:var(--coral)}
.cta-sub{
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;line-height:2;
  color:rgba(248,246,241,.55);margin:34px auto 0;max-width:440px;
}
.cta-btn{
  display:flex;align-items:center;gap:12px;
  width:fit-content;margin:50px auto 0;
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  padding:18px 36px;border-radius:999px;border:none;
  background:var(--coral);color:#fff;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;
}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(232,93,63,.45)}
.cta-btn .arr{transition:transform .3s}
.cta-btn:hover .arr{transform:translateX(4px)}
.cta-meta{
  margin-top:48px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(248,246,241,.35);
}
footer{
  position:relative;z-index:2;
  margin-top:140px;padding-top:34px;
  border-top:1px solid var(--line-dark);
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(248,246,241,.4);
}
footer .f-brand{font-family:var(--serif);font-size:20px;letter-spacing:.01em;text-transform:none;color:var(--porcelain)}
footer .f-brand .dot{color:var(--coral)}
footer nav{display:flex;gap:24px}
footer nav a{transition:color .25s}
footer nav a:hover{color:var(--porcelain)}
@media(max-width:768px){
  .cta{padding-top:120px}
  footer{flex-direction:column;text-align:center;margin-top:96px}
}

/* ============================================================
   CONFIGURATOR — "Make It Yours"
   ============================================================ */
.config{background:var(--porcelain);padding:140px 0 150px;position:relative;z-index:4}
.config-head{text-align:center;margin-bottom:58px}
.config-head .kicker{justify-content:center;margin-bottom:18px}
.config-head .kicker::before{display:none}
.config-head h2{font-size:clamp(42px,5.6vw,76px);font-weight:400;letter-spacing:-.01em;line-height:1.02}
.config-head h2 em{font-style:italic;color:var(--coral)}
.config-head p{
  font-family:var(--mono);font-size:12px;letter-spacing:.05em;line-height:2;
  color:var(--stone);margin:20px auto 0;max-width:460px;
}
/* step indicator */
.cfg-steps{display:flex;justify-content:center;margin:0 auto 52px;max-width:620px}
.cfg-dot{
  position:relative;flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;
  background:none;border:none;padding:0;cursor:pointer;
}
.cfg-dot:not(:first-child)::before{
  content:"";position:absolute;top:19px;right:50%;width:100%;height:1px;
  background:var(--line-light);transition:background .4s;
}
.cfg-dot.active:not(:first-child)::before,
.cfg-dot.done:not(:first-child)::before{background:var(--coral)}
.cfg-dot .d-num{
  position:relative;z-index:1;
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:12px;
  background:#fff;border:1px solid var(--line-light);color:var(--stone);
  transition:background .3s,border-color .3s,color .3s;
}
.cfg-dot.active .d-num{background:var(--coral);border-color:var(--coral);color:#fff}
.cfg-dot.done .d-num{border-color:var(--coral);color:var(--coral)}
.cfg-dot .d-lab{
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--stone);transition:color .3s;
}
.cfg-dot.active .d-lab{color:var(--ink)}
/* stage + panes */
.cfg-stage{max-width:760px;margin:0 auto}
.cfg-pane{display:none}
.cfg-pane.on{display:block}
.cfg-pane-title{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--coral);margin-bottom:22px;
}
/* step 1: frame cards */
.cfg-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cfg-card{
  position:relative;text-align:left;
  background:#fff;border:1px solid var(--line-light);border-radius:14px;
  padding:22px 18px 20px;cursor:pointer;font-family:var(--serif);
  transition:border-color .25s,box-shadow .25s,transform .25s;
}
.cfg-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(17,17,17,.07)}
.cfg-card h4{font-size:21px;font-weight:400;line-height:1.1;padding-right:24px}
.cfg-card .c-spec{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;line-height:1.8;
  color:var(--stone);margin:10px 0 14px;
}
.cfg-card .c-pr{font-family:var(--mono);font-size:13px;font-weight:700}
.cfg-card .cfg-check{
  position:absolute;top:12px;right:12px;width:22px;height:22px;border-radius:50%;
  background:var(--coral);color:#fff;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:scale(.4);transition:opacity .25s,transform .25s cubic-bezier(.2,.8,.2,1);
}
.cfg-card .cfg-check svg{width:11px;height:11px}
.cfg-card.sel{border-color:var(--coral);box-shadow:0 0 0 3px rgba(232,93,63,.14)}
.cfg-card.sel .cfg-check{opacity:1;transform:scale(1)}
/* fields */
.f-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.f-grid-4{grid-template-columns:repeat(4,1fr)}
.f-wide{grid-column:1/-1}
.f label{
  display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--stone);margin-bottom:8px;
}
.f input,.f textarea{
  width:100%;padding:13px 14px;
  font-family:var(--mono);font-size:13px;color:var(--ink);
  background:#fff;border:1px solid var(--line-light);border-radius:10px;
  transition:border-color .2s,box-shadow .2s;
}
.f input:focus,.f textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(232,93,63,.12)}
.f input.err{border-color:#d8232a;box-shadow:0 0 0 3px rgba(216,35,42,.12)}
.f textarea{resize:vertical;min-height:84px}
.f .f-flex{display:flex;gap:10px;align-items:stretch}
.f .f-flex input{flex:1;min-width:0}
.seg{display:inline-flex;border:1px solid var(--line-light);border-radius:10px;overflow:hidden;background:#fff}
.seg button{
  padding:0 16px;border:none;background:transparent;cursor:pointer;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--stone);
  transition:background .2s,color .2s;
}
.seg button.active{background:var(--ink);color:var(--porcelain)}
.f-req{color:var(--coral)}
/* hyrox extras */
.hyx{display:none;margin-top:22px;padding-top:22px;border-top:1px dashed rgba(232,93,63,.4)}
.hyx.on{display:block}
.hyx .hyx-title{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--coral);margin-bottom:16px;
}
.hyx-splits{margin-top:16px}
.hyx-splits summary{
  cursor:pointer;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--stone);padding:6px 0;
}
.hyx-splits[open] summary{color:var(--ink)}
.hyx-splits .f-grid{margin-top:14px}
/* step 3 */
.swatch-row{display:flex;gap:18px;flex-wrap:wrap}
.sw{display:flex;flex-direction:column;align-items:center;gap:7px;background:none;border:none;cursor:pointer;padding:0}
.sw i{
  display:block;width:38px;height:38px;border-radius:50%;
  border:2px solid rgba(17,17,17,.1);transition:transform .15s,box-shadow .15s,border-color .15s;
}
.sw:hover i{transform:scale(1.08)}
.sw.sel i{border-color:var(--coral);box-shadow:0 0 0 3px rgba(232,93,63,.2)}
.sw span{font-family:var(--mono);font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone)}
.f .char{display:block;text-align:right;font-family:var(--mono);font-size:9px;color:var(--stone);margin-top:6px}
.cfg-info{
  margin-top:22px;padding:14px 16px;border:1px dashed rgba(232,93,63,.45);border-radius:10px;
  background:rgba(232,93,63,.05);
  font-family:var(--mono);font-size:10.5px;line-height:1.9;letter-spacing:.03em;color:var(--stone);
}
.cfg-info b{color:var(--ink);font-weight:700}
.cfg-info ul{list-style:none;margin-top:8px;display:flex;flex-direction:column;gap:7px}
.cfg-info li{padding-left:16px;position:relative}
.cfg-info li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:1.5px;background:var(--coral)}
/* GPX upload */
.gpx-drop{
  position:relative;display:flex;align-items:center;justify-content:center;
  padding:22px 16px;border:1.5px dashed var(--line-light);border-radius:10px;
  background:#fff;cursor:pointer;
  transition:border-color .2s,background .2s;
}
.gpx-drop:hover{border-color:var(--coral)}
.gpx-drop.has{border-style:solid;border-color:var(--coral);background:rgba(232,93,63,.05)}
.gpx-drop input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.gpx-drop .gpx-cta{
  display:flex;align-items:center;gap:10px;pointer-events:none;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);
}
.gpx-drop.has .gpx-cta{color:var(--ink);text-transform:none;letter-spacing:.02em}
.gpx-drop .gpx-cta svg{width:16px;height:16px;color:var(--coral);flex-shrink:0}
.gpx-status{display:block;font-family:var(--mono);font-size:10px;line-height:1.7;margin-top:8px;color:var(--stone)}
.gpx-status.ok{color:#2D6A4F}
.gpx-alt{margin-top:16px}
.gpx-alt summary{
  cursor:pointer;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--stone);padding:4px 0;
}
.gpx-alt[open] summary{color:var(--ink)}
.gpx-alt .cfg-info{margin-top:12px}
/* step 4 */
.cfg-sum{
  background:#fff;border:1px solid var(--line-light);border-radius:14px;
  padding:26px 26px 10px;margin-bottom:26px;
}
.cfg-sum .s-row{
  display:flex;justify-content:space-between;gap:18px;align-items:baseline;
  padding:11px 0;border-bottom:1px solid var(--line-light);
}
.cfg-sum .s-row:last-child{border-bottom:none}
.cfg-sum .s-key{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);flex-shrink:0}
.cfg-sum .s-val{font-family:var(--mono);font-size:12.5px;color:var(--ink);text-align:right;overflow-wrap:anywhere}
.cfg-sum .s-val.price{font-weight:700;color:var(--coral)}
.cfg-wa-wrap{text-align:center;margin-top:32px}
.cfg-wa{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  padding:17px 36px;border-radius:999px;border:none;cursor:pointer;
  background:var(--coral);color:#fff;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;
}
.cfg-wa:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(232,93,63,.4)}
.cfg-wa:active{transform:translateY(0);box-shadow:none}
.cfg-wa svg{width:18px;height:18px;flex-shrink:0}
.cfg-wa-note{
  text-align:center;margin-top:16px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--stone);
}
/* footer bar: running total + nav */
.cfg-foot{
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  max-width:760px;margin:36px auto 0;
  border-top:1px solid var(--line-light);padding-top:22px;
}
.cfg-total{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone)}
.cfg-total b{color:var(--ink);font-weight:700}
.cfg-total .tp{color:var(--coral);font-weight:700}
.cfg-btns{display:flex;gap:12px}
.cfg-back{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  padding:13px 22px;border-radius:999px;cursor:pointer;
  border:1px solid var(--line-light);background:transparent;color:var(--ink);
  transition:border-color .2s;
}
.cfg-back:hover{border-color:var(--ink)}
.cfg-back[hidden]{display:none}
.cfg-next{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  padding:13px 26px;border-radius:999px;cursor:pointer;border:none;
  background:var(--coral);color:#fff;
  transition:transform .2s,box-shadow .2s;
}
.cfg-next:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(232,93,63,.35)}
.cfg-next[hidden]{display:none}
@media(max-width:900px){
  .cfg-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .config{padding:96px 0 110px}
  .cfg-steps{max-width:100%}
  .cfg-dot .d-lab{font-size:8px}
  .f-grid{grid-template-columns:1fr}
  .f-grid-4{grid-template-columns:repeat(2,1fr)}
  .cfg-foot{flex-direction:column-reverse;align-items:stretch}
  .cfg-btns{justify-content:space-between}
  .cfg-total{text-align:center}
}
@media(max-width:440px){
  .cfg-cards{grid-template-columns:1fr}
}

/* ---------- reduced motion / no-GSAP fallback ---------- */
body.no-fx .run{height:auto}
body.no-fx .run-stick{position:relative;height:100vh}
body.no-fx .run-hud,body.no-fx .run-cap,body.no-fx #run-title,
body.no-fx .disc-reveal,body.no-fx #runner{display:none}
body.no-fx .detail{height:auto}
body.no-fx .detail-stick{position:relative;height:auto;display:block;padding:16vh 0;overflow:visible}
body.no-fx .d-block{
  position:static;transform:none;opacity:1;visibility:visible;
  margin:0 auto 14vh;max-width:900px;
}
body.no-fx .d-block:last-child{margin-bottom:0}
body.no-fx .detail-progress{display:none}
@media (prefers-reduced-motion: reduce){
  .hero-scrollcue .stem::after,#runner .pulse{animation:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   PAYMENT MODAL
   ============================================================ */
.pay-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.72);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.pay-overlay.open{opacity:1;pointer-events:auto;}
.pay-modal{
  background:var(--night);border:1px solid rgba(248,246,241,.12);
  border-radius:20px;padding:48px 40px 36px;
  max-width:400px;width:90%;text-align:center;
  transform:translateY(24px);transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.pay-overlay.open .pay-modal{transform:translateY(0);}
.pay-modal-icon{
  font-size:24px;color:var(--coral);
  width:56px;height:56px;line-height:56px;
  background:rgba(232,93,63,.12);border-radius:50%;
  margin:0 auto 20px;
}
.pay-modal-title{
  font-family:var(--serif);font-size:22px;font-weight:400;
  color:var(--porcelain);margin:0 0 12px;
}
.pay-modal-msg{
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;line-height:1.8;
  color:rgba(248,246,241,.55);margin:0 0 24px;
}
.pay-modal-edition{
  font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.08em;
  color:var(--porcelain);margin:0 0 20px;
}
.pay-modal-paynow{
  background:rgba(248,246,241,.06);border:1px solid rgba(248,246,241,.12);
  border-radius:12px;padding:16px 20px;margin:0 0 24px;text-align:left;
}
.pay-modal-paynow p{
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;line-height:1.8;
  color:rgba(248,246,241,.75);margin:0;
}
.pay-modal-paynow strong{color:var(--porcelain);}
.pay-modal-ref{font-size:10.5px!important;color:rgba(248,246,241,.4)!important;}
.pay-modal-btn{
  display:flex;align-items:center;justify-content:center;
  width:100%;padding:17px 24px;border-radius:999px;text-decoration:none;
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  background:var(--coral);color:#fff;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s;
  margin-bottom:14px;
}
.pay-modal-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(232,93,63,.4);}
.pay-modal-secure{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(248,246,241,.25);margin:0 0 20px;
}
.pay-modal-close{
  background:none;border:none;cursor:pointer;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(248,246,241,.35);padding:6px 12px;transition:color .2s;
}
.pay-modal-close:hover{color:var(--porcelain);}
