/* ════════════════════════════════════════════════════════════════════════
   FleetFixer marketing component library
   ────────────────────────────────────────────────────────────────────────
   Repeatable building blocks extracted from the home page (index.html) so
   every public-facing page renders with one design language: typography,
   spacing, colour and motion.

   Load order on a page is:
     marketing-tokens.css   (legacy + .sec layout primitives)
     mega-menu.css          (injected nav + footer chrome)
     platform-page.css      (pf-* product/feature blocks, optional)
     ff-tokens.css          (Pine & Citrus tokens, light + dark)  <-- wins :root
     marketing.css          (THIS FILE: shared sections + chrome)

   Brand: Pine & Citrus. Display type Hanken Grotesk on headings, Inter for
   body. All surfaces are tokenised (var(--panel), var(--stroke), ...) so the
   [data-theme="dark"] override in ff-tokens.css repaints the whole estate
   with no markup change.

   Page-specific bits (the home boat search, boat modal, exact hero image)
   stay inline on their page. Everything reusable lives here.
   ════════════════════════════════════════════════════════════════════════ */

/* Display face on every section heading */
.hero h1, .sec-title, .pcard h3, .spotlight h3, .cta-banner h2, .suite-banner h3,
.statband .metric-val, .step h3, .news-card h3, .plat-title, .tool-card h3,
.tm-metric .v, .band-inner h2, .tslide-q, .rewind-show h2, .contact-aside h2,
.mk-prose h2, .mk-prose h3,
.pf-hero h1, .pf-cta h2, .pf-split-prose h2, .pf-free h2{ font-family:var(--font-display); }

/* Page canvas + the faint sea-green backdrop wash showing through sections */
body{ background:var(--bg); background-image:var(--backdrop); background-attachment:fixed; }

/* ═══════════════════════════════ HERO ═══════════════════════════════ */
/* A page sets its image with style="--hero-img:url('/assets/x.jpg')" on the
   .hero element (and optionally --hero-img-mobile). No image -> dark wash. */
.hero{
  position:relative; overflow:hidden;
  min-height:100svh; display:flex; align-items:center;
  padding:96px 24px 56px;
  background-color:var(--hero-dark);
  background-image:
    linear-gradient(180deg, rgba(7,18,14,.46) 0%, rgba(7,18,14,.30) 42%, rgba(7,18,14,.64) 100%),
    var(--hero-img, none);
  background-size:cover; background-position:center; background-repeat:no-repeat;
}
/* Shorter hero variant for content pages that do not need a full viewport */
.hero.hero-compact{ min-height:auto; padding:150px 24px 96px; }
/* Screenshot mode caps the viewport hero so a full-page capture stays representative */
.ff-shot .hero{ min-height:680px; }

.hero::before{ content:""; position:absolute; top:-30%; left:-10%; width:60%; height:80%; pointer-events:none;
  background:radial-gradient(circle, rgba(46,155,121,.22) 0%, transparent 72%); filter:blur(80px); }
.hero::after{ content:""; position:absolute; bottom:-20%; right:-5%; width:50%; height:70%; pointer-events:none;
  background:radial-gradient(circle, rgba(111,208,168,.16) 0%, transparent 72%); filter:blur(80px); }
.hero-grid{ position:absolute; inset:0; z-index:1; pointer-events:none;
  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:64px 64px; mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%); }

.hero-inner{ position:relative; z-index:2; width:100%; max-width:860px; margin:0 auto; text-align:center; }
.hero-inner.left{ text-align:left; margin:0; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:600; letter-spacing:.6px;
  text-transform:uppercase; color:rgba(255,255,255,.6); background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12); padding:8px 18px; border-radius:99px; margin-bottom:28px; }
.hero-eyebrow-dot{ width:7px; height:7px; border-radius:50%; background:#22c55e; animation:pulse-dot 2s infinite; }
@keyframes pulse-dot{ 0%,100%{opacity:1} 50%{opacity:.3} }
.hero h1{ font-size:clamp(40px,6.4vw,76px); font-weight:900; line-height:1.02; letter-spacing:-.04em; color:#fff; margin-bottom:20px; }
.hero h1 .accent{ background:var(--brand-gradient-soft); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-subtitle{ font-size:clamp(17px,2vw,20px); line-height:1.7; color:rgba(255,255,255,.66); max-width:680px; margin:0 auto 40px; }
.hero-inner.left .hero-subtitle{ margin-left:0; }

/* Hero call-to-action buttons (light pill primary, glass ghost) */
.hero-ctas{ display:flex; justify-content:center; gap:12px; flex-wrap:wrap; margin-top:8px; }
.hero-inner.left .hero-ctas{ justify-content:flex-start; }
.hero-btn{ text-decoration:none; padding:14px 26px; border-radius:12px; font-weight:700; font-size:15px;
  display:inline-flex; align-items:center; gap:9px; transition:transform .15s var(--ease), box-shadow .2s var(--ease); }
.hero-btn-primary{ background:#fff; color:var(--pine-800); }
.hero-btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 40px rgba(0,0,0,.32); }
.hero-btn-ghost{ background:rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.25); }
.hero-btn-ghost:hover{ background:rgba(255,255,255,.16); transform:translateY(-2px); }

/* App-launcher chips under the hero */
.hero-apps{ display:flex; justify-content:center; gap:10px; flex-wrap:wrap; margin-top:36px; }
.hero-app{ display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:99px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); color:rgba(255,255,255,.82);
  font-size:13px; font-weight:600; text-decoration:none; transition:background .15s,border-color .15s,transform .15s; }
.hero-app:hover{ background:rgba(255,255,255,.12); border-color:rgba(63,182,128,.5); transform:translateY(-1px); }
.hero-app i{ color:var(--accent-light); }

/* Hero proof stats row */
.hero-proof{ display:flex; justify-content:center; gap:48px; margin-top:44px; flex-wrap:wrap; }
.hero-inner.left .hero-proof{ justify-content:flex-start; }
.proof-item{ display:flex; flex-direction:column; align-items:center; }
.hero-inner.left .proof-item{ align-items:flex-start; }
.proof-item strong{ font-size:28px; font-weight:800; color:#fff; line-height:1.2; letter-spacing:-.02em; }
.proof-item span{ font-size:12px; color:rgba(255,255,255,.4); margin-top:2px; font-weight:500; }

/* ═══════════════════════════ SECTION RHYTHM ═══════════════════════════ */
/* (Base .sec / .sec-header / .sec-title / .sec-label / .sec-sub come from
   marketing-tokens.css. These are home-page level overrides + helpers.) */
.sec-platforms{ padding:120px 24px; background:transparent; }
.sec-platforms-inner{ max-width:1200px; margin:0 auto; }
.sec-platforms .sec-header{ margin-bottom:40px; }

/* ════════════════════ ALL-ACCESS / SUITE BANNER ════════════════════ */
.suite-banner{ position:relative; overflow:hidden; max-width:1200px; margin:0 auto 22px; border-radius:24px;
  padding:36px 40px; background:var(--brand-gradient); color:#fff; display:flex; align-items:center;
  justify-content:space-between; gap:28px; flex-wrap:wrap; box-shadow:var(--shadow-lg); }
.suite-banner::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(700px 220px at 88% 0%,rgba(255,255,255,.16),transparent 60%); }
.suite-banner-text{ position:relative; z-index:1; max-width:660px; }
.suite-banner-eyebrow{ display:block; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1.4px; color:rgba(255,255,255,.72); margin-bottom:10px; }
.suite-banner h3{ font-size:clamp(22px,2.6vw,30px); font-weight:800; letter-spacing:-.02em; line-height:1.18; margin-bottom:8px; }
.suite-banner p{ font-size:15px; line-height:1.6; color:rgba(255,255,255,.85); }
.suite-banner-actions{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:flex-end; gap:8px; }
.suite-banner .sb-btn{ display:inline-flex; align-items:center; gap:8px; padding:13px 24px; border-radius:12px; font-weight:700; font-size:14.5px; text-decoration:none; transition:transform .15s,box-shadow .15s; }
.suite-banner .sb-btn:hover{ transform:translateY(-1px); }
.suite-banner .sb-primary{ background:#fff; color:var(--accent); box-shadow:0 10px 28px rgba(0,0,0,.18); }
.suite-banner-price{ font-size:13px; color:rgba(255,255,255,.72); }
.suite-banner-price strong{ color:#fff; font-size:15px; }

/* ═══════════════════════ PLATFORM CARDS (light) ═══════════════════════ */
.platforms-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.pcard{ background:var(--panel); border:1px solid var(--stroke); border-radius:22px; padding:32px 28px 28px;
  position:relative; overflow:hidden; display:flex; flex-direction:column; gap:14px; text-decoration:none;
  color:var(--text); transition:border-color .2s,transform .2s,box-shadow .2s; }
.pcard *{ text-decoration:none; }
.pcard:hover{ border-color:transparent; transform:translateY(-4px); box-shadow:0 24px 56px rgba(15,23,42,.1),0 0 0 1.5px var(--pcard-accent,var(--accent)); }
.pcard::after{ content:""; position:absolute; top:0; left:0; right:0; height:4px; background:var(--pcard-gradient,var(--brand-gradient)); opacity:0; transition:opacity .2s; }
.pcard:hover::after{ opacity:1; }
.pcard-badge{ position:absolute; top:20px; right:20px; font-size:10px; font-weight:800; letter-spacing:1px; color:#fff; background:var(--pcard-accent,var(--accent)); padding:4px 9px; border-radius:99px; }
.pcard-icon{ width:52px; height:52px; border-radius:15px; background:var(--pcard-gradient,var(--brand-gradient)); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:22px; box-shadow:0 8px 20px var(--pcard-shadow,rgba(15,77,58,.25)); }
.pcard h3{ font-size:21px; font-weight:800; letter-spacing:-.02em; color:var(--text); margin-top:4px; }
.pcard .pcard-pitch{ font-size:14.5px; color:var(--muted); line-height:1.6; }
.pcard ul{ list-style:none; display:flex; flex-direction:column; gap:10px; margin:4px 0 10px; padding:16px 0 0; border-top:1px solid var(--stroke); }
.pcard li{ font-size:14px; color:var(--text); display:flex; align-items:flex-start; gap:10px; line-height:1.5; font-weight:500; }
.pcard li i{ color:var(--pcard-accent,var(--accent)); font-size:11px; margin-top:6px; flex-shrink:0; }
.pcard-cta{ display:inline-flex; align-items:center; gap:8px; color:var(--pcard-accent,var(--accent)); font-weight:700; font-size:14px; margin-top:auto; padding-top:4px; }
.pcard-cta i{ transition:transform .18s; }
.pcard:hover .pcard-cta i{ transform:translateX(4px); }
.pcard-maint{ --pcard-gradient:linear-gradient(135deg,var(--pine-700),var(--pine-400)); --pcard-accent:var(--pine-700); --pcard-shadow:rgba(15,77,58,.28); }
.pcard-race{ --pcard-gradient:linear-gradient(135deg,var(--pine-800),var(--pine-500)); --pcard-accent:var(--pine-600); --pcard-shadow:rgba(10,58,43,.28); }
.pcard-book{ --pcard-gradient:linear-gradient(135deg,var(--pine-600),var(--sea-400)); --pcard-accent:var(--pine-600); --pcard-shadow:rgba(21,97,74,.24); }
.pcard-learn{ --pcard-gradient:linear-gradient(135deg,var(--sea-500),var(--sea-300)); --pcard-accent:var(--sea-600); --pcard-shadow:rgba(63,182,128,.24); }

/* ════════════════════ ALTERNATING FEATURE SPOTLIGHTS ════════════════════ */
/* A rounded sheet that can tuck between full-width image bands (negative
   margins). Drop the .tuck modifier when used as a standalone section. */
.spotlights{ position:relative; z-index:1; background:var(--bg); }
.spotlights.tuck{ border-radius:clamp(22px,3vw,36px); margin-top:calc(-1 * clamp(24px,4vw,44px)); margin-bottom:calc(-1 * clamp(24px,4vw,44px)); }

/* Layered-overlap helpers for the home page's stacked feel: a content section
   that sits directly ABOVE a full-bleed .band gets .tuck-bottom (rounds its
   bottom and pulls down over the band); one directly BELOW gets .tuck-top.
   Both carry an opaque page background so the rounded corners reveal the band. */
.tuck-top{ position:relative; z-index:1; background:var(--bg); border-radius:clamp(22px,3vw,36px) clamp(22px,3vw,36px) 0 0; margin-top:calc(-1 * clamp(24px,4vw,44px)); }
.tuck-bottom{ position:relative; z-index:1; background:var(--bg); border-radius:0 0 clamp(22px,3vw,36px) clamp(22px,3vw,36px); margin-bottom:calc(-1 * clamp(24px,4vw,44px)); }
.spotlight-inner{ max-width:1160px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; padding:80px 24px; }
.spotlight + .spotlight .spotlight-inner{ border-top:1px solid var(--stroke); }
.spotlight.reverse .spotlight-prose{ order:2; }
.spotlight-kicker{ display:inline-flex; align-items:center; gap:8px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1.2px; color:var(--accent); background:var(--accent-soft); padding:6px 14px; border-radius:99px; margin-bottom:16px; }
.spotlight h3{ font-size:clamp(26px,3.4vw,38px); font-weight:800; letter-spacing:-.025em; line-height:1.12; margin-bottom:14px; color:var(--text-strong); }
.spotlight-prose>p{ font-size:16px; color:var(--muted); line-height:1.7; margin-bottom:18px; max-width:31em; }
.spotlight ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
.spotlight li{ display:flex; gap:11px; font-size:15px; color:var(--text); font-weight:500; line-height:1.5; }
.spotlight li i{ color:var(--accent); font-size:13px; margin-top:5px; flex-shrink:0; }
.spotlight-art{ border-radius:20px; overflow:hidden; min-height:300px; display:flex; align-items:center; justify-content:center; background:var(--brand-gradient); color:#fff; box-shadow:var(--shadow-lg); position:relative; }
.spotlight-art>i{ font-size:84px; opacity:.92; position:relative; z-index:1; }
.spotlight-art::after{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(440px 240px at 28% 22%, rgba(111,208,168,.22), transparent 72%); }
.spotlight-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

/* ═══════════════════ FULL-BLEED PARALLAX IMAGE BAND ═══════════════════ */
/* Page sets the image with style="background-image:url(...)" on .band-bg.
   Add .band-2 to flip the gradient + right-align the copy. */
.band{ position:relative; overflow:hidden; isolation:isolate; min-height:clamp(360px,46vw,520px); display:flex; align-items:center; background:var(--surface-2); }
.band-bg{ position:absolute; left:0; right:0; top:-14%; height:128%; z-index:0; background-position:center; background-size:cover; background-repeat:no-repeat; will-change:transform; }
.band::after{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(90deg, rgba(7,18,14,.74) 0%, rgba(7,18,14,.40) 58%, rgba(7,18,14,.18) 100%); }
.band-inner{ position:relative; z-index:2; max-width:1160px; margin:0 auto; padding:clamp(40px,6vw,72px) clamp(24px,4vw,56px); width:100%; will-change:transform, opacity; }
.band-inner h2{ color:#fff; font-size:clamp(28px,4.4vw,52px); font-weight:800; letter-spacing:-.03em; line-height:1.06; max-width:15em; }
.band-inner p{ color:rgba(255,255,255,.84); font-size:clamp(15px,1.6vw,18px); margin-top:14px; max-width:34em; line-height:1.6; }
.band.band-2::after{ background:linear-gradient(90deg, rgba(7,18,14,.18) 0%, rgba(7,18,14,.40) 45%, rgba(7,18,14,.74) 100%); }
.band.band-2 .band-inner{ text-align:right; margin-left:auto; }
.band.band-2 .band-inner h2{ margin-left:auto; }
.band.band-2 .band-inner p{ margin-left:auto; }

/* End image: parallax, fades to black */
.endscape{ position:relative; z-index:0; overflow:hidden; isolation:isolate; min-height:clamp(440px,64vh,820px); background:#000; }
.endscape::after{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,.75) 82%, #000 100%); }

/* ══════════════════════════ FREE TOOLS GRID ══════════════════════════ */
.tools{ position:relative; z-index:1; background:var(--bg); padding:clamp(64px,8vw,104px) 24px; }
.tools.tuck{ border-radius:clamp(22px,3vw,36px) clamp(22px,3vw,36px) 0 0; margin-top:calc(-1 * clamp(24px,4vw,44px)); }
.tools-inner{ max-width:1160px; margin:0 auto; }
.tools-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:36px; }
.tool-card{ display:flex; flex-direction:column; gap:12px; padding:26px 24px 24px; border-radius:18px; background:var(--panel); border:1px solid var(--stroke); box-shadow:var(--shadow-xs); transition:transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease); }
.tool-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--stroke-strong); }
.tool-ic{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; font-size:19px; color:#fff; background:var(--brand-gradient); }
.tool-card h3{ font-size:18px; font-weight:800; color:var(--text-strong); }
.tool-card p{ font-size:14px; color:var(--muted); line-height:1.6; flex:1; }
.tool-tag{ font-size:10.5px; font-weight:800; letter-spacing:.4px; text-transform:uppercase; color:var(--accent); background:var(--accent-soft); padding:3px 10px; border-radius:99px; width:max-content; }
.tool-link{ font-size:13.5px; font-weight:700; color:var(--accent); display:inline-flex; align-items:center; gap:6px; margin-top:2px; text-decoration:none; }
.tool-link i{ transition:transform .18s; }
.tool-card:hover .tool-link i{ transform:translateX(3px); }

/* ══════════════════════ HOW IT WORKS (3 steps) ══════════════════════ */
.sec-how{ background:transparent; border-top:1px solid var(--stroke); }
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; position:relative; }
.steps::before{ content:""; position:absolute; top:28px; left:calc(16.66% + 28px); right:calc(16.66% + 28px); height:2px; background:var(--stroke); }
.step{ text-align:center; position:relative; }
.step-num{ width:56px; height:56px; border-radius:50%; background:var(--brand-gradient); color:#fff; display:flex; align-items:center; justify-content:center; font-size:22px; font-weight:800; margin:0 auto 20px; position:relative; z-index:2; }
.step h3{ font-size:18px; font-weight:700; margin-bottom:8px; color:var(--text-strong); }
.step p{ font-size:14px; color:var(--muted); line-height:1.65; max-width:280px; margin:0 auto; }

/* ═════════════════ TESTIMONIALS + METRICS (carousel) ═════════════════ */
.tm{ position:relative; z-index:1; background:var(--bg); padding:clamp(64px,8vw,104px) 24px; }
.tm.tuck{ border-radius:clamp(22px,3vw,36px) clamp(22px,3vw,36px) 0 0; margin-top:calc(-1 * clamp(24px,4vw,44px)); }
.tm-inner{ max-width:1160px; margin:0 auto; }
.tm-top{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:36px; }
.tm-metric{ position:relative; overflow:hidden; padding:28px 24px; border-radius:18px; color:#fff; background:var(--brand-gradient); }
.tm-metric .v{ font-size:clamp(30px,4vw,46px); font-weight:900; letter-spacing:-.02em; line-height:1; }
.tm-metric .l{ font-size:12.5px; color:rgba(255,255,255,.82); margin-top:8px; font-weight:600; }
.tm-metric::after{ content:""; position:absolute; right:-24px; top:-24px; width:130px; height:130px; border-radius:50%; background:radial-gradient(circle, rgba(111,208,168,.30), transparent 70%); }
.tm-quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.tm-card{ padding:26px 24px; border-radius:18px; background:var(--panel); border:1px solid var(--stroke); box-shadow:var(--shadow-xs); display:flex; flex-direction:column; gap:14px; }
.tm-stars{ color:var(--highlight-strong); font-size:13px; letter-spacing:3px; }
.tm-card .q{ font-size:15px; line-height:1.62; color:var(--text); flex:1; }
.tm-who{ display:flex; align-items:center; gap:12px; }
.tm-av{ width:40px; height:40px; border-radius:50%; background:var(--brand-gradient); color:#fff; display:grid; place-items:center; font-weight:800; font-size:14px; flex-shrink:0; }
.tm-who .n{ font-weight:800; font-size:13.5px; color:var(--text-strong); }
.tm-who .r{ font-size:12px; color:var(--muted); }

/* Near-full-width testimonial carousel with peeking slides */
.tcar{ position:relative; margin-top:8px; }
.tcar-vp{ display:flex; gap:22px; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; padding-block:6px;
  padding-inline:calc((100% - min(1280px, 92%)) / 2); scrollbar-width:none; -ms-overflow-style:none; }
.tcar-vp::-webkit-scrollbar{ display:none; }
.tslide{ position:relative; flex:0 0 min(1280px, 92%); scroll-snap-align:center; aspect-ratio:21 / 9; border-radius:24px; overflow:hidden; background:#0E1714; box-shadow:var(--shadow-lg); }
.tslide>img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.tslide::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(7,18,14,.88) 0%, rgba(7,18,14,.62) 36%, rgba(7,18,14,.12) 66%, rgba(7,18,14,0) 85%); }
.tslide-body{ position:relative; z-index:1; height:100%; display:flex; flex-direction:column; justify-content:center; gap:2px; max-width:600px; padding:clamp(28px,5vw,72px); }
.tslide-q{ color:#fff; font-size:clamp(22px,2.7vw,40px); font-weight:800; letter-spacing:-.02em; line-height:1.12; }
.tslide-n{ color:#fff; font-weight:800; font-size:15px; margin-top:18px; }
.tslide-r{ color:rgba(255,255,255,.72); font-size:13.5px; }
.tslide-cta{ margin-top:22px; display:inline-flex; align-items:center; gap:8px; background:#fff; color:var(--pine-800); font-weight:700; font-size:14px; padding:11px 22px; border-radius:99px; text-decoration:none; width:max-content; transition:background-color var(--dur-1) var(--ease), transform var(--dur-1) var(--ease); }
.tslide-cta:hover{ background:var(--sea-100); transform:translateY(-1px); }
.tcar-nav{ position:absolute; top:50%; transform:translateY(-50%); z-index:3; width:48px; height:48px; border-radius:50%; background:var(--panel); color:var(--text); border:1px solid var(--stroke); box-shadow:var(--shadow); cursor:pointer; display:grid; place-items:center; font-size:15px; transition:transform var(--dur-1) var(--ease), background-color var(--dur-1) var(--ease); }
.tcar-nav:hover{ background:var(--surface-2); transform:translateY(-50%) scale(1.06); }
.tcar-prev{ left:max(10px, 2vw); }
.tcar-next{ right:max(10px, 2vw); }
.tcar-dots{ display:flex; gap:8px; justify-content:center; margin-top:24px; }
.tcar-dot{ width:8px; height:8px; padding:0; border:none; border-radius:99px; background:var(--stroke-strong); cursor:pointer; transition:width var(--dur-1) var(--ease), background-color var(--dur-1) var(--ease); }
.tcar-dot.on{ width:24px; background:var(--accent); }

/* Simple static testimonial cards (no carousel) */
.testimonials-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.tcard{ padding:28px; background:var(--panel); border:1px solid var(--stroke); border-radius:18px; border-top:3px solid var(--accent); transition:all .2s; }
.tcard:hover{ box-shadow:0 8px 24px rgba(0,0,0,.04); transform:translateY(-2px); }
.tcard .quote{ font-size:14px; line-height:1.65; color:var(--text); margin-bottom:14px; font-style:italic; }
.tcard .author{ font-size:13px; font-weight:700; }
.tcard .role{ font-size:11px; color:var(--accent); font-weight:600; margin-top:2px; }

/* ════════════════════════ DARK STAT BAND ════════════════════════ */
.statband{ max-width:1100px; margin:0 auto 48px; border-radius:24px; background:var(--brand-gradient); color:#fff; padding:56px 32px; text-align:center; position:relative; overflow:hidden; }
.statband::after{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(700px 220px at 50% 0%, rgba(111,208,168,.18), transparent 62%); }
.statband-grid{ position:relative; z-index:1; display:flex; justify-content:center; gap:64px; flex-wrap:wrap; }
.statband .metric-val{ font-size:clamp(34px,5vw,52px); font-weight:900; letter-spacing:-.02em; line-height:1; color:#fff; }
.statband .metric-label{ font-size:13px; color:rgba(255,255,255,.62); font-weight:600; margin-top:8px; }

/* ═══════════════════════ NEWS REEL (horizontal) ═══════════════════════ */
.sec-news-reel{ position:relative; z-index:1; padding:80px 24px; background:transparent; border-top:1px solid var(--stroke); }
.sec-news-reel.tuck{ border-radius:0 0 clamp(22px,3vw,36px) clamp(22px,3vw,36px); margin-bottom:calc(-1 * clamp(24px,4vw,44px)); }
.news-reel-head{ max-width:1200px; margin:0 auto 28px; display:flex; justify-content:space-between; align-items:flex-end; gap:20px; flex-wrap:wrap; }
.news-reel-head .sec-title{ margin-bottom:4px; }
.news-reel-head .viewall{ text-decoration:none; color:var(--accent); font-weight:700; font-size:14px; display:inline-flex; align-items:center; gap:6px; white-space:nowrap; }
.news-reel-head .viewall:hover{ gap:10px; }
.news-reel-scroll{ max-width:1200px; margin:0 auto; display:grid; grid-auto-flow:column; grid-auto-columns:320px; gap:18px; overflow-x:auto; padding:4px 4px 24px; scroll-snap-type:x mandatory; scrollbar-width:thin; }
.news-card{ scroll-snap-align:start; background:var(--panel); border:1px solid var(--stroke); border-radius:14px; overflow:hidden; display:flex; flex-direction:column; text-decoration:none; color:inherit; transition:border-color .15s,transform .15s,box-shadow .15s; }
.news-card:hover{ border-color:var(--stroke-strong); transform:translateY(-2px); box-shadow:0 14px 32px rgba(15,23,42,.06); }
.news-card img{ width:100%; height:160px; object-fit:cover; display:block; }
.news-card-body{ padding:16px 18px 18px; display:flex; flex-direction:column; gap:6px; flex:1; }
.news-chip{ display:inline-block; width:max-content; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; color:var(--accent); background:var(--accent-soft); padding:3px 9px; border-radius:99px; }
.news-date{ font-size:12px; color:var(--muted); }
.news-card h3{ font-size:16px; font-weight:700; line-height:1.3; margin:2px 0 4px; }
.news-card p{ font-size:13px; color:var(--muted); line-height:1.55; margin-bottom:6px; flex:1; }
.news-card-arrow{ font-size:13px; color:var(--accent); font-weight:600; margin-top:auto; }

/* ═════════════════════ STANDARD CARD / BENTO GRID ═════════════════════ */
.bento{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; }
.bento-card{ background:var(--panel); border:1px solid var(--stroke); border-radius:var(--radius); padding:28px; transition:all .25s; position:relative; overflow:hidden; }
.bento-card:hover{ border-color:var(--stroke-strong); box-shadow:0 8px 32px rgba(0,0,0,.04); transform:translateY(-2px); }
.bento-card.wide{ grid-column:span 2; }
.bento-icon{ width:44px; height:44px; border-radius:12px; background:var(--brand-gradient); color:#fff; display:flex; align-items:center; justify-content:center; font-size:17px; margin-bottom:16px; }
.bento-card h3{ font-size:17px; font-weight:700; margin-bottom:6px; line-height:1.3; color:var(--text-strong); }
.bento-card p{ font-size:14px; color:var(--muted); line-height:1.6; }

/* ════════════════════════ FAQ ACCORDION ════════════════════════ */
.faq-list{ max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:10px; }
.faq-item{ background:var(--panel); border:1px solid var(--stroke); border-radius:12px; overflow:hidden; }
.faq-item summary{ padding:18px 22px; cursor:pointer; font-size:15px; font-weight:600; display:flex; justify-content:space-between; align-items:center; list-style:none; color:var(--text); }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"\f078"; font-family:"Font Awesome 6 Free"; font-weight:900; font-size:11px; color:var(--muted); transition:transform .2s; }
.faq-item[open] summary::after{ transform:rotate(180deg); }
.faq-item .faq-body{ padding:0 22px 20px; font-size:14px; color:var(--muted); line-height:1.7; }

/* ════════════════════════ CTA BANNER ════════════════════════ */
.cta-banner{ background:var(--brand-gradient); color:#fff; padding:100px 24px; text-align:center; position:relative; overflow:hidden; }
.cta-banner::after{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(720px 300px at 50% 0%,rgba(255,255,255,.12),transparent 60%); }
.cta-banner h2{ font-size:clamp(30px,4vw,46px); font-weight:800; letter-spacing:-.02em; margin-bottom:12px; position:relative; z-index:1; }
.cta-banner p{ font-size:16px; opacity:.9; margin-bottom:24px; max-width:560px; margin-left:auto; margin-right:auto; position:relative; z-index:1; }
.cta-btns{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; position:relative; z-index:1; }
.cta-btn{ text-decoration:none; padding:13px 24px; border-radius:10px; font-weight:700; font-size:15px; display:inline-flex; align-items:center; gap:8px; }
.cta-btn-primary{ background:#fff; color:var(--accent); }
.cta-btn-ghost{ background:rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.25); }

/* Bundle / all-access highlight block (light) */
.sec-home-bundle{ background:
    radial-gradient(1200px 300px at 10% 0%, var(--accent-soft), transparent 60%),
    radial-gradient(1200px 300px at 90% 100%, var(--accent-soft), transparent 60%),
    var(--panel);
  border-top:1px solid var(--stroke); border-bottom:1px solid var(--stroke); }
.sec-home-bundle .pf-pricing{ background:transparent; padding-top:72px; padding-bottom:72px; }

/* ═════════════════════ DARK PLATFORM GRID (hover image) ═════════════════════ */
.platgrid{ background:#000; padding:clamp(20px,4vw,48px) 24px clamp(64px,9vw,120px); }
.platgrid-inner{ max-width:1200px; margin:0 auto; }
.platgrid-head{ text-align:center; max-width:680px; margin:0 auto clamp(36px,5vw,56px); }
.platgrid-label{ font-size:12px; font-weight:800; letter-spacing:1.4px; text-transform:uppercase; color:var(--sea-300,#8fe3c0); }
.platgrid-title{ font-size:clamp(28px,4vw,46px); font-weight:800; letter-spacing:-.03em; color:#fff; margin-top:10px; }
.platgrid-sub{ font-size:clamp(15px,1.6vw,17px); color:rgba(255,255,255,.6); margin-top:12px; line-height:1.6; }
.platgrid-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.plat-card{ position:relative; overflow:hidden; isolation:isolate; min-height:clamp(280px,30vw,360px); border-radius:18px; background:#121212; border:1px solid rgba(255,255,255,.08); display:flex; flex-direction:column; justify-content:space-between; gap:24px; padding:26px; text-decoration:none; color:#fff; transition:border-color .3s ease, transform .3s ease, box-shadow .3s ease; }
.plat-card:hover{ border-color:rgba(255,255,255,.18); transform:translateY(-4px); box-shadow:0 24px 60px rgba(0,0,0,.5); }
.plat-img{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; opacity:0; transform:scale(1.08); transition:opacity .55s ease, transform 6s ease; }
.plat-card:hover .plat-img{ opacity:1; transform:scale(1); }
.plat-card::after{ content:""; position:absolute; inset:0; z-index:1; pointer-events:none; background:linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,0) 38%, rgba(0,0,0,.72) 100%); opacity:0; transition:opacity .55s ease; }
.plat-card:hover::after{ opacity:1; }
.plat-ic{ position:relative; z-index:2; align-self:flex-start; width:46px; height:46px; border-radius:12px; display:grid; place-items:center; font-size:19px; color:#fff; background:var(--brand-gradient, var(--accent,#0c6f7e)); box-shadow:0 6px 18px rgba(0,0,0,.35); }
.plat-body{ position:relative; z-index:2; display:flex; flex-direction:column; gap:7px; }
.plat-title{ font-size:22px; font-weight:800; letter-spacing:-.02em; }
.plat-desc{ font-size:14px; line-height:1.5; color:rgba(255,255,255,.62); transition:color .3s ease; }
.plat-card:hover .plat-desc{ color:rgba(255,255,255,.85); }
.plat-cap{ margin-top:6px; display:inline-flex; align-items:center; gap:8px; font-size:13.5px; font-weight:700; color:#fff; opacity:0; transform:translateY(6px); transition:opacity .35s ease, transform .35s ease; }
.plat-card:hover .plat-cap{ opacity:1; transform:none; }
.plat-cap i{ font-size:12px; transition:transform .2s ease; }
.plat-card:hover .plat-cap i{ transform:translateX(3px); }

/* ════════════════════════ CONTACT / FORM ════════════════════════ */
.contact{ padding:clamp(64px,8vw,104px) 24px; }
.contact-inner{ max-width:1100px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }
.contact-card{ background:var(--panel); border:1px solid var(--stroke); border-radius:20px; padding:28px; box-shadow:var(--shadow-sm); }
.contact-card label{ display:block; font-size:12.5px; font-weight:700; color:var(--muted); margin:14px 0 6px; }
.contact-card label:first-of-type{ margin-top:0; }
.contact-card input,.contact-card textarea,.contact-card select{ width:100%; padding:12px 14px; border-radius:12px; border:1px solid var(--stroke); background:var(--panel-2); color:var(--text); font:inherit; font-size:14px; }
.contact-card input:focus,.contact-card textarea:focus,.contact-card select:focus{ outline:none; border-color:var(--accent); box-shadow:var(--focus-ring); }
.contact-aside h2{ font-size:clamp(24px,3vw,34px); font-weight:800; color:var(--text-strong); letter-spacing:-.02em; margin-bottom:10px; }
.contact-aside>p{ font-size:15px; color:var(--muted); line-height:1.7; margin-bottom:18px; max-width:34em; }
.contact-meta{ display:flex; flex-direction:column; gap:12px; }
.contact-meta .row{ display:flex; gap:12px; align-items:flex-start; font-size:14.5px; color:var(--text); }
.contact-meta i{ color:var(--accent); margin-top:3px; width:18px; text-align:center; }
.contact-meta address{ font-style:normal; line-height:1.6; color:var(--text); }
.contact-meta a{ color:var(--accent); }

/* ════════════════════════ LONG-FORM PROSE ════════════════════════ */
/* For about / mission / editorial body copy on a tokenised surface. */
.mk-prose{ max-width:760px; margin:0 auto; }
.mk-prose h2{ font-size:clamp(24px,3vw,34px); font-weight:800; letter-spacing:-.02em; line-height:1.2; color:var(--text-strong); margin:0 0 14px; }
.mk-prose h3{ font-size:20px; font-weight:700; color:var(--text-strong); margin:28px 0 10px; }
.mk-prose p{ font-size:16px; color:var(--muted); line-height:1.75; margin-bottom:16px; }
.mk-prose ul{ list-style:none; display:flex; flex-direction:column; gap:10px; margin:16px 0; padding:0; }
.mk-prose ul li{ position:relative; padding-left:26px; font-size:15.5px; color:var(--text); line-height:1.6; }
.mk-prose ul li::before{ content:"\f00c"; font-family:"Font Awesome 6 Free"; font-weight:900; position:absolute; left:0; top:2px; color:var(--accent); font-size:12px; }
.mk-prose a{ color:var(--accent); }

/* Value / feature card grid (generic, tokenised) */
.mk-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.mk-card{ background:var(--panel); border:1px solid var(--stroke); border-radius:var(--radius-lg); padding:26px; box-shadow:var(--shadow-xs); transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease); }
.mk-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--stroke-strong); }
.mk-card .mk-card-ic{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; font-size:19px; color:#fff; background:var(--brand-gradient); margin-bottom:14px; }
.mk-card h3{ font-size:17px; font-weight:700; color:var(--text-strong); margin-bottom:6px; }
.mk-card p{ font-size:14px; color:var(--muted); line-height:1.6; }

/* ════════════════════════ NAV: glass over a dark hero ════════════════════════
   Transparent over the hero, then a frosted floating pill once scrolled, then a
   full solid bar while a mega-dropdown is open. Pages add the .scrolled /
   .ff-mega-active classes through mega-menu.js + a tiny scroll listener (see
   marketing.js). */
.ff-nav{ position:fixed; left:0; right:0; top:0; background:transparent; border-bottom:1px solid transparent;
  -webkit-backdrop-filter:none; backdrop-filter:none; box-shadow:none;
  transition:background-color .35s ease, backdrop-filter .35s ease, border-color .35s ease, box-shadow .35s ease, max-width .35s ease, margin .35s ease, border-radius .35s ease; }
.ff-nav .ff-nav-link, .ff-nav .ff-nav-trigger{ color:rgba(255,255,255,.92); }
.ff-nav .ff-nav-link:hover, .ff-nav .ff-nav-trigger:hover{ color:#fff; background:rgba(255,255,255,.14); }
.ff-nav .ff-nav-login{ color:#fff; opacity:.9; }
.ff-nav .ff-nav-burger{ color:#fff; }
.ff-nav .ff-nav-logo{ transition:filter .3s ease; }
.ff-nav.scrolled .ff-nav-logo, .ff-nav.ff-mega-active .ff-nav-logo{ filter:invert(1); }
[data-theme="dark"] .ff-nav.scrolled .ff-nav-logo, [data-theme="dark"] .ff-nav.ff-mega-active .ff-nav-logo{ filter:none; }

.ff-nav.scrolled{ margin:12px auto 0; max-width:1180px; background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:blur(18px) saturate(180%); backdrop-filter:blur(18px) saturate(180%);
  border:1px solid rgba(255,255,255,.55); border-radius:18px; box-shadow:0 10px 34px rgba(7,18,14,.14); }
.ff-nav.scrolled .ff-nav-link, .ff-nav.scrolled .ff-nav-trigger{ color:var(--muted); }
.ff-nav.scrolled .ff-nav-link:hover, .ff-nav.scrolled .ff-nav-trigger:hover{ color:var(--text); background:rgba(15,23,42,.05); }
.ff-nav.scrolled .ff-nav-login{ color:var(--text); opacity:.7; }
.ff-nav.scrolled .ff-nav-burger{ color:var(--text); }
[data-theme="dark"] .ff-nav.scrolled{ background:rgba(16,23,20,.62); border-color:rgba(255,255,255,.10); box-shadow:0 10px 34px rgba(0,0,0,.42); }
[data-theme="dark"] .ff-nav.scrolled .ff-nav-link, [data-theme="dark"] .ff-nav.scrolled .ff-nav-trigger{ color:var(--muted); }
[data-theme="dark"] .ff-nav.scrolled .ff-nav-login, [data-theme="dark"] .ff-nav.scrolled .ff-nav-burger{ color:var(--text); }

.ff-nav.ff-mega-active{ margin:0; max-width:none; top:0; border-radius:0; background:rgba(255,255,255,.94);
  -webkit-backdrop-filter:blur(18px) saturate(180%); backdrop-filter:blur(18px) saturate(180%);
  border:1px solid transparent; border-bottom:1px solid var(--stroke); box-shadow:none; }
.ff-nav.ff-mega-active .ff-nav-link, .ff-nav.ff-mega-active .ff-nav-trigger{ color:var(--muted); }
.ff-nav.ff-mega-active .ff-nav-link:hover, .ff-nav.ff-mega-active .ff-nav-trigger:hover{ color:var(--text); background:rgba(15,23,42,.05); }
.ff-nav.ff-mega-active .ff-nav-login{ color:var(--text); opacity:.7; }
.ff-nav.ff-mega-active .ff-nav-burger{ color:var(--text); }
[data-theme="dark"] .ff-nav.ff-mega-active{ background:rgba(16,23,20,.94); border-bottom-color:rgba(255,255,255,.10); }
[data-theme="dark"] .ff-nav.ff-mega-active .ff-nav-link, [data-theme="dark"] .ff-nav.ff-mega-active .ff-nav-trigger{ color:var(--muted); }
[data-theme="dark"] .ff-nav.ff-mega-active .ff-nav-login, [data-theme="dark"] .ff-nav.ff-mega-active .ff-nav-burger{ color:var(--text); }

/* Theme toggle (floating) */
.ff-theme-toggle{ display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:999px;
  border:1px solid var(--stroke); background:var(--panel); color:var(--text); cursor:pointer;
  transition:background-color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease), transform var(--dur-1) var(--ease); }
.ff-theme-toggle:hover{ background:var(--surface-2); border-color:var(--stroke-strong); transform:translateY(-1px); }
.ff-theme-toggle .ff-ico-sun{ display:none; } .ff-theme-toggle .ff-ico-moon{ display:inline; }
[data-theme="dark"] .ff-theme-toggle .ff-ico-sun{ display:inline; } [data-theme="dark"] .ff-theme-toggle .ff-ico-moon{ display:none; }
.ff-theme-toggle.ff-floating{ position:fixed; right:18px; bottom:18px; z-index:120; box-shadow:var(--shadow); }

/* ════════════════════════ FOOTER theming (on-brand, near-black) ════════════════════════ */
.ff-footer{ background:#000; color:#B7C7BD; border-top:1px solid rgba(255,255,255,.07); }
.ff-footer a{ color:#9DB0A6; transition:color var(--dur-1) var(--ease); }
.ff-footer a:hover{ color:#fff; }
.ff-footer h4{ color:#fff; }
.ff-footer .ff-footer-logo{ height:30px; opacity:.95; }

/* ════════════════════════ RESPONSIVE ════════════════════════ */
@media(max-width:1024px){
  .platforms-grid,.bento,.testimonials-grid{ grid-template-columns:1fr 1fr; }
  .bento-card.wide{ grid-column:span 2; }
}
@media(max-width:900px){
  .spotlight-inner{ grid-template-columns:1fr; gap:30px; padding:56px 20px; }
  .spotlight.reverse .spotlight-prose{ order:0; }
  .spotlight-art{ min-height:220px; }
  .statband-grid{ gap:36px; }
  .suite-banner{ padding:28px 26px; }
  .suite-banner-actions{ align-items:flex-start; }
  .contact-inner{ grid-template-columns:1fr; }
  .tools-grid,.tm-top,.tm-quotes,.mk-cards{ grid-template-columns:1fr; }
  .tslide{ aspect-ratio:3 / 4; }
  .tslide::after{ background:linear-gradient(180deg, rgba(7,18,14,.50) 0%, rgba(7,18,14,.20) 32%, rgba(7,18,14,.86) 100%); }
  .tslide-body{ justify-content:flex-end; max-width:none; }
  .tslide-q{ font-size:clamp(21px,5.6vw,30px); }
  .tcar-nav{ display:none; }
  .platgrid-grid{ grid-template-columns:1fr 1fr; }
}
@media(max-width:768px){
  .hero{ padding:120px 20px 56px; }
  .hero h1{ font-size:clamp(30px,7.4vw,48px); letter-spacing:-.03em; }
  .hero-inner{ overflow-wrap:break-word; }
  .hero-proof{ gap:28px; }
  .proof-item strong{ font-size:22px; }
  .platforms-grid,.bento,.testimonials-grid{ grid-template-columns:1fr; }
  .bento-card.wide{ grid-column:span 1; }
  .steps{ grid-template-columns:1fr; gap:32px; }
  .steps::before{ display:none; }
  .news-reel-scroll{ grid-auto-columns:85%; }
}
@media(max-width:560px){
  .platgrid-grid{ grid-template-columns:1fr; }
  .hero-proof{ flex-wrap:wrap; gap:20px; }
}
