/* ============================================================
   BLASTTRACK — design tokens
   ============================================================ */
:root{
  --bg:#0A0A0A;
  --bg-2:#0E0E0E;
  --surface:#141414;
  --card:#1C1C1C;
  --card-elev:#242424;
  --border:#2A2A2A;
  --border-strong:#3A3A3A;

  --orange:#E8611A;
  --orange-dim:#B84810;
  --orange-glow:rgba(232,97,26,.45);
  --green:#2ECC40;
  --amber:#FFB020;
  --red:#FF4136;

  --text:#F5F5F5;
  --text-2:#A0A0A0;
  --text-3:#6B6B6B;

  --display:'Barlow Condensed',Impact,'Helvetica Neue',sans-serif;
  --body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;

  --pad:20px;
  --max:1200px;
  --section-gap:80px;

  --ease-out-expo:cubic-bezier(.16,1,.3,1);
  --ease-out-cubic:cubic-bezier(.33,1,.68,1);
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:80px;
}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font:400 16px/1.6 var(--body);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;-webkit-tap-highlight-color:transparent}

.skip{
  position:absolute;left:-9999px;top:0;
  background:var(--orange);color:#fff;
  padding:12px 16px;z-index:1000;
  font-family:var(--mono);font-size:13px;
  text-transform:uppercase;letter-spacing:.06em;
}
.skip:focus{left:0}

.mono{font-family:var(--mono)}

/* Dots */
.dot{
  display:inline-block;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--text-3);
  margin-right:8px;
  vertical-align:middle;
  flex-shrink:0;
}
.dot-green{background:var(--green);box-shadow:0 0 8px rgba(46,204,64,.6)}
.dot-amber{background:var(--amber);box-shadow:0 0 8px rgba(255,176,32,.6)}
.dot-red{background:var(--red);box-shadow:0 0 8px rgba(255,65,54,.6)}
.dot-orange{background:var(--orange);box-shadow:0 0 8px var(--orange-glow)}

.dot.pulse{position:relative}
.dot.pulse::after{
  content:"";position:absolute;inset:-4px;
  border-radius:50%;
  border:1px solid currentColor;
  opacity:.6;
  animation:pulse 1.8s ease-out infinite;
}
@keyframes pulse{
  0%{transform:scale(.5);opacity:.6}
  100%{transform:scale(1.6);opacity:0}
}

/* ============================================================
   NAV (sticky, blurred)
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:50;
  background:rgba(10,10,10,.78);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(232,97,26,0);
  transition:border-color .3s ease;
  padding-top:env(safe-area-inset-top);
}
.nav.is-stuck{border-bottom-color:rgba(232,97,26,.28)}
.nav-inner{
  max-width:var(--max);
  margin:0 auto;
  display:flex;align-items:center;gap:12px;
  padding:14px var(--pad);
}

.wordmark{
  display:inline-flex;align-items:center;gap:8px;
  font:700 22px/1 var(--display);
  letter-spacing:.02em;
  color:var(--text);
  text-transform:uppercase;
}
.wordmark-icon{
  width:32px;height:32px;
  border-radius:7px;
  margin-right:2px;
  flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.04);
}
.wordmark-bar{
  display:inline-block;
  width:2px;height:18px;
  background:var(--orange);
  box-shadow:0 0 10px var(--orange-glow);
}
.wordmark-track{color:var(--orange)}
.wordmark-sm{font-size:18px}
.wordmark-sm .wordmark-bar{height:14px}
.wordmark-sm .wordmark-icon{width:24px;height:24px;border-radius:5px}

.nav-links{
  display:none;
  margin-left:auto;
  align-items:center;gap:24px;
  font:500 13px/1 var(--mono);
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--text-2);
}
.nav-links a{
  position:relative;
  padding:6px 0;
  transition:color .15s ease;
}
.nav-links a:hover{color:var(--text)}

.nav-cta{
  margin-left:auto;
  display:inline-flex;align-items:center;
  background:var(--orange);
  color:#fff;
  font:500 12px/1 var(--mono);
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:11px 16px;
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
  transition:background .15s ease;
}
.nav-cta:hover{background:#FF7530}

@media (min-width:768px){
  .nav-links{display:inline-flex}
  .nav-cta{margin-left:0}
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font:600 14px/1 var(--body);
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:18px 26px;
  min-height:56px;
  border:1px solid transparent;
  transition:transform .15s ease,background .15s ease,border-color .15s ease,color .15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}

.btn-primary{
  background:var(--orange);
  color:#fff;
  box-shadow:0 8px 20px -8px var(--orange-glow);
}
.btn-primary:hover{background:#FF7530}

.btn-secondary{
  background:transparent;
  color:var(--text);
  border-color:var(--border-strong);
}
.btn-secondary:hover{
  border-color:var(--orange);
  color:var(--orange);
}

.btn-notched{
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
}

.btn-lg{
  padding:22px 36px;
  font-size:16px;
  min-height:64px;
}

.btn-ic{flex-shrink:0}

/* ============================================================
   HAZARD STRIPE BAND
   ============================================================ */
.hazard-band{
  height:10px;
  width:100%;
  background:repeating-linear-gradient(
    -45deg,
    var(--orange) 0 14px,
    #0A0A0A 14px 28px
  );
  background-size:40px 40px;
  animation:hazard-pan 20s linear infinite;
  border-top:1px solid rgba(232,97,26,.3);
  border-bottom:1px solid rgba(232,97,26,.3);
}
@keyframes hazard-pan{
  from{background-position:0 0}
  to{background-position:80px 0}
}

/* ============================================================
   PHONE MOCKUP
   ============================================================ */
.phone{
  position:relative;
  width:280px;
  aspect-ratio:331/720;
  flex-shrink:0;
}
.phone-frame{
  position:relative;
  width:100%;
  height:100%;
  background:#000;
  border-radius:36px;
  border:1px solid var(--border-strong);
  padding:8px;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.06),
    0 30px 80px -20px rgba(0,0,0,.9),
    0 10px 30px -10px rgba(232,97,26,.15);
  overflow:hidden;
}
.phone-frame img{
  width:100%;
  height:100%;
  border-radius:28px;
  object-fit:cover;
  display:block;
}
.phone-notch{
  position:absolute;
  top:14px;left:50%;
  transform:translateX(-50%);
  width:80px;height:22px;
  background:#000;
  border-radius:14px;
  z-index:2;
  border:1px solid #000;
}
.phone-hero{width:280px}
.phone-md{width:300px}

/* ============================================================
   HERO — Two-column on desktop, stacked on mobile (Headspace pattern)
   ============================================================ */
.hero{
  position:relative;
  overflow:hidden;
  padding:112px var(--pad) 56px;
}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg-radial{
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(ellipse 60% 50% at 50% 30%,rgba(232,97,26,.10) 0%,transparent 60%),
    radial-gradient(ellipse 80% 50% at 30% 70%,rgba(184,72,16,.06) 0%,transparent 60%);
  animation:slow-rotate 28s linear infinite;
}
.hero-bg-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 30%,transparent 80%);
}
@keyframes slow-rotate{
  from{transform:rotate(0)}
  to{transform:rotate(360deg)}
}

.hero-inner{
  position:relative;z-index:1;
  max-width:var(--max);
  margin:0 auto;
  display:flex;flex-direction:column;
  gap:40px;
  align-items:center;
  text-align:center;
}

.hero-copy{
  display:flex;flex-direction:column;
  align-items:center;
  gap:18px;
  width:100%;
}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font:500 11px/1 var(--mono);
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--text-2);
  padding:8px 12px;
  border:1px solid var(--border);
  background:rgba(20,20,20,.5);
}
.hero-eyebrow .dot{margin-right:0;width:6px;height:6px}

.hero-headline{
  font:700 clamp(48px,11vw,72px)/.9 var(--display);
  text-transform:uppercase;
  letter-spacing:-.02em;
  margin:0;
  text-wrap:balance;
  max-width:14ch;
}
.hero-headline em{color:var(--orange);font-style:normal}

.hero-sub{
  font:400 17px/1.55 var(--body);
  color:var(--text-2);
  max-width:48ch;
  margin:0;
}

.hero-ctas{
  display:flex;flex-direction:column;
  gap:14px;
  align-items:center;
}
.hero-meta{
  font:500 12px/1 var(--mono);
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--text-3);
}

.hero-img{
  position:relative;
  display:flex;justify-content:center;align-items:center;
  width:100%;
}

@media (min-width:768px){
  .hero{padding:128px var(--pad) 80px}
  .hero-headline{font-size:88px;line-height:.88;max-width:18ch}
  .hero-sub{font-size:19px;max-width:52ch}
  .hero-ctas{flex-direction:row;gap:24px}
  .phone-hero{width:300px}
}

@media (min-width:1024px){
  .hero{padding:140px var(--pad) 100px}
  .hero-inner{
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
    text-align:left;
    gap:56px;
  }
  .hero-copy{
    align-items:flex-start;
    flex:1 1 60%;
    min-width:0;
  }
  .hero-headline{font-size:104px;max-width:none}
  .hero-sub{max-width:46ch}
  .hero-ctas{justify-content:flex-start}
  .hero-img{
    flex:0 0 auto;
    width:auto;
  }
  .phone-hero{width:340px}
}

@media (min-width:1280px){
  .hero-headline{font-size:120px}
  .phone-hero{width:360px}
}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{
  position:relative;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,#0E0E0E 0%,#0A0A0A 100%);
  overflow:hidden;
  padding:22px 0;
}
.trust-track{
  display:flex;align-items:center;gap:32px;
  white-space:nowrap;
  font:700 22px/1 var(--display);
  letter-spacing:.14em;
  text-transform:uppercase;
  padding-left:var(--pad);
  animation:trust-marquee 50s linear infinite;
  will-change:transform;
}
.trust-item{
  flex-shrink:0;
  color:transparent;
  -webkit-text-stroke:1px var(--text-2);
}
.trust-sep{
  flex-shrink:0;
  color:var(--orange);
  font-weight:700;
  font-size:18px;
}
@keyframes trust-marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

@media (min-width:768px){
  .trust{padding:28px 0}
  .trust-track{
    font-size:28px;
    gap:36px;
  }
  .trust-sep{font-size:22px}
}

/* ============================================================
   SHARED — section eyebrow tag (used in proof, testimonials, faq)
   ============================================================ */
.block-tag{
  font:500 11px/1 var(--mono);
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--orange);
}

/* ============================================================
   SOCIAL PROOF — Smart insights + stats + quote
   ============================================================ */
.proof{
  background:linear-gradient(180deg,var(--bg) 0%,var(--surface) 50%,var(--bg) 100%);
  padding:var(--section-gap) var(--pad);
  position:relative;
}
.proof::before,
.proof::after{
  content:"";
  position:absolute;
  left:0;right:0;
  height:1px;
  background:var(--border);
}
.proof::before{top:0}
.proof::after{bottom:0}

.proof-inner{
  max-width:var(--max);
  margin:0 auto;
  display:flex;flex-direction:column;
  gap:48px;
}

.proof-head{
  display:flex;flex-direction:column;
  align-items:flex-start;
  gap:16px;
  max-width:680px;
}
.proof-title{
  font:700 clamp(36px,7vw,56px)/.95 var(--display);
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin:0;
  text-wrap:balance;
}
.proof-sub{
  font:400 16px/1.6 var(--body);
  color:var(--text-2);
  margin:0;
}

.proof-grid{
  display:flex;flex-direction:column;
  gap:32px;
  align-items:center;
}
.proof-phone{
  display:flex;justify-content:center;
  flex-shrink:0;
}
.proof-cards{
  display:flex;flex-direction:column;
  gap:14px;
  width:100%;
}
.proof-card{
  background:var(--card);
  border:1px solid var(--border);
  padding:18px 20px;
  display:flex;flex-direction:column;
  gap:10px;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
  transition:border-color .2s ease;
}
.proof-card:hover{border-color:var(--border-strong)}
.proof-tag{
  font:500 10px/1 var(--mono);
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--orange);
}
.proof-quote{
  font:500 17px/1.45 var(--body);
  color:var(--text);
  margin:0;
}
.proof-conf{
  display:inline-flex;align-items:center;gap:8px;
  font:500 10px/1 var(--mono);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-2);
}
.proof-conf .dot{width:6px;height:6px;margin-right:0}

.proof-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:32px 0;
}
.proof-stat{
  display:flex;flex-direction:column;
  align-items:center;
  text-align:center;
  gap:6px;
}
.proof-stat-num{
  font:700 clamp(40px,8vw,64px)/1 var(--display);
  color:var(--text);
  letter-spacing:-.01em;
  display:inline-flex;align-items:baseline;
}
.proof-stat-unit{
  font-size:.55em;
  color:var(--orange);
  margin-left:2px;
}
.proof-stat-lbl{
  font:500 11px/1.2 var(--mono);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-3);
}

@media (min-width:768px){
  .proof-stats{grid-template-columns:repeat(4,1fr)}
}

@media (min-width:1024px){
  .proof-grid{
    flex-direction:row;
    align-items:flex-start;
    gap:60px;
  }
  .proof-cards{flex:1}
  .phone-md{width:340px}
}

/* ============================================================
   TESTIMONIALS — Swipeable carousel of operator reviews
   ============================================================ */
.testimonials{
  padding:var(--section-gap) 0;
  background:var(--bg);
}
.testimonials-head{
  max-width:var(--max);
  margin:0 auto 40px;
  padding:0 var(--pad);
  display:flex;flex-direction:column;
  align-items:flex-start;
  gap:14px;
}
.testimonials-title{
  font:700 clamp(36px,7vw,56px)/.95 var(--display);
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin:0;
  text-wrap:balance;
}
.testimonials-sub{
  font:400 16px/1.6 var(--body);
  color:var(--text-2);
  margin:0;
  max-width:54ch;
}

.testimonials-carousel{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
}

.testimonials-track{
  display:flex;
  gap:16px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scroll-padding-inline:var(--pad);
  padding:6px var(--pad) 28px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  -ms-overflow-style:none;
  overscroll-behavior-x:contain;
}
.testimonials-track::-webkit-scrollbar{display:none}

.testimonial{
  flex:0 0 calc(100% - 32px);
  max-width:520px;
  scroll-snap-align:start;
  position:relative;
  background:var(--card);
  border:1px solid var(--border);
  padding:48px 28px 32px;
  display:flex;flex-direction:column;
  justify-content:center;
  min-height:200px;
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px));
  transition:border-color .2s ease;
}
.testimonial:hover{border-color:var(--border-strong)}

.testimonial-mark{
  position:absolute;
  top:14px;left:18px;
  font:700 64px/1 var(--display);
  color:var(--orange);
  opacity:.32;
  pointer-events:none;
}

.testimonial-quote{
  position:relative;
  font:500 18px/1.5 var(--body);
  color:var(--text);
  margin:0;
  text-wrap:balance;
}

/* Carousel controls */
.testimonials-controls{
  display:flex;align-items:center;justify-content:center;
  gap:14px;
  padding:0 var(--pad);
  margin-top:4px;
}
.testimonials-arrow{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:transparent;
  border:1px solid var(--border-strong);
  color:var(--text);
  cursor:pointer;
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
  transition:border-color .15s ease,color .15s ease,background .15s ease;
  flex-shrink:0;
}
.testimonials-arrow:hover{
  border-color:var(--orange);
  color:var(--orange);
  background:rgba(232,97,26,.06);
}
.testimonials-arrow:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:2px;
}

.testimonials-dots{
  display:flex;align-items:center;
  gap:8px;
}
.testimonials-dot{
  width:8px;height:8px;
  border:0;
  padding:0;
  background:var(--border-strong);
  cursor:pointer;
  border-radius:50%;
  transition:background .2s ease,transform .2s ease;
}
.testimonials-dot:hover{background:var(--text-2)}
.testimonials-dot.is-active{
  background:var(--orange);
  transform:scale(1.25);
  box-shadow:0 0 8px var(--orange-glow);
}
.testimonials-dot:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:2px;
}

@media (min-width:768px){
  .testimonial{
    flex:0 0 480px;
    padding:36px 32px 28px;
  }
  .testimonial-quote{font-size:20px}
  .testimonials-track{padding:8px var(--pad) 36px}
}

/* ============================================================
   WORKFLOWS — Tappable grid → modal
   ============================================================ */
.workflows{
  --c-orange:#E8611A;
  --c-white:#E8E8E8;
  --c-yellow:#FFB020;
  --c-red:#FF4136;
  --c-green:#2ECC40;
  --c-blue:#3D8BFD;

  padding:var(--section-gap) var(--pad);
  max-width:var(--max);
  margin:0 auto;
}
.workflow-color-01{--c:var(--c-orange);--c-text:#fff}
.workflow-color-02{--c:var(--c-white);--c-text:#0A0A0A}
.workflow-color-03{--c:var(--c-yellow);--c-text:#0A0A0A}
.workflow-color-04{--c:var(--c-red);--c-text:#fff}
.workflow-color-05{--c:var(--c-green);--c-text:#0A0A0A}
.workflow-color-06{--c:var(--c-blue);--c-text:#fff}

.workflows-head{
  text-align:center;
  margin:0 auto 48px;
  max-width:720px;
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
.workflows-title{
  font:700 clamp(40px,9vw,72px)/.92 var(--display);
  text-transform:uppercase;
  letter-spacing:-.02em;
  margin:0;
  text-wrap:balance;
}
.workflows-title em{color:var(--orange);font-style:normal}
.workflows-sub{
  font:400 16px/1.6 var(--body);
  color:var(--text-2);
  margin:0;
  max-width:54ch;
}

.workflow-grid{
  list-style:none;
  padding:0;margin:0;
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}

.workflow-card{display:contents}

.workflow-trigger{
  position:relative;
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  grid-template-rows:auto auto;
  grid-template-areas:
    "num icon icon icon"
    "name name tease chev";
  gap:6px 14px;
  align-items:center;
  width:100%;
  background:var(--card);
  border:1px solid var(--border);
  padding:18px 20px;
  text-align:left;
  cursor:pointer;
  transition:border-color .2s ease,transform .15s ease,background .2s ease;
  min-height:88px;
}
.workflow-trigger:hover{
  border-color:var(--c);
  background:var(--card-elev);
  transform:translateY(-1px);
}
.workflow-trigger:focus-visible{
  outline:2px solid var(--c);
  outline-offset:2px;
}

.wf-num{
  grid-area:num;
  font:500 11px/1 var(--mono);
  letter-spacing:.14em;
  color:var(--c);
  align-self:start;
}
.wf-name{
  grid-area:name;
  font:700 22px/1 var(--display);
  text-transform:uppercase;
  letter-spacing:-.005em;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.wf-tease{
  display:none;
}
.wf-chev{
  grid-area:chev;
  font:400 28px/1 var(--display);
  color:var(--text-3);
  transition:color .2s ease,transform .2s ease;
  padding-left:8px;
}
.workflow-trigger:hover .wf-chev{color:var(--c);transform:translateX(2px)}

/* Card bracket corners (color-coded) */
.wf-bracket{
  position:absolute;
  width:14px;height:14px;
  border:2px solid var(--c);
  pointer-events:none;
}
.wf-bracket-tl{top:-1px;left:-1px;border-right:0;border-bottom:0}
.wf-bracket-tr{top:-1px;right:-1px;border-left:0;border-bottom:0}
.wf-bracket-bl{bottom:-1px;left:-1px;border-right:0;border-top:0}
.wf-bracket-br{bottom:-1px;right:-1px;border-left:0;border-top:0}

/* Card icon — always a 56×56 square on the right */
.wf-icon{
  grid-area:icon;
  width:56px;
  height:56px;
  flex-shrink:0;
  align-self:start;
  justify-self:end;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--c);
}

/* 01 Target — corner brackets + center dot, fills the square */
.wf-icon-target{position:relative}
.wf-tgt-bracket{
  position:absolute;
  width:14px;height:14px;
  border:2px solid var(--c);
}
.wf-tgt-tl{top:4px;left:4px;border-right:0;border-bottom:0}
.wf-tgt-tr{top:4px;right:4px;border-left:0;border-bottom:0}
.wf-tgt-bl{bottom:4px;left:4px;border-right:0;border-top:0}
.wf-tgt-br{bottom:4px;right:4px;border-left:0;border-top:0}
.wf-tgt-dot{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:10px;height:10px;
  background:var(--c);
  border-radius:50%;
}

/* 02 Receipt — bordered square with $ amount + lines */
.wf-icon-receipt{
  flex-direction:column;
  align-items:stretch;
  justify-content:center;
  gap:4px;
  border:1px solid var(--c);
  padding:7px 8px;
  font-size:9px;
  font-weight:700;
  letter-spacing:-.02em;
  color:var(--c);
}
.wf-receipt-amt{
  text-align:right;
  font-size:10px;
  margin-bottom:2px;
}
.wf-receipt-line{
  display:block;
  width:100%;
  height:1px;
  background:var(--c);
  opacity:.55;
}

/* 03 Gauge — vertical bars filling the square */
.wf-icon-gauge{
  align-items:flex-end;
  justify-content:center;
  gap:3px;
  padding:6px;
}
.wf-icon-gauge span{
  display:block;
  width:4px;
  height:var(--h);
  background:var(--c);
}

/* 04 Checklist — bordered square with 3 rows */
.wf-icon-checklist{
  flex-direction:column;
  align-items:stretch;
  justify-content:center;
  gap:4px;
  border:1px solid var(--c);
  padding:8px 8px;
}
.wf-cl-row{display:flex;align-items:center;gap:5px}
.wf-cl-box{
  display:block;
  width:8px;height:8px;
  border:1px solid var(--c);
  flex-shrink:0;
}
.wf-cl-box.checked{background:var(--c)}
.wf-cl-line{
  display:block;
  flex:1;
  height:1px;
  background:var(--c);
  opacity:.55;
}

/* 05 Bar chart — ascending vertical bars */
.wf-icon-chart{
  align-items:flex-end;
  justify-content:center;
  gap:4px;
  padding:6px;
}
.wf-icon-chart span{
  display:block;
  width:5px;
  height:var(--h);
  background:var(--c);
}

/* 06 Business card — bordered square with stacked card text */
.wf-icon-card{
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:2px;
  border:1px solid var(--c);
  padding:6px 7px;
  font-size:6px;
  letter-spacing:.04em;
  color:var(--c);
  line-height:1.2;
}
.wf-bcard-tag{
  font-weight:700;
  letter-spacing:.08em;
  font-size:5.5px;
}
.wf-bcard-name{
  font-family:var(--body);
  font-size:7px;
  font-weight:700;
  color:var(--text);
  line-height:1.1;
}
.wf-bcard-meta{
  opacity:.75;
  font-size:5.5px;
}

/* ---- Tablet+ : show the tease line, slightly different layout ---- */
@media (min-width:560px){
  .workflow-trigger{
    grid-template-areas:
      "num name name icon"
      "tease tease tease icon"
      "chev chev chev icon";
    grid-template-columns:auto 1fr 1fr auto;
    grid-template-rows:auto auto auto;
    align-items:start;
    padding:22px 24px;
    min-height:140px;
  }
  .wf-icon{
    grid-area:icon;
    align-self:start;
    justify-self:end;
    height:auto;
  }
  .wf-name{font-size:26px;white-space:normal}
  .wf-tease{
    grid-area:tease;
    display:block;
    font:400 14px/1.4 var(--body);
    color:var(--text-2);
    margin-top:4px;
  }
  .wf-chev{
    grid-area:chev;
    align-self:end;
    justify-self:start;
    padding-left:0;
    padding-top:8px;
    font-size:24px;
  }
}

/* ---- Desktop : 2-column grid ---- */
@media (min-width:768px){
  .workflow-grid{
    grid-template-columns:1fr 1fr;
    gap:18px;
  }
  .workflows-head{margin-bottom:64px}
}

/* ---- Wide : 3-column grid ---- */
@media (min-width:1024px){
  .workflow-grid{grid-template-columns:repeat(3,1fr)}
  .workflow-trigger{min-height:160px}
  .wf-name{font-size:28px}
}

/* ============================================================
   WORKFLOW MODAL — centered, section-color background
   ============================================================ */
.wf-modal{
  --c:var(--orange);
  --c-text:#fff;
  position:fixed;
  inset:0;
  width:100vw;height:100vh;
  max-width:none;max-height:none;
  border:0;padding:0;margin:0;
  background:transparent;
  color:var(--c-text);
  overflow:hidden;
}
.wf-modal::backdrop{
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.wf-modal[open]{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
}

.wf-modal-card{
  position:relative;
  width:100%;
  max-width:520px;
  max-height:92vh;
  background:var(--c);
  color:var(--c-text);
  padding:40px 26px 28px;
  display:flex;flex-direction:column;
  gap:18px;
  overflow-y:auto;
  animation:wf-fade-in .35s var(--ease-out-expo);
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px));
  box-shadow:0 24px 80px rgba(0,0,0,.6);
}

@keyframes wf-fade-in{
  from{transform:scale(.96) translateY(12px);opacity:0}
  to{transform:scale(1) translateY(0);opacity:1}
}

/* Subtle bracket accents in contrast color */
.wf-modal-card .wf-bracket{
  width:18px;height:18px;
  border-width:2px;
  border-color:var(--c-text);
  opacity:.45;
}

/* Modal close button — contrast color over translucent dark */
.wf-close{
  position:absolute;
  top:10px;right:10px;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.16);
  color:var(--c-text);
  font:400 24px/1 var(--body);
  border-radius:50%;
  cursor:pointer;
  z-index:2;
  transition:background .15s ease,transform .15s ease;
}
.wf-close:hover{background:rgba(0,0,0,.32);transform:rotate(90deg)}

.wf-modal-num{
  font:500 12px/1 var(--mono);
  letter-spacing:.14em;
  color:var(--c-text);
  opacity:.7;
}
.wf-modal-title{
  font:700 clamp(32px,7vw,40px)/.95 var(--display);
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin:0;
  color:var(--c-text);
  text-wrap:balance;
}
.wf-modal-desc{
  font:400 16px/1.55 var(--body);
  color:var(--c-text);
  opacity:.85;
  margin:0;
}

.wf-modal-list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;
  gap:10px;
  border-top:1px solid color-mix(in srgb,var(--c-text) 28%,transparent);
  border-bottom:1px solid color-mix(in srgb,var(--c-text) 28%,transparent);
  padding:18px 0;
}
.wf-modal-list li{
  display:flex;align-items:center;gap:12px;
  font:600 13px/1 var(--mono);
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--c-text);
}
.wf-marker{
  display:block;
  width:10px;height:10px;
  background:var(--c-text);
  flex-shrink:0;
}

/* CTA reads as the inverse of the modal — contrast bg, color text */
.wf-modal-cta{
  align-self:stretch;
  margin-top:auto;
  background:var(--c-text);
  color:var(--c);
  box-shadow:0 8px 20px -8px rgba(0,0,0,.4);
}
.wf-modal-cta:hover{
  background:var(--c-text);
  color:var(--c);
  opacity:.92;
}

@media (min-width:768px){
  .wf-modal-card{
    padding:48px 36px 32px;
  }
}

/* Lock body scroll when modal is open */
body:has(.wf-modal[open]){
  overflow:hidden;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq{
  padding:var(--section-gap) var(--pad);
  background:var(--bg);
}
.faq-inner{
  max-width:880px;
  margin:0 auto;
  display:flex;flex-direction:column;
  gap:36px;
}
.faq-head{
  display:flex;flex-direction:column;
  align-items:flex-start;
  gap:12px;
}
.faq-title{
  font:700 clamp(36px,7vw,56px)/.95 var(--display);
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin:0;
}
.faq-list{
  display:flex;flex-direction:column;
  border-top:1px solid var(--border);
}
.faq-item{
  border-bottom:1px solid var(--border);
}
.faq-item summary{
  list-style:none;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 0;
  cursor:pointer;
  gap:24px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-q{
  font:600 17px/1.4 var(--body);
  color:var(--text);
  flex:1;
}
.faq-ic{
  flex-shrink:0;
  position:relative;
  width:14px;height:14px;
}
.faq-ic::before,
.faq-ic::after{
  content:"";
  position:absolute;
  inset:0;margin:auto;
  background:var(--orange);
}
.faq-ic::before{width:14px;height:2px}
.faq-ic::after{width:2px;height:14px;transition:transform .2s ease}
.faq-item[open] .faq-ic::after{transform:scaleY(0)}
.faq-a{
  padding:0 0 22px;
  max-width:64ch;
}
.faq-a p{
  margin:0;
  font:400 15px/1.6 var(--body);
  color:var(--text-2);
}

@media (min-width:768px){
  .faq-q{font-size:19px}
}

/* ============================================================
   FINAL CTA
   ============================================================ */
.finalcta{
  position:relative;
  background:
    radial-gradient(ellipse 80% 60% at 50% 30%,rgba(232,97,26,.08) 0%,transparent 70%),
    var(--bg);
  text-align:center;
  overflow:hidden;
}
.finalcta .hazard-band{margin-bottom:var(--section-gap)}

.finalcta-inner{
  max-width:760px;
  margin:0 auto;
  padding:0 var(--pad) var(--section-gap);
  display:flex;flex-direction:column;
  align-items:center;
  gap:24px;
}
.finalcta-icon{
  width:96px;height:96px;
  border-radius:22px;
  box-shadow:
    0 18px 44px rgba(232,97,26,.28),
    0 6px 16px rgba(0,0,0,.6),
    0 0 0 1px rgba(255,255,255,.06);
  margin-bottom:8px;
}
.finalcta-title{
  font:700 clamp(40px,9vw,80px)/.92 var(--display);
  text-transform:uppercase;
  letter-spacing:-.02em;
  margin:0;
  text-wrap:balance;
}
.finalcta-sub{
  font:400 17px/1.5 var(--body);
  color:var(--text-2);
  margin:0;
  max-width:46ch;
}
.finalcta-meta{
  font:500 11px/1 var(--mono);
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text-3);
  padding-top:8px;
}

.appstore-badge{
  display:inline-flex;flex-direction:column;
  align-items:flex-start;
  background:#000;
  border:1px solid var(--border-strong);
  padding:10px 18px;
  min-width:180px;
  transition:border-color .15s ease;
}
.appstore-badge:hover{border-color:var(--orange)}
.appstore-pre{
  font:400 10px/1 var(--body);
  color:var(--text-2);
  text-transform:uppercase;
  letter-spacing:.1em;
}
.appstore-name{
  font:600 18px/1.2 var(--body);
  color:var(--text);
  margin-top:4px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:#070707;
  border-top:1px solid var(--border);
  padding:36px var(--pad) calc(36px + env(safe-area-inset-bottom));
}
.footer-inner{
  max-width:var(--max);
  margin:0 auto;
  display:flex;flex-direction:column;
  align-items:center;
  gap:24px;
  text-align:center;
}
.footer-nav{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:18px 24px;
  font:500 12px/1 var(--mono);
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--text-2);
}
.footer-nav a:hover{color:var(--orange)}
.footer-meta{
  font-size:11px;
  letter-spacing:.12em;
  color:var(--text-3);
  text-transform:uppercase;
}

@media (min-width:768px){
  .footer-inner{
    flex-direction:row;
    justify-content:space-between;
    text-align:left;
  }
  .footer-nav{justify-content:flex-end}
}

/* ============================================================
   STICKY BOTTOM CTA
   ============================================================ */
.sticky-cta{
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:40;
  padding:0 12px env(safe-area-inset-bottom);
  transform:translateY(110%);
  transition:transform 300ms var(--ease-out-cubic);
  pointer-events:none;
}
.sticky-cta.is-visible{transform:translateY(0);pointer-events:auto}
.sticky-cta-inner{
  max-width:var(--max);
  margin:0 auto;
  background:var(--surface);
  border:1px solid var(--orange);
  border-bottom:0;
  padding:12px 14px calc(12px + max(0px,env(safe-area-inset-bottom)));
  display:flex;align-items:center;gap:12px;
  box-shadow:0 -10px 40px rgba(0,0,0,.6);
  position:relative;
}
.sticky-cta-inner::before{
  content:"";
  position:absolute;
  top:-1px;left:0;right:0;
  height:2px;
  background:repeating-linear-gradient(
    -45deg,
    var(--orange) 0 8px,
    #0A0A0A 8px 16px
  );
}
.sticky-cta-icon{
  width:36px;height:36px;
  border-radius:8px;
  flex-shrink:0;
  box-shadow:0 2px 6px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04);
}
.sticky-cta-copy{
  flex:1;
  display:flex;flex-direction:column;
  gap:2px;
  min-width:0;
}
.sticky-cta-headline{
  font:700 14px/1.1 var(--display);
  text-transform:uppercase;
  letter-spacing:.005em;
  color:var(--text);
}
.sticky-cta-meta{
  font-size:10px;
  letter-spacing:.12em;
  color:var(--text-3);
  text-transform:uppercase;
}
.sticky-cta-btn{
  padding:14px 18px;
  min-height:48px;
  font-size:13px;
}

@media (min-width:768px){
  .sticky-cta-inner{padding:14px 18px}
  .sticky-cta-headline{font-size:16px}
}
@media (min-width:1024px){
  .sticky-cta{display:none}
}

/* ============================================================
   SCROLL REVEALS
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo);
}
.reveal.in-view{opacity:1;transform:translateY(0)}

.reveal-stagger > *{
  opacity:0;
  transform:translateY(16px);
  transition:opacity .6s var(--ease-out-expo),transform .6s var(--ease-out-expo);
}
.reveal-stagger.in-view > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in-view > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in-view > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.in-view > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.in-view > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.in-view > *:nth-child(5){transition-delay:.33s}

/* ============================================================
   RESPONSIVE TOKENS
   ============================================================ */
@media (min-width:768px){
  :root{--pad:32px;--section-gap:120px}
  body{font-size:17px}
}
@media (min-width:1024px){
  :root{--pad:48px}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal,.reveal-stagger > *{opacity:1;transform:none}
  .hero-bg-radial{animation:none}
  .hazard-band{animation:none}
  .trust-track{animation:none}
}

/* ============================================================
   LEGAL PAGES (privacy, terms)
   ============================================================ */
.legal-page{
  padding:96px var(--pad) var(--section-gap);
  background:var(--bg);
  min-height:60vh;
}
.legal{
  max-width:760px;
  margin:0 auto;
}
.legal-head{
  display:flex;flex-direction:column;
  gap:14px;
  padding-bottom:32px;
  border-bottom:1px solid var(--border);
  margin-bottom:32px;
}
.legal-eyebrow{
  font:500 11px/1 var(--mono);
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--orange);
}
.legal-title{
  font:700 clamp(40px,8vw,64px)/.95 var(--display);
  text-transform:uppercase;
  letter-spacing:-.02em;
  margin:0;
}
.legal-meta{
  font:500 11px/1 var(--mono);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-3);
}
.legal-tldr{
  background:var(--card);
  border:1px solid var(--orange);
  padding:20px 22px;
  margin-bottom:48px;
  display:flex;flex-direction:column;
  gap:10px;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
}
.legal-tldr-tag{
  font:500 11px/1 var(--mono);
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--orange);
}
.legal-tldr p{
  margin:0;
  font:500 17px/1.5 var(--body);
  color:var(--text);
  text-wrap:balance;
}
.legal-section{
  display:flex;flex-direction:column;
  gap:14px;
  margin-bottom:48px;
  scroll-margin-top:96px;
}
.legal-num{
  font:500 11px/1 var(--mono);
  letter-spacing:.14em;
  color:var(--orange);
}
.legal-section-title{
  font:700 26px/1.1 var(--display);
  text-transform:uppercase;
  letter-spacing:-.005em;
  margin:0;
  color:var(--text);
}
.legal-section p{
  font:400 16px/1.65 var(--body);
  color:var(--text-2);
  margin:0;
}
.legal-section ul{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;flex-direction:column;
  gap:8px;
}
.legal-section ul li{
  display:flex;align-items:flex-start;gap:10px;
  font:400 16px/1.55 var(--body);
  color:var(--text-2);
}
.legal-section ul li::before{
  content:"";
  display:inline-block;
  width:6px;height:6px;
  background:var(--orange);
  margin-top:9px;
  flex-shrink:0;
}
.legal-section a{
  color:var(--orange);
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
  transition:color .15s ease;
}
.legal-section a:hover{color:#FF7530}
.legal-section strong{
  color:var(--text);
  font-weight:700;
}

@media (min-width:768px){
  .legal-page{padding-top:140px}
  .legal-section-title{font-size:32px}
}

/* ============================================================
   PRINT
   ============================================================ */
@media print{
  .nav,.sticky-cta{display:none !important}
  body{background:#fff;color:#000}
}
