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

:root{
  --azul:#0b3c5d;
  --azul2:#082b44;
  --azul3:#0e527a;
  --verde:#1b8f3a;
  --verde2:#20c05a;
  --verde3:#2dd36f;
  --cinza:#f1f3f5;
  --cinza2:#eef1f4;
  --texto:#1c1c1c;
  --branco:#ffffff;
  --borda: rgba(255,255,255,.14);
  --vidro: rgba(255,255,255,.10);
  --sombra: 0 18px 60px rgba(0,0,0,.25);
}

html,body{margin:0;padding:0;width:100%;max-width:100%;overflow-x:hidden;}
*{box-sizing:border-box;}

body{
  font-family:'Inter',Arial,Helvetica,sans-serif;
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(14,82,122,.08), transparent 60%),
    radial-gradient(900px 500px at 80% 10%, rgba(32,192,90,.06), transparent 55%),
    linear-gradient(180deg,#f4f6f8 0%,#eef1f4 100%);
  color:var(--texto);
  line-height:1.6;
  scroll-behavior:smooth;
}

img,iframe,video{max-width:100%;height:auto;display:block;}

a{color:var(--verde);text-decoration:none;font-weight:700;}
a:hover{text-decoration:none;}

/* =========================
   SPLASH
   ========================= */

.splash{
  position:fixed;inset:0;z-index:9999;
  display:grid;place-items:center;overflow:hidden;
  background:linear-gradient(135deg,var(--azul2) 0%,var(--azul) 45%,var(--azul3) 100%);
}

.splash-bg{
  position:absolute;inset:-20%;
  background:
    radial-gradient(1200px 600px at 15% 15%,rgba(32,192,90,.22),transparent 60%),
    radial-gradient(900px 500px at 85% 20%,rgba(14,82,122,.42),transparent 55%),
    radial-gradient(800px 420px at 65% 90%,rgba(0,255,150,.14),transparent 60%),
    radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:auto,auto,auto,4px 4px;
  opacity:.95;filter:saturate(1.05);transform:scale(1.06);
  animation:splashDepth 1.9s ease-out both;
}

@keyframes splashDepth{
  0%{transform:scale(1.28);filter:blur(2px) saturate(1.2);opacity:.55;}
  70%{filter:blur(0px) saturate(1.05);opacity:.95;}
  100%{transform:scale(1.06);}
}

.splash::after{
  content:"";position:absolute;left:-40%;top:58%;width:180%;height:3px;
  background:linear-gradient(to right,transparent,rgba(32,192,90,.25),rgba(0,255,150,.60),rgba(32,192,90,.25),transparent);
  box-shadow:0 0 26px rgba(0,255,150,.55);transform:skewY(-2deg);
  animation:splashScan 1.3s linear infinite;opacity:.85;
}

@keyframes splashScan{
  0%{transform:translateX(-10%) skewY(-2deg);opacity:.40;}
  40%{opacity:1;}
  100%{transform:translateX(10%) skewY(-2deg);opacity:.40;}
}

.splash-content{
  position:relative;z-index:1;text-align:center;padding:22px 18px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:22px;box-shadow:0 18px 60px rgba(0,0,0,.28);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transform:translateY(6px);animation:splashPop .9s ease-out both;
}

@keyframes splashPop{
  0%{transform:translateY(18px) scale(.98);opacity:0;}
  100%{transform:translateY(6px) scale(1);opacity:1;}
}

.splash-logo{
  width:min(320px,75vw);height:auto;display:block;margin:0 auto 10px auto;
  filter:drop-shadow(0 12px 26px rgba(0,0,0,.35));
}

.splash-loader{display:flex;justify-content:center;gap:7px;}
.splash-loader span{
  width:8px;height:8px;border-radius:999px;background:rgba(0,255,150,.85);
  box-shadow:0 0 18px rgba(0,255,150,.55);animation:splashDot .9s ease-in-out infinite;
}
.splash-loader span:nth-child(2){animation-delay:.12s;}
.splash-loader span:nth-child(3){animation-delay:.24s;}

@keyframes splashDot{
  0%,100%{transform:translateY(0);opacity:.55;}
  50%{transform:translateY(-6px);opacity:1;}
}

.splash.splash-hide{animation:splashFadeOut .65s ease forwards;}
@keyframes splashFadeOut{to{opacity:0;visibility:hidden;}}

/* =========================
   HEADER
   ========================= */

header{
  position:relative;overflow:hidden;color:#fff;
  background:
    radial-gradient(1000px 380px at 10% 10%,rgba(32,192,90,.10),transparent 60%),
    radial-gradient(900px 420px at 85% 20%,rgba(14,82,122,.20),transparent 55%),
    linear-gradient(135deg,#021018 0%,#041b28 42%,#083655 100%);
  padding:0;box-shadow:none;
}

header::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:4px 4px;opacity:.18;mix-blend-mode:overlay;
}

header::after{
  content:"";position:absolute;left:-30%;top:52%;width:160%;height:2px;
  background:linear-gradient(to right,transparent,rgba(32,192,90,.18),rgba(0,255,150,.48),rgba(32,192,90,.18),transparent);
  box-shadow:0 0 14px rgba(0,255,150,.35);transform:skewY(-2deg);
  animation:scanline 5.5s linear infinite;opacity:.88;
}

@keyframes scanline{
  0%{transform:translateX(-12%) skewY(-2deg);opacity:.65;}
  40%{opacity:1;}
  100%{transform:translateX(12%) skewY(-2deg);opacity:.65;}
}

.header-container{
  max-width:100%;margin:0;display:grid;
  grid-template-columns:230px 1fr 180px;
  align-items:center;gap:18px;background:transparent;border:0;
  border-radius:0;padding:18px 28px 14px;box-shadow:none;
  backdrop-filter:none;-webkit-backdrop-filter:none;
  min-width:0;position:relative;z-index:2;
}

.logo-area{display:flex;align-items:center;justify-content:flex-start;min-width:0;}
.logo-gva{display:flex;align-items:center;justify-content:flex-end;min-width:0;}
.logo{height:58px;width:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.24));}
.gva-logo{height:80px;width:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.24));}

.menu-area{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-width:0;}
.menu-area p{margin:0 0 10px;color:rgba(255,255,255,.96);font-size:13px;font-weight:700;line-height:1.2;}

/* =========================
   NAV (aplicado em todas as páginas)
   ========================= */

.main-nav-faithful,
nav.main-nav-faithful{
  display:flex;align-items:center;justify-content:center;gap:34px;flex-wrap:nowrap;
}

.main-nav-faithful a{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  padding:4px 0 14px;border:none;border-radius:0;background:transparent;
  box-shadow:none;color:#fff;font-size:14px;font-weight:700;
  white-space:nowrap;text-decoration:none;letter-spacing:.1px;
  transition:color .15s ease;
}

.main-nav-faithful a:hover{background:transparent;box-shadow:none;transform:none;color:rgba(255,255,255,.85);}

.main-nav-faithful a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:3px;
  border-radius:999px;background:linear-gradient(90deg,#18c85e,#3ff08b);
  box-shadow:0 0 10px rgba(45,211,111,.25);transform:scaleX(0);
  transform-origin:center;opacity:0;transition:.18s ease;
}

.main-nav-faithful a:hover::after,
.main-nav-faithful a.active::after{transform:scaleX(1);opacity:1;}
.main-nav-faithful a.active{color:#fff;font-weight:800;}

/* =========================
   MAIN HOME
   ========================= */

.site-main{max-width:100%;margin:0;padding:0 0 28px;}

/* =========================
   HERO HOME
   ========================= */

.hero-top-faithful{
  margin:0;border-radius:0;overflow:hidden;
  background:
    linear-gradient(90deg,rgba(0,11,18,.98) 0%,rgba(2,18,28,.92) 38%,rgba(2,18,28,.60) 62%,rgba(2,18,28,.15) 100%),
    url('../images/rodocacamba.jpg') center/cover no-repeat;
  box-shadow:none;max-width:none;padding:0;
}

.hero-top-grid{display:grid;grid-template-columns:1fr;align-items:stretch;min-height:560px;}

.hero-left{
  padding:64px 42px 40px 32px;color:#fff;max-width:700px;
  background:radial-gradient(500px 260px at 15% 25%,rgba(45,211,111,.10),transparent 60%);
  display:flex;flex-direction:column;justify-content:center;
}

.hero-kicker{margin:0 0 14px;color:#28d66d;font-size:16px;font-weight:900;letter-spacing:.5px;text-transform:uppercase;}

.hero-top-faithful h1{margin:0 0 18px;font-size:60px;line-height:1.02;color:#fff;font-weight:900;}
.hero-top-faithful h1 span{color:#20d35f;}

.hero-sub{max-width:560px;margin:0 0 28px;font-size:20px;color:rgba(255,255,255,.92);}

.hero-mini-features{display:flex;align-items:flex-start;gap:22px;flex-wrap:wrap;margin-bottom:30px;}

.hero-feature{display:flex;align-items:flex-start;gap:12px;min-width:145px;}
.hero-feature-icon{font-size:28px;line-height:1;}
.hero-feature strong{display:block;color:#fff;font-size:18px;line-height:1.1;}
.hero-feature small{display:block;color:rgba(255,255,255,.80);font-size:14px;line-height:1.2;margin-top:3px;}

.hero-buttons{display:flex;gap:16px;flex-wrap:wrap;}

.btn,.btn-outline{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:48px;padding:0 22px;border-radius:12px;font-weight:800;
  letter-spacing:.2px;text-decoration:none;font-family:inherit;
  transition:transform .12s ease,filter .12s ease,box-shadow .12s ease,background .12s ease;
}

.btn{
  background:linear-gradient(135deg,var(--verde) 0%,var(--verde2) 100%);
  color:#fff;box-shadow:0 10px 28px rgba(32,192,90,.28);
  border:1px solid rgba(255,255,255,.14);
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.04);box-shadow:0 14px 36px rgba(32,192,90,.36);color:#fff;}

.btn-outline{color:#fff;border:2px solid rgba(255,255,255,.26);background:rgba(255,255,255,.03);box-shadow:0 10px 28px rgba(0,0,0,.15);}
.btn-outline:hover{transform:translateY(-2px);background:rgba(255,255,255,.09);color:#fff;}

.hero-btn-primary,.hero-btn-secondary{min-height:60px;padding:0 28px;font-size:20px;border-radius:14px;}
.hero-btn-primary{background:linear-gradient(135deg,#18bb54 0%,#2dd36f 100%);}
.hero-btn-secondary{border:2px solid rgba(255,255,255,.26);background:rgba(255,255,255,.03);color:#fff;}

.hero-right{display:none;}

/* =========================
   STATS
   ========================= */

.faithful-stats{
  max-width:none;margin:0;border-radius:0;padding:0;
  background:linear-gradient(90deg,#03151e 0%,#041821 100%);
  box-shadow:none;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:0;border-top:1px solid rgba(255,255,255,.04);
}

.faithful-stats .stats-item{padding:22px 26px;background:transparent;border-right:1px solid rgba(255,255,255,.06);color:#fff;}
.faithful-stats .stats-item:last-child{border-right:none;}
.faithful-stats .stats-item strong{display:block;color:#23d363;font-size:22px;font-weight:900;margin-bottom:6px;}
.faithful-stats .stats-item span{display:block;color:#fff;opacity:.94;font-size:15px;font-weight:600;}
.faithful-stats .stats-item-map strong{font-size:24px;}

/* =========================
   HOME LAYOUT
   ========================= */

.home-layout{
  max-width:1700px;margin:26px auto 0;padding:0 36px;
  display:grid;grid-template-columns:1.55fr .95fr;gap:20px;align-items:start;
}

.home-left,.home-right{min-width:0;display:flex;flex-direction:column;gap:18px;}

/* =========================
   CARDS
   ========================= */

.card,.operational-panel,.cta-banner,.regional-card{
  border:1px solid rgba(11,60,93,.08);border-radius:20px;
  background:rgba(255,255,255,.97);
  box-shadow:0 10px 26px rgba(10,30,60,.08),0 0 0 1px rgba(255,255,255,.35) inset;
}

.card{padding:24px;}

.card h2,.operational-panel h2,.cta-banner h2,.regional-card h2{margin:0 0 10px;color:var(--azul);font-size:22px;font-weight:800;}
.card h3{margin:0 0 10px;color:var(--azul);font-size:18px;font-weight:700;}
.card p{margin:8px 0;}

.section-link{margin:14px 0 0;}

/* =========================
   SERVIÇOS HOME
   ========================= */

.services-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:16px;}

.service-box{
  padding:20px 14px;border-radius:14px;background:#fff;
  border:1px solid rgba(11,60,93,.07);
  box-shadow:0 6px 16px rgba(10,30,60,.05);
  text-align:center;
  transition:transform .15s ease,box-shadow .15s ease;
}
.service-box:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(10,30,60,.10);}

.service-icon{font-size:32px;margin-bottom:10px;}
.service-box h3{margin:0 0 8px;color:var(--azul);font-size:16px;font-weight:700;}
.service-box p{margin:0;font-size:13px;color:#5a5a6a;line-height:1.5;}

/* =========================
   COMO FUNCIONA
   ========================= */

.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:16px;}

.step-box{
  padding:20px 16px;border-radius:14px;background:#fff;
  border:1px solid rgba(11,60,93,.07);
  box-shadow:0 6px 16px rgba(10,30,60,.05);
  transition:transform .15s ease,box-shadow .15s ease;
}
.step-box:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(10,30,60,.09);}

.step-number{
  width:36px;height:36px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-weight:900;color:#fff;font-size:16px;
  background:linear-gradient(135deg,var(--verde),var(--verde2));margin-bottom:12px;
}

.step-box h3{margin:0 0 8px;color:var(--azul);font-size:16px;font-weight:700;}
.step-box p{margin:0;font-size:13px;color:#5a5a6a;line-height:1.5;}

/* =========================
   REGIONAL
   ========================= */

.regional-card{display:grid;grid-template-columns:100px 1fr;gap:18px;padding:22px;}
.regional-map{display:flex;align-items:center;justify-content:center;font-size:50px;border-radius:16px;background:linear-gradient(180deg,#eef6f2,#f8fbf9);}

.check-list{margin:6px 0 0;padding-left:20px;}
.check-list li{margin-bottom:6px;font-size:14px;color:#444;}

/* =========================
   CTA BANNER
   ========================= */

.cta-banner{
  position:relative;overflow:hidden;min-height:200px;
  background:
    linear-gradient(90deg,rgba(4,18,28,.93) 0%,rgba(4,18,28,.65) 42%,rgba(4,18,28,.12) 100%),
    url("../images/rodocacamba.jpg");
  background-size:cover;background-position:center;
}

.cta-banner-content{position:relative;z-index:1;max-width:600px;padding:32px 30px;color:#fff;}
.cta-banner h2{color:#fff;font-size:26px;}
.cta-banner h2 span{color:var(--verde3);}
.cta-banner p{margin:0 0 18px;color:rgba(255,255,255,.90);font-size:15px;}

/* =========================
   PAINEL OPERACIONAL
   ========================= */

.operational-panel{
  padding:22px;
  background:linear-gradient(180deg,#031c16 0%,#062821 100%);
  color:#fff;
}

.operational-panel h2{color:#fff;font-size:20px;}
.panel-subtitle{margin:0 0 16px;color:rgba(255,255,255,.75);font-size:14px;}

.panel-slider-card{overflow:hidden;border-radius:16px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);margin-bottom:14px;}
.panel-slider-card img{width:100%;height:200px;object-fit:cover;}
.panel-slider-caption{padding:12px 14px;}
.panel-slider-caption strong{display:block;color:#fff;font-size:17px;}
.panel-slider-caption span{display:block;font-size:13px;color:rgba(255,255,255,.78);}

.panel-item{padding:13px 16px;margin-bottom:10px;border-radius:12px;background:linear-gradient(90deg,rgba(255,255,255,.06),rgba(45,211,111,.06));border:1px solid rgba(255,255,255,.08);}
.panel-item strong{display:block;color:#fff;margin-bottom:2px;font-size:14px;}
.panel-item span{display:block;color:rgba(255,255,255,.78);font-size:13px;}

.panel-btn{width:100%;margin-top:8px;}
.panel-footer-text{margin:12px 0 0;text-align:center;color:rgba(255,255,255,.75);font-size:13px;}

/* =========================
   CLIENTES HOME
   ========================= */

#clientes{padding:24px;}
#clientes h2{margin-bottom:14px;}

.logos-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}

.logo-tile{
  display:flex;align-items:center;justify-content:center;
  padding:16px 12px;border-radius:14px;background:rgba(255,255,255,.98);
  border:1px solid rgba(11,60,93,.08);
  box-shadow:0 6px 16px rgba(10,30,60,.05),0 0 0 1px rgba(255,255,255,.45) inset;
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;
  text-decoration:none;
}

.logo-tile img{width:100%;height:44px;object-fit:contain;display:block;transition:transform .15s ease;}
.logo-tile:hover{transform:translateY(-2px);border-color:rgba(32,192,90,.25);box-shadow:0 10px 24px rgba(10,30,60,.10);}
.logo-tile:hover img{transform:scale(1.04);}

/* =========================
   CLIENTES.HTML HERO
   ========================= */

.clientes-page{padding:24px;}

.clientes-hero{
  position:relative;border-radius:20px;overflow:hidden;min-height:180px;
  background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.25)),url("../images/bg-estrada.jpg");
  background-size:cover;background-position:center;
  box-shadow:0 14px 40px rgba(10,30,60,.12),0 0 0 1px rgba(255,255,255,.35) inset;
}

.clientes-hero-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(900px 400px at 15% 20%,rgba(32,192,90,.18),transparent 60%),
    radial-gradient(900px 400px at 85% 20%,rgba(14,82,122,.22),transparent 55%);
  pointer-events:none;
}

.clientes-hero-content{position:relative;z-index:1;padding:32px 24px;color:#fff;max-width:900px;}

.clientes-kicker{
  display:inline-flex;font-weight:900;letter-spacing:.6px;font-size:11px;
  padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.20);text-transform:uppercase;
}

.clientes-hero h2{margin:12px 0 6px;font-size:40px;line-height:1.05;color:#fff;font-weight:900;}
.clientes-hero p{margin:0;opacity:.90;font-size:16px;max-width:600px;}

/* =========================
   INNER PAGE LAYOUT
   ========================= */

.inner-page{max-width:1280px;margin:0 auto;padding:36px 36px 60px;}

.page-hero{
  border-radius:20px;overflow:hidden;padding:40px 36px;margin-bottom:28px;
  background:
    radial-gradient(900px 400px at 10% 30%,rgba(32,192,90,.15),transparent 60%),
    linear-gradient(135deg,#021018 0%,#041b28 55%,#083655 100%);
  color:#fff;
  box-shadow:0 14px 40px rgba(10,30,60,.14);
}

.page-hero-kicker{
  display:inline-flex;font-weight:800;font-size:11px;letter-spacing:.8px;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);margin-bottom:14px;color:rgba(255,255,255,.90);
}

.page-hero h1{margin:0 0 10px;font-size:40px;font-weight:900;color:#fff;line-height:1.1;}
.page-hero p{margin:0;font-size:17px;color:rgba(255,255,255,.85);max-width:680px;line-height:1.6;}

/* =========================
   GRID GENÉRICO (páginas internas)
   ========================= */

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;margin-top:18px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:18px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px;}

/* =========================
   SOBRE
   ========================= */

.video-wrapper{
  position:relative;padding-bottom:56.25%;height:0;overflow:hidden;
  border-radius:16px;margin:20px 0;
  box-shadow:0 14px 36px rgba(10,30,60,.12);
  background:#000;
}
.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;}

.sobre-pilares{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:14px;margin-top:14px;
}

.pilar-item{
  display:flex;align-items:flex-start;gap:14px;padding:18px;
  border-radius:14px;background:#fff;
  border:1px solid rgba(11,60,93,.07);
  box-shadow:0 6px 16px rgba(10,30,60,.05);
  transition:transform .15s ease;
}
.pilar-item:hover{transform:translateY(-2px);}
.pilar-icon{font-size:28px;flex-shrink:0;line-height:1;}
.pilar-text strong{display:block;color:var(--azul);font-size:15px;font-weight:700;margin-bottom:4px;}
.pilar-text span{font-size:13px;color:#5a5a6a;line-height:1.4;}

/* =========================
   CONTATO
   ========================= */

.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px;}

.contact-card{
  padding:26px;border-radius:18px;background:#fff;
  border:1px solid rgba(11,60,93,.08);
  box-shadow:0 8px 20px rgba(10,30,60,.07);
  display:flex;flex-direction:column;gap:10px;
}

.contact-card-icon{font-size:36px;margin-bottom:4px;}
.contact-card h3{margin:0;color:var(--azul);font-size:19px;font-weight:800;}
.contact-card p{margin:0;font-size:14px;color:#444;line-height:1.6;}
.contact-card strong{color:var(--texto);}
.contact-card .btn{margin-top:auto;width:100%;justify-content:center;}

.quotation-card{
  padding:30px;border-radius:18px;
  background:linear-gradient(135deg,var(--azul2),var(--azul3));
  color:#fff;margin-top:22px;
  display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  box-shadow:0 14px 36px rgba(10,30,60,.18);
}

.quotation-card h3{margin:0 0 8px;font-size:22px;font-weight:800;color:#fff;}
.quotation-card p{margin:0;font-size:15px;color:rgba(255,255,255,.85);max-width:520px;}
.quotation-card .btn{white-space:nowrap;padding:0 28px;min-height:52px;background:linear-gradient(135deg,#18c85e,#2dd36f);font-size:15px;}

/* =========================
   REGIÕES
   ========================= */

.region-card{
  padding:24px;border-radius:18px;background:#fff;
  border:1px solid rgba(11,60,93,.08);
  box-shadow:0 8px 20px rgba(10,30,60,.07);
  display:flex;flex-direction:column;gap:8px;
  transition:transform .15s ease,box-shadow .15s ease;
}
.region-card:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(10,30,60,.11);}

.region-card h3{margin:0;color:var(--azul);font-size:18px;font-weight:800;border-bottom:2px solid #eef1f4;padding-bottom:10px;margin-bottom:4px;}
.region-card .info-row{display:flex;align-items:flex-start;gap:8px;font-size:14px;}
.region-card .info-label{font-weight:700;color:var(--azul);min-width:90px;flex-shrink:0;}
.region-card .info-value{color:#444;overflow-wrap:break-word;word-break:break-all;min-width:0;}
.region-card .btn{margin-top:8px;width:100%;justify-content:center;font-size:14px;min-height:42px;}

.region-card.pending{opacity:.75;}
.region-card.pending .btn{background:rgba(11,60,93,.15);box-shadow:none;color:var(--azul);cursor:default;pointer-events:none;}

.badge-breve{
  display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;
  padding:3px 10px;border-radius:999px;background:rgba(11,60,93,.08);color:var(--azul);
  margin-left:auto;text-transform:uppercase;letter-spacing:.4px;
}

/* =========================
   FROTA
   ========================= */

.frota-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;flex-wrap:wrap;gap:8px;
}

.frota-badge{
  display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;
  padding:4px 12px;border-radius:999px;background:linear-gradient(135deg,rgba(32,192,90,.12),rgba(45,211,111,.18));
  color:var(--verde);border:1px solid rgba(32,192,90,.20);
}

.frota-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px;}
.frota-list li{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-radius:12px;background:#f8fafb;
  border:1px solid rgba(11,60,93,.06);font-size:14px;
}
.frota-list li strong{font-size:20px;font-weight:900;color:var(--verde);}

.card.frota{position:relative;overflow:hidden;}
.card.frota::before{
  content:"";position:absolute;inset:0;background-repeat:no-repeat;
  background-position:right 18px center;background-size:140px auto;opacity:.08;
  filter:saturate(1.05);pointer-events:none;
}
.card.frota > *{position:relative;z-index:1;}
.card.frota.nova-frota::before{background-image:url("../images/logo-novafrota.png");}
.card.frota.lucesi::before{background-image:url("../images/logo-lucesi.png");}
.card.frota.gva::before{background-image:url("../images/logo-gva.png");}

/* =========================
   GVA
   ========================= */

.gva-steps{display:flex;flex-direction:column;gap:10px;margin-top:10px;}
.gva-step{
  display:flex;align-items:flex-start;gap:14px;padding:14px 16px;
  border-radius:12px;background:#f8fafb;border:1px solid rgba(11,60,93,.06);
}
.gva-step-num{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:14px;color:#fff;
  background:linear-gradient(135deg,var(--verde),var(--verde2));
}
.gva-step-text strong{display:block;color:var(--azul);font-size:14px;font-weight:700;}
.gva-step-text span{display:block;font-size:13px;color:#5a5a6a;line-height:1.4;}

.gva-cta{
  padding:36px 32px;border-radius:20px;margin-top:24px;text-align:center;
  background:linear-gradient(135deg,var(--azul2) 0%,var(--azul3) 100%);
  box-shadow:0 14px 40px rgba(10,30,60,.16);
}
.gva-cta h2{color:#fff;margin:0 0 10px;font-size:26px;}
.gva-cta p{color:rgba(255,255,255,.85);margin:0 0 22px;font-size:15px;}
.gva-cta .btn{margin:0 auto;padding:0 36px;min-height:56px;font-size:17px;
  background:linear-gradient(135deg,#18c85e,#2dd36f);}
.gva-cta small{display:block;color:rgba(255,255,255,.60);font-size:12px;margin-top:14px;}

/* =========================
   SERVIÇOS DETALHES
   ========================= */

.servico-card{
  padding:26px;border-radius:18px;background:#fff;
  border:1px solid rgba(11,60,93,.08);
  box-shadow:0 8px 20px rgba(10,30,60,.06);
  transition:transform .15s ease,box-shadow .15s ease;
}
.servico-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(10,30,60,.11);}
.servico-card-icon{font-size:44px;margin-bottom:14px;}
.servico-card h3{margin:0 0 10px;color:var(--azul);font-size:20px;font-weight:800;}
.servico-card p{margin:0;color:#5a5a6a;font-size:14px;line-height:1.65;}

.servicos-cta{
  margin-top:28px;padding:30px;border-radius:18px;text-align:center;
  background:linear-gradient(90deg,rgba(4,18,28,.93),rgba(4,18,28,.80)),url("../images/rodocacamba.jpg");
  background-size:cover;background-position:center;
  box-shadow:0 12px 32px rgba(10,30,60,.14);
}
.servicos-cta p{color:rgba(255,255,255,.85);font-size:16px;margin:0 0 20px;}
.servicos-cta .servicos-cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* =========================
   FOOTER
   ========================= */

footer{
  margin-top:32px;
  background:linear-gradient(180deg,#05151f 0%,#071c28 100%);
  color:#fff;
}

.footer-top{
  max-width:1700px;margin:0 auto;padding:16px 24px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
}

.footer-pill{
  padding:14px 16px;border-radius:14px;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);text-align:center;font-weight:600;font-size:14px;
  transition:background .15s ease;
}
.footer-pill:hover{background:rgba(255,255,255,.08);}

.footer-bottom{
  max-width:1700px;margin:0 auto;padding:14px 24px 20px;
  text-align:center;color:rgba(255,255,255,.75);font-size:13px;
  border-top:1px solid rgba(255,255,255,.05);
}

.footer-inner{
  max-width:1280px;margin:0 auto;padding:28px 36px 10px;
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px;
}

.footer-col h4{color:#fff;margin:0 0 10px;font-size:15px;font-weight:700;}
.footer-col p,.footer-col a{color:rgba(255,255,255,.65);font-size:13px;display:block;margin-bottom:6px;font-weight:400;}
.footer-col a:hover{color:rgba(255,255,255,.90);}

.footer-inner-bottom{
  max-width:1280px;margin:0 auto;padding:12px 36px 24px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:space-between;
  color:rgba(255,255,255,.55);font-size:12px;flex-wrap:wrap;gap:8px;
}

/* =========================
   UTILITIES
   ========================= */

.section-intro{font-size:16px;color:#555;margin:0 0 24px;line-height:1.65;max-width:760px;}
.mt-sm{margin-top:16px;}
.mt-md{margin-top:24px;}
.text-center{text-align:center;}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width:1180px){
  .services-grid{grid-template-columns:repeat(3,1fr);}
  .logos-grid{grid-template-columns:repeat(4,1fr);}
  .hero-top-grid{grid-template-columns:1fr;}
  .faithful-stats{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:repeat(2,1fr);}
  .footer-inner{grid-template-columns:1fr 1fr;}
  .grid-3{grid-template-columns:repeat(2,1fr);}
}

@media (max-width:980px){
  .home-layout{grid-template-columns:1fr;padding:0 18px;}
  .steps-grid{grid-template-columns:repeat(2,1fr);}
  .regional-card{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:repeat(2,1fr);}
  .quotation-card{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .grid-2,.grid-3{grid-template-columns:1fr;}
  .inner-page{padding:24px 20px 48px;}
  .page-hero{padding:28px 24px;}
  .page-hero h1{font-size:32px;}
}

@media (max-width:768px){
  .header-container{grid-template-columns:1fr;gap:12px;padding:16px 14px 12px;text-align:center;}
  .logo-area,.logo-gva{justify-content:center;}
  .menu-area{text-align:center;}
  .menu-area p{margin-bottom:8px;font-size:12px;}
  .main-nav-faithful{gap:18px;flex-wrap:wrap;}
  .logo{height:50px;}
  .gva-logo{height:42px;}
  .hero-left{padding:28px 20px;}
  .hero-top-faithful h1{font-size:38px;}
  .hero-sub{font-size:17px;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .logos-grid{grid-template-columns:repeat(3,1fr);}
  .faithful-stats .stats-item-map strong{font-size:20px;}
  .footer-inner{grid-template-columns:1fr;gap:20px;}
  .sobre-pilares{grid-template-columns:1fr 1fr;}
}

@media (max-width:600px){
  .site-main{padding:0 0 18px;}
  .main-nav-faithful{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;gap:22px;padding:0 2px 4px;}
  .main-nav-faithful::-webkit-scrollbar{height:0;}
  .hero-top-faithful h1{font-size:30px;}
  .hero-buttons{flex-direction:column;}
  .faithful-stats{grid-template-columns:1fr;}
  .services-grid,.steps-grid,.logos-grid{grid-template-columns:1fr 1fr;}
  .footer-top{grid-template-columns:1fr;}
  .gva-logo{height:40px;}
  .logo{height:46px;}
  .card.frota::before{background-size:100px auto;opacity:.06;}
  .sobre-pilares{grid-template-columns:1fr;}
  .servicos-cta .servicos-cta-btns{flex-direction:column;align-items:center;}
  .inner-page{padding:16px 14px 40px;}
  .page-hero{padding:22px 16px;}
  .page-hero h1{font-size:26px;}
  .grid{grid-template-columns:1fr;}
  .footer-inner-bottom{flex-direction:column;text-align:center;}
}

@media (prefers-reduced-motion:reduce){
  .splash-bg,.splash::after{animation:none!important;}
}
