/* ============================================================
   SteelToe Digital — Brand System (Production)
   Dark, industrial, condensed. Accent = trade blue #3098D3.
   ============================================================ */

/* ---- Design Tokens ---- */
:root{
  --accent:#3098D3; --accent-bright:#4FB2EC; --accent-ink:#06141E; --accent-soft:rgba(48,152,211,.14);
  --ink:#0C0F12;
  --surface-1:#14181D;
  --surface-2:#1B2027;
  --surface-3:#222831;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --text:#EEF2F6;
  --muted:#9CA7B2;
  --faint:#69737E;
  --font-display:"Saira Condensed",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;
  --maxw:1200px;
  --gutter:clamp(20px,5vw,40px);
  --section-y:clamp(64px,9vw,128px);
  --radius:6px;
  --shadow:0 24px 60px -20px rgba(0,0,0,.6);
}

/* ---- Base Reset ---- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--ink);
  color:var(--text);
  font-family:var(--font-body);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* ---- Typography ---- */
.display,h1,h2,h3{
  font-family:var(--font-display);
  font-weight:800;
  line-height:.94;
  letter-spacing:-.01em;
  text-transform:uppercase;
  margin:0;
}
h1{font-size:clamp(2.8rem,7vw,6rem)}
h2{font-size:clamp(2.1rem,4.6vw,3.6rem)}
h3{font-size:clamp(1.4rem,2.4vw,2rem);font-weight:700}
p{margin:0 0 1em;text-wrap:pretty}
.lead{font-size:clamp(1.05rem,1.6vw,1.35rem);color:var(--muted);line-height:1.55}
em,.ital{font-style:italic}
strong{color:var(--text);font-weight:700}

/* ---- Kicker / Eyebrow ---- */
.kicker{
  font-family:var(--font-mono);font-size:.78rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:12px;
}
.kicker::before{content:"";width:28px;height:2px;background:var(--accent);display:inline-block}
.kicker.center::after{content:"";width:28px;height:2px;background:var(--accent);display:inline-block}
.kicker.center{justify-content:center}

.accent{color:var(--accent)}
.muted{color:var(--muted)}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:1360px;margin:0 auto;padding-inline:var(--gutter)}
section{padding-block:var(--section-y)}
.section-head{max-width:640px;margin-bottom:clamp(36px,5vw,64px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .kicker{margin-bottom:20px}
.section-head p{margin-top:18px}
.surface{background:var(--surface-1)}
.divider{height:1px;background:var(--line);border:0;margin:0}

/* ---- Blueprint Grid Background ---- */
.grid-bg{position:relative}
.grid-bg::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,#000,transparent 75%);
  mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,#000,transparent 75%);
  opacity:.6;
}
.grid-bg>*{position:relative;z-index:1}

/* ---- Hazard Stripe ---- */
.hazard{
  background:repeating-linear-gradient(-45deg,var(--accent) 0 14px,transparent 14px 28px);
  height:6px;width:100%;opacity:.9;
}

/* ---- Buttons ---- */
.btn{
  --clip:10px;
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:700;font-size:1.05rem;
  text-transform:uppercase;letter-spacing:.04em;
  padding:15px 26px;border:0;cursor:pointer;
  background:var(--accent);color:var(--accent-ink);
  clip-path:polygon(0 0,100% 0,100% calc(100% - var(--clip)),calc(100% - var(--clip)) 100%,0 100%);
  transition:transform .15s ease,background .15s ease,box-shadow .15s ease;
  line-height:1;white-space:nowrap;
}
.btn:hover{background:var(--accent-bright);transform:translateY(-2px)}
.btn .arrow{transition:transform .15s ease}
.btn:hover .arrow{transform:translateX(4px)}
.btn-ghost{
  background:transparent;color:var(--text);
  box-shadow:inset 0 0 0 1.5px var(--line-2);
  clip-path:none;
}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--accent);color:var(--text);background:transparent}
.btn-sm{padding:11px 18px;font-size:.92rem}
.btn-block{display:flex;width:100%;justify-content:center}
.textlink{
  font-family:var(--font-mono);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);display:inline-flex;gap:8px;align-items:center;font-weight:500;
}
.textlink .arrow{transition:transform .15s ease}
.textlink:hover .arrow{transform:translateX(4px)}

/* Elementor button integration */
.btn-cut .elementor-button,
.btn-cut a.elementor-button{
  --clip:10px;
  clip-path:polygon(0 0,100% 0,100% calc(100% - var(--clip)),calc(100% - var(--clip)) 100%,0 100%);
  border-radius:0 !important;
  transition:transform .15s ease, background .15s ease;
}
.btn-cut .elementor-button:hover{transform:translateY(-2px)}

/* ---- Header / Nav ---- */
.topbar{
  background:#000;color:var(--muted);font-family:var(--font-mono);
  font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  border-bottom:1px solid var(--line);
}
.topbar .wrap-wide{display:flex;align-items:center;justify-content:space-between;height:38px;gap:20px}
.topbar a{color:var(--muted)}
.topbar a:hover{color:var(--text)}
.topbar .stars{color:var(--accent)}
.topbar .tb-right{display:flex;gap:26px;align-items:center}
.topbar .tb-right span{display:inline-flex;gap:8px;align-items:center;white-space:nowrap}
.topbar .wrap-wide>span:first-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar a{white-space:nowrap}

.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(12,15,18,.85);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav.scrolled{border-bottom-color:var(--line-2)}
.nav .wrap-wide{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.nav .logo img{height:34px;width:auto}
.nav-links{display:flex;gap:26px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{
  font-family:var(--font-display);font-weight:600;text-transform:uppercase;
  font-size:1.02rem;letter-spacing:.03em;color:var(--text);position:relative;padding:6px 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--accent);transition:width .2s ease;
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--accent)}
.nav-cta{display:flex;align-items:center;gap:18px}
.nav-phone{font-family:var(--font-display);font-weight:700;font-size:1.05rem;display:inline-flex;gap:8px;align-items:center;white-space:nowrap}
.nav-phone:hover{color:var(--accent)}
.burger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;flex-direction:column;gap:5px;justify-content:center;align-items:center}
.burger span{display:block;width:24px;height:2px;background:var(--text);transition:.2s}
.mobile-menu{display:none}

/* ---- Trust Badges ---- */
.badges{display:flex;flex-wrap:wrap;gap:14px;align-items:stretch}
.badge{
  display:flex;align-items:center;gap:12px;padding:12px 16px;
  background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius);
}
.badge .num{font-family:var(--font-display);font-weight:800;font-size:1.5rem;line-height:1;color:var(--accent)}
.badge .lbl{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);line-height:1.3}
.stars{color:var(--accent);letter-spacing:1px}

/* ---- Cards ---- */
.card{
  background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;transition:border-color .2s ease,transform .2s ease,background .2s ease;
}
.card:hover{border-color:var(--line-2);transform:translateY(-4px)}

/* ---- Numbered Token ---- */
.token{
  font-family:var(--font-mono);font-weight:700;font-size:.95rem;color:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;border:1.5px solid var(--accent);border-radius:4px;
  background:var(--accent-soft);
}

/* ---- Image Placeholders ---- */
.ph{
  position:relative;overflow:hidden;border-radius:var(--radius);
  background:
    repeating-linear-gradient(135deg,rgba(255,255,255,.025) 0 12px,transparent 12px 24px),
    var(--surface-2);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  min-height:200px;color:var(--faint);
}
.ph::after{
  content:attr(data-label);
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--faint);padding:8px 14px;border:1px dashed var(--line-2);border-radius:4px;
  background:rgba(0,0,0,.25);text-align:center;max-width:80%;
}
.ph .corner{position:absolute;width:14px;height:14px;border:2px solid var(--line-2)}
.ph .corner.tl{top:10px;left:10px;border-right:0;border-bottom:0}
.ph .corner.tr{top:10px;right:10px;border-left:0;border-bottom:0}
.ph .corner.bl{bottom:10px;left:10px;border-right:0;border-top:0}
.ph .corner.br{bottom:10px;right:10px;border-left:0;border-top:0}

/* ---- Stat Block ---- */
.stat .n{font-family:var(--font-display);font-weight:800;font-size:clamp(2.6rem,5vw,4rem);line-height:.9;color:var(--text)}
.stat .n .accent{color:var(--accent)}
.stat .l{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:10px}

/* ---- Comparison Table ---- */
.compare{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface-1)}
.compare-head{display:grid;grid-template-columns:1fr 1fr}
.compare-head>div{padding:18px 24px;font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:1.15rem}
.compare-head .them{color:var(--muted);background:var(--surface-2)}
.compare-head .us{color:var(--accent-ink);background:var(--accent)}
.compare-row{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line)}
.compare-row>div{padding:16px 24px;font-size:.98rem}
.compare-row .them{color:var(--muted);border-right:1px solid var(--line)}
.compare-row .us{color:var(--text);background:var(--accent-soft)}
.compare-row .us strong{color:var(--text)}

/* ---- Process Steps ---- */
.steps{display:grid;gap:0}
.step{display:grid;grid-template-columns:auto 1fr;gap:28px;padding:30px 0;border-top:1px solid var(--line);align-items:start}
.step:last-child{border-bottom:1px solid var(--line)}
.step .idx{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,4vw,3.4rem);line-height:.8;color:var(--accent);width:clamp(60px,8vw,110px)}
.step h3{margin-bottom:10px}
.step p{margin:0;color:var(--muted);max-width:60ch}

/* ---- Packages ---- */
.pkgs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.pkg{
  background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius);
  padding:32px;display:flex;flex-direction:column;gap:18px;position:relative;transition:.2s;
}
.pkg:hover{border-color:var(--line-2);transform:translateY(-4px)}
.pkg.featured{border-color:var(--accent);background:linear-gradient(180deg,var(--accent-soft),var(--surface-1) 160px)}
.pkg .pkg-tag{position:absolute;top:-12px;left:32px;background:var(--accent);color:var(--accent-ink);font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:3px;font-weight:700}
.pkg .pmeta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.pkg h3{font-size:1.9rem}
.pkg .pdesc{color:var(--muted);font-size:.95rem;margin:0}
.pkg ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.pkg li{display:grid;grid-template-columns:auto 1fr;gap:12px;font-size:.94rem;color:var(--text);align-items:start}
.pkg li::before{content:"";width:16px;height:16px;margin-top:4px;background:var(--accent);clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%)}
.pkg .btn{margin-top:auto}

/* ---- Check List (hero, packages) ---- */
.check-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.check-list li{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start}
.check-list li::before{content:"";width:16px;height:16px;margin-top:4px;background:var(--accent);clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%)}

/* ---- FAQ Accordion ---- */
.faq{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;background:none;border:0;cursor:pointer;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:26px 0;color:var(--text);font-family:var(--font-display);font-weight:700;
  text-transform:uppercase;font-size:clamp(1.1rem,1.8vw,1.45rem);letter-spacing:.01em;
}
.faq-q .pm{position:relative;width:22px;height:22px;flex:none}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--accent);transition:.2s}
.faq-q .pm::before{top:10px;left:0;width:22px;height:2px}
.faq-q .pm::after{top:0;left:10px;width:2px;height:22px}
.faq-item.open .pm::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a-inner{padding:0 0 26px;color:var(--muted);max-width:75ch}

/* ---- CTA Band ---- */
.cta-band{background:var(--surface-1);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.cta-band .hazard-edge{position:absolute;top:0;left:0;right:0}

/* ---- Footer ---- */
.footer{background:#000;border-top:1px solid var(--line);padding-block:64px 32px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.footer .logo img{height:40px;margin-bottom:20px}
.footer h4{font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:1.05rem;letter-spacing:.05em;margin:0 0 16px;color:var(--text)}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.footer a{color:var(--muted);font-size:.95rem}
.footer a:hover{color:var(--accent)}
.footer .contact-line{display:flex;gap:10px;color:var(--muted);font-size:.95rem;margin-bottom:11px}
.footer .contact-line .k{color:var(--accent);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;min-width:54px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:48px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);flex-wrap:wrap}
.socials{display:flex;gap:14px}
.socials a{width:36px;height:36px;border:1px solid var(--line);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.socials a:hover{border-color:var(--accent);color:var(--accent)}

/* ---- Page Hero (interior) ---- */
.page-hero{padding-block:clamp(60px,8vw,110px) clamp(40px,5vw,64px);border-bottom:1px solid var(--line)}
.page-hero .crumb{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:22px}
.page-hero .crumb .accent{color:var(--accent)}
.page-hero h1{max-width:16ch}
.page-hero p{max-width:60ch;margin-top:22px}

/* ---- Utilities ---- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gap-sm{gap:14px}
.center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:24px}.mt-l{margin-top:40px}
.flex{display:flex}.aic{align-items:center}.jcb{justify-content:space-between}.wrapf{flex-wrap:wrap}
.btn-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.tag-row{display:flex;flex-wrap:wrap;gap:10px}
.tag{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line-2);border-radius:3px;padding:8px 14px}
.tag.on{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}

/* ---- Carousel ---- */
.carousel{position:relative}
.car-viewport{overflow:hidden}
.car-track{display:flex;transition:transform .45s cubic-bezier(.4,.1,.2,1)}
.car-track>*{flex:0 0 100%;min-width:0}
.car-nav{display:flex;gap:10px}
.car-btn{
  width:50px;height:50px;border:1px solid var(--line-2);background:var(--surface-1);
  color:var(--text);cursor:pointer;border-radius:4px;font-size:1.2rem;
  display:flex;align-items:center;justify-content:center;transition:.18s;
}
.car-btn:hover{border-color:var(--accent);color:var(--accent)}
.car-dots{display:flex;gap:8px;align-items:center}
.car-dot{width:9px;height:9px;border-radius:50%;border:0;background:var(--line-2);cursor:pointer;padding:0;transition:.2s}
.car-dot.on{background:var(--accent);width:26px;border-radius:5px}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden;padding-block:clamp(48px,7vw,96px) clamp(56px,8vw,104px)}
.hero .eyebrow-bar{margin-bottom:26px}
.hero h1{margin-bottom:26px}
.hero h1 .ital{color:var(--accent);font-style:italic;display:inline-block}
.hero .lead{max-width:52ch;margin-bottom:30px}
.hero-points{list-style:none;margin:0 0 34px;padding:0;display:flex;flex-direction:column;gap:13px}
.hero-points li{display:grid;grid-template-columns:auto 1fr;gap:13px;align-items:start;font-size:1.02rem;color:var(--text)}
.hero-points li::before{content:"";width:18px;height:18px;margin-top:3px;background:var(--accent);clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%)}
.hero-media{position:relative}
.hero-media .ph{min-height:clamp(320px,46vw,540px);height:100%}
.hero-float{
  position:absolute;left:-22px;bottom:28px;background:var(--ink);border:1px solid var(--line-2);
  border-radius:var(--radius);padding:18px 22px;display:flex;gap:16px;align-items:center;box-shadow:var(--shadow);
}
.hero-float .n{font-family:var(--font-display);font-weight:800;font-size:2.4rem;line-height:.85;color:var(--accent)}
.hero-float .l{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);line-height:1.3;max-width:14ch}

/* Split hero (production direction) */
.hero-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
@media (max-width:860px){
  .hero-split{grid-template-columns:1fr}
  .hero-split .hero-media{margin-top:14px}
  .hero-float{left:12px;right:12px;bottom:12px}
}

/* ---- Serve Band ---- */
.serve-band{border-block:1px solid var(--line);background:var(--surface-1)}
.serve-band .wrap-wide{display:flex;flex-wrap:wrap;gap:18px 40px;align-items:center;justify-content:center;padding-block:30px}
.serve-band .item{font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:clamp(1.1rem,2vw,1.6rem);color:var(--faint);transition:.2s;letter-spacing:.01em}
.serve-band .item:hover{color:var(--accent)}
.serve-band .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.6}

/* ---- Service Rows ---- */
.svc-row{display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;padding:30px 0;border-top:1px solid var(--line);transition:.2s}
.svc-row:last-child{border-bottom:1px solid var(--line)}
.svc-row:hover{padding-inline:8px;background:var(--surface-1)}
.svc-row h3{margin-bottom:8px}
.svc-row p{margin:0;color:var(--muted);max-width:62ch}
.svc-row .num{font-family:var(--font-mono);color:var(--accent);font-weight:700;font-size:.95rem}

/* ---- Team ---- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.team-card .ph{aspect-ratio:4/5;min-height:0;margin-bottom:18px}
.team-card h3{font-size:1.4rem}
.team-card .role{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-top:6px}

/* ---- Speed-to-Lead Panel ---- */
.s2l{border:1px solid var(--accent);border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,var(--accent-soft),var(--surface-1) 62%)}
.s2l-grid{display:grid;grid-template-columns:1.05fr .95fr}
.s2l-vis{padding:clamp(28px,4vw,52px);border-left:1px solid var(--line);
  display:flex;flex-direction:column;justify-content:center;gap:18px;background:rgba(0,0,0,.18)}
.race-cap{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0}
.race .race-top{display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.race .race-top b{font-family:var(--font-display);font-weight:800;font-size:1.15rem}
.race .bar{height:14px;border-radius:7px;background:var(--surface-3);overflow:hidden;margin-top:8px}
.race .fill{height:100%;border-radius:7px;width:0;transition:width 1.1s cubic-bezier(.3,.8,.3,1)}
.race.us .fill{background:var(--accent);box-shadow:0 0 16px var(--accent-soft)}
.race.us .race-top b{color:var(--accent)}
.race.them .fill{background:repeating-linear-gradient(-45deg,var(--faint) 0 8px,transparent 8px 16px)}
.race.them .race-top b{color:var(--faint)}
.s2l.in .race.us .fill{width:8%}
.s2l.in .race.them .fill{width:100%}
.race-note{color:var(--muted);font-size:.9rem;margin:6px 0 0}
.s2l-flow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:6px;
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.s2l-flow .node{padding:8px 13px;border:1px solid var(--line-2);border-radius:4px;color:var(--text)}
.s2l-flow .node.ai{border-color:var(--accent);color:var(--accent)}
.s2l-flow .arr{color:var(--accent)}

/* ---- Pricing Matrix ---- */
.incl{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface-1)}
.incl-head{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;background:var(--surface-2)}
.incl-head>div{padding:18px 20px;font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:1rem;text-align:center}
.incl-head>div:first-child{text-align:left}
.incl-row{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;border-top:1px solid var(--line)}
.incl-row>div{padding:14px 20px;font-size:.95rem}
.incl-row>div:not(:first-child){text-align:center;font-family:var(--font-mono);font-size:.82rem}
.incl-row .yes{color:var(--accent)}
.incl-row .no{color:var(--faint)}

/* ---- Scroll Reveal ---- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   Blog + Conversion Components
   ============================================================ */

/* ---- Email Forms ---- */
.email-form{display:flex;gap:10px;flex-wrap:wrap}
.email-form input[type=email]{
  flex:1;min-width:200px;background:var(--surface-2);border:1px solid var(--line-2);
  border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:1rem;
  padding:14px 16px;outline:none;transition:.15s;
}
.email-form input[type=email]:focus{border-color:var(--accent);background:var(--surface-3)}
.email-form input.err{border-color:var(--accent);background:rgba(224,33,47,.06)}
.email-form .btn{flex:none}
.js-msg{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);min-height:1em;display:block;margin-top:8px;letter-spacing:.04em}
.email-ok{font-family:var(--font-display);font-weight:700;text-transform:uppercase;color:var(--accent);font-size:1.2rem;letter-spacing:.02em;padding:6px 0}
.email-fine{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;color:var(--faint);margin-top:12px}

/* ---- Blog Hero ---- */
.blog-hero{padding-block:clamp(56px,8vw,104px) clamp(32px,4vw,52px)}
.blog-hero .kicker{margin-bottom:22px}

/* ---- Category Chips ---- */
.cat-row{display:flex;flex-wrap:wrap;gap:10px;padding-block:24px;border-block:1px solid var(--line)}
.cat-chip{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);border:1px solid var(--line-2);border-radius:3px;padding:9px 16px;cursor:pointer;
  background:none;transition:.15s;
}
.cat-chip:hover{border-color:var(--accent);color:var(--text)}
.cat-chip.on{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}

/* ---- Featured Post ---- */
.feat-post{display:grid;grid-template-columns:1.15fr .85fr;gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface-1);transition:.2s}
.feat-post:hover{border-color:var(--line-2)}
.feat-post .ph{border:0;border-radius:0;min-height:360px}
.feat-post .fp-body{padding:clamp(28px,4vw,48px);display:flex;flex-direction:column;gap:16px;justify-content:center}
.feat-post h2{font-size:clamp(1.8rem,3.2vw,2.8rem)}
.feat-post .excerpt{color:var(--muted);font-size:1.05rem}
@media (max-width:820px){.feat-post{grid-template-columns:1fr}.feat-post .ph{min-height:240px}}

/* ---- Post Meta ---- */
.post-meta{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.post-meta .accent{color:var(--accent)}
.post-tag{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}

/* ---- Post Grid & Cards ---- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{display:flex;flex-direction:column;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.2s}
.post-card:hover{border-color:var(--line-2);transform:translateY(-4px)}
.post-card .ph{border:0;border-radius:0;min-height:190px}
.post-card .pc-body{padding:24px;display:flex;flex-direction:column;gap:12px;flex:1}
.post-card h3{font-size:1.35rem;line-height:1.02}
.post-card .excerpt{color:var(--muted);font-size:.95rem;margin:0;flex:1}
.post-card .post-meta{font-size:.66rem}

/* ---- Newsletter Band ---- */
.news-band{background:var(--surface-1);border-block:1px solid var(--line);position:relative;overflow:hidden}
.news-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
@media (max-width:820px){.news-inner{grid-template-columns:1fr}}
.news-inner h2{font-size:clamp(2rem,4vw,3.2rem)}

/* ---- Lead Magnet ---- */
.magnet{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,4vw,56px);align-items:center;
  border:1px solid var(--accent);border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(120deg,var(--accent-soft),var(--surface-1) 60%);padding:clamp(28px,4vw,52px)}
.magnet .cover{aspect-ratio:3/4;max-width:240px;width:100%}
.magnet .cover.ph{min-height:0}
@media (max-width:680px){.magnet{grid-template-columns:1fr;text-align:center}.magnet .cover{margin-inline:auto}.magnet .email-form{justify-content:center}}

/* ---- Single Post Layout ---- */
.progress-track{position:sticky;top:0;z-index:90;height:3px;background:transparent}
.progress-bar{height:3px;width:0;background:var(--accent);transition:width .1s linear}

.post-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:clamp(32px,5vw,72px);align-items:start}

/* ---- Article Typography ---- */
.article{max-width:none}
.article p,.article li{font-size:1.12rem;line-height:1.72;color:#D7DEE5}
.article>p:first-of-type{font-size:1.25rem;color:var(--text)}
.article h2{font-size:clamp(1.7rem,3vw,2.4rem);margin:48px 0 18px}
.article h3{font-size:clamp(1.3rem,2vw,1.7rem);margin:36px 0 14px;color:var(--text)}
.article ul{padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px;margin:22px 0}
.article ul li{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start}
.article ul li::before{content:"";width:16px;height:16px;margin-top:7px;background:var(--accent);clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%);flex:none}
.article blockquote{margin:34px 0;padding:8px 0 8px 28px;border-left:3px solid var(--accent);
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:clamp(1.5rem,2.6vw,2.1rem);line-height:1.04;color:var(--text)}
.article figure{margin:34px 0}
.article figure figcaption{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:10px}
.article .ph{min-height:300px}
.article a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* Elementor Post Content integration */
.post-content p,.post-content li{font-size:1.12rem;line-height:1.72;color:#D7DEE5}
.post-content>p:first-of-type{font-size:1.25rem;color:var(--text)}
.post-content h2{font-family:var(--font-display);font-weight:800;text-transform:uppercase;
  font-size:clamp(1.7rem,3vw,2.4rem);margin:48px 0 18px;line-height:1.02}
.post-content h3{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:clamp(1.3rem,2vw,1.7rem);margin:36px 0 14px;color:var(--text)}
.post-content blockquote{margin:34px 0;padding:8px 0 8px 28px;border-left:3px solid var(--accent);
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:clamp(1.5rem,2.6vw,2.1rem);line-height:1.04;color:var(--text)}
.post-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.post-content img,.post-content figure{margin:34px 0;border-radius:var(--radius)}
.post-content figcaption{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--faint);margin-top:10px}

/* ---- Inline Content Upgrade ---- */
.upgrade{border:1px dashed var(--accent);border-radius:var(--radius);background:var(--accent-soft);
  padding:28px;margin:40px 0;display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.upgrade .up-ic{font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--accent);line-height:1}
.upgrade .up-body{flex:1;min-width:240px}
.upgrade h4{font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:1.3rem;margin:0 0 6px;color:var(--text)}
.upgrade p{margin:0;color:var(--muted);font-size:.95rem}

/* ---- Sticky Sidebar ---- */
.post-side{position:sticky;top:88px;display:flex;flex-direction:column;gap:22px}
.side-card{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.side-card.accenty{border-color:var(--accent);background:linear-gradient(180deg,var(--accent-soft),var(--surface-1) 140px)}
.side-card h4{font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:1.25rem;margin:0 0 8px}
.side-card p{color:var(--muted);font-size:.92rem;margin:0 0 16px}
.side-card .email-form{flex-direction:column}
.side-card .email-form input[type=email]{min-width:0}
.popular{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.popular li{border-top:1px solid var(--line);padding:14px 0}
.popular li:first-child{border-top:0;padding-top:0}
.popular a{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start}
.popular .num{font-family:var(--font-display);font-weight:800;color:var(--accent);font-size:1.4rem;line-height:.9}
.popular .t{font-weight:600;font-size:.95rem;line-height:1.3;color:var(--text)}
.popular a:hover .t{color:var(--accent)}

/* ---- Author Box ---- */
.author{display:flex;gap:20px;align-items:center;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-1);padding:26px;margin-top:48px}
.author .ph{width:84px;height:84px;min-height:0;flex:none;border-radius:50%}
.author h4{font-family:var(--font-display);font-weight:700;text-transform:uppercase;margin:0;font-size:1.3rem}
.author .role{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:4px 0 8px}
.author p{margin:0;color:var(--muted);font-size:.92rem}

/* ---- Sticky Bottom Capture Bar ---- */
.sticky-bar{position:fixed;left:0;right:0;bottom:0;z-index:120;transform:translateY(110%);transition:transform .35s cubic-bezier(.3,.7,.4,1);
  background:rgba(12,15,18,.92);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--line-2)}
.sticky-bar.show{transform:none}
.sticky-bar .sb-inner{display:flex;align-items:center;gap:20px;padding:14px var(--gutter);max-width:1360px;margin:0 auto}
.sticky-bar .sb-copy{flex:1;min-width:0}
.sticky-bar .sb-copy b{font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:1.15rem;display:block;line-height:1.05}
.sticky-bar .sb-copy span{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;color:var(--muted)}
.sticky-bar .email-form{flex:none;width:min(420px,46vw)}
.sticky-bar .sb-x{background:none;border:0;color:var(--faint);font-size:1.3rem;cursor:pointer;padding:4px 8px;line-height:1}
.sticky-bar .sb-x:hover{color:var(--text)}

/* ---- Elementor Form Field Overrides ---- */
.elementor-field-group .elementor-field{
  background:var(--surface-2) !important;
  border:1px solid var(--line-2) !important;
  border-radius:var(--radius) !important;
  color:var(--text) !important;
  font-family:var(--font-body) !important;
  font-size:1rem !important;
  padding:14px 16px !important;
}
.elementor-field-group .elementor-field:focus{
  border-color:var(--accent) !important;
  background:var(--surface-3) !important;
}
.elementor-field-group label{
  font-family:var(--font-mono) !important;
  font-size:.72rem !important;
  letter-spacing:.1em !important;
  text-transform:uppercase !important;
  color:var(--muted) !important;
}
.elementor-field-group .elementor-field-required::after{
  color:var(--accent) !important;
}

/* ============================================================
   Responsive Breakpoints
   ============================================================ */
@media (max-width:1240px){
  .nav-phone{display:none}
  .nav-links{gap:18px}
  .nav-links a{font-size:.94rem}
}
@media (max-width:1080px){
  .nav-links,.nav-phone{display:none}
  .burger{display:flex}
  .topbar{display:none}
  .mobile-menu{
    display:block;position:fixed;inset:0;z-index:200;background:var(--ink);
    transform:translateX(100%);transition:transform .3s ease;padding:24px var(--gutter);overflow-y:auto;
  }
  .mobile-menu.open{transform:none}
  .mobile-menu .mm-head{display:flex;justify-content:space-between;align-items:center;height:50px;margin-bottom:20px}
  .mobile-menu .mm-head img{height:32px}
  .mobile-menu .mm-x{background:none;border:0;color:var(--text);font-size:1.6rem;cursor:pointer}
  .mobile-menu nav{display:flex;flex-direction:column;gap:4px}
  .mobile-menu nav a{font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:1.8rem;padding:12px 0;border-bottom:1px solid var(--line)}
  .mobile-menu .mm-foot{margin-top:30px;display:flex;flex-direction:column;gap:16px}
}
@media (max-width:1000px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .pkgs{grid-template-columns:1fr;max-width:520px;margin-inline:auto}
}
@media (max-width:980px){
  .post-layout{grid-template-columns:1fr}
  .post-side{order:2;position:static}
  .post-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:880px){
  .s2l-grid{grid-template-columns:1fr}
  .s2l-vis{border-left:0;border-top:1px solid var(--line)}
}
@media (max-width:860px){
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .compare-head>div,.compare-row>div{padding-inline:16px}
  .team-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .incl{overflow-x:auto}
  .incl-head,.incl-row{min-width:560px}
  .sticky-bar .sb-copy span{display:none}
  .sticky-bar .email-form{width:auto;flex:1}
  .sticky-bar .email-form input[type=email]{min-width:0}
  .sticky-bar .sb-inner{gap:12px;padding-block:10px}
  .feat-post{grid-template-columns:1fr}
  .feat-post .ph{min-height:240px}
}
@media (max-width:700px){
  .svc-row{grid-template-columns:auto 1fr;gap:18px}
  .svc-row .textlink{grid-column:2}
}
@media (max-width:620px){
  .post-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  body{font-size:16px}
  .grid-4{grid-template-columns:1fr 1fr}
  .step{grid-template-columns:1fr;gap:8px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .compare-head>div{font-size:.95rem}
}
@media (max-width:520px){
  .team-grid{grid-template-columns:1fr}
  .sticky-bar .sb-copy b{font-size:1rem}
}

/* ---- Reduced Motion ---- */
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto}
  .race .fill{transition:none}
}
