/* ============================================================================
   ERA LOGISTIC INC. - STYLESHEET
   Light theme, professional logistics website
   ============================================================================ */

/* ============ CSS VARIABLES (Design Tokens) ============ */
:root{
  /* Color palette */
  --bg:#fafaf7;           /* Main background - warm cream */
  --bg-2:#f3f2ec;         /* Secondary background */
  --bg-3:#eeede5;         /* Tertiary background */
  --paper:#ffffff;        /* Pure white for cards */
  --ink:#0a0a0a;          /* Primary text - near black */
  --ink-2:#1a1a1a;        /* Secondary text */
  --ink-dim:#5a5a5a;      /* Dimmed text */
  --ink-faint:#9a9a94;    /* Faint text */
  --line:#e5e3da;         /* Border color - light */
  --line-2:#d4d2c7;       /* Border color - medium */
  --line-3:#bcbab0;       /* Border color - dark */
  
  /* Brand colors */
  --yellow:#FFD400;       /* Primary accent - ERA yellow */
  --yellow-2:#FFC700;     /* Hover state */
  --yellow-deep:#E8B800;  /* Darker accent */
  --yellow-soft:#FFF6CC;  /* Soft background */
  
  /* Typography */
  --display:'Fraunces', Georgia, serif;          /* Headlines */
  --body:'Inter', system-ui, sans-serif;         /* Body text */
  --mono:'JetBrains Mono', ui-monospace, monospace;  /* Labels & metadata */
  
  /* Layout */
  --pad-x:clamp(20px, 4vw, 72px);  /* Responsive horizontal padding */
  
  /* Shadows */
  --shadow-sm:0 1px 2px rgba(0,0,0,.04), 0 2px 8px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.06), 0 12px 28px rgba(0,0,0,.05);
  --shadow-lg:0 12px 32px rgba(0,0,0,.08), 0 24px 64px rgba(0,0,0,.06);
}

/* ============ GLOBAL RESETS & BASE STYLES ============ */

/* Reset default spacing */
*{margin:0;padding:0;box-sizing:border-box}

/* Base HTML & body styles */
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Link & button resets */
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}

/* Media resets */
img,svg{display:block;max-width:100%}

/* Text selection color */
::selection{background:var(--yellow);color:#0a0a0a}

/* ============ CUSTOM SCROLLBAR ============ */
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:0;border:3px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--ink)}

/* ============ VISUAL EFFECTS & OVERLAYS ============ */

/* Subtle grain texture overlay (fixed position) */
.grain{
  pointer-events:none;
  position:fixed;inset:0;z-index:9999;
  opacity:.025;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* Page transition curtain (sweeps up/down between pages) */
.curtain{
  position:fixed;inset:0;background:var(--ink);
  z-index:9998;transform:translateY(100%);
  pointer-events:none;
}
.curtain.in{animation:curtain-in .5s cubic-bezier(.7,0,.3,1) forwards}
.curtain.out{animation:curtain-out .5s cubic-bezier(.7,0,.3,1) forwards}
@keyframes curtain-in{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes curtain-out{from{transform:translateY(0)}to{transform:translateY(-100%)}}

/* ============================================================================
   NAVIGATION BAR (Fixed header)
   ============================================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:8px var(--pad-x);
  background:rgba(250,250,247,.85);
  backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid var(--line);
  transition:padding .3s ease;
}
.nav.scrolled{padding:4px var(--pad-x)}

.logo{display:block;transition:opacity .25s ease}
.logo:hover{opacity:.75}
.logo-img{height:100px;width:auto;display:block}

.nav-links{display:flex;gap:4px}
.nav-links a{
  position:relative;padding:8px 16px;
  font-size:14px;font-weight:500;
  color:var(--ink-dim);transition:color .25s ease;
}
.nav-links a::after{
  content:"";position:absolute;left:50%;bottom:0;
  width:0;height:2px;background:var(--yellow);
  transition:width .3s ease, left .3s ease;
}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:20px;left:calc(50% - 10px)}

.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;
  background:var(--ink);color:#fff;
  font-weight:600;font-size:13px;letter-spacing:.2px;
  border:1px solid var(--ink);border-radius:999px;
  transition:all .25s ease;
  position:relative;overflow:hidden;
}
.nav-cta::before{
  content:"";position:absolute;inset:0;background:var(--yellow);
  transform:translateY(100%);transition:transform .3s cubic-bezier(.7,0,.3,1);z-index:0;
}
.nav-cta:hover::before{transform:translateY(0)}
.nav-cta:hover{color:var(--ink)}
.nav-cta span,.nav-cta svg{position:relative;z-index:1}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:22px;height:2px;background:var(--ink);transition:all .3s}

@media (max-width:900px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav.open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.open .nav-toggle span:nth-child(2){opacity:0}
  .nav.open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav.open .nav-links{
    display:flex;flex-direction:column;gap:0;
    position:absolute;top:100%;left:0;right:0;
    background:var(--paper);padding:16px var(--pad-x) 24px;
    border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-md);
  }
  .nav.open .nav-links a{padding:14px 0;font-size:18px;border-bottom:1px solid var(--line)}
  .nav.open .nav-links a:last-child{border-bottom:none}
}

/* ============================================================================
   HERO IMAGE BLOCKS (Featured images with overlay captions)
   ============================================================================ */
.hero-image-block{
  position:relative;
  min-height:520px;
  background:var(--bg-2);
  border-bottom:1px solid var(--line);
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.hero-image-block img{
  width:100%;height:100%;object-fit:cover;
  position:absolute;inset:0;
}
.hero-image-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(10,10,10,.3) 0%, rgba(10,10,10,.1) 50%, rgba(250,250,247,.6) 100%);
  z-index:1;
}
.hero-image-caption{
  position:relative;z-index:2;
  background:rgba(250,250,247,.92);backdrop-filter:blur(12px);
  padding:24px 32px;border:1px solid var(--line);
  max-width:600px;margin:0 var(--pad-x);
  box-shadow:var(--shadow-lg);
}
.hero-image-caption h3{
  font-family:var(--display);font-size:28px;font-weight:500;
  letter-spacing:-.6px;margin-bottom:10px;color:var(--ink);
}
.hero-image-caption p{
  color:var(--ink-dim);font-size:15px;line-height:1.65;
}

@media (max-width:900px){
  .hero-image-block{min-height:400px}
  .hero-image-caption{padding:20px 24px}
  .hero-image-caption h3{font-size:22px}
}

/* ============================================================================
   PAGE BASE & LAYOUT
   ============================================================================ */
main{padding-top:78px}
.page{
  min-height:calc(100vh - 78px);
  animation:page-fade .5s ease both;
}
@keyframes page-fade{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

/* ============================================================================
   HERO SECTION (Homepage main hero)
   ============================================================================ */
.hero{
  position:relative;
  min-height:calc(100vh - 78px);
  padding:80px var(--pad-x) 60px;
  display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at 70% 50%, #000 25%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at 70% 50%, #000 25%, transparent 70%);
  opacity:.7;
}
.hero-spotlight{
  position:absolute;width:800px;height:800px;
  background:radial-gradient(circle, rgba(255,212,0,.22) 0%, transparent 60%);
  top:-200px;right:-150px;pointer-events:none;
  animation:pulse 10s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{transform:scale(1);opacity:.7}
  50%{transform:scale(1.12);opacity:1}
}

.hero-meta{
  display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:2.5px;
  color:var(--ink-dim);margin-bottom:32px;
  position:relative;z-index:2;font-weight:500;
  animation:slide-up .8s .1s both;
}
.hero-meta .dot{
  width:8px;height:8px;background:var(--yellow);border-radius:50%;
  box-shadow:0 0 0 4px rgba(255,212,0,.25);
  animation:blink 1.8s infinite;
}
@keyframes blink{50%{opacity:.4}}
.hero-meta::after{content:"";flex:1;height:1px;background:var(--line-2);max-width:100px}

.hero h1{
  font-family:var(--display);
  font-size:clamp(56px, 11vw, 180px);
  font-weight:400;
  line-height:1.1;letter-spacing:-3.5px;
  position:relative;z-index:2;
  color:var(--ink);
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.hero h1 .word{display:inline-block;overflow:visible;vertical-align:bottom}
.hero h1 .word span{display:inline-block;animation:rise 1s cubic-bezier(.25,1,.5,1) both}
.hero h1 .word:nth-child(1) span{animation-delay:.15s}
.hero h1 .word:nth-child(3) span{animation-delay:.25s}
.hero h1 .word:nth-child(5) span{animation-delay:.35s}
.hero h1 em{
  font-style:italic;font-weight:400;
  font-variation-settings:"opsz" 144, "SOFT" 100;
  position:relative;
}
.hero h1 em::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:8%;
  height:.4em;background:var(--yellow);z-index:-1;
  transform:skew(-4deg);
}
@keyframes rise{from{transform:translateY(110%)}to{transform:translateY(0)}}

.hero-bottom{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:48px;flex-wrap:wrap;
  margin-top:56px;position:relative;z-index:2;
}
.hero-lede{
  max-width:480px;font-size:17px;color:var(--ink-dim);
  line-height:1.65;animation:slide-up 1s .8s both;
}
.hero-lede strong{color:var(--ink);font-weight:600}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;animation:slide-up 1s .9s both}

@keyframes slide-up{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

/* ============================================================================
   BUTTONS & CALL-TO-ACTION ELEMENTS
   ============================================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 28px;font-weight:600;font-size:14px;
  letter-spacing:.1px;
  border-radius:999px;
  position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  background:var(--ink);color:#fff;
  border:1px solid var(--ink);
  box-shadow:var(--shadow-sm);
}
.btn-primary::before{
  content:"";position:absolute;inset:0;background:var(--yellow);
  transform:translateY(100%);transition:transform .35s cubic-bezier(.7,0,.3,1);z-index:0;
}
.btn-primary:hover::before{transform:translateY(0)}
.btn-primary:hover{color:var(--ink);box-shadow:var(--shadow-md)}
.btn-primary > *{position:relative;z-index:1}

.btn-ghost{
  background:transparent;color:var(--ink);
  border:1px solid var(--line-3);
}
.btn-ghost:hover{border-color:var(--ink);background:var(--paper);box-shadow:var(--shadow-sm)}

/* Rest of CSS continues exactly as before... */

/* ============ STATS STRIP ============ */
.stats-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--paper);
}
.stat{
  padding:40px var(--pad-x);
  border-right:1px solid var(--line);
  position:relative;overflow:hidden;
  transition:background .35s ease;
}
.stat:last-child{border-right:none}
.stat:hover{background:var(--bg-2)}
.stat-num{
  font-family:var(--display);font-size:clamp(40px,5vw,68px);
  color:var(--ink);line-height:1;letter-spacing:-2px;font-weight:500;
  font-variation-settings:"opsz" 72;
}
.stat-label{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  color:var(--ink-dim);margin-top:12px;text-transform:uppercase;font-weight:500;
}
.stat::before{
  content:"";position:absolute;top:0;left:0;width:0;height:3px;
  background:var(--yellow);transition:width .5s ease;
}
.stat:hover::before{width:100%}

@media (max-width:900px){
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .stat{border-bottom:1px solid var(--line)}
  .stat:nth-child(2){border-right:none}
}

/* Stats strip modifier */
.stats-strip--no-top{border-top:none}

/* Section modifiers */
.section-head--compact{margin-bottom:48px}
.h2--compact{font-size:clamp(36px,5vw,64px)}

/* ============ MARQUEE ============ */
.marquee{
  background:var(--ink);color:#fff;
  padding:20px 0;overflow:hidden;
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
}
.marquee-track{
  display:flex;gap:48px;white-space:nowrap;
  animation:marquee 40s linear infinite;
  font-family:var(--display);font-size:24px;font-weight:400;
  letter-spacing:-.5px;font-style:italic;
}
.marquee-track span{display:inline-flex;align-items:center;gap:48px}
.marquee-track span::after{
  content:"";display:inline-block;width:8px;height:8px;
  background:var(--yellow);border-radius:50%;
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ============ SECTIONS ============ */
.section{padding:120px var(--pad-x);border-bottom:1px solid var(--line);position:relative}
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:48px;flex-wrap:wrap;margin-bottom:72px;
}
.section-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:3px;
  color:var(--ink-dim);margin-bottom:20px;text-transform:uppercase;
  display:flex;align-items:center;gap:14px;font-weight:500;
}
.section-eyebrow::before{content:"";width:32px;height:1px;background:var(--ink)}
.section-eyebrow .num{color:var(--yellow-deep)}

.section h2{
  font-family:var(--display);
  font-size:clamp(40px,7vw,92px);
  line-height:1;letter-spacing:-2.5px;font-weight:400;
  max-width:920px;color:var(--ink);
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.section h2 em{
  font-style:italic;font-weight:400;
  font-variation-settings:"opsz" 144, "SOFT" 100;
  position:relative;
}
.section h2 em::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:8%;
  height:.35em;background:var(--yellow);z-index:-1;
  transform:skew(-4deg);
}
.section-side{max-width:380px;color:var(--ink-dim);font-size:15px;line-height:1.7}

/* ============ HOME: WHAT WE DO ============ */
.what-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);
  background:var(--paper);
}
.what-card{
  padding:48px 36px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
  transition:background .35s ease;
  display:flex;flex-direction:column;gap:18px;
  min-height:300px;
}
.what-card:nth-child(3n){border-right:none}
.what-card:hover{background:var(--bg-2)}
.what-card .num{
  font-family:var(--mono);font-size:11px;color:var(--ink-faint);
  letter-spacing:2px;font-weight:500;
}
.what-card h3{
  font-family:var(--display);font-size:24px;line-height:1.15;
  letter-spacing:-.6px;font-weight:500;color:var(--ink);
}
.what-card p{color:var(--ink-dim);font-size:14.5px;line-height:1.65;flex:1}
.what-card .arrow{
  width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s ease;align-self:flex-start;
  background:var(--paper);
}
.what-card:hover .arrow{
  background:var(--yellow);border-color:var(--yellow);color:#0a0a0a;
  transform:rotate(-45deg) scale(1.05);
}
.what-card::after{
  content:"";position:absolute;bottom:0;left:0;height:3px;width:0;
  background:var(--yellow);transition:width .4s ease;
}
.what-card:hover::after{width:100%}

@media (max-width:900px){
  .what-grid{grid-template-columns:1fr}
  .what-card{border-right:none !important}
}

/* ============ HOME: PROCESS ============ */
.process{
  background:var(--bg-2);padding:120px var(--pad-x);
  border-bottom:1px solid var(--line);position:relative;
  overflow:hidden;
}
.process::before{
  content:"PROCESS · PROCESS · PROCESS · PROCESS · PROCESS";
  position:absolute;top:30px;left:0;right:0;
  font-family:var(--display);font-size:140px;font-style:italic;
  color:var(--bg-3);white-space:nowrap;letter-spacing:-3px;
  pointer-events:none;overflow:hidden;font-weight:400;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.process-inner{position:relative;z-index:1;margin-top:60px}
.process-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line-2);border-left:1px solid var(--line-2);
  background:var(--paper);
}
.proc{
  padding:40px 32px;
  border-right:1px solid var(--line-2);border-bottom:1px solid var(--line-2);
  position:relative;transition:background .3s;
}
.proc:hover{background:var(--bg-2)}
.proc-num{
  font-family:var(--display);font-size:64px;color:var(--yellow-deep);
  line-height:1;letter-spacing:-3px;font-weight:500;font-style:italic;
  font-variation-settings:"opsz" 72, "SOFT" 100;
}
.proc h4{
  font-family:var(--display);font-size:20px;
  margin-top:24px;margin-bottom:12px;letter-spacing:-.4px;font-weight:500;
}
.proc p{color:var(--ink-dim);font-size:14px;line-height:1.65}

@media (max-width:900px){
  .process-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============ HOME: COVERAGE ============ */
.coverage{
  display:grid;grid-template-columns:1.1fr .9fr;gap:0;
  border-bottom:1px solid var(--line);
  background:var(--paper);
}
.coverage-text{padding:120px var(--pad-x);border-right:1px solid var(--line)}
.coverage-text h2{
  font-family:var(--display);font-size:clamp(40px,6vw,80px);
  line-height:1;letter-spacing:-2px;font-weight:400;
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.coverage-text h2 em{
  font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
  position:relative;
}
.coverage-text h2 em::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:8%;
  height:.35em;background:var(--yellow);z-index:-1;
  transform:skew(-4deg);
}
.coverage-text p{margin-top:24px;color:var(--ink-dim);font-size:16px;max-width:480px;line-height:1.7}
.coverage-list{margin-top:40px;display:flex;flex-wrap:wrap;gap:8px}
.coverage-list span{
  padding:8px 16px;border:1px solid var(--line-2);
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;
  color:var(--ink-dim);transition:all .25s;border-radius:999px;
  background:var(--paper);font-weight:500;
}
.coverage-list span:hover{border-color:var(--ink);color:var(--ink);background:var(--yellow)}

.coverage-visual{
  position:relative;background:var(--bg-2);
  display:flex;align-items:center;justify-content:center;
  padding:60px 40px;overflow:hidden;
  min-height:520px;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:40px 40px;
}
.coverage-visual svg{width:100%;height:auto;max-width:520px}

@media (max-width:1000px){
  .coverage{grid-template-columns:1fr}
  .coverage-text{border-right:none;border-bottom:1px solid var(--line)}
}

/* ============ TRUST / VALUES ROW ============ */
.values{
  padding:80px var(--pad-x);background:var(--paper);
  border-bottom:1px solid var(--line);
}
.values-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:48px;
}
.value{display:flex;flex-direction:column;gap:12px}
.value-icon{
  width:44px;height:44px;border-radius:50%;
  background:var(--yellow-soft);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
}
.value h4{font-family:var(--display);font-size:20px;font-weight:500;letter-spacing:-.3px}
.value p{font-size:14px;color:var(--ink-dim);line-height:1.6}

@media (max-width:900px){
  .values-grid{grid-template-columns:repeat(2,1fr);gap:32px}
}
@media (max-width:600px){
  .values-grid{grid-template-columns:1fr}
}

/* ============ CTA BLOCK ============ */
.cta-block{
  padding:140px var(--pad-x);text-align:center;
  background:var(--ink);color:#fff;
  position:relative;overflow:hidden;
}
.cta-block::before,.cta-block::after{
  content:"FREIGHT MOVES";
  position:absolute;font-family:var(--display);font-style:italic;font-weight:400;
  font-size:240px;line-height:1;letter-spacing:-6px;
  color:rgba(255,255,255,.04);white-space:nowrap;
  pointer-events:none;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.cta-block::before{top:-30px;left:-100px}
.cta-block::after{bottom:-30px;right:-100px}
.cta-block-inner{position:relative;z-index:1;max-width:920px;margin:0 auto}
.cta-block h2{
  font-family:var(--display);
  font-size:clamp(40px,8vw,110px);line-height:1;
  letter-spacing:-3px;font-weight:400;color:#fff;
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.cta-block h2 em{
  font-style:italic;color:var(--yellow);
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.cta-block p{margin-top:24px;font-size:18px;color:rgba(255,255,255,.7);max-width:560px;margin-left:auto;margin-right:auto}
.cta-block .btn{
  margin-top:40px;background:var(--yellow);color:var(--ink);
  border-color:var(--yellow);
}
.cta-block .btn::before{background:#fff}
.cta-block .btn:hover{color:var(--ink)}

/* ============ PAGE HEADER (sub pages) ============ */
.page-header{
  padding:100px var(--pad-x) 80px;
  border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
  background:var(--paper);
}
.page-header-meta{
  font-family:var(--mono);font-size:11px;color:var(--ink-dim);
  letter-spacing:3px;text-transform:uppercase;margin-bottom:28px;
  display:flex;align-items:center;gap:14px;font-weight:500;
}
.page-header-meta::before{content:"";width:40px;height:1px;background:var(--ink)}
.page-header-meta .num{color:var(--yellow-deep)}
.page-header h1{
  font-family:var(--display);font-size:clamp(54px,10vw,160px);
  line-height:.92;letter-spacing:-3px;font-weight:400;color:var(--ink);
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.page-header h1 em{
  font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
  position:relative;
}
.page-header h1 em::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:8%;
  height:.35em;background:var(--yellow);z-index:-1;
  transform:skew(-4deg);
}
.page-header p{
  margin-top:32px;max-width:620px;color:var(--ink-dim);
  font-size:17px;line-height:1.7;
}

/* ============ SERVICES PAGE ============ */
.services-list{
  padding:0;border-top:1px solid var(--line);
  background:var(--paper);
}
.svc{
  padding:36px var(--pad-x);
  display:grid;grid-template-columns:80px 1fr 60px 200px;
  align-items:center;gap:32px;
  border-bottom:1px solid var(--line);
  cursor:pointer;position:relative;overflow:hidden;
  transition:background .35s ease;
}
.svc:hover{background:var(--bg-2)}
.svc-num{
  font-family:var(--mono);font-size:13px;color:var(--ink-faint);
  letter-spacing:2px;font-weight:500;
}
.svc-title{
  font-family:var(--display);font-size:clamp(24px,3vw,40px);
  letter-spacing:-1px;line-height:1.05;font-weight:500;
}
.svc-desc{
  color:var(--ink-dim);font-size:14.5px;margin-top:10px;
  max-width:600px;line-height:1.65;
}
.svc-icon{
  width:60px;height:60px;border-radius:50%;
  border:1px solid var(--line-2);background:var(--paper);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);transition:all .3s ease;
}
.svc:hover .svc-icon{
  background:var(--yellow);color:var(--ink);border-color:var(--yellow);
  transform:rotate(-12deg) scale(1.05);
}
.svc-tag{
  font-family:var(--mono);font-size:11px;color:var(--ink-dim);
  letter-spacing:1.5px;text-align:right;text-transform:uppercase;font-weight:500;
}

@media (max-width:1000px){
  .svc{grid-template-columns:60px 1fr 50px;gap:20px;padding:28px var(--pad-x)}
  .svc-tag{display:none}
  .svc-icon{width:50px;height:50px}
}

/* ============ FLEET PAGE ============ */
.fleet-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  border-top:1px solid var(--line);
  background:var(--paper);
}
.fleet-card{
  padding:64px var(--pad-x);
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
  min-height:400px;display:flex;flex-direction:column;justify-content:space-between;
  transition:background .35s ease;
}
.fleet-card:nth-child(2n){border-right:none}
.fleet-card:hover{background:var(--bg-2)}
.fleet-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}
.fleet-tag{
  font-family:var(--mono);font-size:11px;color:var(--ink-dim);
  letter-spacing:2px;text-transform:uppercase;font-weight:500;
  display:flex;align-items:center;gap:10px;
}
.fleet-tag::before{content:"";width:6px;height:6px;background:var(--yellow);border-radius:50%}
.fleet-icon-wrap{
  width:72px;height:72px;border-radius:50%;
  border:1px solid var(--line-2);background:var(--paper);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);transition:all .3s;flex-shrink:0;
}
.fleet-card:hover .fleet-icon-wrap{
  background:var(--yellow);color:var(--ink);border-color:var(--yellow);
  transform:rotate(8deg);
}
.fleet-count{
  font-family:var(--display);
  font-size:clamp(80px,12vw,180px);
  line-height:.85;letter-spacing:-6px;font-weight:400;
  color:var(--ink);
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.fleet-count .plus{
  color:var(--yellow-deep);font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.fleet-count .sub{
  display:block;font-family:var(--mono);
  font-size:12px;color:var(--ink-dim);
  letter-spacing:2px;margin-top:14px;
  font-weight:500;font-style:normal;
}
.fleet-name{
  font-family:var(--display);font-size:26px;font-weight:500;
  letter-spacing:-.5px;margin-top:16px;
}
.fleet-desc{color:var(--ink-dim);font-size:14.5px;margin-top:8px;max-width:340px;line-height:1.65}

@media (max-width:900px){
  .fleet-grid{grid-template-columns:1fr}
  .fleet-card{border-right:none !important;padding:48px var(--pad-x);min-height:auto}
}

/* Fleet bottom strip */
.fleet-strip{
  background:var(--ink);color:#fff;
  padding:64px var(--pad-x);
  display:grid;grid-template-columns:repeat(3,1fr);gap:48px;
}
.fleet-strip-item h4{
  font-family:var(--display);font-size:22px;font-weight:500;
  letter-spacing:-.4px;margin-bottom:10px;
}
.fleet-strip-item h4 em{color:var(--yellow);font-style:italic}
.fleet-strip-item p{font-size:14.5px;line-height:1.65;color:rgba(255,255,255,.7)}

@media (max-width:900px){
  .fleet-strip{grid-template-columns:1fr;gap:32px}
}

/* ============ CONTACT PAGE ============ */
.contact-wrap{
  display:grid;grid-template-columns:1.15fr 1fr;
  border-top:1px solid var(--line);min-height:700px;
  background:var(--paper);
}
.contact-info{
  padding:80px var(--pad-x);border-right:1px solid var(--line);
}
.contact-info h2{
  font-family:var(--display);font-size:clamp(40px,6vw,80px);
  line-height:1;letter-spacing:-2px;font-weight:400;
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.contact-info h2 em{
  font-style:italic;
  font-variation-settings:"opsz" 144, "SOFT" 100;
  position:relative;
}
.contact-info h2 em::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:8%;
  height:.35em;background:var(--yellow);z-index:-1;
  transform:skew(-4deg);
}
.contact-info > p{
  margin-top:24px;color:var(--ink-dim);font-size:16px;
  max-width:480px;line-height:1.7;
}

.contact-blocks{margin-top:60px;display:flex;flex-direction:column;gap:0}
.contact-block{
  padding:28px 0;border-top:1px solid var(--line);
  display:grid;grid-template-columns:140px 1fr;gap:24px;align-items:start;
  transition:padding-left .25s ease;
}
.contact-block:hover{padding-left:8px}
.contact-block:last-child{border-bottom:1px solid var(--line)}
.contact-block-label{
  font-family:var(--mono);font-size:11px;color:var(--ink-dim);
  letter-spacing:2px;text-transform:uppercase;padding-top:6px;font-weight:500;
}
.contact-block-value{
  font-family:var(--display);font-size:22px;line-height:1.3;
  letter-spacing:-.4px;font-weight:500;
}
.contact-block-value a{
  display:inline-block;position:relative;transition:color .25s;
  background-image:linear-gradient(var(--yellow),var(--yellow));
  background-size:0% 35%;background-repeat:no-repeat;
  background-position:0 88%;
  transition:background-size .35s ease;
}
.contact-block-value a:hover{background-size:100% 35%}
.contact-block-value small{
  display:block;font-family:var(--body);font-size:13.5px;
  color:var(--ink-dim);font-weight:400;
  margin-top:6px;letter-spacing:0;
}

.contact-form{padding:80px var(--pad-x);background:var(--bg-2);position:relative}
.contact-form h3{
  font-family:var(--display);font-size:34px;
  margin-bottom:8px;letter-spacing:-.6px;font-weight:500;
}
.contact-form > p{color:var(--ink-dim);margin-bottom:36px;font-size:14.5px}
.field{margin-bottom:24px}
.field label{
  display:block;font-family:var(--mono);font-size:11px;
  letter-spacing:2px;color:var(--ink-dim);margin-bottom:8px;
  text-transform:uppercase;font-weight:500;
}
.field input,.field textarea,.field select{
  width:100%;background:transparent;
  border:none;border-bottom:1.5px solid var(--line-2);
  padding:12px 0;color:var(--ink);font-family:var(--body);
  font-size:16px;transition:border-color .25s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-bottom-color:var(--ink);
}
.field input:hover,.field textarea:hover,.field select:hover{border-bottom-color:var(--line-3)}
.field textarea{resize:vertical;min-height:100px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.contact-form .btn{margin-top:8px;width:100%;justify-content:center}

@media (max-width:900px){
  .contact-wrap{grid-template-columns:1fr}
  .contact-info{border-right:none;border-bottom:1px solid var(--line)}
  .contact-block{grid-template-columns:1fr;gap:6px}
  .field-row{grid-template-columns:1fr}
}

/* Map block */
.map-strip{
  background:var(--paper);padding:80px var(--pad-x);
  display:grid;grid-template-columns:1fr 1.2fr;gap:64px;
  align-items:center;border-bottom:1px solid var(--line);
}
.map-strip h3{
  font-family:var(--display);font-size:42px;
  letter-spacing:-.8px;line-height:1;font-weight:500;
}
.map-strip h3 em{color:var(--yellow-deep);font-style:italic}
.map-strip p{margin-top:18px;color:var(--ink-dim);max-width:420px;line-height:1.65}
.map-visual{
  background:var(--bg-2);border:1px solid var(--line);border-radius:4px;
  height:300px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:30px 30px;
}

@media (max-width:900px){
  .map-strip{grid-template-columns:1fr;gap:32px}
}

/* ============ FOOTER ============ */
.footer{
  background:var(--ink);color:rgba(255,255,255,.85);
  padding:80px var(--pad-x) 32px;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1.5fr;gap:48px;
  padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-brand .footer-logo{
  font-family:var(--display);font-size:42px;letter-spacing:-1.5px;
  color:var(--yellow);font-weight:500;font-style:italic;
  font-variation-settings:"opsz" 72, "SOFT" 100;
}
.footer-brand p{margin-top:16px;color:rgba(255,255,255,.6);font-size:14.5px;max-width:280px;line-height:1.65}
.footer h4{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  color:#fff;margin-bottom:20px;text-transform:uppercase;font-weight:500;
}
.footer a{display:block;color:rgba(255,255,255,.6);font-size:14.5px;padding:6px 0;transition:color .2s}
.footer a:hover{color:var(--yellow)}
.footer p{color:rgba(255,255,255,.6);font-size:14.5px;line-height:1.7}
.footer p a{display:inline;padding:0}

.footer-ticker{overflow:hidden;border-top:1px solid rgba(255,255,255,.1);padding-top:16px;margin-top:8px}
.footer-ticker-track{
  display:flex;gap:32px;white-space:nowrap;
  animation:marquee 50s linear infinite;
  font-family:var(--mono);font-size:12px;color:rgba(255,255,255,.5);letter-spacing:1px;
}

.footer-bottom{
  padding-top:24px;display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.4);letter-spacing:1px;
}

@media (max-width:1000px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
}

/* ============ REVEAL ON SCROLL ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.33s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.40s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.47s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.54s}

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