/* ============================================================
   HERO ABSCHLEPPDIENST — v5
   VeloTrax-inspired · Navy #001B5E · Yellow #F5C800
   Font: Inter
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap');

:root {
  --navy:      #001B5E;
  --navy-mid:  #0A2472;
  --navy-dark: #010E35;
  --yellow:    #F5C800;
  --yellow-d:  #D9A800;
  --white:     #FFFFFF;
  --off:       #F7F8FA;
  --ink:       #0D1117;
  --body:      #4B5563;
  --subtle:    #9CA3AF;
  --line:      #E5E7EB;
  --font: 'Inter', system-ui, sans-serif;
  --nav-h: 72px;
  --max: 1160px;
  --r: 12px;
  --r-lg: 20px;
  transition-timing: cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--font);color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100vw}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none}

/* ── LAYOUT ─────────────────────── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 1.5rem;width:100%;box-sizing:border-box}
.sec{padding:100px 0}
.sec-sm{padding:64px 0}

/* ── SECTION LABEL ─────────────────── */
.sec-label{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--yellow);margin-bottom:.85rem;
}
.sec-label::before{
  content:'';width:28px;height:2px;background:var(--yellow);border-radius:2px;display:block;
}
.sec-label.dark{color:var(--yellow)}
.sec-label.light{color:var(--yellow)}

/* ── HEADINGS ──────────────────────── */
.h-display{
  font-size:clamp(2.8rem,5vw,5.4rem);
  font-weight:900;line-height:1.0;letter-spacing:-.03em;
}
.h1{
  font-size:clamp(2.2rem,4.5vw,3.8rem);
  font-weight:800;line-height:1.08;letter-spacing:-.025em;
}
.h2{
  font-size:clamp(1.8rem,3.5vw,3rem);
  font-weight:800;line-height:1.1;letter-spacing:-.02em;
}
.h3{
  font-size:1.2rem;font-weight:700;line-height:1.3;letter-spacing:-.01em;
}
.body-text{font-size:.97rem;line-height:1.78;color:var(--body)}
.small-text{font-size:.82rem;line-height:1.65;color:var(--subtle)}

/* ── BUTTONS ───────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.78rem 1.75rem;font-size:.9rem;font-weight:700;
  border-radius:var(--r);border:2px solid transparent;
  cursor:pointer;transition:all .2s;white-space:nowrap;letter-spacing:-.01em;
}
.btn-lg{padding:.9rem 2.1rem;font-size:.97rem}
.btn-yellow{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.btn-yellow:hover{background:var(--yellow-d);border-color:var(--yellow-d);transform:translateY(-2px)}
.btn-white{background:var(--white);color:var(--navy);border-color:var(--white)}
.btn-white:hover{background:var(--off);transform:translateY(-2px)}
.btn-outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,.4)}
.btn-outline-white:hover{border-color:var(--white);background:rgba(255,255,255,.08)}
.btn-outline-navy{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline-navy:hover{background:var(--navy);color:var(--white)}
.btn-navy{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-mid);transform:translateY(-2px)}

/* ========================================================
   TOPBAR
   ======================================================== */
.topbar{
  background:var(--navy-dark);
  padding:.5rem 0;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.topbar-inner{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;
}
.topbar-left{display:flex;gap:1.5rem;flex-wrap:wrap}
.topbar-left a,.topbar-left span{
  font-size:.78rem;font-weight:500;color:rgba(255,255,255,.45);
  display:flex;align-items:center;gap:.35rem;transition:color .15s;
}
.topbar-left a:hover{color:rgba(255,255,255,.8)}
.topbar-right{display:flex;align-items:center;gap:1rem}
.topbar-phone{
  display:flex;align-items:center;gap:.4rem;
  font-size:.82rem;font-weight:700;color:var(--yellow);letter-spacing:.02em;
}
.topbar-tag{
  background:var(--yellow);color:var(--ink);
  font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:.25rem .7rem;border-radius:100px;
}

/* ========================================================
   NAVBAR
   ======================================================== */
.navbar{
  background:var(--navy);
  position:sticky;top:0;z-index:1500;
  height:var(--nav-h);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav-inner{
  height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.logo{display:flex;align-items:center;gap:.75rem;z-index:10;flex-shrink:0}
.logo-icon{
  width:42px;height:42px;background:var(--yellow);border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;
}
.logo-name{
  font-size:.95rem;font-weight:900;color:var(--white);letter-spacing:-.01em;line-height:1.2;
}
.logo-name span{color:var(--yellow);display:block;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}

.nav-links{display:flex;align-items:center;gap:.05rem}
.nav-links a{
  font-size:.84rem;font-weight:500;color:rgba(255,255,255,.65);
  padding:.4rem .8rem;border-radius:8px;transition:all .15s;letter-spacing:-.01em;
}
.nav-links a:hover,.nav-links a.active{color:var(--white);background:rgba(255,255,255,.1)}
.nav-links .cta-link{
  background:var(--yellow);color:var(--ink);font-weight:700;
  margin-left:.35rem;padding:.42rem 1.1rem;
}
.nav-links .cta-link:hover{background:var(--yellow-d)}

.nav-phone{
  display:flex;align-items:center;gap:.5rem;
  font-size:.88rem;font-weight:700;color:var(--white);letter-spacing:-.01em;
}
.nav-phone-icon{
  width:34px;height:34px;background:var(--yellow);border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--ink);flex-shrink:0;
}

/* hamburger */
.hamburger{
  display:none;flex-direction:column;gap:4px;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:8px;background:rgba(255,255,255,.1);
  z-index:10;flex-shrink:0;
}
.hamburger span{
  display:block;width:20px;height:2px;background:var(--white);border-radius:2px;
  transition:transform .28s,opacity .28s;
}
.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.nav-overlay{
  display:none;position:fixed;inset:0;z-index:1400;
  background:rgba(0,0,0,.6);opacity:0;transition:opacity .25s;
}
.nav-overlay.open{display:block;opacity:1}

/* ========================================================
   ETA BAR (below navbar, all pages)
   ======================================================== */
.eta-bar{
  background:var(--yellow);padding:.38rem 0;text-align:center;
}
.eta-bar-inner{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.45rem;
}
.eta-dot{width:7px;height:7px;background:var(--navy);border-radius:50%;animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}
.eta-bar-icon{font-size:.85rem;flex-shrink:0;line-height:1}
.eta-bar-text{font-size:.75rem;font-weight:700;color:var(--navy);letter-spacing:.01em}
.eta-bar-sep{color:rgba(0,27,94,.3);font-size:.8rem;padding:0 .1rem}


/* ========================================================
   REAL IMAGES (replaced placeholders)
   ======================================================== */
.ph-img{
  display:block;width:100%;object-fit:cover;
  border-radius:var(--r-lg);
}
.ph-img.why-dark-img{height:500px}
.ph-img.about-img{height:540px}
.ph-img.detail-img{height:480px}
.ph-img.faq-placeholder{height:320px}

/* ========================================================
   HERO SECTION
   ======================================================== */
.hero{
  background:var(--navy);
  position:relative;overflow:hidden;min-height:88svh;
  display:flex;align-items:center;
}
/* Big background truck SVG — decorative */
.hero-bg-shape{
  position:absolute;right:-80px;top:50%;transform:translateY(-50%);
  opacity:.04;pointer-events:none;z-index:0;
  width:680px;height:auto;
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 480px;gap:4rem;align-items:center;
  padding:96px 0 80px;width:100%;box-sizing:border-box;overflow:hidden;
}
/* Tags row */
.hero-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.75rem}
.hero-tag{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.8);font-size:.75rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;padding:.3rem .85rem;border-radius:100px;
}
.hero-tag.active{background:var(--yellow);color:var(--navy);border-color:var(--yellow)}
.hero h1{color:var(--white);margin:1rem 0}
.hero h1 em{color:var(--yellow);font-style:normal;display:block}
.hero-desc{color:rgba(255,255,255,.55);font-size:1rem;line-height:1.78;max-width:480px;margin-bottom:2.25rem}
.hero-btns{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.75rem}
/* Trust strip */
.hero-trust{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.65rem 1.5rem;
  padding-top:1.75rem;
  border-top:1px solid rgba(255,255,255,.1);
}
.trust-item{
  display:flex;align-items:center;gap:.45rem;
  font-size:.78rem;color:rgba(255,255,255,.45);font-weight:500;
}
.trust-item b{color:var(--yellow);font-weight:700;font-size:.88rem}

/* Hero right — placeholder card */
.hero-visual{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:20px;padding:2rem;display:flex;flex-direction:column;gap:1rem;
}
.hero-card-top{
  border-radius:12px;
  height:220px;
  position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.07);
}
.hero-card-img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;border-radius:12px;
}
.hero-eta-big{
  text-align:center;background:var(--yellow);border-radius:12px;
  padding:1.25rem;
}
.eta-big-num{
  font-size:2.8rem;font-weight:900;color:var(--navy);line-height:1;
  letter-spacing:-.05em;display:block;
}
.eta-big-label{
  font-size:.7rem;font-weight:700;color:var(--navy-dark);letter-spacing:.08em;
  text-transform:uppercase;margin-top:.15rem;display:block;
}
.eta-big-note{font-size:.65rem;color:rgba(0,27,94,.55);margin-top:.4rem}
.hero-stats-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.hero-stat{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  border-radius:10px;padding:.9rem;text-align:center;
}
.hero-stat b{
  display:block;font-size:1.4rem;font-weight:900;color:var(--yellow);
  letter-spacing:-.03em;line-height:1;
}
.hero-stat span{font-size:.68rem;color:rgba(255,255,255,.4);font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;margin-top:.25rem;display:block}

/* ========================================================
   LOGOS / TRUST BAND
   ======================================================== */
.trust-band{
  background:var(--off);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:1.5rem 0;
}
.trust-band-inner{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:2.5rem;
}
.trust-band-item{
  font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--subtle);display:flex;align-items:center;gap:.5rem;
}
.trust-band-item b{color:var(--body)}

/* ========================================================
   WHY CHOOSE US — dark full-width
   ======================================================== */
.why-dark{background:var(--navy-dark);padding:100px 0}
.why-dark-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;
}
.why-dark-img{
  height:500px;border-radius:var(--r-lg);
}
.why-dark-content .sec-label{margin-bottom:.65rem}
.why-dark-content h2{color:var(--white);margin:.3rem 0 1.1rem}
.why-dark-content .body-text{color:rgba(255,255,255,.5);margin-bottom:2rem}
.why-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;
  background:rgba(255,255,255,.08);border-radius:var(--r);overflow:hidden;
  margin-top:2.5rem;
}
.ws-item{
  background:rgba(255,255,255,.03);
  padding:1.25rem 1rem;
  text-align:center;
  width:100%;box-sizing:border-box;
}
.ws-num{
  font-size:2rem;font-weight:900;color:var(--yellow);
  letter-spacing:-.03em;line-height:1;display:block;
}
.ws-label{
  font-size:.62rem;color:rgba(255,255,255,.4);text-transform:uppercase;
  letter-spacing:.1em;font-weight:600;margin-top:.3rem;display:block;
  word-break:break-word;
}

/* ========================================================
   SERVICES — card grid with hover overlay
   ======================================================== */
.services-sec{padding:100px 0;background:var(--white)}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem;
}
.svc-card{
  border-radius:var(--r-lg);overflow:hidden;position:relative;cursor:pointer;
  border:1px solid var(--line);
  transition:box-shadow .25s, transform .25s;
}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,27,94,.12)}
/* Top image area */
.svc-img{
  height:200px;position:relative;overflow:hidden;
  background:linear-gradient(145deg,var(--navy-dark) 0%,var(--navy-mid) 100%);
}
.svc-img-inner{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-size:3rem;opacity:.25;transition:opacity .25s;
}
.svc-card:hover .svc-img-inner{opacity:.4}
.svc-num{
  position:absolute;top:.85rem;left:.85rem;
  background:var(--yellow);color:var(--navy);
  font-size:.65rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  padding:.25rem .6rem;border-radius:6px;
}
/* Card body */
.svc-body{padding:1.5rem 1.75rem 1.75rem}
.svc-body h3{font-size:1.05rem;font-weight:700;margin-bottom:.5rem;color:var(--ink)}
.svc-body p{font-size:.875rem;color:var(--body);line-height:1.7;margin-bottom:1.25rem}
.svc-link{
  font-size:.78rem;font-weight:700;color:var(--navy);
  text-transform:uppercase;letter-spacing:.08em;
  display:inline-flex;align-items:center;gap:.35rem;
  transition:gap .15s;
}
.svc-link:hover{gap:.6rem;color:var(--navy-mid)}
/* Wide card */
.svc-card.wide{grid-column:span 2}
.svc-card.wide .svc-img{height:240px}

/* ========================================================
   ABOUT US — split
   ======================================================== */
.about-sec{padding:100px 0;background:var(--off)}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;
}
.about-img-wrap{position:relative;padding-bottom:2.5rem}
.about-img{
  height:540px;border-radius:var(--r-lg);
}
.about-badge{
  position:absolute;bottom:-1rem;right:0;
  background:var(--yellow);border-radius:var(--r-lg);
  padding:1.5rem 2rem;text-align:center;
  box-shadow:0 8px 32px rgba(0,27,94,.2);
  max-width:160px;
}
.about-badge-num{
  font-size:3rem;font-weight:900;color:var(--navy);
  letter-spacing:-.05em;line-height:1;display:block;
}
.about-badge-label{
  font-size:.7rem;font-weight:700;color:var(--navy-dark);
  text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem;display:block;
}
.about-content .sec-label{margin-bottom:.65rem}
.about-content h2{margin:.3rem 0 1.1rem;color:var(--ink)}
.about-features{
  display:flex;flex-direction:column;gap:0;margin:2rem 0;
}
.about-feat{
  display:flex;gap:1.1rem;align-items:flex-start;
  padding:1rem 0;border-top:1px solid var(--line);
}
.about-feat:last-child{border-bottom:1px solid var(--line)}
.af-dot{
  width:10px;height:10px;min-width:10px;background:var(--yellow);border-radius:50%;margin-top:5px;
}
.af-text h4{font-size:.92rem;font-weight:700;margin-bottom:.2rem;color:var(--ink)}
.af-text p{font-size:.85rem;color:var(--body);line-height:1.65}

/* ========================================================
   STATS STRIP
   ======================================================== */
.stats-strip{background:var(--navy);padding:72px 0}
.stats-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-left:1px solid rgba(255,255,255,.08);
}
.stat-col{
  text-align:center;padding:2rem 1.5rem;
  border-right:1px solid rgba(255,255,255,.08);
}
.stat-n{
  font-size:clamp(2.4rem,4vw,3.6rem);font-weight:900;color:var(--yellow);
  letter-spacing:-.04em;line-height:1;display:block;
}
.stat-l{
  font-size:.72rem;font-weight:600;color:rgba(255,255,255,.4);
  text-transform:uppercase;letter-spacing:.1em;margin-top:.4rem;display:block;
}

/* ========================================================
   PROCESS — how it works
   ======================================================== */
.process-sec{padding:100px 0;background:var(--off)}
.process-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  margin-top:3.5rem;
}
.process-step{
  padding:2.5rem 2rem;border-right:1px solid var(--line);
  position:relative;transition:background .2s;
}
.process-step:last-child{border-right:none}
.process-step:hover{background:var(--white)}
.process-n{
  width:44px;height:44px;background:var(--navy);color:var(--yellow);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:800;letter-spacing:.06em;
  margin-bottom:1.4rem;
}
.process-step h4{font-size:1rem;font-weight:700;margin-bottom:.5rem;color:var(--ink)}
.process-step p{font-size:.875rem;color:var(--body);line-height:1.7}

/* ========================================================
   TESTIMONIALS
   ======================================================== */
.testi-sec{padding:100px 0;background:var(--navy-dark)}
.testi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3.5rem;
}
.testi-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r-lg);padding:2rem;
  transition:border-color .2s,background .2s;
}
.testi-card:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18)}
.testi-quote{
  font-size:2rem;color:var(--yellow);line-height:1;margin-bottom:.75rem;font-family:Georgia,serif;
}
.testi-text{
  font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.78;margin-bottom:1.5rem;font-style:italic;
}
.testi-meta{display:flex;align-items:center;gap:.75rem}
.testi-av{
  width:40px;height:40px;background:var(--navy-mid);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.78rem;font-weight:800;color:var(--yellow);flex-shrink:0;
  border:2px solid rgba(245,200,0,.3);
}
.testi-name{font-size:.88rem;font-weight:700;color:var(--white)}
.testi-loc{font-size:.75rem;color:rgba(255,255,255,.35);margin-top:2px}
.testi-stars{color:var(--yellow);font-size:.72rem;letter-spacing:2px;margin-bottom:.75rem}

/* ========================================================
   FAQ
   ======================================================== */
.faq-sec{padding:100px 0;background:var(--white)}
.faq-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;margin-top:0;
}
.faq-left{}
.faq-left h2{margin:.3rem 0 1.1rem;color:var(--ink)}
.faq-left .body-text{margin-bottom:2rem}
.faq-placeholder{
  height:360px;border-radius:var(--r-lg);margin-top:2rem;
}
.faq-list{display:flex;flex-direction:column;gap:.5rem}
.faq-item{
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  transition:border-color .2s;
}
.faq-item.open{border-color:var(--navy)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.15rem 1.4rem;cursor:pointer;
  font-size:.93rem;font-weight:600;color:var(--ink);
  transition:background .15s;letter-spacing:-.01em;
}
.faq-q:hover{background:var(--off)}
.faq-item.open .faq-q{background:var(--navy);color:var(--white)}
.faq-ic{
  width:26px;height:26px;min-width:26px;border-radius:50%;
  border:2px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;color:var(--subtle);
  transition:all .25s;flex-shrink:0;
}
.faq-item.open .faq-ic{
  background:var(--yellow);border-color:var(--yellow);color:var(--navy);
  transform:rotate(45deg);
}
.faq-a{
  display:none;padding:.9rem 1.4rem 1.25rem;
  font-size:.875rem;color:var(--body);line-height:1.75;
}
.faq-item.open .faq-a{display:block}

/* ========================================================
   CTA BAND
   ======================================================== */
.cta-band{
  background:var(--navy);position:relative;overflow:hidden;padding:100px 0;
}
.cta-band-inner{
  display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;
}
.cta-band h2{color:var(--white);margin:.5rem 0 1rem}
.cta-band .sec-label{margin-bottom:.5rem}
.cta-band .body-text{color:rgba(255,255,255,.5);max-width:520px}
.cta-btns{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
.cta-right-card{
  background:var(--yellow);border-radius:var(--r-lg);
  padding:2.5rem 2rem;text-align:center;min-width:220px;flex-shrink:0;
}
.cta-right-card .big-num{
  font-size:3.6rem;font-weight:900;color:var(--navy);
  letter-spacing:-.05em;line-height:1;display:block;
}
.cta-right-card .big-label{
  font-size:.72rem;font-weight:700;color:var(--navy-dark);
  text-transform:uppercase;letter-spacing:.1em;display:block;margin-top:.2rem;
}
.cta-right-card .big-note{
  font-size:.68rem;color:rgba(0,27,94,.5);margin-top:.7rem;line-height:1.5;
}
/* BG decoration */
.cta-band::before{
  content:'';position:absolute;right:-100px;top:-100px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,200,0,.08) 0%,transparent 70%);
  pointer-events:none;
}

/* ========================================================
   FOOTER
   ======================================================== */
.footer{background:var(--ink);padding:80px 0 0}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:2rem;
  padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-brand p{
  font-size:.875rem;color:rgba(255,255,255,.35);line-height:1.78;
  margin-top:.85rem;max-width:280px;
}
.footer-socials{display:flex;gap:.5rem;margin-top:1.25rem}
.footer-socials a{
  width:36px;height:36px;background:rgba(255,255,255,.07);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  transition:all .18s;
}
.footer-socials a:hover{background:var(--yellow)}
.footer-socials a svg{width:16px;height:16px;fill:rgba(255,255,255,.4);stroke:rgba(255,255,255,.4);transition:fill .18s,stroke .18s}
.footer-socials a:hover svg{fill:var(--navy);stroke:var(--navy)}
.footer-col h5{
  font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:rgba(255,255,255,.25);margin-bottom:1.1rem;
}
.footer-nav{display:flex;flex-direction:column;gap:.5rem}
.footer-nav a{
  font-size:.875rem;color:rgba(255,255,255,.45);transition:color .15s;
}
.footer-nav a:hover{color:var(--white)}
.footer-contact{display:flex;flex-direction:column;gap:.6rem}
.fc-item{font-size:.875rem;color:rgba(255,255,255,.45)}
.fc-item a{color:rgba(255,255,255,.6);transition:color .15s}
.fc-item a:hover{color:var(--white)}
.fc-item.phone a{
  font-size:1.1rem;font-weight:800;color:var(--yellow);letter-spacing:-.01em;
}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:.75rem;padding:1.1rem 0;
}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.22)}
.footer-legal{display:flex;gap:1.25rem}
.footer-legal a{font-size:.78rem;color:rgba(255,255,255,.22);transition:color .15s}
.footer-legal a:hover{color:rgba(255,255,255,.6)}

/* ========================================================
   PAGE HERO (inner pages)
   ======================================================== */
.page-hero{
  background:var(--navy);position:relative;overflow:hidden;
  padding:96px 0 80px;
}
.page-hero-bg{
  position:absolute;inset:0;opacity:.04;
  background:repeating-linear-gradient(
    45deg,rgba(255,255,255,.05) 0,rgba(255,255,255,.05) 1px,
    transparent 1px,transparent 40px
  );
}
.page-hero .wrap{position:relative;z-index:1}
.breadcrumb{
  display:flex;align-items:center;gap:.35rem;
  font-size:.78rem;font-weight:500;margin-bottom:1.25rem;
}
.breadcrumb a{color:rgba(255,255,255,.35);transition:color .15s}
.breadcrumb a:hover{color:rgba(255,255,255,.75)}
.breadcrumb span{color:rgba(255,255,255,.7)}
.breadcrumb-sep{color:rgba(255,255,255,.25)}
.page-hero h1{color:var(--white);margin:.3rem 0 .85rem}
.page-hero .body-text{color:rgba(255,255,255,.5);max-width:560px}
.ph-btns{margin-top:1.75rem;display:flex;flex-wrap:wrap;gap:.75rem}

/* ========================================================
   DETAIL SECTION (inner pages)
   ======================================================== */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.detail-grid .detail-img{height:480px;border-radius:var(--r-lg)}
.detail-feats{display:flex;flex-direction:column;gap:0;margin:1.75rem 0}
.d-feat{
  display:flex;gap:1rem;padding:1.1rem 0;
  border-top:1px solid var(--line);align-items:flex-start;
}
.d-feat:last-child{border-bottom:1px solid var(--line)}
.d-feat-tag{
  background:var(--navy);color:var(--yellow);
  font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:.2rem .5rem;border-radius:5px;flex-shrink:0;margin-top:2px;
}
.d-feat h4{font-size:.9rem;font-weight:700;margin-bottom:.18rem;color:var(--ink)}
.d-feat p{font-size:.84rem;color:var(--body);margin:0;line-height:1.65}
.check-list{display:flex;flex-direction:column;gap:.55rem}
.check-list li{
  display:flex;align-items:flex-start;gap:.65rem;
  font-size:.9rem;color:var(--body);line-height:1.65;
}
.check-list li::before{
  content:'';width:16px;height:16px;min-width:16px;
  background:var(--navy);border-radius:50%;
  background-image:url("data:image/svg+xml,%3Csvg width='8' height='6' viewBox='0 0 8 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 3L3 5L7 1' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;margin-top:3px;
}

/* ========================================================
   CONTACT PAGE
   ======================================================== */
.contact-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:3.5rem;align-items:start}
.contact-sidebar{display:flex;flex-direction:column;gap:.85rem}
.contact-eta{
  background:var(--navy);border-radius:var(--r-lg);padding:2rem;text-align:center;
}
.contact-eta-n{
  font-size:3.4rem;font-weight:900;color:var(--yellow);
  letter-spacing:-.05em;line-height:1;display:block;
}
.contact-eta-u{
  font-size:.72rem;font-weight:700;color:rgba(255,255,255,.4);
  text-transform:uppercase;letter-spacing:.1em;display:block;margin-top:.2rem;
}
.contact-eta-note{font-size:.72rem;color:rgba(255,255,255,.28);margin-top:.65rem;line-height:1.55}
.c-info{
  background:var(--off);border:1px solid var(--line);border-radius:var(--r);
  padding:.95rem 1.2rem;display:flex;gap:.8rem;align-items:center;
  transition:border-color .2s;
}
.c-info:hover{border-color:var(--navy)}
.c-info-icon{
  width:38px;height:38px;min-width:38px;background:var(--navy);
  border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;
}
.c-info h4{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--subtle);margin-bottom:.18rem;font-weight:600}
.c-info p,.c-info a{font-size:.92rem;font-weight:600;color:var(--ink)}
.form-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:2.5rem;
}
.form-group{margin-bottom:1rem}
.form-label{
  display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--ink);margin-bottom:.4rem;
}
.form-control{
  width:100%;padding:.75rem 1rem;
  border:1.5px solid var(--line);border-radius:var(--r);
  font-family:var(--font);font-size:.92rem;color:var(--ink);
  background:var(--white);outline:none;transition:border-color .2s,box-shadow .2s;
  -webkit-appearance:none;
}
.form-control:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,27,94,.07)}
textarea.form-control{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.form-check{display:flex;align-items:flex-start;gap:.6rem}
.form-check input{margin-top:3px;accent-color:var(--navy);flex-shrink:0}
.form-check label{font-size:.8rem;color:var(--body);line-height:1.55}
.form-check a{color:var(--navy)}
.map-wrap{margin-top:2rem;border-radius:var(--r-lg);overflow:hidden;height:300px;border:1px solid var(--line)}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}
.f-msg{padding:.85rem 1rem;border-radius:var(--r);margin-bottom:1rem;font-size:.875rem;font-weight:600;display:none}
.f-msg.ok{background:#ECFDF5;color:#065F46;border:1px solid #A7F3D0;display:block}
.f-msg.err{background:#FEF2F2;color:#991B1B;border:1px solid #FECACA;display:block}

/* ========================================================
   FLOATING ELEMENTS
   ======================================================== */
.fab{
  position:fixed;bottom:1.25rem;left:1.25rem;
  background:var(--yellow);color:var(--navy);
  font-size:.82rem;font-weight:700;
  padding:.65rem 1.25rem;border-radius:100px;
  display:none;align-items:center;gap:.4rem;
  z-index:990;box-shadow:0 4px 16px rgba(245,200,0,.4);
  letter-spacing:-.01em;
}
.btn-top{
  position:fixed;bottom:1.25rem;right:1.25rem;
  width:40px;height:40px;background:var(--navy);color:var(--white);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:.85rem;z-index:990;opacity:0;pointer-events:none;
  transition:all .22s;border:1px solid rgba(255,255,255,.1);
}
.btn-top.show{opacity:1;pointer-events:all}
.btn-top:hover{background:var(--navy-mid);transform:translateY(-2px)}

/* ========================================================
   SCROLL REVEAL
   ======================================================== */
.fi{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.fi.in{opacity:1;transform:none}
.fi-d1{transition-delay:.07s}
.fi-d2{transition-delay:.14s}
.fi-d3{transition-delay:.21s}

/* ========================================================
   MOBILE DRAWER
   ======================================================== */
/* ================================================================
   RESPONSIVE — Mobile-first, Google CWV compliant
   Breakpoints: 1024 · 900 · 768 · 480 · 380
   ================================================================ */

/* ── 1024px: tablet landscape ─── */
@media(max-width:1024px){
  /* Hero */
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-visual{display:none}
  .hero-bg-shape{display:none}

  /* Sections */
  .why-dark-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-img-wrap{padding-bottom:2.5rem}
  .about-badge{right:0;bottom:-.5rem}

  /* Services */
  .services-grid{grid-template-columns:1fr 1fr}
  .svc-card.wide{grid-column:span 2}

  /* FAQ */
  .faq-grid{grid-template-columns:1fr;gap:2.5rem}
  .faq-placeholder{display:none}

  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr 1fr;gap:1.75rem}

  /* Detail pages */
  .detail-grid{grid-template-columns:1fr;gap:2rem}
  .detail-grid .ph-img{height:260px!important;order:-1}

  /* Contact */
  .contact-layout{grid-template-columns:1fr}

  /* CTA */
  .cta-band-inner{grid-template-columns:1fr}
  .cta-right-card{display:none}

  /* Testimonials / stats */
  .testi-grid{grid-template-columns:1fr 1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .stat-col:nth-child(2){border-right:none}
  .stat-col:nth-child(3){border-top:1px solid rgba(255,255,255,.08)}
  .stat-col:nth-child(4){border-top:1px solid rgba(255,255,255,.08);border-right:none}

  .trust-band-inner{gap:1.25rem}
}

/* ── 900px: tablet portrait / mobile nav trigger ─── */
@media(max-width:900px){
  /* Show hamburger, hide desktop phone */
  .hamburger{display:flex}
  .nav-phone{display:none}

  /* Navbar must be ABOVE overlay in stacking order.
     navbar=1500 > overlay=1400, so nav-links children (z-index inside 1500 context) win */
  .navbar{z-index:1500}

  /* Slide-in drawer — lives inside navbar stacking context, always wins vs overlay */
  .nav-links{
    position:fixed;top:0;right:0;bottom:0;
    width:min(300px,84vw);
    background:var(--navy-dark);
    flex-direction:column;align-items:stretch;
    padding:calc(var(--nav-h) + .75rem) 0 2.5rem;
    z-index:50;gap:0;
    transform:translateX(100%);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
    overflow-y:auto;
    border-left:1px solid rgba(255,255,255,.07);
    max-width:100vw;
    box-sizing:border-box;
  }
  .nav-links.open{transform:translateX(0)}
  /* Overlay: below navbar (1400 < 1500) so it never blocks nav-links */
  .nav-overlay{z-index:1400}
  .hamburger{z-index:20}

  .nav-links li{border-bottom:1px solid rgba(255,255,255,.05)}
  .nav-links li:last-child{border:none}
  .nav-links a{
    display:flex;align-items:center;padding:.9rem 1.5rem;
    font-size:.92rem;font-weight:500;border-radius:0;
    color:rgba(255,255,255,.65);white-space:nowrap;
    cursor:pointer;
  }
  .nav-links a:hover,
  .nav-links a.active{color:var(--white);background:rgba(255,255,255,.05)}
  .nav-links .cta-link{
    margin:1.25rem 1.25rem 0!important;
    padding:.85rem 1.25rem!important;
    border-radius:var(--r)!important;
    justify-content:center;font-size:.92rem;
    background:var(--yellow)!important;color:var(--navy)!important;
  }
  .nav-tel-mobile{
    display:flex!important;margin:.85rem 1.25rem 0;
    padding:.9rem 1.25rem;
    background:rgba(245,200,0,.1);
    border:1px solid rgba(245,200,0,.18);
    border-radius:var(--r);font-size:1rem;font-weight:700;
    color:var(--yellow)!important;
    align-items:center;gap:.5rem;
  }
}

/* ── 768px: mobile ─── */
@media(max-width:768px){
  /* Spacing */
  :root{--nav-h:60px}
  .sec{padding:60px 0}
  .sec-sm{padding:48px 0}
  .wrap{padding:0 1rem}

  /* Hide topbar */
  .topbar{display:none}

  /* Hero — prevent overflow */
  .hero{min-height:auto}
  .hero-grid{padding:64px 0 56px;width:100%;box-sizing:border-box}
  .hero h1{word-break:break-word}
  .hero-tags{gap:.4rem}
  .hero-btns{flex-direction:column;width:100%}
  .hero-btns .btn{width:100%;justify-content:center}
  /* hero trust - keep 2x2 grid, centered */
  .hero-trust{
    grid-template-columns:1fr 1fr;
    gap:.55rem 1rem;
    justify-items:start;
  }
  .trust-item{font-size:.75rem}

  /* ETA bar — keep single row, smaller */
  .eta-bar-inner{flex-wrap:wrap;gap:.3rem}
  .eta-bar-sep{display:inline}

  /* Trust band */
  .trust-band-inner{
    display:grid;grid-template-columns:1fr 1fr;
    gap:.75rem;text-align:center;justify-items:center;
  }

  /* Why dark */
  .why-dark{padding:60px 0}
  .ph-img.why-dark-img{height:220px!important}
  .why-stats{grid-template-columns:1fr 1fr}
  .ws-item{padding:1rem .75rem;text-align:center}
  .ws-num{font-size:1.6rem}

  /* About */
  .about-img-wrap{padding-bottom:3rem}
  .ph-img.about-img{height:240px!important}
  .about-badge{
    position:relative;right:auto;bottom:auto;
    margin-top:1rem;display:inline-block;
  }

  /* Services */
  .services-grid{grid-template-columns:1fr;gap:1rem}
  .svc-card.wide{grid-column:span 1}
  .svc-img{height:160px}
  .svc-card.wide .svc-img{height:180px}

  /* Stats */
  .stats-strip{padding:48px 0}
  .stats-row{grid-template-columns:1fr 1fr}
  .stat-col{padding:1.5rem 1rem}

  /* Process */
  .process-grid{
    grid-template-columns:1fr;
    border-radius:var(--r);
  }
  .process-step{
    border-right:none;
    border-bottom:1px solid var(--line);
    padding:1.75rem 1.25rem;
  }
  .process-step:last-child{border-bottom:none}

  /* Testimonials */
  .testi-grid{grid-template-columns:1fr}

  /* FAQ */
  .faq-q{font-size:.88rem;padding:1rem 1.1rem}
  .faq-a{padding:.75rem 1.1rem 1rem;font-size:.84rem}

  /* CTA */
  .cta-band{padding:60px 0}
  .cta-btns{flex-direction:column}
  .cta-btns .btn{width:100%;justify-content:center}

  /* Page hero */
  .page-hero{padding:64px 0 56px}
  .ph-btns{flex-direction:column}
  .ph-btns .btn{width:100%;justify-content:center}

  /* Detail pages */
  .ph-img.detail-img{height:220px!important;order:-1}
  .detail-feats .d-feat{gap:.75rem}

  /* Contact */
  .contact-sidebar{gap:.65rem}
  .contact-eta-n{font-size:2.6rem}
  .form-card{padding:1.5rem}
  .form-row{grid-template-columns:1fr}
  .map-wrap{height:240px}

  /* Footer */
  .footer{padding:56px 0 0}
  .footer-grid{grid-template-columns:1fr;gap:1.75rem}
  .footer-brand p{max-width:100%}

  /* Floating */
  .fab{display:flex;font-size:.78rem;padding:.6rem 1rem}
  .btn-top{bottom:4.5rem}
}

/* ── 480px: small mobile ─── */
@media(max-width:480px){
  .sec{padding:48px 0}

  /* Typography scale down */
  .h-display{font-size:2.4rem;letter-spacing:-.025em}
  .h1{font-size:2rem}
  .h2{font-size:1.7rem}

  /* Navbar */
  .logo-name{font-size:.8rem}
  .logo-icon{width:36px;height:36px;font-size:1.1rem}

  /* Hero */
  .hero-grid{padding:52px 0 48px}
  .hero-trust{flex-direction:column;gap:.65rem;align-items:flex-start}
  .trust-item{font-size:.75rem}

  /* Why stats */
  .why-stats{grid-template-columns:1fr 1fr}

  /* About badge — inline, not absolute */
  .about-img-wrap{padding-bottom:0}
  .about-badge{padding:1rem 1.25rem}
  .about-badge-num{font-size:2.4rem}

  /* Services */
  .svc-body h3{font-size:.97rem}
  .svc-body p{font-size:.84rem}

  /* Stats */
  .stat-n{font-size:2.2rem}
  .stat-col{padding:1.25rem .75rem}

  /* Process */
  .process-step{padding:1.5rem 1rem}

  /* Testimonials */
  .testi-text{font-size:.84rem}

  /* Contact */
  .contact-eta-n{font-size:2.2rem}
  .form-card{padding:1.25rem}

  /* CTA */
  .cta-band h2{font-size:1.7rem}

  /* Trust band */
  .trust-band-inner{grid-template-columns:1fr;text-align:left;justify-items:start}

  /* Footer */
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:.5rem}
  .footer-legal{gap:1rem}
}

/* ── 380px: very small (iPhone SE etc.) ─── */
@media(max-width:380px){
  .wrap{padding:0 .85rem}
  .h-display{font-size:2rem}
  .h1{font-size:1.75rem}
  .h2{font-size:1.5rem}
  .hero-tags .hero-tag{font-size:.65rem;padding:.25rem .65rem}
  .btn{padding:.65rem 1.25rem;font-size:.84rem}
  .btn-lg{padding:.72rem 1.4rem;font-size:.88rem}
  .nav-links{width:92vw}
  .eta-bar-text{font-size:.68rem}
  .stats-row{grid-template-columns:1fr 1fr}
  .stat-n{font-size:1.9rem}
  .why-stats{grid-template-columns:1fr 1fr}
  .ws-num{font-size:1.75rem}
  .form-control{font-size:.88rem;padding:.65rem .85rem}
}
