/* ============================================================
   Cross Trade Shipping — design tokens
   (HelveticaNowDisplay + sky-blue #19A4B1 accent)
   ============================================================ */

/* ---------- Fonts (local HelveticaNowDisplay .woff) ---------- */
@font-face{
  font-family:'HelveticaNowDisplay';
  src:url('assets/fonts/HelveticaNowDisplay-Medium.woff') format('woff');
  font-weight:400;font-display:swap;
}
@font-face{
  font-family:'HelveticaNowDisplay';
  src:url('assets/fonts/HelveticaNowDisplay-Medium.woff') format('woff');
  font-weight:500;font-display:swap;
}
@font-face{
  font-family:'HelveticaNowDisplay';
  src:url('assets/fonts/HelveticaNowDisplay-Bold.woff') format('woff');
  font-weight:700;font-display:swap;
}
@font-face{
  font-family:'HelveticaNowDisplay';
  src:url('assets/fonts/HelveticaNowDisplay-Black.woff') format('woff');
  font-weight:900;font-display:swap;
}

:root{
  /* --- Surfaces (tinted toward navy, never pure white/black) --- */
  --bg:#FAFBFC;
  --bg-soft:#EEF3F5;
  --bg-tint:#F4F8F9;
  --navy:#0B1F33;
  --navy-2:#081726;

  /* --- Ink --- */
  --ink:#0C1E32;
  --ink-soft:#3F5772;
  --muted:#6F84A0;
  --on-dark:#EAF1F5;
  --on-dark-soft:#9DB2C6;

  /* --- Accent (brand sky blue) --- */
  --blue:#19A4B1;
  --blue-bright:#3FC3D0;
  --blue-deep:#0E7C87;
  --gold:#C9963F;
  --gold-bright:#E0B25A;

  /* Legacy aliases mapped to blue so existing rules keep working */
  --orange:var(--blue);
  --orange-bright:var(--blue-bright);
  --orange-deep:var(--blue-deep);
  --teal:var(--blue);
  --teal-bright:var(--blue-bright);
  --teal-deep:var(--blue-deep);

  /* --- Borders / elevation --- */
  --line:rgba(11,31,51,.10);
  --line-strong:rgba(11,31,51,.16);
  --sh-sm:0 1px 2px rgba(11,31,51,.06), 0 2px 8px rgba(11,31,51,.05);
  --sh-md:0 8px 24px rgba(11,31,51,.10);
  --sh-lg:0 24px 60px rgba(11,31,51,.16);

  /* --- Type scale (1.25 ratio, fluid) --- */
  --t-xs:.78rem; --t-sm:.9rem; --t-base:1.0625rem; --t-md:1.25rem;
  --t-lg:clamp(1.4rem,2.4vw,1.75rem);
  --t-xl:clamp(1.9rem,4vw,2.9rem);
  --t-2xl:clamp(2.6rem,6.2vw,4.6rem);
  --t-hero:clamp(3rem,9vw,8rem);

  /* --- Spacing scale (8px) --- */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px;
  --s7:48px; --s8:64px; --s9:96px; --s10:128px;
  --section:clamp(72px,10vw,168px);

  /* --- Layout --- */
  --maxw:clamp(1120px,90vw,1640px);
  --gutter:clamp(20px,5vw,72px);
  --measure:62ch;
  --radius:18px;
  --radius-sm:12px;

  /* --- Motion --- */
  --eo:cubic-bezier(.16,1,.3,1);
  --eio:cubic-bezier(.4,0,.2,1);
  --wipe:cubic-bezier(.75,0,.125,1);
  --fast:180ms;
  --dur-default:300ms;

  /* --- Type families (single sans) --- */
  --serif:"HelveticaNowDisplay",system-ui,-apple-system,sans-serif;
  --sans:"HelveticaNowDisplay",system-ui,-apple-system,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans); background:var(--bg); color:var(--ink);
  font-size:var(--t-base); line-height:1.5; font-weight:400;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
@media(min-width:2200px){ body{font-size:1.2rem} :root{--maxw:1640px} }
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.kicker{font-size:var(--t-sm);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-deep);display:flex;align-items:center;gap:14px}
.kicker::before{content:"";width:34px;height:1.5px;background:var(--blue)}
.kicker--light{color:var(--blue-bright)}
.kicker--light::before{background:var(--blue-bright)}
em{font-style:italic;color:var(--blue-deep)}

/* ---------- Image utilities ---------- */
.img-wrap{position:relative}
.img-wrap::after{content:"";width:100%;height:0;padding-bottom:var(--aspect);display:block}
.img-height{width:auto;height:100%}
.img-fill{height:100%;width:100%;object-fit:cover}
.img-fit{height:100%;width:100%;object-fit:contain}
.img-abs{position:absolute;top:0;left:0;right:0;bottom:0}

/* ---------- Buttons (two-layer wipe hover) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--sans);font-weight:500;font-size:var(--t-sm);letter-spacing:.01em;
  padding:14px 26px;border-radius:999px;cursor:pointer;
  border:1.5px solid transparent;min-height:48px;
  position:relative;overflow:hidden;z-index:1;-webkit-backface-visibility:hidden;
  background:var(--blue);color:#fff;box-shadow:var(--sh-sm);
  transition:color var(--dur-default) ease,border-color var(--fast) var(--eo),transform var(--fast) var(--eo),box-shadow var(--fast) var(--eo);
}
.btn::before,.btn::after{
  content:"";position:absolute;height:100%;width:100%;top:0;left:-100%;z-index:-1;
  transition:transform .3s var(--wipe);
}
.btn::before{background:var(--blue-bright)}
.btn::after{background:var(--blue)}
.btn:hover::before,.btn:hover::after{transform:translate3d(100%,0,0)}
.btn:hover::after{transition-delay:.175s}
.btn:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn:active{transform:translateY(0)}

.btn--solid{background:var(--blue);color:#fff;box-shadow:var(--sh-sm)}

.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost::before{background:rgba(255,255,255,.12)}
.btn--ghost::after{background:rgba(255,255,255,.22)}
.btn--ghost:hover{border-color:#fff;color:#fff;transform:translateY(-2px)}
.btn--pill{background:transparent;border-color:var(--line-strong);color:var(--ink)}
.btn--pill::before{background:var(--bg-soft)}
.btn--pill::after{background:var(--line-strong)}
.btn--pill:hover{border-color:var(--blue);color:var(--ink)}
.btn--lg{font-size:var(--t-md);padding:18px 36px}
.btn:focus-visible{outline:3px solid var(--blue-bright);outline-offset:3px}
a:focus-visible{outline:3px solid var(--blue-bright);outline-offset:3px;border-radius:4px}

/* ---------- Loader ---------- */
.loader{position:fixed;inset:0;z-index:9999;background:var(--navy);display:grid;place-items:center}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:22px}
.loader__mark{width:64px;opacity:0}
.loader__count{font-family:var(--serif);font-weight:500;font-size:var(--t-xl);color:var(--on-dark);display:flex;gap:2px}
.loader.done{pointer-events:none}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;padding:18px 0;transition:background var(--fast) var(--eo),box-shadow var(--fast) var(--eo),padding var(--fast) var(--eo)}
.nav__row{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav__logo{height:38px;width:auto;filter:brightness(0) invert(1);transition:filter var(--fast) var(--eo)}
.nav__links{display:flex;gap:34px}
.nav__links a{font-size:var(--t-sm);font-weight:500;color:rgba(255,255,255,.92);position:relative;padding:4px 0;transition:color var(--fast) var(--eo)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--blue-bright);transition:width var(--fast) var(--eo)}
.nav__links a:hover::after{width:100%}
.nav__cta{color:#fff;border-color:rgba(255,255,255,.45)}
.nav__cta:hover{border-color:#fff}
.nav.scrolled{background:rgba(250,251,252,.92);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding:12px 0}
.nav.scrolled .nav__logo{filter:none}
.nav.scrolled .nav__links a{color:var(--ink-soft)}
.nav.scrolled .nav__links a:hover{color:var(--blue-deep)}
.nav.scrolled .nav__cta{color:var(--ink);border-color:var(--line-strong)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center}
.nav__burger span{width:24px;height:2px;background:#fff;transition:transform var(--fast) var(--eo),opacity var(--fast)}
.nav.scrolled .nav__burger span{background:var(--ink)}

/* ---------- Mobile menu ---------- */
.menu{position:fixed;inset:0;z-index:850;background:var(--navy);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;opacity:0;pointer-events:none;transition:opacity 300ms var(--eo)}
.menu.open{opacity:1;pointer-events:auto}
.menu a{font-family:var(--serif);font-weight:500;font-size:var(--t-xl);color:var(--on-dark)}
.menu .btn{font-family:var(--sans);font-size:var(--t-base);color:#fff;border-color:rgba(255,255,255,.4)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;display:flex;align-items:center;z-index:1}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__video{width:100%;height:100%;object-fit:cover}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,23,38,.72) 0%,rgba(8,23,38,.42) 45%,rgba(8,23,38,.18) 100%)}
.hero__content{position:relative;z-index:2;width:100%}
.hero__kicker{color:var(--on-dark);font-size:var(--t-sm);font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--s5)}
.hero__title{font-family:var(--serif);font-weight:400;color:#fff;font-size:var(--t-hero);line-height:.95;letter-spacing:-.01em}
.hline{display:block;overflow:hidden}
.hero__title [data-hline]{display:block}
.hero__ship{position:absolute;left:50%;top:74%;width:min(7vw,96px);z-index:1;transform:translate(-50%,0);filter:drop-shadow(0 16px 36px rgba(0,0,0,.5));pointer-events:none;will-change:transform}
.hero__desc{position:absolute;right:var(--gutter);bottom:96px;z-index:3;max-width:25ch;color:var(--on-dark);font-size:var(--t-md);line-height:1.45;text-align:right;text-shadow:0 2px 16px rgba(8,23,38,.55)}
.hero__desc .accent{color:var(--blue-bright);font-weight:500}
.hero__backer{position:absolute;left:var(--gutter);bottom:96px;z-index:2;display:flex;flex-direction:column;gap:12px}
.hero__backer-label{font-size:var(--t-xs);letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.62)}
.hero__backer-row{display:flex;align-items:center;gap:14px;font-size:var(--t-sm);font-weight:600;letter-spacing:.06em;color:#fff}
.hero__backer-row i{width:5px;height:5px;border-radius:50%;background:var(--blue-bright)}
.hero__scroll{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.62);font-size:var(--t-xs);letter-spacing:.16em;text-transform:uppercase}

.shift{position:relative;z-index:2;background:var(--bg);box-shadow:0 -40px 80px rgba(8,23,38,.18)}

/* ---------- Intro ---------- */
.intro{padding:var(--section) 0}
.intro__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:var(--s7) var(--s9);align-items:start}
.intro .kicker{grid-column:1/-1}
.intro__head{font-family:var(--serif);font-weight:400;font-size:var(--t-2xl);line-height:1.0;letter-spacing:-.02em}
.intro__body p{color:var(--ink-soft);font-size:var(--t-md);max-width:var(--measure)}
.intro__body p+p{margin-top:var(--s5)}

/* ---------- Statement ---------- */
.statement{position:relative;background:var(--navy);color:#fff;min-height:108vh;display:grid;place-items:center;overflow:hidden;isolation:isolate}
.statement::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:30px 30px;opacity:.5;z-index:-1}
.statement__ship{position:absolute;width:min(40vw,560px);right:6%;bottom:2%;transform:rotate(20deg);z-index:0;filter:drop-shadow(0 30px 60px rgba(0,0,0,.5))}
.statement__type{position:relative;z-index:1;font-family:var(--serif);font-weight:400;font-size:clamp(3rem,11vw,9.5rem);line-height:.9;letter-spacing:-.02em;text-align:center}
.statement__row{display:block}
.statement__row--accent{background:linear-gradient(100deg,var(--blue-bright),var(--gold-bright));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Trust marquee ---------- */
.trust{padding:var(--s9) 0 var(--s8);text-align:center;overflow:hidden}
.trust__label{font-size:var(--t-sm);font-weight:600;letter-spacing:.04em;color:var(--muted);margin-bottom:var(--s6)}
.marquee{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee__track{display:inline-flex;align-items:center;gap:38px;white-space:nowrap;will-change:transform;font-family:var(--serif);font-size:clamp(1.6rem,3.4vw,2.6rem);font-weight:500;color:var(--ink);letter-spacing:-.01em}
.marquee__track i{color:var(--blue);font-style:normal}

/* ---------- Problem ---------- */
.problem{padding:var(--section) 0;background:var(--bg-soft)}
.problem__head{font-family:var(--serif);font-weight:400;font-size:var(--t-2xl);line-height:1.0;letter-spacing:-.02em;margin:var(--s5) 0 var(--s7);max-width:18ch}
.problem__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s7) var(--s9);align-items:start}
.problem__lead p{color:var(--ink-soft);font-size:var(--t-md);max-width:var(--measure)}
.problem__list{list-style:none;display:flex;flex-direction:column;gap:var(--s5)}
.problem__list li{display:flex;gap:var(--s4);align-items:baseline;padding-bottom:var(--s5);border-bottom:1px solid var(--line);font-size:var(--t-md);color:var(--ink);font-weight:500}
.problem__list li span{font-family:var(--serif);font-size:var(--t-base);color:var(--blue-deep);font-weight:700;flex:0 0 auto;font-variant-numeric:tabular-nums}

/* ---------- Solution (services) ---------- */
.solution{padding:var(--section) 0;background:var(--navy);color:#fff}
.solution__head{font-family:var(--serif);font-weight:400;font-size:var(--t-2xl);line-height:1.0;letter-spacing:-.02em;margin:var(--s5) 0 var(--s8);max-width:22ch;color:#fff}
.solution__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s5)}
.solution .card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12)}
.solution .card:hover{background:rgba(25,164,177,.1);border-color:rgba(63,195,208,.4)}
.solution .card h3{color:#fff}
.solution .card p{color:var(--on-dark-soft)}
.solution .card__no{color:var(--blue-bright)}
.card{background:var(--bg-tint);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s7);transition:transform var(--fast) var(--eo),box-shadow var(--fast) var(--eo),border-color var(--fast) var(--eo)}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:rgba(25,164,177,.35)}
.card__no{font-family:var(--serif);font-weight:500;font-size:var(--t-xl);color:var(--blue);display:block;margin-bottom:var(--s4)}
.card h3{font-family:var(--serif);font-weight:400;font-size:var(--t-lg);margin-bottom:var(--s3);letter-spacing:-.01em}
.card p{color:var(--ink-soft);font-size:var(--t-base)}

/* ---------- Stats ---------- */
.stats{padding:var(--section) 0;background:var(--navy);color:#fff}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s6);margin-top:var(--s7)}
.stat__num,.stat__plus{font-family:var(--serif);font-weight:500;font-size:clamp(3rem,5.5vw,5rem);line-height:1;background:linear-gradient(160deg,var(--blue-bright),var(--gold-bright));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__plus{font-size:clamp(2rem,3.5vw,3rem)}
.stat p{color:var(--on-dark-soft);font-size:var(--t-base);margin-top:var(--s4);max-width:24ch}

/* ---------- Horizontal scroll gallery ---------- */
.hscroll{position:relative}
.hscroll__pin{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;display:flex;align-items:center}
.hscroll__track{display:flex;gap:var(--s5);padding-inline:var(--gutter);will-change:transform}
.panel{flex:0 0 min(72vw,860px);height:74vh}
.panel__inner{position:relative;height:100%;border-radius:var(--radius);overflow:hidden;background-image:var(--img);background-size:cover;background-position:center}
.panel__inner::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,23,38,.82),rgba(8,23,38,.05) 55%)}
.panel__cap{position:absolute;left:var(--s6);bottom:var(--s6);right:var(--s6);z-index:1;color:#fff}
.panel__cap span{font-size:var(--t-sm);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-bright)}
.panel__cap h3{font-family:var(--serif);font-weight:400;font-size:var(--t-lg);margin-top:var(--s2);max-width:18ch}
.hscroll.is-static .hscroll__pin{height:auto;display:block;padding:var(--s7) 0}
.hscroll.is-static .hscroll__track{flex-direction:column;transform:none!important}
.hscroll.is-static .panel{flex:none;width:100%;height:60vh}

/* ---------- Network ---------- */
.network{position:relative;padding:var(--section) 0;color:#fff;overflow:hidden;background:var(--navy)}
.network__bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.network__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(8,23,38,.95),rgba(8,23,38,.78))}
.network__content{position:relative;z-index:1}
.network__head{font-family:var(--serif);font-weight:400;font-size:var(--t-2xl);line-height:1.0;letter-spacing:-.02em;margin:var(--s5) 0 var(--s7);max-width:18ch}
.ports{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s3)}
.ports li{border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:12px 8px;text-align:center;font-weight:500;font-size:var(--t-sm);color:var(--on-dark);transition:background var(--fast) var(--eo),border-color var(--fast) var(--eo)}
.ports li:hover{background:rgba(25,164,177,.18);border-color:var(--blue-bright)}

/* ---------- Paradigm ---------- */
.paradigm{padding:var(--section) 0;background:var(--bg);overflow:hidden}
.paradigm__head{font-family:var(--serif);font-weight:400;font-size:var(--t-2xl);line-height:1.0;letter-spacing:-.02em;max-width:20ch;margin-bottom:var(--s9)}
.paradigm__ships{position:relative;height:clamp(120px,18vw,260px);margin-bottom:var(--s8);display:grid;place-items:center}
.paradigm__big,.paradigm__small{position:absolute;left:50%;top:50%;will-change:transform,opacity}
.paradigm__big{width:min(86vw,1100px);transform:translate(-50%,-50%)}
.paradigm__small{width:min(24vw,260px);transform:translate(-50%,-50%) scale(.4);opacity:0}
.paradigm__captions{display:grid;grid-template-columns:1fr 1fr;gap:var(--s6)}
.paradigm__captions span{font-size:var(--t-md);color:var(--ink-soft);max-width:28ch}
.paradigm__captions--accent{color:var(--blue-deep)!important;font-weight:500}

/* ---------- Why ---------- */
.why{position:relative;padding:var(--section) 0;color:#fff;overflow:hidden}
.why__bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.why__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(8,23,38,.95),rgba(8,23,38,.74))}
.why__content{position:relative;z-index:1}
.why__head{font-family:var(--serif);font-weight:400;font-size:var(--t-2xl);line-height:1.0;letter-spacing:-.02em;margin:var(--s5) 0 var(--s8);max-width:20ch}
.why__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
.feature{padding-top:var(--s5);border-top:2px solid var(--blue-bright)}
.feature h3{font-family:var(--serif);font-weight:400;font-size:var(--t-lg);margin-bottom:var(--s3)}
.feature p{color:var(--on-dark-soft)}

/* ---------- FAQ ---------- */
.faq{padding:var(--section) 0;background:var(--bg-soft)}
.faq__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:var(--s7) var(--s9);align-items:start}
.faq__head{font-family:var(--serif);font-weight:400;font-size:var(--t-xl);line-height:1.02;letter-spacing:-.02em;margin-top:var(--s4)}
.faq__list{display:flex;flex-direction:column}
.qa{border-top:1px solid var(--line-strong)}
.qa:last-child{border-bottom:1px solid var(--line-strong)}
.qa summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:var(--s4);padding:var(--s5) 0;font-family:var(--serif);font-weight:400;font-size:var(--t-lg);color:var(--ink);transition:color var(--fast) var(--eo)}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"";flex:0 0 auto;width:14px;height:14px;background:linear-gradient(var(--blue-deep),var(--blue-deep)) no-repeat center/14px 2px,linear-gradient(var(--blue-deep),var(--blue-deep)) no-repeat center/2px 14px;transition:transform var(--fast) var(--eo)}
.qa[open] summary::after{transform:rotate(45deg)}
.qa summary:hover{color:var(--blue-deep)}
.qa summary:focus-visible{outline:3px solid var(--blue-bright);outline-offset:3px;border-radius:4px}
.qa p{color:var(--ink-soft);font-size:var(--t-base);max-width:var(--measure);padding-bottom:var(--s5);line-height:1.5}

/* ---------- Reviews ---------- */
.reviews{padding:var(--section) 0;background:var(--navy);color:#fff}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);margin-top:var(--s7)}
.quote blockquote{font-family:var(--serif);font-weight:400;font-style:italic;font-size:var(--t-md);line-height:1.4;color:var(--on-dark)}
.quote figcaption{margin-top:var(--s5);font-size:var(--t-sm);color:var(--blue-bright);font-weight:600}

/* ---------- CTA ---------- */
.cta{padding:var(--section) 0;background:linear-gradient(120deg,var(--blue-deep),var(--blue));color:#fff;text-align:center}
.cta__inner{display:flex;flex-direction:column;align-items:center;gap:var(--s5)}
.cta__head{font-family:var(--serif);font-weight:400;font-size:var(--t-2xl);line-height:1.0;letter-spacing:-.02em;max-width:20ch}
.cta__lead{font-size:var(--t-md);color:rgba(255,255,255,.9)}
.cta .btn--solid{background:#fff;color:var(--blue-deep)}
.cta .btn--solid::before{background:var(--navy-2)}
.cta .btn--solid::after{background:var(--navy)}
.cta .btn--solid:hover{color:#fff}

/* ---------- Footer ---------- */
.footer{background:var(--navy-2);color:var(--on-dark);padding-top:var(--s8)}
.footer__marquee{padding:var(--s5) 0;border-block:1px solid rgba(255,255,255,.08)}
.footer__marquee .marquee__track{font-size:clamp(1.4rem,3vw,2.2rem);color:rgba(255,255,255,.22)}
.footer__marquee .marquee__track i{color:var(--blue)}
.footer__cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:var(--s6);padding-block:var(--s8)}
.footer__logo{height:34px;filter:brightness(0) invert(1);margin-bottom:var(--s4)}
.footer__brand p{color:var(--on-dark-soft);font-size:var(--t-sm);max-width:38ch}
.footer__col h4{font-size:var(--t-sm);font-weight:700;letter-spacing:.04em;margin-bottom:var(--s4)}
.footer__col a,.footer__col p{display:block;color:var(--on-dark-soft);font-size:var(--t-sm);margin-bottom:var(--s2);transition:color var(--fast) var(--eo)}
.footer__col a:hover{color:var(--blue-bright)}
.footer__base{display:flex;justify-content:space-between;gap:var(--s4);padding-block:var(--s5);border-top:1px solid rgba(255,255,255,.08);font-size:var(--t-xs);color:var(--muted);flex-wrap:wrap}

/* ---------- Footer oversized wordmark (award-site style) ---------- */
.footer__wordmark{
  padding:var(--s6) var(--gutter) 0;
  line-height:.9;letter-spacing:-.04em;
  font-family:var(--serif);font-weight:900;
  text-transform:uppercase;overflow:hidden;white-space:nowrap;
}
.footer__wordmark-line{
  display:block;
  font-size:clamp(2.6rem,13vw,11rem);
  color:rgba(255,255,255,.06);            /* faint ghost text, not a bright gradient */
}
}
@media(max-width:680px){
  .footer__wordmark{line-height:.86}
}

/* ============================================================
   Reveal states (opacity/clip only — no CLS). JS adds .in
   ============================================================ */
:root{
  --ease-soft:cubic-bezier(.22,.61,.36,1);
  --ease-rise:cubic-bezier(.16,1,.3,1);
  --rev-dur:1.05s;
}
[data-reveal]{opacity:0;transform:translateY(14px);filter:blur(6px);transition:opacity var(--rev-dur) var(--ease-soft),transform var(--rev-dur) var(--ease-soft),filter var(--rev-dur) var(--ease-soft);transition-delay:calc(var(--i,0)*70ms)}
[data-reveal].in{opacity:1;transform:none;filter:blur(0)}
[data-fade]{opacity:0;transition:opacity 1.1s var(--ease-soft);transition-delay:calc(.25s + var(--i,0)*120ms)}
[data-fade].in{opacity:1}
[data-hline]{transform:translateY(112%);transition:transform 1.15s var(--ease-rise);transition-delay:calc(var(--i,0)*90ms)}
[data-hline].in{transform:translateY(0)}
.statement__row{opacity:0;transform:translateY(30px);filter:blur(8px);transition:opacity 1.1s var(--ease-soft),transform 1.1s var(--ease-soft),filter 1.1s var(--ease-soft);transition-delay:calc(var(--i,0)*110ms)}
.statement__row.in{opacity:1;transform:none;filter:blur(0)}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:980px){
  .intro__grid{grid-template-columns:1fr;gap:var(--s5)}
  .solution__grid,.stats__grid,.why__grid,.reviews__grid,.problem__grid,.faq__grid{grid-template-columns:1fr 1fr}
  .ports{grid-template-columns:repeat(3,1fr)}
  .footer__cols{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .solution__grid,.stats__grid,.why__grid,.reviews__grid,.ports,.footer__cols,.problem__grid,.faq__grid,.paradigm__captions{grid-template-columns:1fr}
  .statement{min-height:90vh}
  .statement__ship{width:62vw;opacity:.16;right:-6%;bottom:8%}
  .footer__base{justify-content:flex-start}
  .hero__desc{position:static;text-align:left;max-width:none;margin-top:var(--s5);padding-inline:var(--gutter)}
  .hero__backer{position:static;padding-inline:var(--gutter);margin-top:var(--s5)}
  .hero__content{margin-bottom:auto}
  .hero{align-items:flex-start;padding-top:34vh}
  .hero__ship{width:84px;bottom:-8%}
  .hero__scroll{display:none}
  .paradigm__big{width:140vw}
}
feBlend
/* ============================================================
   Reduced motion
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  [data-reveal],[data-fade],[data-hline],.statement__row{opacity:1!important;transform:none!important;transition:none!important}
  .paradigm__small{opacity:1;transform:translate(-50%,-50%) scale(1)}
  .paradigm__big{opacity:.25}
  .hero__video{display:none}
  .hero{background:var(--navy)}
}