/* ============================================================
   YES CARGO — motion + brand system
   Faithful re-creation of the reference site's animation language
   (preloader counter, .animable reveals, clip-reveal titles,
   color-shifting sections, zigzag "bite" dividers, sliders).
   ============================================================ */

:root{
  /* Brand (sampled from logo) */
  --blue:#004f71;
  --blue-deep:#00374f;
  --blue-ink:#06222e;
  --blue-soft:#5a93a9;
  --orange:#f3702a;
  --crimson:#b91543;

  /* Neutrals — premium warm paper */
  --paper:#f3efe9;
  --paper-2:#eae3d8;
  --ink:#0d2530;

  /* Active theme (shifts per section via JS) */
  --theme:var(--blue);
  --theme-ink:#ffffff;

  --maxw:1680px;
  --gutter:clamp(20px,5vw,90px);
  --header-h:88px;

  --ease:cubic-bezier(.16,1,.3,1);
  --ease-soft:cubic-bezier(.4,0,.1,1);

  /* Motion intensity (1..10) drives distance & duration */
  --mi:9;
  --rv-dist:calc(8px + var(--mi) * 1.1%);
  --rv-dur:calc(.55s + var(--mi) * .045s);

  --font-display:"Archivo","Archivo Expanded",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --font-mono:"DM Mono",ui-monospace,monospace;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--blue-ink);
  color:var(--ink);
  font-size:18px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.is-locked{ overflow:hidden; height:100vh; }

a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{list-style:none;margin:0;padding:0;}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit;}

::selection{ background:var(--orange); color:#fff; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

/* Lenis */
html.lenis,html.lenis body{height:auto;}
.lenis.lenis-smooth{scroll-behavior:auto !important;}
.lenis.lenis-stopped{overflow:hidden;}

/* =========================================================
   TYPE SCALE
   ========================================================= */
.display{
  font-family:var(--font-display);
  font-weight:800;
  line-height:.92;
  letter-spacing:-.02em;
  font-stretch:125%;
  text-transform:none;
}
h1,h2,h3{ font-family:var(--font-display); font-weight:800; letter-spacing:-.02em; line-height:.95; margin:0; }
.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:500;
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{ content:""; width:2.4em;height:1px;background:currentColor;opacity:.6; }
p{margin:0 0 1em;}
.lead{ font-size:clamp(1.15rem,1.7vw,1.5rem); line-height:1.45; max-width:42ch; }

/* =========================================================
   PRELOADER  (rotating sail + 0→100 counter + clip reveal)
   ========================================================= */
#preloader{
  position:fixed; inset:0; z-index:1000;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:var(--blue-ink);
  color:var(--paper);
  gap:42px;
  transition:clip-path 1.05s var(--ease), opacity .7s ease .15s, visibility 0s linear 1.05s;
  clip-path:inset(0 0 0 0);
}
#preloader.done{ clip-path:inset(0 0 100% 0); opacity:0; visibility:hidden; pointer-events:none; }
.pl-grid{
  position:absolute; inset:0; opacity:.10;
  background-image:linear-gradient(var(--blue-soft) 1px,transparent 1px),
                   linear-gradient(90deg,var(--blue-soft) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 50% 45%,#000,transparent 75%);
}
.pl-mark{ position:relative; width:120px; height:120px; }
.pl-mark svg{ width:100%; height:100%; display:block; }
.pl-mark .sail{ transform-origin:50% 90%; animation:sailSway 2.4s var(--ease-soft) infinite alternate; }
@keyframes sailSway{ from{transform:rotate(-7deg);} to{transform:rotate(7deg);} }
.pl-count{
  font-family:var(--font-mono); font-weight:500;
  font-size:clamp(3rem,9vw,7rem); line-height:1; letter-spacing:-.03em;
  display:flex; align-items:flex-end; gap:.05em;
}
.pl-count .pct{ font-size:.32em; transform:translateY(-.4em); opacity:.6; }
.pl-bar{ width:min(280px,60vw); height:2px; background:rgba(255,255,255,.18); overflow:hidden; }
.pl-bar i{ display:block; height:100%; width:0%; background:var(--orange); }
.pl-word{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.3em; text-transform:uppercase;
  opacity:.5;
}

/* prevent flash before JS: lock scroll during load */
html.is-loading body{ overflow:hidden; }

/* =========================================================
   HEADER
   ========================================================= */
#site-header{
  position:fixed; top:0; left:0; right:0; z-index:120;
  height:var(--header-h);
  display:flex; align-items:center;
  transition:transform .5s var(--ease), background .5s ease, backdrop-filter .5s ease;
  will-change:transform;
}
#site-header.is-solid{
  background:color-mix(in srgb, var(--theme) 88%, transparent);
  backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:0 1px 0 rgba(255,255,255,.08);
}
#site-header.is-hidden{ transform:translateY(-110%); }
#site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; width:100%; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:46px; width:auto; filter:none; }
.brand .badge-light{ display:none; }
/* white logo treatment over dark themes handled via mix */
.nav{ display:flex; align-items:center; gap:clamp(14px,2vw,38px); }
.nav a{
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:#fff; position:relative; padding:6px 0; opacity:.85; transition:opacity .3s;
}
.nav a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--orange); transition:width .4s var(--ease); }
.nav a:hover{ opacity:1; } .nav a:hover::after{ width:100%; }
.header-right{ display:flex; align-items:center; gap:18px; }
.lang{ display:flex; gap:2px; font-family:var(--font-mono); font-size:.72rem; color:#fff; }
.lang button{ padding:5px 8px; opacity:.5; letter-spacing:.1em; text-transform:uppercase; transition:opacity .3s; border-radius:4px; }
.lang button.active{ opacity:1; }
.lang button:hover{ opacity:.85; }
.lang .sep{ opacity:.3; align-self:center; }
.btn-cta{
  display:inline-flex; align-items:center; gap:.6em;
  background:var(--orange); color:#fff;
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase;
  padding:13px 20px; border-radius:100px;
  transition:transform .35s var(--ease), background .35s;
  white-space:nowrap;
}
.btn-cta:hover{ transform:translateY(-2px); background:#ff7e38; }
.btn-cta svg{ width:14px;height:14px; }
.hamb{ display:none; }

/* =========================================================
   GENERIC SECTION + COLOR SHIFT
   ========================================================= */
main{ position:relative; z-index:2; }
.section{ position:relative; }
.section--pad{ padding-block:clamp(90px,12vh,180px); }
.theme-fill{ position:fixed; inset:0; z-index:0; background:var(--theme); transition:background .9s var(--ease-soft); }

/* =========================================================
   ANIMABLE / WAYPOINT REVEALS (faithful to reference)
   ========================================================= */
.animable_holder{ overflow:hidden; display:block; }
.animable{
  transform:translateY(calc(100% + var(--rv-dist)));
  opacity:0;
  transition:transform var(--rv-dur) var(--ease), opacity calc(var(--rv-dur) * .9) ease;
  will-change:transform,opacity;
  transition-delay:var(--d,0ms);
}
.waypoint.has--inview .animable,
.animable_holder.has--inview .animable,
.has--inview > .animable{ transform:translateY(0); opacity:1; }
.animable_holder.fast .animable, .fast > .animable{ --rv-dur:.6s; }

/* fade/slide (sliders, media) */
.faded{ opacity:0; transform:translateY(40px) scale(.985); transition:opacity 1s ease, transform 1.1s var(--ease); transition-delay:var(--d,0ms); }
.faded.to-left{ transform:translateX(60px) scale(.99); }
.has--inview .faded, .faded.has--inview{ opacity:1; transform:none; }

/* generic element reveal */
[data-reveal]{ opacity:0; transform:translateY(var(--rv-dist)); transition:opacity var(--rv-dur) ease, transform var(--rv-dur) var(--ease); transition-delay:var(--d,0ms); }
[data-reveal].is-in{ opacity:1; transform:none; }

/* clip-reveal title: lines slide up */
.ttl{ display:block; }
.ttl .line{ display:block; overflow:hidden; padding-bottom:.08em; }
.ttl .line > span{
  display:block; line-height:1;
  transform:translateY(112%) rotate(2deg);
  transition:transform calc(var(--rv-dur) + .1s) var(--ease);
  transition-delay:var(--d,0ms);
}
.ttl.is-in .line > span{ transform:none; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  color:#fff; overflow:hidden; isolation:isolate;
}
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media .ph{ width:100%; height:120%; }
.hero__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(6,34,46,.35) 0%,rgba(6,34,46,.15) 40%,rgba(6,34,46,.85) 100%); z-index:1; }
.hero__inner{ width:100%; max-width:var(--maxw); margin-inline:auto; padding:0 var(--gutter) clamp(48px,8vh,110px); position:relative; z-index:2; }
.hero__eyebrow{ color:var(--orange); margin-bottom:26px; }
.hero h1{
  font-family:var(--font-display); font-weight:800; font-stretch:125%;
  font-size:clamp(3.4rem,12vw,12.5rem); line-height:.86; letter-spacing:-.03em;
  text-transform:uppercase;
  margin-bottom:.28em;
}
.hero h1 .stroke{ -webkit-text-stroke:2px rgba(255,255,255,.9); color:transparent; }
.hero h1 em{ font-style:normal; color:var(--orange); }
.hero__row{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:30px; }
.hero__lead{ max-width:46ch; font-size:clamp(1.05rem,1.5vw,1.4rem); opacity:.92; }
.hero__cta{
  display:inline-flex; align-items:center; gap:.8em;
  font-family:var(--font-display); font-weight:800; font-stretch:110%;
  font-size:clamp(1.3rem,2.4vw,2.4rem); text-transform:uppercase; letter-spacing:-.01em;
  color:#fff; white-space:nowrap;
}
.hero__cta .circ{
  width:1.7em;height:1.7em;border-radius:50%;border:2px solid var(--orange);
  display:grid;place-items:center; transition:background .4s,transform .4s var(--ease); flex:0 0 auto;
}
.hero__cta:hover .circ{ background:var(--orange); transform:rotate(45deg) scale(1.05); }
.hero__cta .circ svg{ width:.7em;height:.7em; }
.hero__scroll{
  position:absolute; left:var(--gutter); bottom:26px; z-index:3;
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.28em; text-transform:uppercase; opacity:.7;
  display:flex; align-items:center; gap:10px;
}
.hero__scroll .ln{ width:1px;height:46px;background:#fff;transform-origin:top;animation:scrollLn 2s var(--ease-soft) infinite; }
@keyframes scrollLn{ 0%{transform:scaleY(0);} 40%{transform:scaleY(1);} 100%{transform:scaleY(0);transform-origin:bottom;} }
/* hero variants (driven by body[data-hero]) */
/* anchored = default: headline bottom-left */
/* centered */
body[data-hero="centered"] .hero{ align-items:center; text-align:center; }
body[data-hero="centered"] .hero__inner{ padding-bottom:0; }
body[data-hero="centered"] .hero__eyebrow{ justify-content:center; }
body[data-hero="centered"] .hero__row{ justify-content:center; flex-direction:column; align-items:center; }
body[data-hero="centered"] .hero__lead{ margin-inline:auto; }
body[data-hero="centered"] .hero__scroll{ left:50%; transform:translateX(-50%); }
/* stacked = editorial: headline top, meta bar bottom */
body[data-hero="stacked"] .hero{ align-items:stretch; }
body[data-hero="stacked"] .hero__inner{ display:flex; flex-direction:column; justify-content:space-between; padding-top:calc(var(--header-h) + 4vh); }
body[data-hero="stacked"] .hero__eyebrow{ margin-bottom:14px; }
body[data-hero="stacked"] h1{ margin-top:.1em; }
body[data-hero="stacked"] .hero__row{ border-top:1px solid rgba(255,255,255,.25); padding-top:26px; }

/* placeholder media */
.ph{
  position:relative; overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 2px, transparent 2px 26px),
    linear-gradient(135deg,var(--blue-deep),var(--blue-ink));
  display:grid; place-items:center;
}
.ph__rombos{
  position:absolute; inset:0; opacity:.5;
  background-image:
    linear-gradient(45deg,rgba(255,255,255,.05) 25%,transparent 25%,transparent 75%,rgba(255,255,255,.05) 75%),
    linear-gradient(45deg,rgba(255,255,255,.05) 25%,transparent 25%,transparent 75%,rgba(255,255,255,.05) 75%);
  background-size:54px 54px; background-position:0 0,27px 27px;
}
.ph__label{
  position:relative; z-index:1; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.22em;
  text-transform:uppercase; color:rgba(255,255,255,.6); border:1px solid rgba(255,255,255,.25);
  padding:8px 14px; border-radius:100px; text-align:center; backdrop-filter:blur(2px);
}

/* =========================================================
   ZIGZAG "BITE" DIVIDER
   ========================================================= */
.bite{
  --s:42px;
  display:block; width:100%; height:clamp(20px,3vw,40px); position:relative; z-index:3;
  background:var(--orange);
  -webkit-mask:conic-gradient(from -45deg at bottom,#0000,#000 1deg 89deg,#0000 90deg) bottom/var(--s) 100% repeat-x;
          mask:conic-gradient(from -45deg at bottom,#0000,#000 1deg 89deg,#0000 90deg) bottom/var(--s) 100% repeat-x;
}
.bite--ink{ background:var(--blue-ink); }
.bite--crimson{ background:var(--crimson); }
.bite--up{ transform:scaleY(-1); }

/* =========================================================
   INTRO / MANIFESTO
   ========================================================= */
.intro{ color:#fff; }
.intro__big{
  font-family:var(--font-display); font-weight:800; font-stretch:110%;
  font-size:clamp(1.9rem,4.6vw,4.6rem); line-height:1.02; letter-spacing:-.02em;
  max-width:20ch;
}
.intro__big .hl{ color:var(--orange); }
.intro__meta{ display:flex; gap:clamp(28px,5vw,90px); flex-wrap:wrap; margin-top:60px; }
.stat{ }
.stat__n{ font-family:var(--font-display); font-weight:800; font-stretch:120%; font-size:clamp(2.6rem,6vw,5.2rem); line-height:1; }
.stat__l{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; opacity:.75; margin-top:8px; }

/* =========================================================
   SERVICIOS  (cards reveal)
   ========================================================= */
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; margin-bottom:clamp(40px,6vw,80px); color:#fff; }
.sec-head h2{ font-size:clamp(2.4rem,6.5vw,6rem); text-transform:uppercase; }
.sec-head .eyebrow{ color:var(--orange); }
.services{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(14px,1.6vw,26px); }
.svc{
  grid-column:span 6; min-height:340px; position:relative; overflow:hidden;
  border-radius:4px; padding:30px; display:flex; flex-direction:column; justify-content:space-between;
  color:#fff; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  transition:transform .6s var(--ease), background .5s;
}
.svc:hover{ transform:translateY(-6px); background:rgba(255,255,255,.09); }
.svc__n{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.2em; opacity:.6; }
.svc__icon{ width:64px;height:64px; color:var(--orange); }
.svc__icon svg{ width:100%;height:100%; }
.svc h3{ font-size:clamp(1.6rem,2.6vw,2.6rem); text-transform:uppercase; margin-top:14px; }
.svc p{ opacity:.82; max-width:44ch; margin-top:10px; margin-bottom:0; }
.svc__top{ display:flex; align-items:flex-start; justify-content:space-between; }
.svc--wide{ grid-column:span 12; min-height:300px; flex-direction:row; align-items:flex-end; gap:40px; }
.svc--wide .svc__icon{ width:84px;height:84px; }
@media(max-width:860px){ .svc{ grid-column:span 12; min-height:260px; } .svc--wide{ flex-direction:column; align-items:flex-start; } }

/* =========================================================
   COBERTURA / RUTAS (map)
   ========================================================= */
.map{ position:relative; }
.map__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(30px,5vw,80px); align-items:center; color:#fff; }
@media(max-width:980px){ .map__grid{ grid-template-columns:1fr; } }
.map__canvas{ position:relative; aspect-ratio:4/3.2; border-radius:6px; overflow:hidden; background:rgba(0,0,0,.18); border:1px solid rgba(255,255,255,.14); }
.map__canvas svg{ position:absolute; inset:0; width:100%; height:100%; }
.route{ fill:none; stroke:var(--orange); stroke-width:2; stroke-linecap:round; stroke-dasharray:6 8; opacity:.9; }
.route--2{ stroke:#fff; opacity:.5; stroke-dasharray:2 9; }
.node{ fill:#fff; } .node--hub{ fill:var(--orange); }
.pulse{ fill:none; stroke:var(--orange); }
.map__list{ }
.map__row{ display:flex; align-items:baseline; justify-content:space-between; gap:20px; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.14); }
.map__row b{ font-family:var(--font-display); font-stretch:110%; font-weight:800; font-size:1.3rem; }
.map__row span{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.12em; opacity:.7; }

/* =========================================================
   FLOTA / CAPACIDADES
   ========================================================= */
.fleet{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(14px,1.6vw,26px); color:#fff; }
.cap{ grid-column:span 3; border-top:1px solid rgba(255,255,255,.25); padding-top:20px; }
@media(max-width:980px){ .cap{ grid-column:span 6; } }
@media(max-width:560px){ .cap{ grid-column:span 12; } }
.cap__n{ font-family:var(--font-display); font-weight:800; font-stretch:120%; font-size:clamp(2.4rem,4vw,3.6rem); line-height:1; color:var(--orange); }
.cap__t{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; margin-top:10px; }
.cap__d{ opacity:.78; font-size:.95rem; margin-top:8px; }

/* slider */
.slider_holder{ width:100%; }
.splide__slide .ph{ aspect-ratio:16/10; width:100%; border-radius:6px; }
.splide__arrows{ display:flex; gap:10px; margin-top:18px; }
.splide__arrow{ position:static; width:46px;height:46px;border-radius:50%; background:transparent; border:1px solid rgba(255,255,255,.3); opacity:1; transform:none; transition:background .3s,border-color .3s; }
.splide__arrow svg{ width:18px;height:18px; fill:#fff; }
.splide__arrow:hover{ background:var(--orange); border-color:var(--orange); }
.splide__pagination{ position:static; margin-top:16px; gap:6px; }
.splide__pagination__page{ background:rgba(255,255,255,.3); } .splide__pagination__page.is-active{ background:var(--orange); transform:scale(1.4); }

/* =========================================================
   PROCESO
   ========================================================= */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,2vw,40px); color:#fff; }
@media(max-width:900px){ .steps{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .steps{ grid-template-columns:1fr; } }
.step{ position:relative; }
.step__n{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:.2em; color:var(--orange); }
.step__bar{ height:2px; background:rgba(255,255,255,.2); margin:18px 0; position:relative; overflow:hidden; }
.step__bar i{ position:absolute; inset:0; background:var(--orange); transform:scaleX(0); transform-origin:left; transition:transform 1s var(--ease); transition-delay:var(--d,0ms); }
.step.is-in .step__bar i{ transform:scaleX(1); }
.step h3{ font-size:clamp(1.5rem,2.2vw,2.1rem); text-transform:uppercase; }
.step p{ opacity:.8; margin-top:10px; font-size:.96rem; }

/* =========================================================
   CLIENTES
   ========================================================= */
.clients__logos{ display:grid; grid-template-columns:repeat(6,1fr); gap:1px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.14); border-radius:6px; overflow:hidden; }
@media(max-width:900px){ .clients__logos{ grid-template-columns:repeat(3,1fr); } }
.clients__logos .cell{ aspect-ratio:2/1; display:grid; place-items:center; background:var(--theme); color:#fff; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.16em; opacity:.75; }
.quote{ color:#fff; }
.quote__t{ font-family:var(--font-display); font-weight:800; font-stretch:110%; font-size:clamp(1.5rem,2.6vw,2.5rem); line-height:1.1; letter-spacing:-.01em; }
.quote .splide, .quote .splide__track, .quote .splide__list, .quote .splide__slide{ width:100%; }
.quote__a{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; opacity:.7; margin-top:24px; }

/* =========================================================
   COTIZAR / CONTACTO
   ========================================================= */
.quote-cta{ color:#fff; }
.quote-cta__big{
  font-family:var(--font-display); font-weight:800; font-stretch:115%;
  font-size:clamp(2.2rem,6.6vw,6.6rem); line-height:1; text-transform:uppercase; letter-spacing:-.03em;
  overflow-wrap:break-word;
}
.quote-cta__big em{ font-style:normal; color:var(--orange); }
.form{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:60px; max-width:900px; }
@media(max-width:680px){ .form{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:8px; }
.field.full{ grid-column:1 / -1; }
.field label{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; opacity:.7; }
.field input,.field select,.field textarea{
  background:transparent; border:0; border-bottom:1px solid rgba(255,255,255,.3);
  color:#fff; padding:12px 2px; font-family:var(--font-body); font-size:1.05rem; outline:none;
  transition:border-color .3s;
}
.field textarea{ resize:vertical; min-height:80px; }
.field input::placeholder,.field textarea::placeholder{ color:rgba(255,255,255,.4); }
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--orange); }
.field select option{ color:#0d2530; }
.btn-submit{
  grid-column:1 / -1; justify-self:start; margin-top:10px;
  display:inline-flex; align-items:center; gap:.8em;
  background:var(--orange); color:#fff; padding:18px 30px; border-radius:100px;
  font-family:var(--font-mono); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  transition:transform .35s var(--ease), background .35s;
}
.btn-submit:hover{ transform:translateY(-3px); background:#ff7e38; }
.contact-strip{ display:flex; flex-wrap:wrap; gap:clamp(24px,5vw,80px); margin-top:70px; color:#fff; }
.contact-strip .ci{ }
.contact-strip .ci span{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; opacity:.6; display:block; margin-bottom:8px; }
.contact-strip .ci b{ font-family:var(--font-display); font-weight:800; font-stretch:110%; font-size:1.4rem; }

/* =========================================================
   FOOTER
   ========================================================= */
footer{ background:var(--blue-ink); color:#fff; padding:clamp(50px,7vw,90px) 0 40px; position:relative; z-index:5; }
.foot__top{ display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; }
.foot__mark img{ height:54px; }
.foot__nav{ display:flex; gap:40px; flex-wrap:wrap; }
.foot__nav a{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; opacity:.75; }
.foot__nav a:hover{ opacity:1; color:var(--orange); }
.foot__bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-top:60px; padding-top:24px; border-top:1px solid rgba(255,255,255,.14); font-family:var(--font-mono); font-size:.72rem; letter-spacing:.1em; opacity:.6; }

/* big outline marquee */
.marquee{ overflow:hidden; white-space:nowrap; padding:30px 0; }
.marquee__in{ display:inline-flex; gap:.4em; will-change:transform; }
.marquee span{
  font-family:var(--font-display); font-weight:800; font-stretch:125%;
  font-size:clamp(3rem,11vw,11rem); text-transform:uppercase; letter-spacing:-.02em;
  -webkit-text-stroke:1.5px rgba(255,255,255,.4); color:transparent; padding-inline:.15em;
}
.marquee span .dot{ color:var(--orange); -webkit-text-stroke:0; }

/* =========================================================
   RESPONSIVE NAV
   ========================================================= */
@media(max-width:1100px){
  .nav{ display:none; }
  .hamb{ display:inline-grid; gap:5px; padding:10px; }
  .hamb b{ display:block; width:26px; height:2px; background:#fff; transition:transform .4s,opacity .3s; }
  #mobile-nav{
    position:fixed; inset:0; z-index:130; background:var(--blue-ink); color:#fff;
    display:flex; flex-direction:column; align-items:center; justify-content:center; gap:24px;
    transform:translateY(-100%); transition:transform .7s var(--ease);
  }
  #mobile-nav.open{ transform:none; }
  #mobile-nav a{ font-family:var(--font-display); font-weight:800; font-stretch:120%; font-size:2.2rem; text-transform:uppercase; }
  body.nav-open .hamb b:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  body.nav-open .hamb b:nth-child(2){ opacity:0; }
  body.nav-open .hamb b:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .header-right .btn-cta{ display:none; }
}

/* reduce motion */
@media(prefers-reduced-motion:reduce){
  *{ animation-duration:.01ms !important; transition-duration:.01ms !important; }
}
