/* ============================================================
   CAR CARRIER NEGOMBO — main site styles
   (admin panel styles live near the bottom of this file)
   ============================================================ */

:root{
  --red:#0066ff;
  --red-2:#3b8bff;
  --red-glow:rgba(0,102,255,.5);
  --ink:#0a0a0a;
  --ink-2:#111111;
  --ink-3:#1a1a1a;
  --paper:#ffffff;
  --paper-2:#f5f6f8;
  --line:rgba(255,255,255,.08);
  --green:#22c55e;
  --green-2:#16a34a;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  --sans:'Inter', system-ui, -apple-system, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--ink);}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;border:0;background:none;cursor:pointer;color:inherit}
img{max-width:100%;display:block}

/* fine grain noise overlay */
.grain::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.5'/></svg>");
  opacity:.18;mix-blend-mode:overlay;
}
.no-grain.grain::before{opacity:0}

/* ---------- PAGE LOADER (red sweep) ---------- */
.loader{
  position:fixed;inset:0;z-index:200;background:#000;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:.3em;
}
.loader .stamp{display:flex;align-items:center;gap:14px;opacity:.85}
.loader .stamp i{color:var(--red);animation:beat 1.6s ease-in-out infinite}
@keyframes beat{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:1}}
.loader.sweep::after{
  content:"";position:absolute;inset:0;background:var(--red);
  transform-origin:left center;animation:sweep 1.05s cubic-bezier(.85,0,.15,1) forwards;
}
.loader.gone{opacity:0;pointer-events:none;transition:opacity .25s ease;}
@keyframes sweep{
  0%{transform:scaleX(0)}
  50%{transform:scaleX(1);transform-origin:left}
  50.01%{transform-origin:right}
  100%{transform:scaleX(0);transform-origin:right}
}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:90;
  transition:padding .3s ease, background .3s ease, backdrop-filter .3s ease;
  padding:18px 0;
}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:0 28px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  background:rgba(10,10,10,.55);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:12px 16px;
  color:#fff;
  transition:padding .3s ease, background .3s ease;
}
.nav.shrunk{padding:10px 0}
.nav.shrunk .nav-inner{padding:8px 14px;background:rgba(10,10,10,.78);}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,#3b8bff,#0040b3);
  box-shadow:0 6px 18px -6px var(--red-glow), inset 0 1px 0 rgba(255,255,255,.25);
  color:#fff;font-size:16px;
}.nav-logo{width:80px;height:80px;object-fit:contain;flex-shrink:0;}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text b{font-weight:900;font-size:15px;letter-spacing:-.01em}
.brand-text small{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;color:rgba(255,255,255,.55);margin-top:4px}
.brand-text b span{color:var(--red-2)}
.brand-text small.powered{color:rgba(255,255,255,.4);font-family:var(--mono);font-size:9px;letter-spacing:.18em;margin-top:3px;display:block;text-transform:uppercase}

.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{
  position:relative;padding:8px 14px;font-size:13.5px;font-weight:500;letter-spacing:.01em;
  border-radius:8px;color:rgba(255,255,255,.78);transition:color .2s;
}
.nav-links a:hover{color:#fff}
.nav-links a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:1px;
  background:var(--red);transform:scaleX(0);transform-origin:left;
  transition:transform .25s cubic-bezier(.6,.2,.2,1);
}
.nav-links a:hover::after{transform:scaleX(1)}

.nav-right{display:flex;align-items:center;gap:10px}
.lang{display:flex;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:3px}
.lang button{
  font-family:var(--mono);font-size:10.5px;padding:5px 9px;border-radius:999px;
  color:rgba(255,255,255,.6);transition:all .2s;letter-spacing:.05em;
}
.lang button.on, .lang button:hover{background:#fff;color:#000}
.call-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--red);color:#fff;font-weight:700;font-size:13px;letter-spacing:.01em;
  padding:9px 16px;border-radius:999px;position:relative;
  transition:transform .15s ease;
}
.call-pill::before{
  content:"";position:absolute;inset:0;border-radius:999px;
  box-shadow:0 0 0 0 var(--red-glow);
  animation:heartbeat 2.4s ease-out infinite;
}
.call-pill:hover{transform:translateY(-1px)}
@keyframes heartbeat{
  0%{box-shadow:0 0 0 0 var(--red-glow)}
  70%{box-shadow:0 0 0 14px rgba(0,102,255,0)}
  100%{box-shadow:0 0 0 0 rgba(0,102,255,0)}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100vh;background:#080808;color:#fff;overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
  padding:140px 0 80px;
}
.hero-mesh{
  position:absolute;inset:-10%;z-index:0;
  background:
    radial-gradient(800px 500px at 75% 30%, var(--red-glow), transparent 60%),
    radial-gradient(700px 480px at 18% 78%, var(--red-glow), transparent 65%),
    radial-gradient(500px 380px at 50% 110%, rgba(120,170,255,.18), transparent 70%);
  filter:blur(40px);
  animation:meshDrift 18s ease-in-out infinite alternate;
}
@keyframes meshDrift{
  0%{transform:translate3d(-2%,0,0) scale(1)}
  100%{transform:translate3d(3%,-3%,0) scale(1.05)}
}
.hero-flare{
  position:absolute;top:20%;right:-5%;width:60vw;height:60vw;max-width:900px;max-height:900px;
  background:radial-gradient(circle,rgba(255,80,80,.35),transparent 60%);
  border-radius:50%;filter:blur(60px);z-index:0;
  animation:flareDrift 14s ease-in-out infinite alternate;
}
@keyframes flareDrift{
  0%{transform:translate(0,0) scale(1);opacity:.7}
  100%{transform:translate(-6%,8%) scale(1.1);opacity:1}
}
.hero-grid{
  position:absolute;inset:0;z-index:0;opacity:.07;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
}

.hero-inner{
  position:relative;z-index:2;max-width:900px;margin:0 auto;padding:0 28px;width:100%;
  display:block;
}
@media(max-width:980px){.hero-inner{grid-template-columns:1fr;gap:40px}}

.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;color:var(--red-2);
  margin-bottom:22px;text-transform:uppercase;
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--red-2);
  box-shadow:0 0 14px var(--red-glow);animation:beat 2.2s ease-in-out infinite}
.eyebrow .bar{width:36px;height:1px;background:var(--red-2);opacity:.5}

.h1{
  font-size:clamp(44px, 6.8vw, 96px);
  line-height:.96;letter-spacing:-.035em;font-weight:900;
  margin-bottom:24px;
}
.h1 .word{display:inline-block;overflow:hidden;vertical-align:bottom;padding:0 .04em 0 0}
.h1 .word > span{display:inline-block;transform:translateY(110%);opacity:0;
  animation:wordRise .85s cubic-bezier(.2,.7,.2,1) forwards;}
.h1 .word.delay-1 > span{animation-delay:.10s}
.h1 .word.delay-2 > span{animation-delay:.16s}
.h1 .word.delay-3 > span{animation-delay:.22s}
.h1 .word.delay-4 > span{animation-delay:.28s}
.h1 .word.delay-5 > span{animation-delay:.34s}
.h1 .word.delay-6 > span{animation-delay:.40s}
.h1 .word.delay-7 > span{animation-delay:.46s}
.h1 .word.delay-8 > span{animation-delay:.52s}
.h1 .word.delay-9 > span{animation-delay:.58s}
@keyframes wordRise{to{transform:translateY(0);opacity:1}}
.h1 em{font-style:normal;color:var(--red-2);position:relative}
.h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.05em;height:.08em;background:currentColor;border-radius:2px;opacity:.4}

.sub{
  font-size:clamp(16px,1.4vw,19px);line-height:1.5;color:rgba(255,255,255,.72);
  max-width:540px;margin-bottom:36px;font-weight:400;
  opacity:0;transform:translateY(18px);animation:fadeUp .8s .65s ease-out forwards;
}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:48px;
  opacity:0;transform:translateY(18px);animation:fadeUp .8s .8s ease-out forwards;}
.btn{
  display:inline-flex;align-items:center;gap:12px;padding:18px 26px;
  font-weight:700;font-size:15px;letter-spacing:.005em;border-radius:14px;
  transition:transform .18s ease, box-shadow .25s ease, background .2s;
  position:relative;overflow:hidden;
}
.btn-red{background:var(--red);color:#fff;box-shadow:0 14px 40px -12px var(--red-glow);}
.btn-red:hover{transform:translateY(-2px);box-shadow:0 18px 50px -10px var(--red-glow)}
.btn-green{background:var(--green);color:#fff;box-shadow:0 14px 40px -14px rgba(34,197,94,.5)}
.btn-green:hover{transform:translateY(-2px)}
.btn .icon-wrap{
  width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.18);
  display:grid;place-items:center;font-size:13px;
}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}
.btn-ghost{
  background:transparent;color:#fff;border:1px solid rgba(255,255,255,.2);
}
.btn-ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.4)}

.trust-row{display:flex;flex-wrap:wrap;gap:8px 28px;
  opacity:0;animation:fadeUp .8s 1s ease-out forwards;}
.trust-row .t{
  display:inline-flex;align-items:center;gap:10px;font-size:12.5px;
  color:rgba(255,255,255,.65);font-family:var(--mono);letter-spacing:.05em;
}
.trust-row .t i{color:var(--red-2);font-size:11px}

/* hero side visual */
.hero-visual{position:relative;height:100%;min-height:480px;}
.hv-card{
  position:absolute;background:rgba(20,20,20,.6);
  border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(20px);
  border-radius:18px;padding:18px;color:#fff;
  box-shadow:0 30px 60px -30px rgba(0,0,0,.7);
}
.hv-status{
  top:0;right:0;width:280px;
  opacity:0;transform:translateY(20px);animation:fadeUp .8s 1.2s ease-out forwards;
}
.hv-status .live{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:#fff}
.hv-status .live .ring{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green);animation:beat 2.2s infinite}
.hv-status .big{font-size:42px;font-weight:900;letter-spacing:-.02em;margin:14px 0 4px;line-height:1}
.hv-status .big small{font-size:14px;font-weight:600;color:rgba(255,255,255,.5)}
.hv-status .lab{font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.5);letter-spacing:.12em}
.hv-status .meter{margin-top:14px;height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.hv-status .meter span{display:block;width:78%;height:100%;background:linear-gradient(90deg,var(--red-2),#ffb84a);animation:meterPulse 2.2s ease-in-out infinite}
@keyframes meterPulse{0%,100%{opacity:.7}50%{opacity:1}}

.hv-truck{
  bottom:20px;left:0;right:40px;
  aspect-ratio:16/10;
  background:
    linear-gradient(180deg,rgba(0,0,0,0) 60%,rgba(0,0,0,.4)),
    repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 12px, rgba(255,255,255,0) 12px 24px),
    linear-gradient(135deg,#1a1a1a,#0d0d0d);
  border:1px solid rgba(255,255,255,.08);border-radius:24px;
  overflow:hidden;display:grid;place-items:end start;padding:22px;
  opacity:0;transform:translateY(20px);animation:fadeUp .9s 1.0s ease-out forwards;
}
.hv-truck::before{
  content:"";position:absolute;inset:auto -20% -40% auto;width:80%;height:80%;
  background:radial-gradient(circle,var(--red-glow),transparent 60%);filter:blur(30px);
}
.hv-truck-svg{width:100%;height:auto;position:relative;z-index:1}
.hv-truck-label{
  position:absolute;top:18px;left:18px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  color:rgba(255,255,255,.55);text-transform:uppercase;
}
.hv-truck-label b{color:var(--red-2);font-weight:600}

.hv-ping{
  bottom:0;right:0;width:200px;
  opacity:0;transform:translateY(20px);animation:fadeUp .8s 1.4s ease-out forwards;
}
.hv-ping .row{display:flex;align-items:center;gap:10px;font-size:12px}
.hv-ping .icon{width:32px;height:32px;border-radius:10px;background:var(--red);display:grid;place-items:center;color:#fff;font-size:13px}
.hv-ping .meta{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;color:rgba(255,255,255,.5);margin-top:8px}
.hv-ping b{font-weight:700;color:#fff;display:block}
.hv-ping span.s{color:rgba(255,255,255,.55);font-size:11px}

/* scroll cue */
.scroll-cue{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:10px;letter-spacing:.32em;color:rgba(255,255,255,.45);
  display:flex;flex-direction:column;align-items:center;gap:8px;z-index:3;
}
.scroll-cue .line{width:1px;height:30px;background:linear-gradient(to bottom,transparent,var(--red-2));animation:scrollDown 1.6s ease-in-out infinite}
@keyframes scrollDown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- SECTION SCAFFOLD ---------- */
section{position:relative}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}
.sec-head{margin-bottom:64px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:end}
@media(max-width:780px){.sec-head{grid-template-columns:1fr}}
.sec-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;color:var(--red);
  text-transform:uppercase;margin-bottom:16px;
}
.sec-eyebrow .num{color:var(--ink);background:#fff;border:1px solid #e5e5e5;border-radius:4px;padding:2px 7px;font-weight:700}
.sec-title{
  font-size:clamp(36px,4.4vw,64px);font-weight:900;letter-spacing:-.025em;line-height:1;
}
.sec-title em{font-style:normal;color:var(--red)}
.sec-sub{font-size:16px;color:rgba(0,0,0,.6);max-width:420px;line-height:1.55}

/* reveal utility */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}
.reveal[data-d="6"]{transition-delay:.48s}

/* ---------- SERVICE BENTO ---------- */
.service{padding:140px 0 100px;background:var(--paper)}
.bento{
  display:grid;grid-template-columns:1.55fr 1fr;gap:18px;
}
@media(max-width:980px){.bento{grid-template-columns:1fr}}
.b-card{
  background:#fff;border:1px solid #ececec;border-radius:24px;padding:36px;
  position:relative;overflow:hidden;transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .3s;
  transform-style:preserve-3d;
}
.b-card:hover{
  border-color:var(--red-glow);
  box-shadow:0 30px 70px -30px var(--red-glow);
}
.b-main{padding:48px;display:flex;flex-direction:column;justify-content:space-between;min-height:480px;background:var(--ink);color:#fff;border-color:transparent}
.b-main::before{
  content:"";position:absolute;inset:auto -20% -40% auto;width:60%;height:60%;
  background:radial-gradient(circle,var(--red-glow),transparent 65%);filter:blur(20px);opacity:.8;
  transition:opacity .3s;
}
.b-main:hover::before{opacity:1}
.b-main h3{font-size:clamp(34px,3.6vw,52px);font-weight:900;line-height:1;letter-spacing:-.025em;margin-bottom:18px;position:relative;z-index:1}
.b-main p{font-size:16px;line-height:1.55;color:rgba(255,255,255,.7);max-width:440px;margin-bottom:28px;position:relative;z-index:1}
.checks{display:grid;gap:14px;margin-bottom:32px;position:relative;z-index:1}
.check{
  display:flex;align-items:center;gap:14px;font-size:15px;font-weight:500;
  opacity:0;transform:translateX(-12px);transition:all .5s ease;
}
.check.in{opacity:1;transform:translateX(0)}
.check .tick{
  width:26px;height:26px;border-radius:8px;background:var(--red);
  display:grid;place-items:center;color:#fff;font-size:11px;flex-shrink:0;
  box-shadow:0 6px 18px -6px var(--red-glow);
}
.b-main .btn{align-self:flex-start;position:relative;z-index:1}

.b-side{display:grid;grid-template-rows:1fr 1fr;gap:18px}
.b-stat{padding:32px;background:#fff;border:1px solid #ececec;border-radius:24px;display:flex;flex-direction:column;justify-content:space-between;min-height:230px;transition:all .35s;position:relative;overflow:hidden}
.b-stat:hover{border-color:var(--red-glow);transform:translateY(-3px);box-shadow:0 20px 50px -20px var(--red-glow)}
.b-stat .lab{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;color:rgba(0,0,0,.45);text-transform:uppercase}
.b-stat .num{font-size:64px;font-weight:900;letter-spacing:-.04em;line-height:1;color:var(--ink)}
.b-stat .num .u{color:var(--red);font-size:32px;vertical-align:super;margin-left:4px;font-weight:800}
.b-stat .desc{font-size:13.5px;color:rgba(0,0,0,.55);line-height:1.5}
.b-stat::after{
  content:"";position:absolute;right:-30%;bottom:-30%;width:60%;height:60%;
  background:radial-gradient(circle,var(--red-glow),transparent 65%);
  transform:scale(0);transition:transform .4s ease;
}
.b-stat:hover::after{transform:scale(1)}

/* ---------- WHY US ---------- */
.why{padding:130px 0;background:var(--ink);color:#fff;position:relative;overflow:hidden}
.why::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at 90% 10%, var(--red-glow), transparent 60%),
    radial-gradient(600px 400px at 0% 90%, var(--red-glow), transparent 60%);
}
.why .sec-eyebrow{color:var(--red-2)}
.why .sec-eyebrow .num{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.1)}
.why .sec-title{color:#fff}
.why .sec-sub{color:rgba(255,255,255,.55)}
.why-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
@media(max-width:980px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.why-grid{grid-template-columns:1fr}}
.why-card{
  padding:48px 32px;border-right:1px solid var(--line);position:relative;
  transition:background .3s;cursor:default;
}
.why-card:last-child{border-right:0}
@media(max-width:980px){
  .why-card:nth-child(2){border-right:0}
  .why-card:nth-child(1),.why-card:nth-child(2){border-bottom:1px solid var(--line)}
}
.why-card:hover{background:rgba(255,255,255,.03)}
.why-card .num-big{
  font-size:78px;font-weight:900;letter-spacing:-.04em;line-height:1;
  background:linear-gradient(180deg,#fff,#777);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:24px;
}
.why-card .num-big .u{font-size:34px;color:var(--red-2);-webkit-text-fill-color:var(--red-2);vertical-align:super;margin-left:4px;font-weight:800}
.why-card .ico{
  position:absolute;top:32px;right:32px;
  width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.06);
  display:grid;place-items:center;color:var(--red-2);font-size:14px;
  border:1px solid var(--line);
}
.why-card h4{font-size:19px;font-weight:800;letter-spacing:-.01em;margin-bottom:10px}
.why-card p{font-size:13.5px;color:rgba(255,255,255,.55);line-height:1.55}

/* ---------- ABOUT ---------- */
.about{padding:140px 0;background:var(--paper-2);position:relative;overflow:hidden}
.about-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
@media(max-width:880px){.about-inner{grid-template-columns:1fr;gap:48px}}
.about-quote{
  font-size:clamp(26px,2.6vw,38px);line-height:1.25;letter-spacing:-.018em;font-weight:600;
}
.about-quote .red{color:var(--red)}
.about-quote .accent{position:relative;display:inline-block}
.about-quote .accent::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.18em;background:var(--red);opacity:.18;z-index:-1}
.about-meta{display:grid;gap:24px}
.about-meta .row{display:flex;gap:16px;align-items:flex-start;padding:20px;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px}
.about-meta .row .ico{width:42px;height:42px;border-radius:12px;background:var(--ink);color:#fff;display:grid;place-items:center;flex-shrink:0;font-size:16px}
.about-meta .row b{display:block;font-size:14px;font-weight:800;margin-bottom:4px;letter-spacing:-.005em}
.about-meta .row span{font-size:13px;color:rgba(0,0,0,.6);line-height:1.5}

/* ---------- GALLERY ---------- */
.gallery{padding:130px 0;background:var(--paper)}
.g-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:160px;gap:14px}
@media(max-width:980px){.g-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:140px}}
@media(max-width:560px){.g-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}}
.g-tile{
  position:relative;overflow:hidden;border-radius:18px;background:#1a1a1a;
  cursor:pointer;
}
.g-tile .ph{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 6s ease, filter .35s ease;
  filter:saturate(.85) contrast(1.05);
}
.g-tile:hover .ph{transform:scale(1.12);filter:saturate(1.1) contrast(1.1)}
.g-tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7));
  opacity:.6;transition:all .35s ease;
}
.g-tile:hover::after{
  background:linear-gradient(180deg,var(--red-glow),rgba(211,47,47,.65));
  opacity:1;
}
.g-tile .lbl{
  position:absolute;left:18px;bottom:16px;color:#fff;z-index:1;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  transform:translateY(8px);opacity:.85;transition:all .3s;
}
.g-tile:hover .lbl{transform:translateY(0);opacity:1}
.g-tile .lbl b{display:block;font-family:var(--sans);font-size:15px;letter-spacing:-.005em;text-transform:none;font-weight:700;margin-top:4px}
.g-tile .corner{
  position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,.12);backdrop-filter:blur(8px);display:grid;place-items:center;color:#fff;
  z-index:1;opacity:0;transform:scale(.7);transition:all .3s;font-size:11px;
}
.g-tile:hover .corner{opacity:1;transform:scale(1)}

/* tile spans */
.g-tile.t1{grid-column:span 3;grid-row:span 2}
.g-tile.t2{grid-column:span 3;grid-row:span 1}
.g-tile.t3{grid-column:span 2;grid-row:span 1}
.g-tile.t4{grid-column:span 1;grid-row:span 1}
.g-tile.t5{grid-column:span 2;grid-row:span 2}
.g-tile.t6{grid-column:span 4;grid-row:span 1}
@media(max-width:980px){
  .g-tile.t1{grid-column:span 3;grid-row:span 2}
  .g-tile.t2{grid-column:span 3}
  .g-tile.t3{grid-column:span 2}
  .g-tile.t4{grid-column:span 1}
  .g-tile.t5{grid-column:span 2;grid-row:span 1}
  .g-tile.t6{grid-column:span 3}
}
@media(max-width:560px){
  .g-tile.t1{grid-column:span 2;grid-row:span 2}
  .g-tile.t2,.g-tile.t3,.g-tile.t4,.g-tile.t5,.g-tile.t6{grid-column:span 2;grid-row:span 1}
}

/* ---------- CONTACT ---------- */
.contact{padding:130px 0;background:var(--paper-2)}
.c-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px}
@media(max-width:980px){.c-grid{grid-template-columns:1fr}}
.c-form{
  background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:24px;padding:40px;
}
.c-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
@media(max-width:560px){.c-form .row{grid-template-columns:1fr}}
.field{position:relative}
.field label{
  position:absolute;left:16px;top:16px;font-size:13px;color:rgba(0,0,0,.45);
  pointer-events:none;transition:all .2s ease;font-weight:500;
  background:#fff;padding:0 4px;
}
.field input, .field select, .field textarea{
  width:100%;padding:18px 16px 14px;border:1.5px solid #e5e5e5;border-radius:12px;
  font-family:inherit;font-size:14.5px;background:#fff;color:var(--ink);transition:all .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none;border-color:var(--red);box-shadow:0 0 0 4px var(--red-glow);
}
.field input:focus + label, .field input:not(:placeholder-shown) + label,
.field textarea:focus + label, .field textarea:not(:placeholder-shown) + label,
.field select:focus + label, .field.has-value label{
  top:-8px;font-size:11px;color:var(--red);font-weight:700;letter-spacing:.05em;
}
.field textarea{resize:vertical;min-height:130px}
.send{
  width:100%;background:var(--red);color:#fff;font-weight:800;font-size:15px;
  padding:18px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;gap:12px;
  transition:all .2s;letter-spacing:.01em;
}
.send:hover{background:#0050cc;transform:translateY(-1px);box-shadow:0 12px 32px -8px var(--red-glow)}
.send i{transition:transform .2s}
.send:hover i{transform:translateX(4px)}
.send-wa{background:#25d366;}
.send-wa:hover{background:#128c4e;box-shadow:0 12px 32px -8px rgba(37,211,102,.45)}
.form-success{
  margin-top:14px;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);
  color:#15803d;padding:14px;border-radius:12px;font-size:13.5px;font-weight:600;
  display:none;align-items:center;gap:10px;
}
.form-success.show{display:flex}
.form-error{
  margin-top:14px;background:rgba(239,68,68,.10);border:1px solid rgba(239,68,68,.3);
  color:#b91c1c;padding:14px;border-radius:12px;font-size:13.5px;font-weight:600;
  display:none;align-items:center;gap:10px;
}
.form-error.show{display:flex}

.c-side{display:grid;gap:14px}
.c-card{
  background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:18px;padding:22px;
  display:flex;align-items:center;gap:18px;transition:all .25s;cursor:pointer;
}
.c-card:hover{transform:translateY(-3px);border-color:var(--red-glow);box-shadow:0 14px 32px -12px var(--red-glow)}
.c-card .ico{
  width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  color:#fff;font-size:18px;flex-shrink:0;
}
.c-card .ico.red{background:var(--red)}
.c-card .ico.green{background:var(--green)}
.c-card .ico.dark{background:var(--ink)}
.c-card .lab{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:rgba(0,0,0,.5);text-transform:uppercase;margin-bottom:4px;display:block}
.c-card b{font-size:16px;font-weight:800;letter-spacing:-.01em;display:block;line-height:1.3}
.c-card .arr{margin-left:auto;color:rgba(0,0,0,.3);transition:all .2s}
.c-card:hover .arr{color:var(--red);transform:translateX(3px)}
.c-map{
  height:280px;border-radius:18px;overflow:hidden;position:relative;
  background:#1a1a1a;color:#fff;
  border:1px solid rgba(0,0,0,.06);
}
.c-map iframe{width:100%;height:100%;border:0;filter:grayscale(.2) contrast(1.05)}
@media(max-width:780px){.c-map{height:240px}.c-map iframe{filter:none}}
.c-map .pin{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:18px;height:18px;border-radius:50%;background:var(--red);
  box-shadow:0 0 0 0 var(--red-glow);animation:heartbeat 1.6s infinite;
  border:3px solid #fff;pointer-events:none;
}
.c-map .lbl{
  position:absolute;left:20px;top:20px;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:rgba(255,255,255,.85);text-transform:uppercase;
  background:rgba(10,10,10,.6);padding:8px 12px;border-radius:8px;backdrop-filter:blur(8px);
}
.c-map .lbl b{display:block;font-family:var(--sans);font-size:14px;color:#fff;text-transform:none;letter-spacing:-.005em;margin-top:4px;font-weight:700}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:#fff;padding:90px 0 30px;position:relative;overflow:hidden}
footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;margin-bottom:60px}
@media(max-width:780px){.f-grid{grid-template-columns:1fr;gap:40px}}
.f-brand{display:flex;flex-direction:column;gap:18px;max-width:380px}
.f-brand .b{display:flex;align-items:center;gap:14px}
.f-brand .b .mk{width:70px;height:70px;background:none;display:grid;place-items:center;}
.f-brand .b .mk img{width:70px;height:70px;object-fit:contain;}
.f-brand .b b{font-size:20px;font-weight:900;letter-spacing:-.01em}
.f-brand .b b span{color:var(--red-2)}
.f-brand p{font-size:14px;color:rgba(255,255,255,.55);line-height:1.6}
.f-social{display:flex;gap:10px;margin-top:4px}
.f-social a{width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.12);display:grid;place-items:center;color:rgba(255,255,255,.6);font-size:14px;transition:all .2s}
.f-social a:hover{background:var(--red);border-color:var(--red);color:#fff}
.f-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:rgba(255,255,255,.5);margin-bottom:18px;text-transform:uppercase;font-weight:600}
.f-col ul{list-style:none;display:grid;gap:10px}
.f-col li{font-size:14px;color:rgba(255,255,255,.7);display:flex;gap:10px;align-items:flex-start}
.f-col li i{color:var(--red-2);font-size:11px;margin-top:5px}
.f-col a:hover{color:#fff}
.f-bottom{
  border-top:1px solid var(--line);padding-top:30px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.4);text-transform:uppercase;
}
.f-bottom .pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--line);border-radius:999px}
.f-bottom .pill .live{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:beat 2.2s infinite}

/* ---------- FLOATING FABs ---------- */
.fab{
  position:fixed;width:62px;height:62px;border-radius:50%;
  display:grid;place-items:center;color:#fff;font-size:22px;
  z-index:80;box-shadow:0 14px 40px -10px rgba(0,0,0,.35);
  transition:transform .2s ease;
}
.fab:hover{transform:scale(1.06)}
.fab-call{right:24px;bottom:24px;background:transparent;box-shadow:none;position:fixed;animation:bounce 2.6s ease-in-out infinite}
.fab-call img{width:62px;height:62px;border-radius:50%;object-fit:contain;}
.fab-call::before,.fab-call::after{display:none!important}
@keyframes siren{
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(1.9);opacity:0}
}
@keyframes bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}
.fab-tip{
  position:absolute;right:74px;top:50%;transform:translateY(-50%) translateX(8px);
  background:#fff;color:var(--ink);font-size:12px;font-weight:700;padding:8px 12px;border-radius:10px;
  white-space:nowrap;opacity:0;pointer-events:none;transition:all .2s;
  box-shadow:0 8px 24px -8px rgba(0,0,0,.3);
}
.fab-call .fab-tip{right:74px;left:auto;transform:translateY(-50%) translateX(8px)}
.fab-call:hover .fab-tip{opacity:1;transform:translateY(-50%) translateX(0)}
.fab-call.no-siren::before, .fab-call.no-siren::after{display:none}

/* ---------- magnetic cursor for buttons ---------- */
.magnetic{will-change:transform;transition:transform .3s cubic-bezier(.2,.7,.2,1)}

/* selection */
::selection{background:var(--red);color:#fff}

/* ---------- NAV: COMPACT PILL + BURGER (mobile) ---------- */
.call-pill-mini{display:none;align-items:center;gap:6px;padding:9px 14px;border-radius:999px;background:var(--red);color:#fff;font-weight:800;font-size:13px;letter-spacing:.01em;position:relative;overflow:hidden}
.call-pill-mini::before{content:"";position:absolute;inset:0;border-radius:999px;box-shadow:0 0 0 0 var(--red-glow);animation:heartbeat 2.4s ease-out infinite}
.call-pill-mini i{font-size:11px;position:relative;z-index:1}
.call-pill-mini span{position:relative;z-index:1}

.burger{display:none;width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);position:relative;flex-direction:column;justify-content:center;align-items:center;gap:5px;transition:background .2s}
.burger:hover{background:rgba(255,255,255,.14)}
.burger span{width:18px;height:2px;background:#fff;border-radius:2px;transition:transform .25s, opacity .25s}
body.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- MOBILE MENU OVERLAY ---------- */
.m-menu{
  position:fixed;left:10px;right:10px;top:60px;z-index:99;
  background:rgba(15,15,17,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.08);border-radius:18px;
  padding:18px;color:#fff;
  transform:translateY(-12px) scale(.98);opacity:0;pointer-events:none;
  transition:transform .26s cubic-bezier(.4,.0,.2,1), opacity .22s;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.6);
  max-height:calc(100vh - 80px);overflow-y:auto;
}
body.menu-open .m-menu{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
.m-menu nav{display:flex;flex-direction:column;gap:2px;margin-bottom:14px}
.m-menu nav a{
  display:flex;justify-content:space-between;align-items:center;
  padding:13px 12px;font-size:16px;font-weight:700;letter-spacing:-.005em;color:#fff;
  border-radius:10px;transition:background .15s;
}
.m-menu nav a:hover, .m-menu nav a:active{background:rgba(255,255,255,.05)}
.m-menu nav a i{color:rgba(255,255,255,.35);font-size:11px}
.m-menu .quick{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.m-menu .quick a{display:flex;align-items:center;gap:8px;padding:13px;border-radius:12px;font-weight:700;font-size:13.5px;color:#fff}
.m-menu .quick .q-call{background:var(--red)}
.m-menu .quick .q-wa{background:var(--green)}
.m-menu .info{display:grid;gap:10px;padding:12px;background:rgba(255,255,255,.04);border-radius:12px;margin-bottom:12px}
.m-menu .info .row{display:flex;gap:10px;font-size:12.5px;color:rgba(255,255,255,.7);align-items:flex-start;line-height:1.5}
.m-menu .info .row i{color:var(--red-2);font-size:11px;margin-top:4px;width:14px;text-align:center}
.m-menu .info .row b{color:#fff;font-weight:700;display:block;font-size:13px;margin-bottom:1px}
.m-menu .lang-row{display:flex;gap:6px;margin-bottom:10px}
.m-menu .lang-row button{flex:1;padding:10px;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.7);letter-spacing:.05em}
.m-menu .lang-row button.on{background:#fff;color:#000;border-color:#fff}
.m-menu .foot{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;color:rgba(255,255,255,.4);text-transform:uppercase;text-align:center;padding-top:8px}
body.menu-open{overflow:hidden}
.menu-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(2px);z-index:98;opacity:0;pointer-events:none;transition:opacity .25s}
body.menu-open .menu-backdrop{opacity:1;pointer-events:auto}

/* ---------- MOBILE BREAKPOINTS ---------- */
@media(max-width:840px){
  .nav-links{display:none}
  .nav-inner{padding:8px 10px;border-radius:14px;gap:8px}
  .nav{padding:10px 0}
  .lang{display:none}
  .call-pill-full{display:none}
  .call-pill-mini{display:inline-flex}
  .burger{display:flex}
  .nav-right{gap:8px}
  .brand-text small.powered{display:none}
  .brand-text b{font-size:14px}
  .brand-mark{width:34px;height:34px}
}

@media(max-width:780px){
  .hero{padding:80px 0 40px;min-height:auto}
  .hero-inner{padding:0 18px;gap:24px}
  .hero-visual{transform:scale(.78);transform-origin:top center;margin-top:-20px}
  .h1{font-size:38px;line-height:1.05}
  .sub{font-size:14px;margin-bottom:20px}
  .cta-row{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:22px}
  .btn{justify-content:center;padding:14px 18px;font-size:14px}
  .scroll-cue{display:none}
  .eyebrow{font-size:10px;letter-spacing:.24em;margin-bottom:14px}
  .trust-row{gap:4px 14px}
  .trust-row .t{font-size:10.5px}
  section{padding-left:0;padding-right:0}
  .wrap{padding:0 16px}
  .service{padding:60px 0 44px}
  .sec-head{margin-bottom:24px;gap:10px}
  .sec-title{font-size:32px;line-height:1.05}
  .sec-eyebrow{font-size:10px;letter-spacing:.2em;margin-bottom:10px}
  .sec-sub{font-size:13.5px}
  .bento{gap:10px}
  .b-main{padding:26px;min-height:auto}
  .b-main h3{font-size:28px}
  .b-main p{font-size:14px;margin-bottom:18px}
  .b-side{grid-template-rows:auto;grid-template-columns:1fr 1fr;gap:10px}
  .b-stat{padding:18px;min-height:140px}
  .b-stat .num{font-size:40px}
  .b-stat .num .u{font-size:20px}
  .b-stat .desc{font-size:11.5px}
  .why{padding:60px 0}
  .why-card{padding:26px 18px}
  .why-card .num-big{font-size:48px;margin-bottom:12px}
  .why-card .num-big .u{font-size:22px}
  .why-card h4{font-size:16px}
  .why-card p{font-size:12.5px}
  .why-card .ico{top:20px;right:18px;width:30px;height:30px}
  .about{padding:60px 0}
  .about-quote{font-size:20px;line-height:1.3}
  .about-meta{grid-template-columns:1fr 1fr;gap:12px}
  .about-meta .row{padding:14px}
  .about-meta .row b{font-size:13px}
  .about-meta .row span{font-size:11.5px}
  .gallery{padding:60px 0}
  .g-grid{grid-template-columns:1fr;grid-auto-rows:180px;gap:8px}
  .g-tile,.g-tile.t1,.g-tile.t2,.g-tile.t3,.g-tile.t4,.g-tile.t5,.g-tile.t6{grid-column:span 1;grid-row:span 1}
  .g-tile.t1{grid-row:span 2}
  .g-tile .lbl{font-size:9.5px}
  .g-tile .lbl b{font-size:13px}
  .contact{padding:60px 0}
  .c-grid{gap:20px}
  .c-form{padding:20px}
  .c-card{padding:16px;gap:12px}
  .c-card .ico{width:42px;height:42px;font-size:15px}
  .c-card b{font-size:14px}
  footer{padding:50px 0 30px}
  .f-grid{grid-template-columns:1fr 1fr;margin-bottom:28px;gap:20px}
  .f-bottom{font-size:10px;flex-direction:column;align-items:flex-start;gap:8px}
}

@media(max-width:560px){
  .hero{padding:72px 0 36px}
  .h1{font-size:32px}
  .b-side{grid-template-columns:1fr 1fr}
  .b-stat{min-height:auto}
  .hero-visual{display:none}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .about-meta{grid-template-columns:1fr}
  .f-grid{grid-template-columns:1fr}
}

/* ---------- SAFETY / COVERAGE / VEHICLES / TESTIMONIAL ---------- */
.safety{padding:130px 0;background:var(--paper)}
.safety-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:80px}
.s-step{background:#fff;border:1px solid #ececec;border-radius:20px;padding:32px;transition:all .3s}
.s-step:hover{border-color:rgba(0,102,255,.4);box-shadow:0 18px 40px -20px var(--red-glow);transform:translateY(-3px)}
.s-step .s-num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--red);margin-bottom:18px}
.s-step h4{font-size:22px;font-weight:800;letter-spacing:-.012em;margin-bottom:8px}
.s-step p{font-size:14.5px;color:rgba(0,0,0,.6);line-height:1.55}
.coverage{display:grid;grid-template-columns:1fr 1.5fr;gap:48px;align-items:center;padding:42px;background:var(--ink);color:#fff;border-radius:24px;margin-bottom:32px;position:relative;overflow:hidden}
.coverage::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 100% 0%,var(--red-glow),transparent 60%);opacity:.6}
.cov-left{position:relative;z-index:1}
.cov-left .sec-eyebrow{color:var(--red-2);margin-bottom:10px}
.cov-left .sec-eyebrow .num{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.1)}
.cov-left h3{font-size:34px;font-weight:900;letter-spacing:-.02em;line-height:1;margin-bottom:10px}
.cov-left p{font-size:14px;color:rgba(255,255,255,.65);line-height:1.5}
.cov-tags{display:flex;flex-wrap:wrap;gap:8px;position:relative;z-index:1}
.cov-tags span{padding:8px 14px;border:1px solid rgba(255,255,255,.14);border-radius:999px;font-size:13px;font-weight:600;color:#fff;background:rgba(255,255,255,.04)}
.cov-tags span.more{background:var(--red);border-color:var(--red);color:#fff}
.vehicles{margin-bottom:32px}
.vehicles .sec-eyebrow{margin-bottom:18px}
.veh-slider{display:flex;align-items:center;gap:10px}
.veh-track-wrap{overflow:hidden;flex:1}
.veh-row{display:flex;gap:18px;transition:transform .4s ease}
.veh-prev,.veh-next{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:2px solid #e4eaf5;background:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center;transition:all .2s;color:var(--ink)}
.veh-prev:hover,.veh-next:hover{border-color:var(--red);color:var(--red)}
@keyframes veh-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.veh{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px 24px;background:#fff;border:1px solid #e4eaf5;border-radius:22px;min-width:200px;transition:border-color .28s,box-shadow .28s;position:relative;overflow:hidden;cursor:default}
.veh::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b8bff,#0066ff);opacity:.28;border-radius:22px 22px 0 0;transition:opacity .28s}
.veh:hover{border-color:rgba(0,102,255,.2);box-shadow:0 16px 36px -8px rgba(0,102,255,.16)}
.veh:hover::before{opacity:1}
.veh svg{width:140px;height:140px;animation:veh-bob 3s ease-in-out infinite}
.veh img{width:190px;height:130px;object-fit:contain;animation:veh-bob 3s ease-in-out infinite}
.veh img[src="/img/vehicles/suv.png"]{transform-origin:center;scale:1.45}
.veh:nth-child(2) svg,.veh:nth-child(2) img{animation-delay:-.5s}
.veh:nth-child(3) svg,.veh:nth-child(3) img{animation-delay:-1s}
.veh:nth-child(4) svg,.veh:nth-child(4) img{animation-delay:-1.5s}
.veh:nth-child(5) svg,.veh:nth-child(5) img{animation-delay:-2s}
.veh:nth-child(6) svg,.veh:nth-child(6) img{animation-delay:-2.5s}
.veh i{font-size:34px;color:var(--red)}
.veh span{font-size:14px;font-weight:700;letter-spacing:.04em;color:#444;text-transform:uppercase}
.testimonial{padding:42px;background:var(--paper-2);border-radius:24px;border:1px solid rgba(0,0,0,.05)}
.testimonial blockquote{font-size:clamp(20px,2.2vw,28px);font-weight:600;line-height:1.4;letter-spacing:-.012em;margin-bottom:18px;color:var(--ink)}
.testimonial figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:rgba(0,0,0,.55);text-transform:uppercase}
.testimonial figcaption b{color:var(--red);font-weight:700}

/* ---------- GALLERY CAROUSEL ---------- */
.g-carousel{display:none}
.g-carousel-always{display:block!important}
.g-carousel-nav{display:flex;justify-content:flex-end;gap:10px;margin-bottom:16px}
.g-prev,.g-next{width:44px;height:44px;border-radius:50%;border:2px solid #e4eaf5;background:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center;transition:all .2s;color:var(--ink)}
.g-prev:hover,.g-next:hover{border-color:var(--red);color:var(--red)}
.g-carousel-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 2px}
.g-carousel-track::-webkit-scrollbar{display:none}
.g-slide{flex:0 0 340px;height:280px;scroll-snap-align:start;border-radius:18px;overflow:hidden;position:relative;background:#1a1a1a;cursor:pointer}
.g-slide .ph{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s}
.g-slide:hover .ph{transform:scale(1.06)}
.g-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7))}
.g-slide .lbl{position:absolute;left:18px;bottom:18px;color:#fff;z-index:1;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}
.g-slide .lbl b{display:block;font-family:var(--sans);font-size:14px;text-transform:none;letter-spacing:-.005em;margin-top:4px;font-weight:700}
.g-dots{display:flex;justify-content:center;gap:6px;margin-top:16px}
.g-dot{width:6px;height:6px;border-radius:50%;background:rgba(0,0,0,.15);transition:all .25s;border:0;padding:0;cursor:pointer}
.g-dot.on{background:var(--red);width:18px;border-radius:3px}
@media(max-width:780px){.g-slide{flex:0 0 78%;height:180px}}

@media(max-width:780px){
  .safety{padding:60px 0}
  .safety-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:36px}
  .safety-grid .s-step:last-child:nth-child(odd){grid-column:1/-1;width:calc(50% - 5px)}
  .s-step{padding:20px}
  .s-step h4{font-size:17px}
  .s-step p{font-size:13px}
  .coverage{grid-template-columns:1fr;gap:18px;padding:22px}
  .cov-left h3{font-size:24px}
  .veh-row{gap:8px}
  .veh{padding:14px 8px 12px;gap:6px}
  .veh svg{width:70px;height:70px}
  .veh img{width:90px;height:60px}
  .veh i{font-size:18px}
  .veh span{font-size:10px}
  .testimonial{padding:22px}
  .testimonial blockquote{font-size:17px}
  .g-grid{display:none}
}

/* ---------- BRANDS STRIP ---------- */
.brands-strip{margin-bottom:32px}
.brands-strip .sec-eyebrow{margin-bottom:16px}
.brands-list-el{display:flex;flex-wrap:wrap;gap:8px}
.brand-tag{padding:12px 24px;border:1px solid #ececec;border-radius:999px;font-size:15px;font-weight:700;color:var(--ink);background:#fff;letter-spacing:-.005em;transition:all .2s;cursor:default}
.brand-tag:hover{border-color:var(--red);color:var(--red)}

/* ---------- TESTIMONIALS SECTION ---------- */
.testimonials-sec{padding:130px 0;background:var(--ink);position:relative;overflow:hidden}
.testimonials-sec::before{content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,var(--red-glow),transparent 65%);opacity:.35;pointer-events:none}
.t-slider{position:relative}
.t-track-wrap{overflow:hidden}
.tcards{display:flex;gap:18px;transition:transform .4s cubic-bezier(.25,.8,.25,1)}
.tcard{flex:0 0 340px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:32px;display:flex;flex-direction:column;transition:border-color .25s,transform .25s}
.t-slider-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px}
.t-prev,.t-next{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);font-size:18px;cursor:pointer;display:grid;place-items:center;color:#fff;transition:all .2s;flex-shrink:0}
.t-prev:hover,.t-next:hover{border-color:var(--red);background:var(--red)}
.t-dots{display:flex;gap:6px;align-items:center}
.t-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.2);border:0;padding:0;cursor:pointer;transition:all .25s}
.t-dot.on{background:var(--red);width:18px;border-radius:3px}
@media(max-width:780px){.tcard{flex:0 0 82vw;padding:20px}}
@media(max-width:560px){.tcard{flex:0 0 88vw}}
.tcard:hover{border-color:rgba(59,139,255,.4);transform:translateY(-3px)}
.tcard-stars{display:flex;gap:3px;color:#fbbf24;font-size:13px;margin-bottom:16px}
.tcard-quote{font-size:15.5px;line-height:1.65;color:rgba(255,255,255,.78);flex:1;margin-bottom:24px}
.tcard-meta b{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--red-2);display:block;margin-bottom:3px}
.tcard-meta span{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:rgba(255,255,255,.38);text-transform:uppercase}

/* ---------- FAQ SECTION ---------- */
.faq-sec{padding:130px 0;background:var(--paper-2)}
.faq-list{display:grid;gap:10px;max-width:860px;margin:0 auto}
.faq-item{background:#fff;border:1px solid #ececec;border-radius:16px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.faq-item.open{border-color:rgba(0,102,255,.3);box-shadow:0 8px 28px -12px var(--red-glow)}
.faq-q{padding:22px 26px;display:flex;justify-content:space-between;align-items:center;gap:18px;cursor:pointer;font-weight:700;font-size:16px;letter-spacing:-.012em;user-select:none}
.faq-q i{color:rgba(0,0,0,.3);font-size:12px;transition:transform .25s,color .2s;flex-shrink:0}
.faq-item.open .faq-q i{transform:rotate(180deg);color:var(--red)}
.faq-a{padding:0 26px;max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1),padding .25s}
.faq-item.open .faq-a{max-height:300px;padding-bottom:22px}
.faq-a p{font-size:15px;line-height:1.65;color:rgba(0,0,0,.62);border-top:1px solid #f0f0f0;padding-top:16px}

@media(max-width:780px){
  .testimonials-sec{padding:60px 0}
  .tcard-quote{font-size:13.5px}
  .tcard-stars{font-size:12px;margin-bottom:12px}
  .faq-sec{padding:60px 0}
  .faq-q{padding:16px 18px;font-size:14px}
  .faq-item.open .faq-a{padding-bottom:16px}
  .faq-a{padding:0 18px}
  .faq-a p{font-size:13px}
  .brands-list-el{gap:6px}
  .brand-tag{padding:7px 12px;font-size:11.5px}
}

/* ============================================================
   ADMIN PANEL STYLES
   ============================================================ */
.cc-input {
  width:100%;padding:12px 14px;border:1px solid #e5e7eb;border-radius:10px;
  font-size:14.5px;background:#fff;color:#111;
  transition:border-color .15s, box-shadow .15s;font-family:inherit;
}
.cc-input:focus { outline:none;border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow); }
textarea.cc-input { resize:vertical;min-height:80px;line-height:1.4 }

.adm-section {
  background:#fff;border:1px solid #e5e7eb;border-radius:14px;
  margin-bottom:14px;overflow:hidden;
}
.adm-section-head {
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;cursor:pointer;user-select:none;
  border-bottom:1px solid transparent;transition:border-color .2s;
}
.adm-section.open .adm-section-head {border-bottom-color:#f0f0f0}
.adm-section-head h3 {font-size:15px;font-weight:700;display:flex;align-items:center;gap:10px;color:#111}
.adm-section-head h3 i.lead {color:var(--red);font-size:12px;width:18px;text-align:center}
.adm-section-head .chev { color:#999;transition:transform .25s }
.adm-section.open .adm-section-head .chev { transform:rotate(180deg) }
.adm-section-body { padding:18px;display:none }
.adm-section.open .adm-section-body { display:block }

.adm-grid-2 { display:grid;grid-template-columns:1fr 1fr;gap:12px }
.adm-grid-3 { display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px }
@media(max-width:720px){ .adm-grid-2,.adm-grid-3{grid-template-columns:1fr} }

.adm-label {
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:#666;margin-bottom:6px;display:block;
}
.adm-row { margin-bottom:12px }

.adm-list { display:grid;gap:10px }
.adm-list-item {
  background:#fafafa;border:1px solid #ececec;border-radius:10px;padding:12px;
  position:relative;
}
.adm-list-item .adm-row{margin-bottom:8px}
.adm-list-item .adm-row:last-child{margin-bottom:0}
.adm-list-item .del-btn {
  position:absolute;top:8px;right:8px;
  background:#fee;color:#b91c1c;border:0;font-size:12px;padding:4px 8px;border-radius:6px;cursor:pointer;
}
.adm-list-item .del-btn:hover{background:#fecaca}
.adm-add-btn {
  width:100%;padding:10px;border:1.5px dashed #d1d5db;border-radius:10px;
  background:#fff;color:#666;font-weight:600;font-size:13px;cursor:pointer;
  transition:all .2s;
}
.adm-add-btn:hover { border-color:var(--red);color:var(--red) }

.adm-toggle {
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  background:#fafafa;border:1px solid #ececec;border-radius:10px;cursor:pointer;
}
.adm-toggle input { width:16px;height:16px;accent-color:var(--red) }
.adm-toggle span { font-size:13.5px;font-weight:600 }

.adm-color-row { display:flex;flex-wrap:wrap;gap:8px;align-items:center }
.adm-color-row .swatch {
  width:34px;height:34px;border-radius:9px;border:2px solid transparent;cursor:pointer;
}
.adm-color-row .swatch.on { border-color:#111 }
.adm-color-row input[type="color"]{width:48px;height:34px;padding:0;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer}

.adm-save-bar {
  position:sticky;bottom:0;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);
  border-top:1px solid #ececec;padding:14px 0;margin-top:18px;
  display:flex;gap:10px;justify-content:flex-end;align-items:center;z-index:5;
}
.adm-save-bar .status { font-size:13px;color:#666;margin-right:auto }
.adm-save-bar .status.ok { color:#16a34a }
.adm-save-bar .status.err { color:#b91c1c }
.adm-save-bar .btn-save {
  background:var(--red);color:#fff;font-weight:700;font-size:14px;padding:10px 22px;border-radius:10px;
}
.adm-save-bar .btn-save:hover{background:#0050cc}
.adm-save-bar .btn-reset {
  background:#f3f4f6;color:#444;font-weight:600;font-size:13px;padding:10px 16px;border-radius:10px;
}

.admin-tab.active {
  background: #fff !important;
  color: var(--ink) !important;
}
table.admin-table th {
  background: #111;color: #fff;text-align:left;
  padding:10px 12px;font-size:13px;letter-spacing:.04em;text-transform:uppercase;
}
table.admin-table td {
  padding:12px;border-bottom:1px solid #eee;font-size:14px;vertical-align:top;
}
table.admin-table tr.unread { background:#fff5f5;font-weight:600 }
