/* ============================================================
   PEGASUS ENTERPRISE — Homepage v2
   Light theme (white, like Absolute Aviation) + motion engine
   Palette: white · navy-black #0A0E1A · red #C31D25 · silver #A6A8AB
   Type: Saira (display) · Inter (body) · JetBrains Mono (labels)
   ============================================================ */

:root{
  /* light surfaces */
  --bg:        #FFFFFF;
  --bg-soft:   #F4F6F9;   /* light grey panel        */
  --bg-soft-2: #ECEFF3;
  /* dark surfaces (hero / fleet showcase / footer) */
  --navy:      #0A0E1A;
  --navy-2:    #0E1424;
  --navy-3:    #161E33;
  /* text */
  --ink:       #0A0E1A;   /* headings on light       */
  --body:      #4B5365;   /* body on light           */
  --muted:     #828A9A;   /* meta on light           */
  --on-dark:   #D7DBE4;   /* body on dark            */
  --muted-d:   #8E96A6;   /* meta on dark            */
  /* accents */
  --red:       #C31D25;
  --red-2:     #E0242D;
  --silver:    #A6A8AB;
  --white:     #FFFFFF;
  /* lines */
  --line:      rgba(10,14,26,.10);
  --line-2:    rgba(10,14,26,.18);
  --line-d:    rgba(255,255,255,.12);
  --line-d2:   rgba(255,255,255,.20);

  --f-display: "Saira","Arial Narrow",sans-serif;
  --f-body:    "Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --f-mono:    "JetBrains Mono",ui-monospace,Menlo,Consolas,monospace;

  --container:1240px;
  --gutter:clamp(20px,5vw,64px);
  --radius:8px;
  --shadow-sm:0 2px 10px rgba(12,18,32,.06);
  --shadow:0 18px 50px -22px rgba(12,18,32,.22);
  --shadow-lg:0 40px 80px -30px rgba(12,18,32,.34);

  /* motion */
  --e-out:cubic-bezier(.16,1,.3,1);      /* expo-out, "framer" feel */
  --e-spring:cubic-bezier(.34,1.32,.5,1);/* gentle overshoot        */
  --e-soft:cubic-bezier(.4,0,.2,1);
  --header-h:118px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--f-body); background:var(--bg); color:var(--body);
  line-height:1.65; font-size:16px; overflow-x:hidden; -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--red); color:#fff; }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ position:relative; padding:clamp(74px,9vw,130px) 0; }
.section--tight{ padding:clamp(52px,6vw,84px) 0; }
#about,#services,#fleet,#airborne,#ground,#gallery,#testimonials,#contact{ scroll-margin-top:118px; }
.bg-soft{ background:var(--bg-soft); }
.band-dark{ background:var(--navy); color:var(--on-dark); position:relative; }
.band-dark::before{ /* subtle red glow */
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(60% 60% at 80% 0%, rgba(195,29,37,.16), transparent 60%);
}

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--f-display); font-weight:700; line-height:1.05; color:var(--ink); letter-spacing:.01em; }
.band-dark h1,.band-dark h2,.band-dark h3,.band-dark h4{ color:#fff; }
.display{ font-size:clamp(2.7rem,6.3vw,5.3rem); font-weight:800; line-height:.98; text-transform:uppercase; letter-spacing:.004em; }
.h2{ font-size:clamp(2rem,4.1vw,3.4rem); text-transform:uppercase; letter-spacing:.01em; }
.h3{ font-size:clamp(1.25rem,2vw,1.7rem); }
p{ color:var(--body); }
.band-dark p{ color:var(--on-dark); }
strong{ color:var(--ink); font-weight:600; }
.band-dark strong{ color:#fff; }

.kicker{ font-family:var(--f-mono); font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.32em; color:var(--red); display:inline-flex; align-items:center; gap:.7rem; }
.kicker::before{ content:""; width:26px; height:2px; background:var(--red); display:inline-block; }
.kicker.center{ justify-content:center; }
.band-dark .kicker{ color:#fff; }
.band-dark .sec-head p{ color:var(--muted-d); }

.sec-head{ max-width:760px; margin-bottom:clamp(34px,4vw,56px); }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head .h2{ margin-top:18px; }
.sec-head p{ margin-top:18px; color:var(--muted); }

.divider{ display:flex; align-items:center; gap:24px; justify-content:center; margin-bottom:48px; }
.divider span{ font-family:var(--f-display); font-weight:300; font-size:clamp(1.5rem,3vw,2.2rem); color:var(--ink); text-transform:lowercase; letter-spacing:.02em; }
.divider::before,.divider::after{ content:""; height:1px; background:var(--line-2); flex:1; max-width:220px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--f-mono); font-size:.78rem; font-weight:600; text-transform:uppercase; letter-spacing:.16em;
  padding:15px 26px 15px 22px; border:1px solid var(--line-2); color:var(--ink);
  background:transparent; border-radius:var(--radius);
  transition:background .45s var(--e-out), color .45s var(--e-out), border-color .45s var(--e-out), transform .3s var(--e-out), box-shadow .45s var(--e-out);
}
.btn .arrow{ width:30px; height:30px; flex:0 0 auto; border-radius:50%; border:1px solid currentColor; display:grid; place-items:center; transition:.45s var(--e-out); }
.btn .arrow svg{ width:13px; height:13px; transition:transform .45s var(--e-out); }
.btn:hover{ border-color:var(--red); background:var(--red); color:#fff; box-shadow:0 16px 30px -14px rgba(195,29,37,.6); }
.btn:hover .arrow{ border-color:#fff; }
.btn:hover .arrow svg{ transform:translateX(3px); }
.btn--solid{ background:var(--red); border-color:var(--red); color:#fff; }
.btn--solid:hover{ background:var(--red-2); border-color:var(--red-2); }
.btn--light{ color:#fff; border-color:var(--line-d2); }
.btn--light:hover{ background:#fff; color:var(--navy); border-color:#fff; box-shadow:0 16px 34px -16px rgba(0,0,0,.6); }

.link-arrow{ display:inline-flex; align-items:center; gap:10px; font-family:var(--f-mono); font-size:.74rem; font-weight:600; text-transform:uppercase; letter-spacing:.16em; color:var(--ink); transition:.3s var(--e-out); }
.band-dark .link-arrow{ color:#fff; }
.link-arrow svg{ width:16px; height:16px; transition:transform .3s var(--e-out); color:var(--red); }
.link-arrow:hover{ color:var(--red); }
.link-arrow:hover svg{ transform:translateX(5px); }

/* ============================================================
   MOTION ENGINE
   ============================================================ */
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; background:linear-gradient(90deg,var(--red),var(--red-2)); z-index:200; transition:width .1s linear; }

.anim{ opacity:0; will-change:opacity,transform; transition:opacity .85s var(--e-out), transform .85s var(--e-out); }
.anim[data-anim="up"]{ transform:translateY(42px); }
.anim[data-anim="down"]{ transform:translateY(-42px); }
.anim[data-anim="left"]{ transform:translateX(-54px); }
.anim[data-anim="right"]{ transform:translateX(54px); }
.anim[data-anim="scale"]{ transform:scale(.9); }
.anim[data-anim="zoom"]{ transform:scale(1.12); }
.anim[data-anim="clip"]{ clip-path:inset(0 0 100% 0); opacity:1; }
.anim.is-visible{ opacity:1; transform:none; clip-path:inset(0 0 0 0); }
.anim.use-spring{ transition-timing-function:var(--e-spring); }

[data-parallax]{ will-change:transform; }

/* ============================================================
   HEADER  (solid white, Absolute-style)
   ============================================================ */
.site-header{ position:fixed; inset:0 0 auto 0; z-index:100; padding:18px 0; background:rgba(255,255,255,.96); transition:padding .45s var(--e-out), box-shadow .45s var(--e-out); }
.site-header::after{ content:""; position:absolute; inset:auto 0 0 0; height:1px; background:var(--line); }
.site-header.scrolled{ padding:10px 0; box-shadow:var(--shadow-sm); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); }
.header-inner{ display:flex; flex-direction:column; align-items:center; gap:14px; }
.brand img{ height:54px; width:auto; transition:height .45s var(--e-out); }
.site-header.scrolled .brand img{ height:40px; }
.main-nav ul{ display:flex; align-items:center; gap:clamp(16px,2.3vw,38px); }
.main-nav a{ font-family:var(--f-mono); font-size:.76rem; font-weight:500; text-transform:uppercase; letter-spacing:.15em; color:#2A3142; padding:6px 0; position:relative; transition:.3s var(--e-out); white-space:nowrap; }
.main-nav a::after{ content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--red); transition:width .35s var(--e-out); }
.main-nav a:hover,.main-nav a.active{ color:var(--red); }
.main-nav a:hover::after,.main-nav a.active::after{ width:100%; }
.nav-toggle{ display:none; position:absolute; right:var(--gutter); top:50%; transform:translateY(-50%); width:42px; height:42px; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--ink); margin:5px auto; transition:.3s var(--e-out); }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============================================================
   HERO  (dark cinematic band)
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; background:var(--navy); }
.hero-slides{ position:absolute; left:0; right:0; top:-8%; height:116%; }
.hero-slide{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transform:scale(1.08); transition:opacity 1.4s var(--e-out); }
.hero-slide.active{ opacity:1; animation:kenburns 8s linear forwards; }
@keyframes kenburns{ from{ transform:scale(1.08); } to{ transform:scale(1); } }
.hero::before{ content:""; position:absolute; inset:0; z-index:2;
  background:linear-gradient(90deg, rgba(6,8,15,.9) 0%, rgba(6,8,15,.5) 44%, rgba(6,8,15,.12) 76%, rgba(6,8,15,.42) 100%),
             linear-gradient(0deg, rgba(6,8,15,.92) 0%, rgba(6,8,15,.08) 46%, rgba(6,8,15,.34) 100%); }
.hero-content{ position:relative; z-index:3; width:100%; padding-bottom:clamp(74px,9vh,120px); padding-top:var(--header-h); }
.hero-content .inner{ max-width:790px; }
.hero h1{ margin:22px 0 0; color:#fff; }
.hero h1 .lt{ display:block; font-weight:300; color:#eef0f5; }
.hero h1 .hv{ display:block; font-weight:800; color:#fff; }
.hero h1 .hv em{ font-style:normal; color:#fff; position:relative; }
.hero h1 .hv em::after{ content:""; position:absolute; left:0; right:0; bottom:.08em; height:.1em; background:var(--red); transform:scaleX(0); transform-origin:left; animation:underline 1s var(--e-out) 1s forwards; }
@keyframes underline{ to{ transform:scaleX(1); } }
.hero .sub{ margin-top:26px; max-width:620px; font-size:clamp(1rem,1.25vw,1.18rem); color:#d6dae3; }
.hero .actions{ margin-top:38px; display:flex; flex-wrap:wrap; gap:16px; }
.hero-rule{ margin-top:42px; height:1px; width:min(560px,80%); background:linear-gradient(90deg,var(--red),rgba(195,29,37,0)); transform-origin:left; }
.hero-dots{ position:absolute; z-index:4; left:var(--gutter); bottom:32px; display:flex; gap:12px; }
.hero-dots button{ width:34px; height:3px; background:rgba(255,255,255,.3); transition:.4s var(--e-out); }
.hero-dots button.active{ background:var(--red); }
.hero-aside{ position:absolute; z-index:4; right:var(--gutter); bottom:32px; display:flex; align-items:center; gap:14px; font-family:var(--f-mono); font-size:.64rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted-d); writing-mode:vertical-rl; }
.hero-aside::after{ content:""; width:1px; height:50px; background:var(--line-d2); animation:scrollpulse 2s ease-in-out infinite; }
@keyframes scrollpulse{ 0%,100%{ opacity:.3; transform:scaleY(.6);} 50%{ opacity:1; transform:scaleY(1);} }

/* ============================================================
   STATS
   ============================================================ */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--bg); box-shadow:var(--shadow); margin-top:-60px; position:relative; z-index:5; }
.stat{ padding:34px clamp(18px,2vw,34px); border-right:1px solid var(--line); }
.stat:last-child{ border-right:none; }
.stat .n{ font-family:var(--f-display); font-weight:800; font-size:clamp(2.2rem,4vw,3.1rem); color:var(--ink); line-height:1; }
.stat .n em{ font-style:normal; color:var(--red); }
.stat .l{ margin-top:10px; font-family:var(--f-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,5vw,80px); align-items:center; }
.about-copy p{ margin-top:18px; }
.about-copy .btn{ margin-top:32px; }
.about-media{ position:relative; }
.about-media img{ width:100%; aspect-ratio:4/4.5; object-fit:cover; border-radius:var(--radius); box-shadow:var(--shadow); }
.about-media .frame{ position:absolute; inset:18px -18px -18px 18px; border:1px solid var(--red); border-radius:var(--radius); z-index:-1; }
.about-media .badge{ position:absolute; left:-12px; bottom:26px; background:var(--red); color:#fff; padding:18px 22px; max-width:230px; box-shadow:var(--shadow); }
.about-media .badge .bn{ font-family:var(--f-display); font-weight:800; font-size:2.1rem; line-height:1; }
.about-media .badge .bl{ font-size:.82rem; margin-top:6px; color:#ffdcde; }

.affil{ margin-top:clamp(48px,6vw,80px); display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.affil-card{ border:1px solid var(--line); background:var(--bg); border-radius:var(--radius); padding:30px 28px; transition:transform .45s var(--e-out), box-shadow .45s var(--e-out), border-color .45s var(--e-out); position:relative; overflow:hidden; }
.affil-card::before{ content:""; position:absolute; left:0; top:0; width:3px; height:0; background:var(--red); transition:height .45s var(--e-out); }
.affil-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.affil-card:hover::before{ height:100%; }
.affil-card .num{ font-family:var(--f-mono); color:var(--red); font-size:.72rem; letter-spacing:.18em; }
.affil-card h4{ font-size:1.15rem; margin:14px 0 8px; color:var(--ink); }
.affil-card p{ font-size:.92rem; color:var(--muted); }
.band-dark .affil-card{ background:var(--navy-2); border-color:var(--line-d); }
.band-dark .affil-card h4{ color:#fff; }
.band-dark .affil-card:hover{ box-shadow:0 30px 60px -30px rgba(0,0,0,.8); }

/* ============================================================
   SERVICES HUB  (image tiles on light section)
   ============================================================ */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc-card{ position:relative; display:block; overflow:hidden; border-radius:var(--radius); min-height:450px; box-shadow:var(--shadow); transition:transform .5s var(--e-out), box-shadow .5s var(--e-out); }
.svc-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.svc-card .media{ position:absolute; inset:0; }
.svc-card .media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--e-out); }
.svc-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,14,26,.1) 0%, rgba(10,14,26,.5) 45%, rgba(8,11,20,.95) 100%); }
.svc-card:hover .media img{ transform:scale(1.08); }
.svc-card .body{ position:absolute; z-index:2; inset:auto 0 0 0; padding:30px clamp(22px,2vw,30px); }
.svc-card .num{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.24em; color:#fff; opacity:.7; }
.svc-card h3{ margin:12px 0 10px; font-size:1.5rem; text-transform:uppercase; letter-spacing:.01em; color:#fff; }
.svc-card p{ font-size:.92rem; color:#dde0e7; max-height:0; opacity:0; overflow:hidden; transition:max-height .5s var(--e-out), opacity .5s var(--e-out); }
.svc-card .link-arrow{ margin-top:18px; color:#fff; }
.svc-card:hover p{ max-height:130px; opacity:1; }
.svc-card .accent{ position:absolute; left:0; top:0; height:4px; width:0; background:var(--red); transition:width .5s var(--e-out); z-index:3; }
.svc-card:hover .accent{ width:100%; }
@media (hover:none){ .svc-card p{ max-height:140px; opacity:1; } }

/* ============================================================
   FLEET  (dark showcase band, accurate Textron renders)
   ============================================================ */
.fleet-top{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.fleet-grid{ margin-top:clamp(34px,4vw,52px); display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.ac-card{ border:1px solid var(--line-d); background:linear-gradient(180deg,var(--navy-3),var(--navy-2)); border-radius:var(--radius); padding:24px; display:flex; flex-direction:column; transition:transform .45s var(--e-out), border-color .45s var(--e-out), box-shadow .45s var(--e-out); position:relative; overflow:hidden; }
.ac-card::before{ content:""; position:absolute; inset:0; background:radial-gradient(120% 70% at 70% 0%, rgba(195,29,37,.14), transparent 60%); opacity:0; transition:opacity .45s var(--e-out); }
.ac-card:hover{ transform:translateY(-6px); border-color:var(--red); box-shadow:0 40px 70px -30px rgba(0,0,0,.85); }
.ac-card:hover::before{ opacity:1; }
.ac-card .cat{ font-family:var(--f-mono); font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); position:relative; z-index:2; }
.ac-card h3{ font-size:1.3rem; margin:6px 0 4px; color:#fff; position:relative; z-index:2; }
.ac-imgwrap{ height:148px; margin:14px 0 18px; display:grid; place-items:center; position:relative; z-index:2; }
.ac-imgwrap img{ max-height:148px; width:auto; object-fit:contain; transition:transform .6s var(--e-out); filter:drop-shadow(0 18px 22px rgba(0,0,0,.55)); }
.ac-card:hover .ac-imgwrap img{ transform:scale(1.06) translateX(6px); }
.ac-specs{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; border-top:1px solid var(--line-d); padding-top:16px; margin-top:auto; position:relative; z-index:2; }
.ac-specs .v{ font-family:var(--f-display); font-weight:700; font-size:1.16rem; color:#fff; }
.ac-specs .k{ font-family:var(--f-mono); font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-d); margin-top:3px; }
.ac-foot{ margin-top:18px; display:flex; align-items:center; justify-content:space-between; position:relative; z-index:2; }
.ac-foot .price{ font-family:var(--f-mono); font-size:.66rem; letter-spacing:.14em; color:var(--silver); text-transform:uppercase; }

/* ============================================================
   SPLIT FEATURE (Airborne) — light
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; align-items:stretch; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.split .media{ position:relative; min-height:520px; overflow:hidden; }
.split .media img{ position:absolute; left:0; right:0; top:-9%; width:100%; height:118%; object-fit:cover; }
.split .copy{ padding:clamp(40px,5vw,80px) clamp(28px,4vw,68px); display:flex; flex-direction:column; justify-content:center; background:var(--bg); }
.split .copy h2{ margin:18px 0 8px; }
.feat-list{ margin-top:24px; display:grid; }
.feat-list li{ display:flex; gap:16px; padding:18px 0; border-top:1px solid var(--line); }
.feat-list li:last-child{ border-bottom:1px solid var(--line); }
.feat-list .fi{ font-family:var(--f-display); font-weight:800; color:var(--red); font-size:1rem; min-width:34px; }
.feat-list h4{ font-size:1.02rem; color:var(--ink); font-family:var(--f-body); font-weight:600; }
.feat-list p{ font-size:.9rem; color:var(--muted); margin-top:3px; }

/* ============================================================
   GROUND (light cards)
   ============================================================ */
.feature-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.feature-cards .affil-card .num{ font-size:1.4rem; font-family:var(--f-display); font-weight:800; letter-spacing:0; }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px; }
.gallery a{ position:relative; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow-sm); }
.gallery a img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--e-out); }
.gallery a::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(8,11,20,.5)); opacity:0; transition:.5s var(--e-out); }
.gallery a:hover img{ transform:scale(1.1); }
.gallery a:hover::after{ opacity:1; }
.gallery .tall{ grid-row:span 2; }
.gallery .wide{ grid-column:span 2; }

/* ============================================================
   TESTIMONIALS (light)
   ============================================================ */
.testi-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.testi{ border:1px solid var(--line); background:var(--bg); border-radius:var(--radius); padding:clamp(28px,3vw,44px); position:relative; transition:transform .45s var(--e-out), box-shadow .45s var(--e-out); }
.testi:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.testi .mark{ font-family:var(--f-display); font-weight:800; font-size:5rem; line-height:.6; color:var(--red); opacity:.18; }
.testi blockquote{ font-family:var(--f-display); font-weight:300; font-size:clamp(1.2rem,1.7vw,1.55rem); color:var(--ink); line-height:1.4; margin:8px 0 24px; }
.testi .who{ display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--line); padding-top:18px; }
.testi .who .nm{ font-family:var(--f-mono); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); }
.testi .who .loc{ font-size:.82rem; color:var(--muted); }
.stars{ color:var(--red); letter-spacing:3px; font-size:.9rem; }

/* ============================================================
   CTA / CONTACT (dark band)
   ============================================================ */
.cta{ position:relative; overflow:hidden; background:linear-gradient(120deg,var(--navy-2),var(--navy)); border-radius:var(--radius); padding:clamp(40px,5vw,72px); box-shadow:var(--shadow-lg); }
.cta::before{ content:""; position:absolute; right:-60px; top:-60px; width:340px; height:340px; background:radial-gradient(circle,rgba(195,29,37,.28),transparent 70%); }
.cta-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(30px,4vw,64px); align-items:center; position:relative; }
.cta .kicker{ color:#ff6168; }
.cta .kicker::before{ background:#ff6168; }
.cta h2{ margin:16px 0 10px; color:#fff; }
.cta p{ color:var(--on-dark); }
.subscribe{ display:flex; gap:10px; margin-top:20px; flex-wrap:wrap; }
.subscribe input{ flex:1; min-width:220px; background:rgba(255,255,255,.05); border:1px solid var(--line-d2); color:#fff; padding:15px 18px; font-family:var(--f-mono); font-size:.82rem; letter-spacing:.04em; border-radius:var(--radius); }
.subscribe input::placeholder{ color:var(--muted-d); }
.subscribe input:focus{ outline:none; border-color:var(--red); }
.cta-side{ border-left:1px solid var(--line-d); padding-left:clamp(20px,3vw,48px); }
.cta-side .row{ display:flex; gap:14px; padding:14px 0; align-items:flex-start; }
.cta-side .row .ic{ color:var(--red-2); flex:0 0 auto; margin-top:2px; }
.cta-side .row .t b{ display:block; color:#fff; font-weight:600; font-size:.95rem; }
.cta-side .row .t span{ font-size:.86rem; color:var(--muted-d); }

/* inquiry form */
.inquiry-form{ position:relative; margin-top:clamp(30px,3vw,44px); border-top:1px solid var(--line-d); padding-top:clamp(28px,3vw,40px); }
.form-label{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:#ff6168; margin:4px 0 18px; }
.form-label.second{ margin-top:30px; }
.form-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:15px; }
.field{ display:flex; flex-direction:column; gap:8px; min-width:0; }
.field.c3{ grid-column:span 3; } .field.c4{ grid-column:span 4; } .field.c6{ grid-column:span 6; } .field.c12{ grid-column:span 12; }
.field label{ font-family:var(--f-mono); font-size:.62rem; letter-spacing:.13em; text-transform:uppercase; color:var(--muted-d); }
.field label .req{ color:var(--red-2); }
.field input,.field select,.field textarea{ width:100%; background:rgba(255,255,255,.05); border:1px solid var(--line-d2); color:#fff; padding:13px 15px; font-family:var(--f-body); font-size:.9rem; border-radius:var(--radius); transition:border-color .3s var(--e-out), background .3s var(--e-out); }
.field input::placeholder,.field textarea::placeholder{ color:#727a8c; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--red); background:rgba(255,255,255,.09); }
.field select{ appearance:none; -webkit-appearance:none; cursor:pointer; padding-right:38px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238E96A6' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; }
.field select option{ color:#0A0E1A; }
.form-actions{ margin-top:30px; display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.form-note{ font-family:var(--f-mono); font-size:.7rem; letter-spacing:.05em; color:var(--muted-d); max-width:360px; }
.form-note.ok{ color:#46d27c; }
@media (max-width:1024px){ .field.c3,.field.c4{ grid-column:span 6; } }
@media (max-width:620px){ .form-grid .field{ grid-column:span 12; } }

/* ============================================================
   FOOTER (dark)
   ============================================================ */
.footer{ background:var(--navy); color:var(--on-dark); border-top:1px solid var(--line-d); padding-top:clamp(56px,6vw,88px); }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:clamp(28px,4vw,56px); padding-bottom:54px; }
.footer .brand img{ height:66px; margin-bottom:20px; }
.footer .blurb{ color:var(--muted-d); font-size:.92rem; max-width:300px; }
.footer .contact-line{ margin-top:18px; font-family:var(--f-mono); font-size:.78rem; letter-spacing:.06em; color:var(--on-dark); }
.footer .contact-line a{ color:var(--red-2); }
.footer h5{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-bottom:20px; }
.footer ul li{ margin-bottom:12px; }
.footer ul a{ color:#c0c5d0; font-size:.92rem; transition:.3s var(--e-out); }
.footer ul a:hover{ color:var(--red-2); padding-left:5px; }
.socials{ display:flex; gap:10px; margin-top:8px; }
.socials a{ width:40px; height:40px; border:1px solid var(--line-d2); border-radius:6px; display:grid; place-items:center; transition:.35s var(--e-out); }
.socials a:hover{ background:var(--red); border-color:var(--red); transform:translateY(-3px); }
.socials svg{ width:17px; height:17px; }
.footer-bottom{ border-top:1px solid var(--line-d); padding:24px 0 34px; display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; }
.footer-bottom .copy{ font-size:.8rem; color:var(--muted-d); }
.footer-bottom .tag{ font-family:var(--f-display); font-weight:300; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); font-size:.9rem; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .about-grid{ grid-template-columns:1fr; }
  .about-media{ max-width:520px; }
  .svc-grid{ grid-template-columns:1fr 1fr; }
  .fleet-grid{ grid-template-columns:1fr 1fr; }
  .feature-cards{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; }
  .split .media{ min-height:320px; }
  .cta-grid{ grid-template-columns:1fr; }
  .cta-side{ border-left:none; border-top:1px solid var(--line-d); padding-left:0; padding-top:24px; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  :root{ --header-h:88px; }
  .site-header{ padding:12px 0; }
  .header-inner{ flex-direction:row; justify-content:space-between; }
  .brand img{ height:38px; }
  .site-header.scrolled .brand img{ height:34px; }
  .nav-toggle{ display:block; position:static; transform:none; }
  .main-nav{ position:fixed; inset:0; background:rgba(255,255,255,.99); display:flex; align-items:center; justify-content:center; transform:translateX(100%); transition:transform .5s var(--e-out); z-index:90; }
  .main-nav.open{ transform:none; }
  .main-nav ul{ flex-direction:column; gap:26px; text-align:center; }
  .main-nav a{ font-size:1.05rem; color:var(--ink); }
  .stats{ grid-template-columns:1fr 1fr; margin-top:-40px; }
  .stat:nth-child(2){ border-right:none; }
  .stat:nth-child(1),.stat:nth-child(2){ border-bottom:1px solid var(--line); }
  .svc-grid{ grid-template-columns:1fr; }
  .svc-card{ min-height:420px; }
  .svc-card p{ max-height:160px; opacity:1; }
  .fleet-grid{ grid-template-columns:1fr; }
  .feature-cards{ grid-template-columns:1fr; }
  .testi-grid{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr 1fr; grid-auto-rows:150px; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-aside{ display:none; }
  .affil{ grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .anim{ opacity:1!important; transform:none!important; clip-path:none!important; }
  .hero-slide.active{ animation:none; }
}
