/* ============================================================
   STARTED — Pilotăm Performanța
   Design system: premium navy + cyan, telemetry-inspired
   ============================================================ */

:root{
  /* Brand palette (from logo) */
  --navy:        #00295A;
  --navy-deep:   #001A3D;
  --navy-abyss:  #00112B;
  --cyan:        #6DC8D4;
  --cyan-soft:   #9BDCE4;
  --white:       #FFFFFF;
  --gray:        #F5F7FA;
  --gray-2:      #E9EEF4;
  --ink:         #0D1726;
  --ink-soft:    #46566B;

  /* Accent (tweakable hue) */
  --accent-h: 189;
  --accent-s: 50%;
  --accent-l: 63%;
  --accent: oklch(0.80 0.07 200);

  /* Lines & surfaces */
  --line-light: rgba(13,23,38,.10);
  --line-faint: rgba(13,23,38,.06);
  --line-dark:  rgba(109,200,212,.16);
  --line-dark-faint: rgba(255,255,255,.07);

  /* Type */
  --font-display: "General Sans", "Satoshi", system-ui, sans-serif;
  --font-body:    "Satoshi", system-ui, sans-serif;
  --font-mono:    "Space Mono", ui-monospace, monospace;

  /* Rhythm */
  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 80px);
  --section-y: clamp(64px, 8vw, 120px);

  /* Motion */
  --motion: 1;            /* tweakable 0..1 */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --radius: 14px;
  --radius-lg: 22px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--font-body);
  background:var(--white);
  color:var(--ink);
  font-size:18px;
  line-height:1.6;
  letter-spacing:-0.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ position:relative; padding-block:var(--section-y); }
.dark{ background:var(--navy-deep); color:var(--white); }
.dark .muted{ color:rgba(255,255,255,.62); }
.abyss{ background:radial-gradient(120% 90% at 50% -10%, #063a78 0%, var(--navy-abyss) 60%); }

/* ---------- Eyebrow / telemetry labels ---------- */
.eyebrow{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--navy);
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-weight:700;
}
.dark .eyebrow{ color:var(--cyan); }
.eyebrow::before{
  content:"";
  width:22px; height:1px;
  background:currentColor;
  opacity:.6;
  display:inline-block;
}
.tick{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.dark .tick{ color:rgba(255,255,255,.5); }

/* ---------- Headings ---------- */
.h-display{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.02;
  letter-spacing:-0.035em;
  font-size:clamp(40px, 7.2vw, 104px);
  text-wrap:balance;
}
.h1{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.04;
  letter-spacing:-0.03em;
  font-size:clamp(34px, 5.2vw, 68px);
  text-wrap:balance;
  margin:0;
}
.h2{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.1;
  letter-spacing:-0.02em;
  font-size:clamp(24px,2.6vw,34px);
  margin:0;
}
.lead{
  font-size:clamp(18px,1.5vw,22px);
  line-height:1.55;
  color:var(--ink-soft);
  max-width:62ch;
  margin:0;
}
.dark .lead{ color:rgba(255,255,255,.7); }
.muted{ color:var(--ink-soft); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 26px;
  border-radius:100px;
  font-weight:600; font-size:16px;
  letter-spacing:-0.01em;
  border:1px solid transparent;
  white-space:nowrap;
  transition:transform .4s var(--ease-out), background .3s, color .3s, border-color .3s, box-shadow .4s;
  will-change:transform;
}
.btn-primary{
  background:var(--cyan);
  color:var(--navy-deep);
  box-shadow:0 0 0 0 rgba(109,200,212,.5);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 40px -12px rgba(109,200,212,.7);
}
.btn-ghost{
  background:transparent;
  border-color:var(--line-light);
  color:var(--ink);
}
.dark .btn-ghost{ border-color:rgba(255,255,255,.22); color:var(--white); }
.btn-ghost:hover{ transform:translateY(-2px); border-color:var(--navy); }
.dark .btn-ghost:hover{ border-color:var(--cyan); background:rgba(109,200,212,.08); }
.btn svg{ transition:transform .4s var(--ease-out); }
.btn:hover svg{ transform:translateX(4px); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:120;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .5s var(--ease), backdrop-filter .5s, border-color .5s, padding .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(16px);
  border-bottom-color:var(--line-light);
  padding-block:13px;
}
.nav .logo{ height:24px; width:auto; }
.nav-left{ display:flex; align-items:center; gap:14px; }
.nav-badge{
  font-family:var(--font-mono); font-size:10px; letter-spacing:.14em;
  text-transform:uppercase; color:rgba(255,255,255,.75);
  border:1px solid rgba(255,255,255,.22); border-radius:100px;
  padding:5px 10px; transition:color .5s, border-color .5s;
}
.nav.scrolled .nav-badge{ color:var(--navy); border-color:var(--line-light); }
.nav-links{ display:flex; gap:28px; align-items:center; }
.nav-links a{ white-space:nowrap; }
.nav-links a{
  font-size:15px; font-weight:500; color:#fff;
  opacity:.8; transition:opacity .3s, color .5s; position:relative;
}
.nav.scrolled .nav-links a{ color:var(--ink); }
.nav-links a:hover{ opacity:1; }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-6px; height:1.5px; width:0;
  background:var(--cyan); transition:width .35s var(--ease-out);
}
.nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:18px; }
.nav-burger{ display:none; }

@media (max-width:1300px){ .nav .nav-badge{ display:none; } }
@media (max-width:1080px){
  .nav-links{ display:none; }
  .nav-cta .btn{ padding:11px 18px; font-size:14px; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:center;
  background:
    radial-gradient(130% 100% at 85% 0%, #06366f 0%, rgba(6,54,111,0) 55%),
    radial-gradient(120% 120% at 10% 110%, #053a78 0%, rgba(5,58,120,0) 50%),
    var(--navy-abyss);
  color:var(--white);
  overflow:hidden;
  padding-top:120px;
}
#hero-canvas{
  position:absolute; inset:0; width:100%; height:100%;
  z-index:0; opacity:.9;
}
.hero-vignette{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(75% 75% at 35% 45%, transparent 40%, rgba(0,17,43,.55) 100%);
}
.hero-inner{ position:relative; z-index:3; }
.hero-grid{
  display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,5vw,72px); align-items:center;
  min-height:min(64vh, 580px);
}
.hero-status{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:12px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--cyan);
  padding:8px 16px; border:1px solid var(--line-dark);
  border-radius:100px; background:rgba(109,200,212,.05);
  margin-bottom:22px;
}
.hero-status .dot{
  width:7px; height:7px; border-radius:50%; background:var(--cyan);
  box-shadow:0 0 0 0 rgba(109,200,212,.7);
  animation:pulse 2.4s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(109,200,212,.6);}
  70%{ box-shadow:0 0 0 10px rgba(109,200,212,0);}
  100%{ box-shadow:0 0 0 0 rgba(109,200,212,0);}
}
.hero h1{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(32px,4.5vw,64px); line-height:1.0; letter-spacing:-0.035em;
  margin:0 0 26px; text-wrap:balance; max-width:640px;
}
.hero h1 .accent{ color:var(--cyan); }
.hero h1 .dim{ color:rgba(255,255,255,.42); }
.hero-sub{ font-size:clamp(16px,1.05vw,18px); color:rgba(255,255,255,.62); max-width:40ch; line-height:1.62; margin:0 0 30px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero-cta .btn-ghost{
  background:transparent;
  border-color:rgba(109,200,212,.34);
  color:rgba(255,255,255,.82);
}
.hero-cta .btn-ghost svg{ color:var(--cyan); }
.hero-cta .btn-ghost:hover{ color:#fff; border-color:var(--cyan); background:rgba(109,200,212,.08); }

/* hero social-proof marquee — full-width band */
.hero-proof{ margin-top:clamp(34px,4vw,52px); padding-top:26px; border-top:1px solid var(--line-dark-faint); width:100%; }
.hero-proof-label{
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(255,255,255,.42); margin:0 0 16px; text-align:center;
}
.hero-marquee{
  position:relative; overflow:hidden; height:28px;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image:linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.hero-track{
  display:flex; align-items:center; gap:64px; width:max-content;
  animation:heroMarquee 52s linear infinite;
}
.hero-track:hover{ animation-play-state:paused; }
.hero-logo{
  font-family:var(--font-display); font-weight:600; font-size:17px; letter-spacing:.04em;
  color:#fff; opacity:.55; white-space:nowrap; transition:opacity .3s var(--ease), transform .3s var(--ease);
  line-height:28px;
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0;
  padding-inline:20px;        /* 20px each side + 64px gap → ≥ 64px (visually ample) */
  min-width:120px;            /* prevents tiny logos from packing too close */
}
.hero-logo:hover{ opacity:1; }
.hero-logo.has-img{ opacity:.9; }
.hero-logo.has-img:hover{ opacity:1; transform:scale(1.05); }
.hero-logo img{
  height:32px; width:auto; max-width:160px; max-height:32px;
  object-fit:contain;
  display:block;
  filter:brightness(0) invert(1);
  transition:filter 300ms ease;
  flex-shrink:0;
}
.hero-logo:hover img{ filter:none; }
@media (max-width:820px){
  .hero-logo img{ height:28px; max-height:28px; }
  .hero-logo{ min-width:96px; padding-inline:12px; }
}
@keyframes heroMarquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .hero-track{ animation:none; } }

/* hero side readout — cockpit instrument */
.readout{
  position:relative;
  overflow:hidden;                         /* keep inner sparkline contained */
  border:1px solid var(--line-dark);
  border-radius:var(--radius-lg);
  background:
    radial-gradient(120% 80% at 80% 0%, rgba(109,200,212,.10), rgba(109,200,212,0) 60%),
    linear-gradient(180deg, rgba(6,32,68,.96), rgba(0,17,43,.94));
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  padding:24px;
  box-shadow:0 40px 90px -50px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.05);
  will-change:transform;
}
.readout-spark{
  height:54px; margin-top:8px;
  width:100%; overflow:hidden;
}
.readout-spark svg{ display:block; width:100%; height:100%; }
.readout-head{
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:rgba(255,255,255,.55);
  padding-bottom:14px; margin-bottom:16px; border-bottom:1px solid var(--line-dark-faint);
}
.readout-head .rd-rec{ color:var(--cyan); display:inline-flex; align-items:center; gap:6px; }
.readout-head .rd-rec::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--cyan); animation:pulse 2s infinite; }
/* route progress strip — ties panel to the flight path */
.rd-route{ display:flex; align-items:center; margin-bottom:7px; }
.rd-wp{ width:8px; height:8px; border-radius:50%; border:1.5px solid rgba(109,200,212,.4); flex:none; }
.rd-wp.done{ background:var(--cyan); border-color:var(--cyan); }
.rd-wp.active{ background:var(--cyan); border-color:var(--cyan); box-shadow:0 0 0 3px rgba(109,200,212,.22); animation:pulse 2s infinite; }
.rd-seg{ flex:1; height:1.5px; background:linear-gradient(90deg, var(--cyan), rgba(109,200,212,.18)); }
.rd-wp:last-child{ border-style:dashed; }
.rd-route-labels{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:9px; letter-spacing:.12em; color:rgba(255,255,255,.4); margin-bottom:18px; }
.readout-row{ display:flex; justify-content:space-between; align-items:baseline; padding:9px 0; }
.readout-row .k{ font-family:var(--font-mono); font-size:12px; letter-spacing:.08em; color:rgba(255,255,255,.55); }
.readout-row .v{ font-family:var(--font-display); font-weight:600; font-size:22px; }
.readout-row .v .up{ color:var(--cyan); font-size:13px; font-family:var(--font-mono); margin-left:6px; }

.hero-scroll{
  position:absolute; left:var(--gutter); bottom:30px; z-index:3;
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:rgba(255,255,255,.45);
}
.hero-scroll .line{ width:40px; height:1px; background:rgba(255,255,255,.3); position:relative; overflow:hidden; }
.hero-scroll .line::after{ content:""; position:absolute; inset:0; width:40%; background:var(--cyan); animation:sweepline 2.6s infinite var(--ease); }
@keyframes sweepline{ 0%{transform:translateX(-100%);}100%{transform:translateX(280%);} }
@media (max-height:900px){ .hero-scroll{ display:none; } }

@media (max-width:920px){
  .hero-grid{ grid-template-columns:1fr; gap:36px; align-items:start; min-height:0; }
  .readout{ max-width:440px; transform:none !important; }
}

/* ---------- Hero responsive system (1280 / 1024 / 768 / 480 / 375) ----------
   Goal: keep cockpit/telemetry aesthetic on desktop, prevent canvas decoration
   from overlapping text on smaller screens, ensure card stays self-contained. */

/* Below large desktop: hide hero-canvas (its absolute-positioned labels
   "TESTING/VALIDATION/ORIGIN/GROWTH" overlap CTAs and card at <1300px). */
@media (max-width:1300px){
  #hero-canvas{ display:none; }
  .hero-vignette{ background:radial-gradient(80% 80% at 40% 30%, transparent 50%, rgba(0,17,43,.65) 100%); }
}

/* Tablet ≤ 920px already restructures grid; tighten paddings + readout. */
@media (max-width:920px){
  .hero{ padding-top:96px; }
  .readout{ width:100%; max-width:520px; }
}

/* Tablet portrait (768px) */
@media (max-width:768px){
  .hero{ padding-top:88px; }
  .hero-grid{ gap:28px; }
  .hero h1{ font-size:clamp(30px,7vw,46px); margin-bottom:20px; }
  .hero-sub{ font-size:15.5px; max-width:none; }
  .readout{ max-width:none; padding:22px; }
  .hero-proof{ margin-top:32px; }
}

/* Phablet (≤ 540px) — stacked, full-width CTAs */
@media (max-width:540px){
  .hero{ padding-top:84px; }
  .hero-status{
    font-size:10.5px; letter-spacing:.12em;
    padding:7px 12px; margin-bottom:18px;
    max-width:100%;
  }
  .hero h1{ font-size:clamp(28px,8.5vw,40px); letter-spacing:-0.03em; margin-bottom:18px; }
  .hero-sub{ font-size:15px; margin-bottom:24px; }
  .hero-cta{ flex-direction:column; align-items:stretch; gap:10px; width:100%; }
  .hero-cta .btn{ width:100%; justify-content:center; }
  .readout{ padding:20px 18px; border-radius:18px; }
  .readout-head{ font-size:10.5px; padding-bottom:12px; margin-bottom:14px; }
  .readout-row{ padding:8px 0; }
  .readout-row .v{ font-size:20px; }
  .readout-row .v .up{ font-size:12px; }
  .readout-spark{ height:46px; }
  .rd-route-labels{ font-size:8.5px; }
  .hero-proof-label{ font-size:9.5px; letter-spacing:.16em; }
}

/* Small mobile (≤ 380px) — iPhone SE & similar */
@media (max-width:380px){
  .hero{ padding-top:78px; }
  .hero-status{ font-size:9.5px; padding:6px 10px; gap:8px; }
  .hero h1{ font-size:clamp(26px,9vw,34px); }
  .hero-sub{ font-size:14.5px; }
  .readout{ padding:18px 16px; }
  .readout-head{ font-size:10px; }
  .readout-row .v{ font-size:18px; }
}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec-head{ max-width:760px; margin-bottom:clamp(28px,3.5vw,52px); }
.sec-head .h1{ margin-top:18px; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head.center .eyebrow{ justify-content:center; }
.sec-head.center .lead{ margin-inline:auto; }

/* corner coordinate frame helper */
.coord{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; color:var(--ink-soft); opacity:.7; }
.dark .coord{ color:rgba(255,255,255,.4); }

/* ============================================================
   TRUST / LOGO WALL
   ============================================================ */
.trust{ padding:40px 0; border-bottom:1px solid var(--line-faint); }
.trust-label{ text-align:center; margin-bottom:24px; }
.badge-wall{
  display:flex; justify-content:center; align-items:center;
  flex-wrap:nowrap; gap:32px;
  max-width:1100px; margin-inline:auto;
}
.badge-card{
  flex:0 1 auto;
  display:flex; align-items:center; justify-content:center;
  background:#fff;
  border:1px solid var(--line-light);
  border-radius:16px;
  padding:22px 20px;
  min-height:140px;
  box-shadow:0 2px 4px rgba(0,41,90,.03), 0 10px 30px -22px rgba(0,41,90,.18);
  transition:transform .25s var(--ease-out), box-shadow .25s var(--ease-out), border-color .25s var(--ease-out);
}
.badge-card img{
  width:auto; height:94px; max-width:100%; object-fit:contain;
  display:block;
}
.badge-card img.badge-tiktok{ height:120px; margin:-12px 0; }
.badge-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 50px -24px rgba(0,41,90,.34);
  border-color:rgba(109,200,212,.55);
}
@media (max-width:860px){
  .badge-wall{ flex-wrap:wrap; gap:18px; max-width:560px; }
  .badge-card{ flex:0 0 calc(50% - 9px); }
}
@media (max-width:460px){
  .badge-wall{ max-width:320px; gap:14px; }
  .badge-card{ flex:0 0 100%; }
}

/* ============================================================
   PILOTING SYSTEM
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-light); border:1px solid var(--line-light); border-radius:var(--radius-lg); overflow:hidden; }
.step{
  background:var(--white); padding:clamp(28px,3vw,44px);
  position:relative; min-height:340px; display:flex; flex-direction:column;
  transition:background .5s var(--ease);
}
.step:hover{ background:var(--gray); }
.step-no{ font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; color:var(--cyan); font-weight:700; }
.step-no b{ color:var(--navy); }
.step-verb{ font-family:var(--font-display); font-weight:600; font-size:clamp(28px,3vw,40px); letter-spacing:-0.03em; color:var(--navy); margin:20px 0 6px; }
.step-title{ font-weight:600; font-size:17px; color:var(--ink); margin-bottom:14px; }
.step-list{ list-style:none; padding:0; margin:auto 0 0; }
.step-list li{ font-size:15px; color:var(--ink-soft); padding:9px 0; border-top:1px solid var(--line-faint); display:flex; align-items:center; gap:10px; }
.step-list li::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--cyan); flex:none; }
.step-track{ position:absolute; left:0; right:0; top:0; height:2px; background:var(--line-light); overflow:hidden; }
.step-track i{ position:absolute; inset:0; width:0; background:var(--cyan); transition:width 1.1s var(--ease); }
.in-view .step-track i{ width:100%; }
@media (max-width:820px){ .steps{ grid-template-columns:1fr; } .step{ min-height:auto; } }

/* ============================================================
   DASHBOARD METRICS
   ============================================================ */
.metrics{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-dark-faint); border:1px solid var(--line-dark-faint); border-radius:var(--radius-lg); overflow:hidden; }
.metric{ padding:clamp(28px,3vw,42px); background:linear-gradient(180deg, rgba(8,40,82,.32), rgba(0,17,43,.1)); position:relative; }
.metric .k{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.5); }
.metric .v{ font-family:var(--font-display); font-weight:600; font-size:clamp(40px,4.4vw,66px); line-height:1; letter-spacing:-0.04em; margin:14px 0 8px; color:#fff; }
.metric .v .u{ color:var(--cyan); }
.metric .lab{ font-size:15px; color:rgba(255,255,255,.62); }
.metric .bars{ display:flex; gap:3px; align-items:flex-end; height:30px; margin-top:18px; }
.metric .bars span{ flex:1; background:var(--cyan); opacity:.45; border-radius:1px; transform:scaleY(0); transform-origin:bottom; transition:transform .8s var(--ease); }
.in-view .metric .bars span{ transform:scaleY(1); }
@media (max-width:880px){ .metrics{ grid-template-columns:repeat(1,1fr);} }

/* ============================================================
   CASE STUDIES
   ============================================================ */
.cases{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.case{
  position:relative; border:1px solid var(--line-light); border-radius:var(--radius-lg);
  padding:clamp(26px,2.6vw,40px); overflow:hidden; background:var(--white);
  transition:transform .5s var(--ease-out), box-shadow .5s, border-color .5s;
}
.case:hover{ transform:translateY(-4px); box-shadow:0 30px 70px -40px rgba(0,41,90,.45); border-color:var(--gray-2); }
.case-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-bottom:24px; }
.case-vert{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--navy); }
.case-tag{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; color:var(--ink-soft); border:1px solid var(--line-light); border-radius:100px; padding:4px 11px; }
.case-result{ font-family:var(--font-display); font-weight:600; font-size:clamp(34px,3.6vw,52px); letter-spacing:-0.04em; line-height:1; color:var(--navy); }
.case-result .plus{ color:var(--cyan); }
.case-desc{ font-size:16px; color:var(--ink-soft); margin:12px 0 0; max-width:34ch; }
.case-chart{ height:120px; margin-top:26px; position:relative; }
.case-chart svg{ width:100%; height:100%; overflow:visible; }
.case-chart .path-line{ fill:none; stroke:var(--cyan); stroke-width:2.5; stroke-linecap:round; stroke-dasharray:1; stroke-dashoffset:1; }
.case-chart .path-area{ fill:url(#caseGrad); opacity:0; transition:opacity .9s .3s var(--ease); }
.case.in-view .path-line{ animation:draw 1.4s var(--ease) forwards; }
.case.in-view .path-area{ opacity:.5; }
.case-chart .node{ r:0; fill:#fff; stroke:var(--cyan); stroke-width:2.5; transition:r .4s .9s var(--ease); }
.case.in-view .node{ r:4.5; }
@keyframes draw{ to{ stroke-dashoffset:0; } }
@media (max-width:820px){ .cases{ grid-template-columns:1fr; } }

/* ============================================================
   SERVICES (flight modules)
   ============================================================ */
.modules{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-light); border:1px solid var(--line-light); border-radius:var(--radius-lg); overflow:hidden; }
.module{
  background:var(--white); padding:clamp(26px,2.6vw,38px); position:relative; min-height:240px;
  display:flex; flex-direction:column; transition:background .5s var(--ease);
  overflow:hidden;
}
.module:hover{ background:var(--navy-deep); color:var(--white); }
.module-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:auto; }
.module-id{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; color:var(--ink-soft); transition:color .5s; }
.module:hover .module-id{ color:var(--cyan); }
.module-led{ width:8px; height:8px; border-radius:50%; background:var(--gray-2); transition:background .5s, box-shadow .5s; }
.module:hover .module-led{ background:var(--cyan); box-shadow:0 0 12px var(--cyan); }
.module h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(22px,2.2vw,28px); letter-spacing:-0.025em; margin:30px 0 8px; }
.module p{ font-size:15px; color:var(--ink-soft); margin:0; transition:color .5s; }
.module:hover p{ color:rgba(255,255,255,.66); }
.module-wave{ position:absolute; right:-10px; bottom:-10px; width:120px; height:60px; opacity:0; transition:opacity .5s; }
.module:hover .module-wave{ opacity:.5; }
@media (max-width:880px){ .modules{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:520px){ .modules{ grid-template-columns:1fr;} }

/* ============================================================
   VERTICALS
   ============================================================ */
.verticals{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.vert{
  border:1px solid var(--line-light); border-radius:var(--radius); padding:24px 22px;
  min-height:150px; display:flex; flex-direction:column; justify-content:space-between;
  position:relative; overflow:hidden; transition:transform .5s var(--ease-out), border-color .5s, background .5s;
  background:var(--white);
}
.vert:hover{ transform:translateY(-4px); border-color:var(--cyan); background:var(--gray); }
.vert-no{ font-family:var(--font-mono); font-size:11px; color:var(--ink-soft); letter-spacing:.12em; }
.vert h4{ font-family:var(--font-display); font-weight:600; font-size:20px; letter-spacing:-0.02em; margin:0; }
.vert .arrow{ opacity:0; transform:translateX(-6px); transition:opacity .4s, transform .4s var(--ease-out); color:var(--navy); }
.vert:hover .arrow{ opacity:1; transform:translateX(0); }
@media (max-width:980px){ .verticals{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:480px){ .verticals{ grid-template-columns:1fr;} }

/* ============================================================
   TEAM
   ============================================================ */
.crew{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.crew-card{ position:relative; }
.crew-photo{
  width:100%; aspect-ratio:3/4; border-radius:var(--radius-lg); overflow:hidden;
  background:var(--gray); transition:transform .5s var(--ease-out), box-shadow .5s;
  position:relative;
}
.crew-card image-slot{ width:100%; height:100%; display:block; }
.crew-card image-slot img{ width:100%; height:100%; object-fit:cover; display:block; }
.crew-meta{ display:flex; justify-content:space-between; align-items:flex-start; margin-top:16px; }
.crew-name{ font-family:var(--font-display); font-weight:600; font-size:19px; letter-spacing:-0.02em; }
.crew-role{ font-size:14px; color:var(--ink-soft); margin-top:2px; }
.crew-tag{ font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; color:var(--cyan); border:1px solid var(--line-light); border-radius:100px; padding:3px 9px; white-space:nowrap; }
@media (max-width:980px){ .crew{ grid-template-columns:repeat(2,1fr);} }

/* ---------- Crew carousel ---------- */
.crew-carousel{ position:relative; }
.crew-carousel .crew-viewport{
  overflow:hidden;
  margin-inline:clamp(-12px, -2vw, -22px); /* let cards bleed slightly to the edges */
  padding-inline:clamp(12px, 2vw, 22px);
  padding-block:8px;
  cursor:grab;
}
.crew-carousel .crew-viewport.is-dragging{ cursor:grabbing; user-select:none; }
.crew-carousel .crew-track{
  display:flex !important;
  grid-template-columns:unset !important;
  gap:22px;
  will-change:transform;
  transition:transform .55s cubic-bezier(.22,.61,.36,1);
  align-items:flex-start;
  touch-action:pan-y;
}
.crew-carousel .crew-track.no-anim{ transition:none; }
.crew-carousel .crew-card{
  flex:0 0 calc((100% - 22px*2) / 3); /* default desktop: 3 visible */
  transition:transform .55s var(--ease-out), opacity .4s ease;
  opacity:.55;
  transform:scale(.92);
}
.crew-carousel .crew-card.is-active{
  opacity:1;
  transform:scale(1.04);
}
.crew-carousel .crew-card.is-near{ opacity:.85; transform:scale(.98); }

@media (max-width:1200px){
  .crew-carousel .crew-card{ flex-basis:calc((100% - 22px*2) / 3); } /* 3 visible */
}
@media (max-width:820px){
  .crew-carousel .crew-card{ flex-basis:calc((100% - 22px) / 2); }   /* 2 visible */
}
@media (max-width:520px){
  .crew-carousel .crew-card{ flex-basis:100%; }                       /* 1 visible */
}

.crew-arrow{
  position:absolute; top:38%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:50%;
  background:#fff; color:var(--ink); border:1px solid var(--line-light);
  display:grid; place-items:center; cursor:pointer; z-index:3;
  box-shadow:0 6px 22px rgba(10,27,42,.10);
  transition:background .18s, transform .18s, box-shadow .18s, color .18s;
}
.crew-arrow:hover{ background:var(--cyan); color:#062229; border-color:var(--cyan); transform:translateY(-50%) scale(1.05); }
.crew-arrow:active{ transform:translateY(-50%) scale(.98); }
.crew-arrow.crew-prev{ left:-22px; }
.crew-arrow.crew-next{ right:-22px; }
@media (max-width:980px){
  .crew-arrow{ width:40px; height:40px; }
  .crew-arrow.crew-prev{ left:4px; }
  .crew-arrow.crew-next{ right:4px; }
}

.crew-dots{
  display:flex; justify-content:center; gap:8px; margin-top:28px;
}
.crew-dots .dot{
  width:8px; height:8px; border-radius:50%;
  background:rgba(10,27,42,.18); border:0; padding:0; cursor:pointer;
  transition:background .2s, width .2s;
}
.crew-dots .dot.is-active{ background:var(--cyan); width:22px; border-radius:99px; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{ display:grid; grid-template-columns:1.1fr .9fr; gap:32px; align-items:stretch; }
.testi-video{ position:relative; border-radius:var(--radius-lg); overflow:hidden; background:var(--navy-deep); min-height:420px; }
.testi-video image-slot{ width:100%; height:100%; display:block; }
.testi-play{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:2; pointer-events:none;
}
.testi-play .ring{
  width:84px; height:84px; border-radius:50%; border:1.5px solid rgba(255,255,255,.7);
  display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px);
  background:rgba(0,17,43,.3);
}
.testi-body{ display:flex; flex-direction:column; justify-content:center; }
.testi-quote{ font-family:var(--font-display); font-weight:500; font-size:clamp(22px,2.4vw,32px); line-height:1.28; letter-spacing:-0.02em; color:var(--white); }
.dark .testi-quote .hl{ color:var(--cyan); }
.testi-author{ display:flex; align-items:center; gap:14px; margin-top:30px; }
.testi-author .av{ width:46px; height:46px; border-radius:50%; overflow:hidden; background:rgba(255,255,255,.1); }
.testi-author .nm{ font-weight:600; }
.testi-author .rl{ font-size:14px; color:rgba(255,255,255,.6); }
.testi-nav{ display:flex; gap:10px; margin-top:36px; }
.testi-dot{ width:34px; height:3px; border-radius:2px; background:rgba(255,255,255,.2); border:none; transition:background .4s; }
.testi-dot.active{ background:var(--cyan); }
@media (max-width:820px){ .testi{ grid-template-columns:1fr; } .testi-video{ min-height:300px; } }

/* ---------- Video testimonials grid ---------- */
.testi-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:22px;
  align-items:stretch;
}
.vtesti{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  aspect-ratio:9 / 14;
  background:#0E2E4A; isolation:isolate;
  transition:transform .35s var(--ease-out), box-shadow .35s;
}
.vtesti-featured{ transform:translateY(-12px); }
.vtesti:hover{ transform:translateY(-6px); box-shadow:0 24px 60px rgba(0,0,0,.45); }
.vtesti-featured:hover{ transform:translateY(-18px); }
.vtesti .vtesti-video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
  background:#0E2E4A;
}
.vtesti::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(8,30,60,0) 35%, rgba(4,15,30,.55) 70%, rgba(4,15,30,.9) 100%);
  pointer-events:none; z-index:1;
  transition:opacity .3s;
}
.vtesti.is-playing::after{ opacity:0; }

.vtesti-play{
  position:absolute; left:50%; top:50%; transform:translate(-50%, -50%);
  width:72px; height:72px; border-radius:50%; padding:0;
  background:var(--cyan); border:none; cursor:pointer;
  display:grid; place-items:center; z-index:2;
  box-shadow:0 0 0 0 rgba(63,200,192,.55), 0 14px 40px rgba(0,0,0,.4);
  transition:transform .25s, box-shadow .35s, background .25s;
  animation:vtesti-pulse 2.4s ease-out infinite;
}
.vtesti-play .ring{
  width:48px; height:48px; border-radius:50%;
  background:#fff; display:grid; place-items:center;
}
.vtesti-play:hover{ transform:translate(-50%,-50%) scale(1.07); background:#5BD8D1; }
.vtesti.is-playing .vtesti-play{ opacity:0; pointer-events:none; transform:translate(-50%,-50%) scale(.7); animation:none; }

@keyframes vtesti-pulse{
  0%   { box-shadow:0 0 0 0 rgba(63,200,192,.55), 0 14px 40px rgba(0,0,0,.4); }
  70%  { box-shadow:0 0 0 22px rgba(63,200,192,0), 0 14px 40px rgba(0,0,0,.4); }
  100% { box-shadow:0 0 0 0 rgba(63,200,192,0), 0 14px 40px rgba(0,0,0,.4); }
}

.vtesti-mark{
  position:absolute; top:18px; right:-30px; z-index:3;
  background:var(--cyan); color:#062229;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; font-weight:700;
  padding:5px 36px; transform:rotate(35deg);
  box-shadow:0 6px 18px rgba(63,200,192,.3);
  transition:opacity .3s;
}
.vtesti.is-playing .vtesti-mark{ opacity:0; }

.vtesti-meta{
  position:absolute; left:18px; right:18px; bottom:18px; z-index:3;
  color:#fff;
  transition:opacity .3s;
}
.vtesti.is-playing .vtesti-meta{ opacity:0; }
.vtesti-name{ font-family:var(--font-display); font-weight:600; font-size:18px; letter-spacing:-0.01em; }
.vtesti-brand{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; color:rgba(255,255,255,.7); margin-top:4px; text-transform:uppercase; }

@media (max-width:980px){
  .testi-grid{ grid-template-columns:1fr 1fr; }
  .vtesti:nth-child(3){ grid-column:span 2; max-width:520px; margin-inline:auto; }
  .vtesti-featured{ transform:none; }
}
@media (max-width:620px){
  .testi-grid{ grid-template-columns:1fr; }
  .vtesti, .vtesti-featured{ transform:none; aspect-ratio:9/12; }
  .vtesti:nth-child(3){ grid-column:auto; }
}

/* ---------- Media appearances (08) ---------- */
.section.media-press{ background:#F8F9FA; }
.media-logos{
  display:flex; align-items:center; justify-content:space-between;
  gap:clamp(20px, 4vw, 56px);
  flex-wrap:wrap;
  margin-top:8px;
}
.media-logo{
  flex:1 1 0; min-width:140px; max-width:220px;
  display:flex; align-items:center; justify-content:center;
  padding:14px 8px; border-radius:12px;
  transition:transform .35s var(--ease-out), background .25s;
}
.media-logo:hover{ background:rgba(10,37,64,.04); transform:translateY(-3px); }
.media-logo img{
  max-width:100%; max-height:60px; width:auto; height:auto; display:block;
  transition:transform .35s ease;
}
.media-logo:hover img{
  transform:scale(1.04);
}
@media (max-width:860px){
  .media-logos{ display:grid; grid-template-columns:repeat(2, 1fr); gap:18px; }
  .media-logo{ max-width:none; }
}
@media (max-width:460px){
  .media-logos{ grid-template-columns:1fr; }
}

/* ============================================================
   FINAL CTA
   ============================================================ */
.cta{ position:relative; overflow:hidden; text-align:center; padding-block:clamp(110px,14vw,200px); }
#cta-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; opacity:.85; }
.cta-inner{ position:relative; z-index:2; }
.cta h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(40px,6vw,86px); letter-spacing:-0.04em; line-height:1; margin:0 auto 26px; max-width:16ch; }
.cta .lead{ margin-inline:auto; color:rgba(255,255,255,.72); }
.cta-btns{ display:flex; gap:16px; justify-content:center; margin-top:42px; flex-wrap:wrap; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy-abyss); color:rgba(255,255,255,.6); padding-block:64px 40px; border-top:1px solid var(--line-dark-faint); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid var(--line-dark-faint); }
.footer .logo{ height:26px; margin-bottom:18px; }
.footer h5{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.45); margin:0 0 16px; }
.footer ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.footer ul a{ font-size:15px; color:rgba(255,255,255,.66); transition:color .3s; }
.footer ul a:hover{ color:var(--cyan); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:28px; font-size:13px; flex-wrap:wrap; gap:12px; }
.footer-bottom .mono{ font-family:var(--font-mono); letter-spacing:.06em; }
@media (max-width:820px){ .footer-grid{ grid-template-columns:1fr 1fr; } }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.reveal.in-view{ opacity:1; transform:none; }
.reveal-d1{ transition-delay:.08s; }
.reveal-d2{ transition-delay:.16s; }
.reveal-d3{ transition-delay:.24s; }
.reveal-d4{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; }
  *{ animation:none !important; }
}

/* mask reveal for headers */
.mask-up{ clip-path:inset(0 0 100% 0); transition:clip-path 1s var(--ease-out); }
.mask-up.in-view{ clip-path:inset(0 0 0 0); }

/* ============================================================
   TWEAKS PANEL
   ============================================================ */
#tweaks{
  position:fixed; right:18px; bottom:18px; z-index:200; width:280px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(18px) saturate(160%);
  border:1px solid var(--line-light); border-radius:18px;
  box-shadow:0 24px 70px -30px rgba(0,41,90,.5);
  padding:18px; font-size:14px; display:none;
}
#tweaks.on{ display:block; }
#tweaks h6{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; margin:0 0 14px; color:var(--navy); display:flex; justify-content:space-between; }
.tw-row{ margin-bottom:16px; }
.tw-row label{ display:block; font-size:12px; color:var(--ink-soft); margin-bottom:7px; font-family:var(--font-mono); letter-spacing:.06em; }
.tw-swatches{ display:flex; gap:8px; }
.tw-sw{ width:30px; height:30px; border-radius:8px; border:2px solid transparent; cursor:pointer; transition:transform .2s; }
.tw-sw:hover{ transform:scale(1.08); }
.tw-sw.sel{ border-color:var(--ink); }
.tw-seg{ display:flex; gap:6px; }
.tw-seg button{ flex:1; padding:7px; border:1px solid var(--line-light); background:#fff; border-radius:8px; font-size:12px; color:var(--ink-soft); transition:all .2s; }
.tw-seg button.sel{ background:var(--navy); color:#fff; border-color:var(--navy); }
#tweaks input[type=range]{ width:100%; accent-color:var(--navy); }

/* ===== SEO breadcrumb-nav (semantic + microdata) ===== */
.breadcrumb-nav{
  padding:96px 0 14px;
  background:#fff;
  position:relative; z-index:1;
}
.inner .breadcrumb-nav{ margin-top:0; }
/* When breadcrumb is present above hero, neutralize hero's extra top padding */
.breadcrumb-nav + .page-hero{ padding-top:var(--section-y); }
.breadcrumb-nav + .page-hero .crumb{ display:none; }
.breadcrumb-nav .wrap{ width:min(1280px, 92vw); margin-inline:auto; }
.breadcrumb-nav ol{
  list-style:none; padding:0; margin:0;
  display:flex; flex-wrap:wrap; align-items:center; gap:6px;
  font-family:var(--font-mono);
  font-size:12px; color:#94A3B8;
  letter-spacing:.04em;
}
.breadcrumb-nav li{ display:inline-flex; align-items:center; }
.breadcrumb-nav li:not(:last-child)::after{
  content:"/"; margin:0 8px; color:#CBD5E1;
}
.breadcrumb-nav a{
  color:#0A2540; text-decoration:none;
  transition:color .15s;
}
.breadcrumb-nav a:hover{ color:#3FC8C0; }
.breadcrumb-nav li:last-child span{ color:#64748B; }

/* FAQ summary now contains an <h3> for SEO; keep visual identical */
.faq summary h3{
  margin:0; padding:0; flex:1;
  font-family:var(--font-display); font-weight:600;
  font-size:18px; color:var(--ink); line-height:1.4;
  display:inline-block;
}
