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

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --navy:        #07111f;
  --navy-mid:    #0d1e35;
  --navy-light:  #142340;
  --blue:        #1455b8;
  --blue-light:  #1e7ae6;
  --cyan:        #00c4e0;
  --cyan-dark:   #008faa;
  --white:       #ffffff;
  --off-white:   #f7fafd;
  --gray-100:    #f0f4f8;
  --gray-200:    #dde4ee;
  --gray-400:    #94a3b8;
  --gray-500:    #64748b;
  --gray-700:    #334155;
  --text:        #1a2b42;
  --success:     #10b981;
  --warning:     #f59e0b;
  --danger:      #ef4444;

  --font: 'Poppins', sans-serif;

  --shadow-xs: 0 1px 4px rgba(0,0,0,.06);
  --shadow-sm: 0 2px 10px rgba(0,0,0,.08);
  --shadow-md: 0 8px 24px rgba(0,0,0,.12);
  --shadow-lg: 0 16px 48px rgba(0,0,0,.18);
  --shadow-xl: 0 24px 64px rgba(0,0,0,.26);

  --r-sm: 8px;
  --r:    12px;
  --r-lg: 20px;
  --r-xl: 50px;

  --ease: cubic-bezier(.4,0,.2,1);
  --t:    all .3s var(--ease);
  --t-f:  all .15s ease;
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--text);background:var(--white);overflow-x:hidden;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button,input,select,textarea{font-family:inherit}

/* ============================================================
   UTILITIES
   ============================================================ */
.container{max-width:1220px;margin:0 auto;padding:0 2rem}
.text-center{text-align:center}
.text-center .section-subtitle{margin:0 auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.section-label{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--cyan-dark);margin-bottom:.8rem;
}
.section-label::before{content:'';display:inline-block;width:20px;height:2px;background:var(--cyan);border-radius:2px}

.section-title{
  font-size:clamp(1.75rem,3.2vw,2.6rem);font-weight:800;color:var(--navy);
  line-height:1.2;margin-bottom:1rem;
}
.section-title.light{color:var(--white)}
.section-title span{color:var(--cyan)}

.section-subtitle{font-size:1.02rem;color:var(--gray-500);line-height:1.75;max-width:580px}
.section-subtitle.light{color:rgba(255,255,255,.68)}

/* Scroll animations */
.fade-up{opacity:0;transform:translateY(32px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.1s}
.fade-up.d2{transition-delay:.2s}
.fade-up.d3{transition-delay:.3s}
.fade-up.d4{transition-delay:.4s}
.fade-up.d5{transition-delay:.5s}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;font-size:.9rem;border:none;cursor:pointer;
  border-radius:var(--r-xl);transition:var(--t);white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,var(--cyan) 0%,var(--blue-light) 100%);
  color:var(--white);padding:13px 30px;
  box-shadow:0 6px 20px rgba(0,196,224,.32);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,196,224,.45)}
.btn-primary:active{transform:translateY(-1px)}

.btn-secondary{
  background:rgba(255,255,255,.1);color:var(--white);padding:13px 28px;
  border:1.5px solid rgba(255,255,255,.25);backdrop-filter:blur(8px);
}
.btn-secondary:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}

.btn-outline-white{
  background:transparent;color:var(--white);padding:11px 24px;
  border:1.5px solid rgba(255,255,255,.4);
}
.btn-outline-white:hover{background:var(--white);color:var(--navy)}

.btn-success{
  background:linear-gradient(135deg,#10b981,#059669);color:var(--white);
  padding:14px 32px;box-shadow:0 6px 20px rgba(16,185,129,.35);width:100%;
  border-radius:var(--r);font-size:1rem;
}
.btn-success:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(16,185,129,.45)}

.btn-full{width:100%;border-radius:var(--r);padding:12px 20px;font-size:.9rem}

.btn-whatsapp{
  background:#25d366;color:var(--white);
  box-shadow:0 6px 20px rgba(37,211,102,.35);
}
.btn-whatsapp:hover{background:#22c55e;transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,211,102,.45)}

/* ============================================================
   NAVBAR
   ============================================================ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:74px;display:flex;align-items:center;padding:0 2rem;
  background:rgba(7,17,31,.95);backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.05);
  transition:height .3s var(--ease),box-shadow .3s;
}
.navbar.scrolled{height:64px;box-shadow:0 4px 28px rgba(0,0,0,.4)}

.nav-logo img{height:68px;width:auto;object-fit:contain;transition:height .3s ease}
.navbar.scrolled .nav-logo img{height:50px}

.nav-links{display:flex;align-items:center;gap:2rem;margin:0 auto}

.nav-links a{
  color:rgba(255,255,255,.78);font-size:.875rem;font-weight:500;
  position:relative;padding:4px 0;letter-spacing:.02em;transition:color .2s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:2px;background:var(--cyan);
  border-radius:2px;transition:width .3s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}

.nav-right{display:flex;align-items:center;gap:1.25rem}

.nav-phone{
  display:flex;align-items:center;gap:6px;
  color:rgba(255,255,255,.7);font-size:.82rem;font-weight:500;
  transition:color .2s;
}
.nav-phone:hover{color:var(--cyan)}
.nav-phone svg{color:var(--cyan);flex-shrink:0}

.nav-cta{
  background:linear-gradient(135deg,var(--cyan),var(--blue-light));
  color:var(--white)!important;padding:10px 22px;border-radius:var(--r-xl);
  font-size:.82rem;font-weight:700;box-shadow:0 4px 14px rgba(0,196,224,.3);
  transition:var(--t)!important;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,196,224,.42)}
.nav-cta::after{display:none!important}

.nav-toggle{
  display:none;flex-direction:column;gap:5px;
  cursor:pointer;padding:4px;background:none;border:none;
}
.nav-toggle span{
  display:block;width:24px;height:2px;
  background:var(--white);border-radius:2px;transition:var(--t);
}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav */
.nav-mobile{
  display:none;position:fixed;top:74px;left:0;right:0;z-index:999;
  background:var(--navy);border-top:1px solid rgba(255,255,255,.06);
  padding:1.5rem 2rem 2rem;flex-direction:column;gap:1.25rem;
  box-shadow:0 16px 48px rgba(0,0,0,.5);
  max-height:calc(100vh - 74px);overflow-y:auto;
}
.nav-mobile.open{display:flex}
.nav-mobile a{color:rgba(255,255,255,.8);font-size:.95rem;font-weight:500;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.05)}
.nav-mobile .nav-cta{border:none;text-align:center;margin-top:.5rem;padding:13px;border-bottom:none}

/* ============================================================
   HERO SLIDER
   ============================================================ */
.hero{position:relative;height:100vh;min-height:620px;overflow:hidden}

.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-video-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(7,17,31,.92) 0%,rgba(7,17,31,.72) 45%,rgba(7,17,31,.38) 100%)}

.hero-slide{
  position:absolute;inset:0;opacity:0;
  transition:opacity 1.2s var(--ease);
  background-size:cover;background-position:center;
  will-change:opacity;
}
.hero-slide.active{opacity:1;z-index:1}

.hero-slide::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(7,17,31,.92) 0%,rgba(7,17,31,.72) 45%,rgba(7,17,31,.38) 100%);
}

/* Per-slide content — hidden by default, shown when .active */
.hero-content{
  position:absolute;inset:0;z-index:10;
  display:flex;align-items:center;
  padding-top:74px;
  opacity:0;visibility:hidden;
  transition:opacity .7s ease,visibility .7s ease;
}
.hero-content.active{opacity:1;visibility:visible}

/* Inner container — proper max-width centering */
.hero-inner{
  width:100%;max-width:1220px;
  margin:0 auto;
  padding:0 clamp(1.5rem,5vw,4rem);
}

/* Slide 1: left-aligned text */
.hero-text{max-width:620px}

/* Slides 2+: fully centered */
.hero-content-center .hero-inner{
  display:flex;flex-direction:column;align-items:center;text-align:center;
}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,196,224,.12);border:1px solid rgba(0,196,224,.28);
  color:var(--cyan);padding:5px 16px;border-radius:var(--r-xl);
  font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:1.4rem;backdrop-filter:blur(8px);
}
.hero-eyebrow span{
  width:6px;height:6px;background:var(--cyan);
  border-radius:50%;animation:blink 1.5s infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero-title{
  font-size:clamp(2.2rem,5.5vw,4rem);
  font-weight:900;color:var(--white);line-height:1.12;
  margin-bottom:1.2rem;text-shadow:0 2px 20px rgba(0,0,0,.35);
}
.hero-title span{color:var(--cyan)}

/* Large centered title for city slides */
.hero-title-city{
  font-size:clamp(3rem,7vw,5.5rem);
  font-weight:900;color:var(--white);
  text-transform:uppercase;letter-spacing:.04em;line-height:1.05;
  margin-bottom:.5rem;text-shadow:0 4px 30px rgba(0,0,0,.5);
}

/* Cyan decorative bar */
.hero-deco{
  width:80px;height:5px;border-radius:3px;
  background:linear-gradient(90deg,var(--cyan),var(--blue));
  margin:1rem auto 1.5rem;
}

.hero-subtitle{
  font-size:1.1rem;color:rgba(255,255,255,.85);
  line-height:1.72;margin-bottom:2.5rem;max-width:520px;
}
/* City slide subtitle */
.hero-subtitle-city{
  font-size:1.15rem;color:rgba(255,255,255,.85);
  font-weight:400;line-height:1.6;margin-bottom:2rem;max-width:480px;
}

.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem}

/* Solicitar orçamento button (city slides) */
.btn-orcamento{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--cyan);color:var(--navy);
  padding:15px 36px;border-radius:var(--r-xl);
  font-size:1rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase;
  border:none;cursor:pointer;transition:var(--t);
  box-shadow:0 8px 28px rgba(0,196,224,.4);text-decoration:none;
}
.btn-orcamento:hover{
  background:var(--white);transform:translateY(-3px);
  box-shadow:0 14px 36px rgba(0,196,224,.5);
}

/* Slide bottom stats bar */
.hero-stats{
  position:absolute;bottom:0;left:0;right:0;z-index:10;
  display:grid;grid-template-columns:repeat(4,1fr);
  background:rgba(7,17,31,.88);backdrop-filter:blur(20px);
  border-top:1px solid rgba(255,255,255,.07);
}
.hero-stat{
  padding:18px 20px;text-align:center;
  border-right:1px solid rgba(255,255,255,.06);
}
.hero-stat:last-child{border-right:none}
.hero-stat-num{font-size:1.7rem;font-weight:800;color:var(--cyan);line-height:1}
.hero-stat-label{font-size:.7rem;color:rgba(255,255,255,.55);font-weight:500;margin-top:3px;letter-spacing:.04em;text-transform:uppercase}

/* Slider nav */
.slider-dots{
  position:absolute;bottom:90px;left:50%;z-index:20;
  transform:translateX(-50%);
  display:flex;gap:8px;
}
.slider-dot{
  width:8px;height:8px;border-radius:4px;
  background:rgba(255,255,255,.3);cursor:pointer;
  transition:var(--t);border:none;
}
.slider-dot.active{width:26px;background:var(--cyan)}

.slider-arrow{
  position:absolute;top:50%;z-index:20;
  transform:translateY(-50%);
  width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:var(--white);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--t);backdrop-filter:blur(8px);
}
.slider-arrow:hover{background:rgba(0,196,224,.25);border-color:var(--cyan)}
.slider-prev{left:1.5rem}
.slider-next{right:1.5rem}

/* ============================================================
   CITY SERVICES — SP + RJ alternating blocks
   ============================================================ */
.city-services{background:var(--white)}

.city-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:520px;
}

/* Reverse: texto à esquerda, imagem à direita */
.city-block-reverse .city-block-img{order:2}
.city-block-reverse .city-block-content{order:1}

/* Image side */
.city-block-img{
  position:relative;overflow:hidden;
  background:var(--navy);
}
.city-block-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  transition:transform .6s ease;
}
.city-block:hover .city-block-img img{transform:scale(1.04)}

/* Duo: two images side by side, seamless */
.city-block-img-duo{
  display:flex;gap:0;
}
.city-block-img-duo img{
  width:50%;flex-shrink:0;
  height:100%;
  object-fit:cover;object-position:center;
  display:block;
  transition:transform .6s ease;
}
.city-block:hover .city-block-img-duo img{transform:scale(1.04)}

/* Content side */
.city-block-content{
  display:flex;flex-direction:column;justify-content:center;
  padding:4rem clamp(2rem,5vw,5rem);
  background:var(--white);
}

/* Alternating tint on content of block 2 */
.city-block-reverse .city-block-content{background:var(--off-white)}

/* Vertical accent bar + title */
.city-title{
  font-size:clamp(1.6rem,2.8vw,2.4rem);
  font-weight:900;color:var(--navy);
  line-height:1.2;margin-bottom:1.4rem;
  display:flex;gap:14px;align-items:flex-start;
}
.city-bar{
  display:block;flex-shrink:0;
  width:5px;height:100%;min-height:3.2em;
  background:linear-gradient(180deg,var(--cyan),var(--blue));
  border-radius:3px;margin-top:.12em;
}

.city-block-content p{
  color:var(--gray-500);line-height:1.8;font-size:.95rem;
  margin-bottom:1rem;
}
.city-block-content p:last-of-type{margin-bottom:1.75rem}
.city-block-content strong{color:var(--navy);font-weight:700}

.city-block-actions{display:flex;gap:.85rem;flex-wrap:wrap}

/* WhatsApp button */
.btn-whatsapp{
  display:inline-flex;align-items:center;gap:8px;
  background:#25d366;color:#fff;
  padding:12px 22px;border-radius:var(--r-xl);
  font-size:.875rem;font-weight:700;
  transition:var(--t);text-decoration:none;
}
.btn-whatsapp:hover{background:#1ebe5d;transform:translateY(-2px)}

/* Responsive */
@media(max-width:900px){
  .city-block{grid-template-columns:1fr;min-height:auto}
  .city-block-reverse .city-block-img{order:0}
  .city-block-reverse .city-block-content{order:0}
  .city-block-img{height:280px}
  .city-block-content{padding:2.5rem 1.5rem}
}

/* ============================================================
   SECTION BASE
   ============================================================ */
section{padding:90px 0}

/* ============================================================
   SERVICES SECTION
   ============================================================ */
.services-section{background:var(--off-white)}

.services-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem;gap:2rem}

.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem;
}

.service-card{
  background:var(--white);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--gray-200);transition:var(--t);cursor:pointer;
  display:flex;flex-direction:column;
}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}

.service-card-img-wrap{
  height:210px;overflow:hidden;position:relative;
}
.service-card-img-wrap img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  transition:transform .5s var(--ease);
}
.service-card:hover .service-card-img-wrap img{transform:scale(1.06)}

.service-card-badge{
  position:absolute;top:12px;right:12px;
  background:var(--cyan);color:var(--navy);
  font-size:.65rem;font-weight:700;padding:4px 10px;
  border-radius:var(--r-xl);letter-spacing:.06em;text-transform:uppercase;
}

.service-card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}

.service-icon{
  width:46px;height:46px;border-radius:var(--r-sm);
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  display:flex;align-items:center;justify-content:center;
  color:var(--white);margin-bottom:1rem;flex-shrink:0;
}

.service-card h3{font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}
.service-card p{font-size:.875rem;color:var(--gray-500);line-height:1.65;flex:1;margin-bottom:1.1rem}

.service-link{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.82rem;font-weight:700;color:var(--blue);transition:var(--t-f);
}
.service-link svg{transition:transform .2s}
.service-card:hover .service-link svg{transform:translateX(4px)}

/* ============================================================
   WHY CHOOSE US
   ============================================================ */
.why-section{background:var(--navy);position:relative;overflow:hidden}
.why-section::before{
  content:'';position:absolute;top:-30%;right:-15%;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(0,196,224,.07) 0%,transparent 70%);
  pointer-events:none;
}

.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}

.why-features{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:2.5rem}

.why-feat{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r);padding:1.4rem;transition:var(--t);
}
.why-feat:hover{
  background:rgba(0,196,224,.07);border-color:rgba(0,196,224,.22);
  transform:translateY(-4px);
}
.why-feat-ico{
  width:42px;height:42px;border-radius:var(--r-sm);
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  display:flex;align-items:center;justify-content:center;
  color:var(--white);margin-bottom:.9rem;
}
.why-feat h4{font-size:.92rem;font-weight:700;color:var(--white);margin-bottom:.35rem}
.why-feat p{font-size:.8rem;color:rgba(255,255,255,.5);line-height:1.65}

.why-img-wrap{position:relative}
.why-img-wrap>img{
  border-radius:var(--r-lg);width:100%;
  box-shadow:var(--shadow-xl);object-fit:cover;max-height:500px;
}
.why-badge{
  position:absolute;bottom:-24px;right:-24px;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  border-radius:var(--r);padding:1.2rem 1.6rem;
  text-align:center;box-shadow:var(--shadow-lg);
}
.why-badge strong{display:block;font-size:2.2rem;font-weight:900;color:var(--white);line-height:1}
.why-badge span{font-size:.72rem;color:rgba(255,255,255,.8);font-weight:500}

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.how-section{background:var(--white)}

.steps-wrap{
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
  margin-top:3rem;position:relative;
}
.steps-wrap::before{display:none}
.steps-track{
  position:absolute;top:36px;left:12.5%;width:75%;
  height:3px;z-index:0;overflow:visible;
}
.steps-track-bg{position:absolute;inset:0;background:rgba(0,0,0,.1);border-radius:2px}
.steps-track-fill{
  position:absolute;top:0;left:0;height:100%;width:0%;
  background:linear-gradient(to right,var(--cyan),var(--blue));
  border-radius:2px;transition:width .12s linear;
}
.steps-moto-runner{
  position:absolute;top:50%;left:0%;
  transform:translate(-50%,-50%);
  transition:left .12s linear;pointer-events:none;
  filter:drop-shadow(0 3px 8px rgba(0,196,224,.5));
}
.step-card{
  text-align:center;position:relative;z-index:1;
  transition:opacity .5s ease,filter .5s ease;
}
.step-card.dim{opacity:.22;filter:grayscale(80%)}
.step-card.active{opacity:1;filter:none}
.step-num{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  color:var(--white);font-size:1.5rem;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.25rem;
  box-shadow:0 8px 24px rgba(0,196,224,.35);
  border:4px solid var(--white);
}
.step-card h4{font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.step-card p{font-size:.82rem;color:var(--gray-500);line-height:1.65}

/* ============================================================
   AREAS SECTION
   ============================================================ */
.areas-section{background:var(--off-white)}

.areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem}

.area-card{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  min-height:440px;cursor:pointer;transition:var(--t);
}
.area-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl)}

.area-card-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform .55s var(--ease);
}
.area-card:hover .area-card-bg{transform:scale(1.05)}

.area-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(7,17,31,.95) 0%,rgba(7,17,31,.55) 50%,rgba(7,17,31,.15) 100%);
  z-index:1;
}

.area-content{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:2.5rem}
.area-tag{
  display:inline-block;background:var(--cyan);color:var(--navy);
  padding:4px 12px;border-radius:var(--r-xl);
  font-size:.65rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.8rem;
}
.area-card h3{font-size:2rem;font-weight:900;color:var(--white);margin-bottom:.4rem}
.area-card p{font-size:.88rem;color:rgba(255,255,255,.72);margin-bottom:1.2rem;line-height:1.65}

.area-zones{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1.5rem}
.area-zone{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.78);padding:3px 10px;border-radius:var(--r-xl);
  font-size:.7rem;font-weight:500;backdrop-filter:blur(4px);
}

/* ============================================================
   FLEET
   ============================================================ */
.fleet-section{background:var(--white)}

.fleet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem;margin-top:3rem}

.fleet-card{
  text-align:center;padding:2rem;border-radius:var(--r-lg);
  border:1.5px solid var(--gray-200);transition:var(--t);background:var(--off-white);
}
.fleet-card:hover{
  border-color:var(--cyan);background:var(--white);
  box-shadow:0 8px 32px rgba(0,196,224,.15);transform:translateY(-5px);
}
.fleet-card img{width:100%;height:170px;object-fit:contain;margin-bottom:1.5rem;transition:transform .4s var(--ease)}
.fleet-card:hover img{transform:scale(1.06)}
.fleet-card h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.fleet-card p{font-size:.85rem;color:var(--gray-500);line-height:1.65}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews-section{background:var(--off-white)}

.reviews-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}

.google-rating{
  display:flex;align-items:center;gap:1.25rem;
  background:var(--white);border:1.5px solid var(--gray-200);
  border-radius:var(--r-lg);padding:1.1rem 1.6rem;
  box-shadow:var(--shadow-sm);
}
.google-logo{width:28px;height:28px}
.rating-num{font-size:2.2rem;font-weight:900;color:var(--navy);line-height:1}
.rating-stars{display:flex;gap:2px;margin-bottom:2px}
.star{color:#f59e0b;font-size:1rem}
.rating-count{font-size:.75rem;color:var(--gray-400)}

.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

.review-card{
  background:var(--white);border-radius:var(--r-lg);padding:1.6rem;
  border:1px solid var(--gray-200);transition:var(--t);
}
.review-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:transparent}

.review-head{display:flex;align-items:center;gap:12px;margin-bottom:1rem}

.review-avatar{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  display:flex;align-items:center;justify-content:center;
  color:var(--white);font-size:.9rem;font-weight:800;
  overflow:hidden;
}
.review-name{font-size:.9rem;font-weight:700;color:var(--navy)}
.review-date{font-size:.72rem;color:var(--gray-400);margin-top:2px}
.review-stars{display:flex;gap:2px;margin-bottom:.75rem}
.review-stars .star{font-size:.85rem}
.review-text{font-size:.875rem;color:var(--gray-700);line-height:1.72}

.review-footer{
  display:flex;align-items:center;gap:6px;
  margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--gray-200);
}
.review-footer span{font-size:.72rem;color:var(--gray-400)}

.reviews-cta-row{text-align:center;margin-top:2.5rem}

.btn-review{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);color:var(--navy);
  border:1.5px solid var(--gray-200);border-radius:var(--r-xl);
  padding:11px 24px;font-size:.875rem;font-weight:700;
  transition:var(--t);box-shadow:var(--shadow-xs);
}
.btn-review:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-sm)}

/* ============================================================
   QUOTE CTA BAND
   ============================================================ */
.cta-band{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 50%,#1a3c7a 100%);
  position:relative;overflow:hidden;
}
.cta-band::after{
  content:'';position:absolute;
  top:-50%;right:-10%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(0,196,224,.1) 0%,transparent 70%);
  pointer-events:none;
}
.cta-band-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:3rem;position:relative;z-index:1;flex-wrap:wrap;
}
.cta-band h2{
  font-size:clamp(1.7rem,3vw,2.5rem);font-weight:900;color:var(--white);line-height:1.15;
}
.cta-band h2 span{color:var(--cyan)}
.cta-band p{font-size:1rem;color:rgba(255,255,255,.65);margin-top:.5rem}
.cta-band-actions{display:flex;flex-direction:column;gap:.875rem;min-width:240px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy);padding:64px 0 0}

.footer-grid{
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1.6fr;gap:3.5rem;
  padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.06);
}

.footer-brand img{height:60px;width:auto;margin-bottom:1rem}
.footer-brand p{font-size:.875rem;line-height:1.75;color:rgba(255,255,255,.48);margin-bottom:1.5rem}

.footer-socials{display:flex;gap:.75rem}
.footer-soc{
  width:38px;height:38px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.55);transition:var(--t);
}
.footer-soc:hover{background:var(--cyan);border-color:var(--cyan);color:var(--white);transform:translateY(-2px)}

.footer-col h4{
  font-size:.75rem;font-weight:700;color:var(--white);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.2rem;
}
.footer-links{display:flex;flex-direction:column;gap:.65rem}
.footer-links a{
  font-size:.875rem;color:rgba(255,255,255,.5);
  transition:var(--t-f);display:flex;align-items:center;gap:6px;
}
.footer-links a:hover{color:var(--cyan);padding-left:5px}

.footer-contact-item{
  display:flex;align-items:flex-start;gap:10px;
  font-size:.875rem;color:rgba(255,255,255,.5);margin-bottom:.8rem;
}
.footer-contact-item svg{color:var(--cyan);flex-shrink:0;margin-top:2px}
.footer-contact-item a{color:rgba(255,255,255,.65);transition:color .2s}
.footer-contact-item a:hover{color:var(--cyan)}

.footer-bottom{
  padding:1.4rem 0;display:flex;align-items:center;
  justify-content:space-between;flex-wrap:wrap;gap:.75rem;
  font-size:.78rem;color:rgba(255,255,255,.28);
}
.footer-bottom a{color:rgba(255,255,255,.4);transition:color .2s}
.footer-bottom a:hover{color:var(--cyan)}
.footer-dev{text-align:center;padding:.6rem 0 1rem;font-size:.72rem;color:rgba(255,255,255,.22)}
.footer-dev a{color:rgba(255,255,255,.38);text-decoration:none;transition:color .2s}
.footer-dev a:hover{color:var(--cyan)}

/* ============================================================
   WHATSAPP FLOAT
   ============================================================ */
.wa-float{
  position:fixed;bottom:28px;right:28px;z-index:990;
  display:flex;flex-direction:column;align-items:flex-end;gap:14px;
}
.wa-float-item{display:flex;align-items:center;gap:10px;justify-content:flex-end}
.wa-float-btn{
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:transform .25s,box-shadow .25s;flex-shrink:0;text-decoration:none;
}
.wa-float-btn-phone{
  background:#1d4ed8;color:var(--white);
  box-shadow:0 6px 20px rgba(29,78,216,.4);
}
.wa-float-btn-phone:hover{transform:scale(1.1);background:#1e40af;box-shadow:0 8px 28px rgba(29,78,216,.55)}
.wa-float-btn-wa{
  background:#25d366;color:var(--white);
  box-shadow:0 6px 20px rgba(37,211,102,.4);
  animation:wa-pulse 2.8s infinite;
}
.wa-float-btn-wa:hover{transform:scale(1.1) !important;background:#22c55e;animation:none}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 6px 20px rgba(37,211,102,.4)}
  50%{box-shadow:0 6px 30px rgba(37,211,102,.65),0 0 0 8px rgba(37,211,102,.08)}
}
.wa-float-tip{
  background:var(--navy);color:var(--white);
  font-size:.75rem;font-weight:600;padding:7px 14px;
  border-radius:999px;white-space:nowrap;pointer-events:none;
  opacity:0;transform:translateX(12px);transition:.25s;
  box-shadow:0 4px 14px rgba(0,0,0,.25);
}
.wa-float-item:hover .wa-float-tip{opacity:1;transform:translateX(0)}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 55%,#1c3d7a 100%);
  padding:148px 0 84px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;bottom:-40%;right:-10%;
  width:550px;height:550px;
  background:radial-gradient(circle,rgba(0,196,224,.1) 0%,transparent 70%);pointer-events:none;
}
.page-hero-inner{position:relative;z-index:1}
.breadcrumb{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  font-size:.78rem;color:rgba(255,255,255,.5);margin-bottom:1rem;
}
.breadcrumb a{color:rgba(255,255,255,.65);transition:color .2s}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb svg{width:11px;height:11px}

.page-hero h1{
  font-size:clamp(2rem,4.5vw,3.2rem);font-weight:900;color:var(--white);
  margin-bottom:1rem;line-height:1.15;
}
.page-hero h1 span{color:var(--cyan)}
.page-hero p{font-size:1.05rem;color:rgba(255,255,255,.68);max-width:560px;line-height:1.75}

/* ============================================================
   COTAÇÃO MODAL
   ============================================================ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(7,17,31,.88);backdrop-filter:blur(10px);
  z-index:2000;display:flex;align-items:center;justify-content:center;
  padding:1rem;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
}
.modal-overlay.open{opacity:1;visibility:visible}

.modal-box{
  background:var(--white);border-radius:var(--r-lg);
  width:100%;max-width:660px;max-height:92vh;
  overflow-y:auto;box-shadow:var(--shadow-xl);
  transform:scale(.96) translateY(16px);transition:transform .3s var(--ease);
}
.modal-overlay.open .modal-box{transform:scale(1) translateY(0)}

.modal-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem 1.75rem;background:var(--navy);
  border-radius:var(--r-lg) var(--r-lg) 0 0;
  position:sticky;top:0;z-index:1;
}
.modal-hd h2{font-size:1.1rem;font-weight:700;color:var(--white)}
.modal-close{
  width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.1);
  border:none;color:var(--white);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:var(--t-f);
}
.modal-close:hover{background:rgba(255,255,255,.22)}

.modal-body{padding:1.75rem}

/* Progress steps */
.modal-progress{
  display:flex;align-items:center;gap:0;
  margin-bottom:1.75rem;border-radius:var(--r-sm);
  overflow:hidden;border:1.5px solid var(--gray-200);
}
.mpstep{
  flex:1;padding:.7rem .5rem;text-align:center;
  font-size:.78rem;font-weight:600;color:var(--gray-500);
  background:var(--gray-100);border-right:1px solid var(--gray-200);
  transition:var(--t-f);cursor:default;
}
.mpstep:last-child{border-right:none}
.mpstep.active{background:var(--blue);color:var(--white)}
.mpstep.done{background:var(--success);color:var(--white)}

/* Form */
.form-group{margin-bottom:1.1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--gray-700);margin-bottom:.36rem}
.req{color:var(--danger)}
.form-input,.form-select,.form-textarea{
  width:100%;padding:10px 13px;font-size:.9rem;color:var(--text);
  background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--r-sm);
  outline:none;transition:border-color .2s,box-shadow .2s;
  font-family:var(--font);
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--blue);box-shadow:0 0 0 3px rgba(20,85,184,.1);
}
.form-input::placeholder{color:var(--gray-400)}
.form-textarea{resize:vertical;min-height:72px}

/* Stop accordion */
.stop-block{
  border:1.5px solid var(--gray-200);border-radius:var(--r);
  overflow:hidden;margin-bottom:1rem;
}
.stop-toggle{
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 1.1rem;background:var(--gray-100);
  cursor:pointer;font-size:.88rem;font-weight:700;color:var(--navy);
  border:none;width:100%;text-align:left;transition:var(--t-f);
}
.stop-toggle:hover{background:var(--gray-200)}
.stop-toggle svg{transition:transform .25s}
.stop-block.open .stop-toggle svg{transform:rotate(180deg)}
.stop-inner{padding:1.2rem;display:none}
.stop-block.open .stop-inner{display:block}

.stop-sep{
  display:flex;align-items:center;gap:8px;
  font-size:.75rem;font-weight:700;color:var(--blue);margin:1rem 0;
}
.stop-sep::before,.stop-sep::after{content:'';flex:1;height:1px;background:var(--gray-200)}

/* Route summary */
.route-sum{border:1.5px solid var(--gray-200);border-radius:var(--r);overflow:hidden;margin-bottom:1rem}
.route-sum-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 1rem;background:var(--gray-100);
  font-size:.72rem;font-weight:700;color:var(--gray-500);
  text-transform:uppercase;letter-spacing:.06em;
}
.route-sum-bd{padding:1rem}

.rp{display:flex;gap:12px;align-items:flex-start;margin-bottom:.75rem}
.rp:last-child{margin-bottom:0}
.rp-dot{
  width:22px;height:22px;border-radius:50%;flex-shrink:0;margin-top:1px;
  display:flex;align-items:center;justify-content:center;
  font-size:.62rem;font-weight:800;color:var(--white);
}
.rp-dot.o{background:var(--blue)}
.rp-dot.d{background:var(--success)}
.rp-dot.e{background:var(--warning)}
.rp-info{}
.rp-lbl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400)}
.rp-addr{font-size:.875rem;color:var(--text);font-weight:500}
.rp-sub{font-size:.75rem;color:var(--gray-500)}

.route-dist{
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 1rem;background:var(--blue);color:var(--white);
  font-size:.875rem;font-weight:600;
}

.btn-rm{background:none;border:none;color:var(--danger);cursor:pointer;padding:2px;display:flex;transition:var(--t-f)}
.btn-rm:hover{transform:scale(1.2)}

/* Price box */
.price-box{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.2rem 1.4rem;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  border-radius:var(--r);margin-bottom:1.25rem;
}
.price-box-lbl{font-size:.82rem;color:rgba(255,255,255,.65)}
.price-box-val{font-size:2rem;font-weight:900;color:var(--cyan)}

/* PIX */
.pix-box{
  text-align:center;padding:1.5rem;
  background:var(--off-white);border-radius:var(--r);
  border:2px dashed var(--gray-200);margin-bottom:1.25rem;
}
.pix-box h3{font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.pix-box p{font-size:.82rem;color:var(--gray-500);margin-bottom:1rem}
#qrcode-container{margin:0 auto .75rem;display:inline-block;padding:10px;background:var(--white);border-radius:var(--r-sm);box-shadow:var(--shadow-sm)}
.pix-key-copy{
  display:flex;gap:.5rem;align-items:center;
  background:var(--white);border:1.5px solid var(--gray-200);
  border-radius:var(--r-sm);padding:8px 12px;margin:0 auto;
  max-width:320px;
}
.pix-key-copy input{flex:1;border:none;outline:none;font-size:.8rem;color:var(--gray-700);background:transparent;font-family:var(--font)}
.pix-key-copy button{
  background:var(--blue);color:var(--white);border:none;
  padding:5px 10px;border-radius:var(--r-sm);font-size:.72rem;font-weight:700;cursor:pointer;
  white-space:nowrap;transition:var(--t-f);
}
.pix-key-copy button:hover{background:var(--blue-light)}

/* Form actions */
.modal-actions{display:grid;grid-template-columns:1fr 2fr;gap:.75rem;margin-top:1.5rem}
.btn-back{
  background:transparent;color:var(--blue);padding:12px;
  border:1.5px solid var(--gray-200);border-radius:var(--r);
  font-size:.9rem;font-weight:700;cursor:pointer;transition:var(--t-f);
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.btn-back:hover{border-color:var(--blue);background:rgba(20,85,184,.04)}

.btn-next{
  background:linear-gradient(135deg,var(--cyan),var(--blue-light));
  color:var(--white);padding:12px;border:none;
  border-radius:var(--r);font-size:.9rem;font-weight:700;
  cursor:pointer;transition:var(--t);
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.btn-next:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,196,224,.35)}

.btn-add-stop{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:10px;border:2px dashed var(--blue);
  background:transparent;color:var(--blue);border-radius:var(--r);
  font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--t-f);
  margin-bottom:1.1rem;
}
.btn-add-stop:hover{background:rgba(20,85,184,.05)}

/* Alerts */
.alert{padding:.8rem 1rem;border-radius:var(--r-sm);font-size:.875rem;font-weight:500;margin-bottom:1rem;display:flex;align-items:flex-start;gap:8px}
.alert-success{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}
.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}
.alert-info{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}

.privacy-note{font-size:.72rem;color:var(--gray-400);text-align:center;margin-top:1rem;line-height:1.5}
.privacy-note a{color:var(--blue);font-weight:500}

/* Success screen */
.success-screen{text-align:center;padding:2.5rem 1rem}
.success-ico{
  width:76px;height:76px;border-radius:50%;margin:0 auto 1.5rem;
  background:linear-gradient(135deg,#10b981,#059669);
  display:flex;align-items:center;justify-content:center;color:var(--white);
  box-shadow:0 8px 28px rgba(16,185,129,.38);
}
.success-screen h3{font-size:1.5rem;font-weight:900;color:var(--navy);margin-bottom:.5rem}
.success-screen p{color:var(--gray-500);font-size:.9rem;line-height:1.7;max-width:360px;margin:0 auto 2rem}

/* Map container */
#cotacao-map-wrap{
  display:none;width:100%;height:260px;
  border-bottom:2px solid var(--gray-200);
}
#cotacao-map-wrap.active{display:block}
#cotacao-map{width:100%;height:100%}

/* Service type toggle buttons */
.svc-btn-group{
  display:flex;flex-wrap:wrap;gap:.5rem;
}
.svc-btn{
  padding:7px 14px;border-radius:var(--r-sm);
  border:1.5px solid var(--gray-200);
  background:var(--white);color:var(--gray-600);
  font-size:.8rem;font-weight:600;cursor:pointer;
  transition:border-color .18s,background .18s,color .18s;
  font-family:var(--font);
}
.svc-btn:hover{border-color:var(--blue);color:var(--blue)}
.svc-btn.active{
  background:var(--blue);border-color:var(--blue);color:var(--white);
}

/* ============================================================
   ABOUT PAGE EXTRAS
   ============================================================ */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem;margin-top:3rem}
.value-card{
  padding:2rem;border-radius:var(--r-lg);
  background:var(--white);border:1.5px solid var(--gray-200);transition:var(--t);
}
.value-card:hover{border-color:var(--cyan);transform:translateY(-5px);box-shadow:0 8px 28px rgba(0,196,224,.15)}
.value-ico{
  width:52px;height:52px;border-radius:var(--r);
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  display:flex;align-items:center;justify-content:center;color:var(--white);margin-bottom:1.2rem;
}
.value-card h3{font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}
.value-card p{font-size:.875rem;color:var(--gray-500);line-height:1.7}

.team-img-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.team-img-wrap img{width:100%;object-fit:cover;height:460px}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start;margin-top:3rem}

.contact-info-card{
  background:var(--navy);border-radius:var(--r-lg);
  padding:2.5rem;color:rgba(255,255,255,.7);
}
.contact-info-card h3{font-size:1.3rem;font-weight:800;color:var(--white);margin-bottom:2rem}
.ci-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:1.5rem}
.ci-ico{
  width:44px;height:44px;border-radius:var(--r-sm);flex-shrink:0;
  background:rgba(0,196,224,.12);border:1px solid rgba(0,196,224,.2);
  display:flex;align-items:center;justify-content:center;color:var(--cyan);
}
.ci-lbl{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.4);margin-bottom:3px}
.ci-val{font-size:.92rem;color:rgba(255,255,255,.82)}
.ci-val a{color:rgba(255,255,255,.82);transition:color .2s}
.ci-val a:hover{color:var(--cyan)}

.map-embed{margin-top:2rem;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.map-embed iframe{display:block;width:100%;border:0}

.contact-form-card{background:var(--white);border-radius:var(--r-lg);padding:2.5rem;border:1.5px solid var(--gray-200)}
.contact-form-card h3{font-size:1.3rem;font-weight:800;color:var(--navy);margin-bottom:.5rem}
.contact-form-card>.sub{font-size:.875rem;color:var(--gray-500);margin-bottom:2rem}

/* ============================================================
   SOLUTION CARDS
   ============================================================ */
.solutions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem}
.sol-card{
  display:flex;gap:1.5rem;padding:1.75rem;
  background:var(--white);border-radius:var(--r-lg);border:1.5px solid var(--gray-200);transition:var(--t);
}
.sol-card:hover{border-color:var(--cyan);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.sol-ico{
  width:56px;height:56px;border-radius:var(--r);flex-shrink:0;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  display:flex;align-items:center;justify-content:center;color:var(--white);
}
.sol-body h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.sol-body p{font-size:.875rem;color:var(--gray-500);line-height:1.7}

/* ============================================================
   SERVICE INNER PAGE
   ============================================================ */
.service-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-top:3rem}
.service-img-stack{position:relative}
.service-img-stack .main-img{border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-height:480px;object-fit:contain;object-position:center center}
.service-features{margin-top:2rem}
.sf-item{display:flex;gap:12px;align-items:flex-start;margin-bottom:1.25rem}
.sf-check{
  width:24px;height:24px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  display:flex;align-items:center;justify-content:center;color:var(--white);margin-top:1px;
}
.sf-item h4{font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:.25rem}
.sf-item p{font-size:.85rem;color:var(--gray-500);line-height:1.65}

.districts-section{background:var(--off-white)}
.districts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2rem}
.district-col h4{
  font-size:.78rem;font-weight:700;color:var(--white);
  text-transform:uppercase;letter-spacing:.08em;
  background:linear-gradient(135deg,var(--blue),var(--cyan-dark));
  padding:.5rem 1rem;border-radius:var(--r-sm);margin-bottom:.75rem;
}
.district-list{display:flex;flex-direction:column;gap:.35rem}
.district-list li{
  font-size:.82rem;color:var(--gray-700);padding:.3rem 0;
  border-bottom:1px solid var(--gray-200);
}
.district-list li:last-child{border-bottom:none}

/* ============================================================
   404
   ============================================================ */
.not-found{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--navy-light));
  text-align:center;padding:2rem;
}
.not-found-inner{}
.nf-num{
  font-size:clamp(6rem,18vw,10rem);font-weight:900;color:var(--cyan);
  line-height:1;opacity:.15;
}
.nf-title{font-size:2rem;font-weight:800;color:var(--white);margin-bottom:.75rem}
.nf-sub{font-size:1rem;color:rgba(255,255,255,.6);margin-bottom:2rem}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .fleet-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .steps-wrap{grid-template-columns:repeat(2,1fr)}
  .steps-wrap::before{display:none}
  .why-grid{grid-template-columns:1fr;gap:3rem}
  .why-img-wrap{max-width:560px;margin:0 auto}
  .districts-grid{grid-template-columns:repeat(2,1fr)}
  .service-content-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  section{padding:64px 0}
  .navbar{padding:0 1.25rem}
  .nav-links,.nav-right{display:none}
  .nav-toggle{display:flex}
  .hero-stats{display:grid;grid-template-columns:1fr 1fr;position:relative;bottom:auto}
  .hero-stat{padding:14px 10px}
  .hero-stat-num{font-size:1.35rem}
  .areas-grid,.reviews-grid{grid-template-columns:1fr}
  .fleet-grid{grid-template-columns:1fr 1fr}
  .steps-wrap{grid-template-columns:1fr 1fr}
  .cta-band-inner{flex-direction:column;align-items:flex-start}
  .cta-band-actions{min-width:auto;width:100%;flex-direction:row}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
  .reviews-top{flex-direction:column;align-items:flex-start}
  .services-grid{grid-template-columns:1fr}
  .solutions-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .modal-actions{grid-template-columns:1fr 2fr}
  .why-features{grid-template-columns:1fr}
  .districts-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .hero-title{font-size:1.9rem}
  .hero-title-city{font-size:2.4rem}
  .hero-ctas{flex-direction:column}
  .fleet-grid,.steps-wrap{grid-template-columns:1fr}
  .cta-band-actions{flex-direction:column}
  .modal-actions{grid-template-columns:1fr}
  .districts-grid{grid-template-columns:1fr}
}

/* =====================================================
   BLOG — Index & Articles
   ===================================================== */

/* Blog hero banner */
.blog-hero{background:var(--navy);padding:5rem 0 4rem;text-align:center;position:relative;overflow:hidden}
.blog-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 60% 50%,rgba(0,212,255,.08) 0%,transparent 70%)}
.blog-hero .section-label{color:var(--cyan);margin-bottom:1rem;display:block}
.blog-hero h1{font-size:clamp(2rem,5vw,3rem);color:#fff;font-weight:800;margin-bottom:1rem}
.blog-hero p{color:rgba(255,255,255,.7);max-width:540px;margin:0 auto}

/* Featured section */
.blog-featured-wrap{display:grid;grid-template-columns:1.5fr 1fr;gap:2rem;align-items:start;margin-bottom:3rem}
.blog-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.07);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(0,0,0,.12)}
.blog-card a{text-decoration:none;color:inherit}
.blog-card-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.blog-card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.blog-tag{display:inline-block;background:var(--cyan);color:var(--navy);font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;padding:3px 10px;border-radius:20px;margin-bottom:.75rem}
.blog-card-title{font-size:1.15rem;font-weight:800;color:var(--navy);line-height:1.35;margin-bottom:.6rem}
.blog-card-title-lg{font-size:1.5rem}
.blog-card-excerpt{font-size:.88rem;color:#555;line-height:1.6;margin-bottom:1rem;flex:1}
.blog-card-meta{font-size:.77rem;color:#888;display:flex;align-items:center;gap:.5rem}
.blog-card-meta span{display:flex;align-items:center;gap:4px}
.blog-card-read{font-size:.82rem;font-weight:700;color:var(--blue);margin-top:1rem;display:inline-flex;align-items:center;gap:5px;transition:gap .2s}
.blog-card:hover .blog-card-read{gap:8px}

/* Secondary cards stack */
.blog-secondary{display:flex;flex-direction:column;gap:1.25rem}
.blog-card-sm{display:flex;gap:1rem;align-items:start;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06);padding:.875rem;transition:transform .25s}
.blog-card-sm:hover{transform:translateY(-3px)}
.blog-card-sm-img{width:90px;min-width:90px;height:70px;object-fit:cover;border-radius:8px}
.blog-card-sm-body{flex:1}
.blog-card-sm-title{font-size:.88rem;font-weight:700;color:var(--navy);line-height:1.35;margin-bottom:.3rem}

/* Recent grid */
.blog-recent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.blog-section-title{font-size:1.4rem;font-weight:800;color:var(--navy);margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}

/* Article page */
.article-page{max-width:780px;margin:0 auto;padding:3rem 1.5rem 5rem}
.article-breadcrumb{font-size:.8rem;color:#888;margin-bottom:2rem;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.article-breadcrumb a{color:var(--blue);text-decoration:none}
.article-breadcrumb a:hover{text-decoration:underline}
.article-breadcrumb span{color:#bbb}
.article-tag-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}
.article-category{background:var(--cyan);color:var(--navy);font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;padding:3px 10px;border-radius:20px}
.article-title{font-size:clamp(1.8rem,4vw,2.5rem);font-weight:900;color:var(--navy);line-height:1.25;margin-bottom:1.25rem}
.article-meta{display:flex;align-items:center;gap:1.25rem;font-size:.82rem;color:#777;margin-bottom:2rem;flex-wrap:wrap}
.article-meta strong{color:var(--navy)}
.article-hero-img{width:100%;border-radius:16px;aspect-ratio:16/9;object-fit:cover;margin-bottom:2.5rem;box-shadow:0 4px 24px rgba(0,0,0,.1)}
.article-body{color:#333;font-size:1.02rem;line-height:1.8}
.article-body h2{font-size:1.5rem;font-weight:800;color:var(--navy);margin:2.5rem 0 1rem;padding-top:.5rem;border-top:3px solid var(--cyan);padding-left:0}
.article-body h3{font-size:1.15rem;font-weight:700;color:var(--navy);margin:2rem 0 .75rem}
.article-body p{margin-bottom:1.25rem}
.article-body ul,.article-body ol{margin:1rem 0 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}
.article-body li{color:#444}
.article-body strong{color:var(--navy)}
.article-body a{color:var(--blue);text-decoration:underline}

/* Info boxes */
.infobox{border-radius:12px;padding:1.5rem;margin:2rem 0}
.infobox-cyan{background:linear-gradient(135deg,#e8faff,#cff5ff);border-left:4px solid var(--cyan)}
.infobox-navy{background:linear-gradient(135deg,#07111f,#0d2240);color:#fff;border-radius:12px}
.infobox-navy h4,.infobox-navy p,.infobox-navy li{color:#fff}
.infobox-yellow{background:#fffbeb;border-left:4px solid #f59e0b}
.infobox-green{background:#f0fdf4;border-left:4px solid #22c55e}
.infobox h4{font-size:1rem;font-weight:800;margin-bottom:.75rem;color:var(--navy)}
.infobox-navy h4{color:var(--cyan)}
.infobox p{margin:0;font-size:.92rem}

/* Numbered card grid */
.numbered-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin:1.5rem 0}
.numbered-card{background:#fff;border:2px solid #e8f4ff;border-radius:12px;padding:1.25rem;position:relative}
.numbered-card-num{font-size:2.5rem;font-weight:900;color:var(--cyan);line-height:1;margin-bottom:.5rem}
.numbered-card-title{font-weight:800;color:var(--navy);font-size:.95rem;margin-bottom:.4rem}
.numbered-card-text{font-size:.84rem;color:#555;line-height:1.55}

/* Comparison table */
.comparison-table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.9rem}
.comparison-table th{background:var(--navy);color:#fff;padding:.75rem 1rem;text-align:left;font-weight:700}
.comparison-table th:first-child{border-radius:8px 0 0 0}
.comparison-table th:last-child{border-radius:0 8px 0 0}
.comparison-table td{padding:.7rem 1rem;border-bottom:1px solid #eee}
.comparison-table tr:nth-child(even) td{background:#f8f9ff}
.comparison-table .check{color:#22c55e;font-weight:700}
.comparison-table .cross{color:#ef4444;font-weight:700}

/* Checklist box */
.checklist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}
.checklist li{display:flex;align-items:flex-start;gap:.75rem;font-size:.92rem;color:#333}
.checklist li::before{content:'✔';color:var(--cyan);font-weight:900;flex-shrink:0;margin-top:2px}

/* Stats bar */
.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;background:var(--navy);border-radius:14px;padding:1.5rem;margin:2rem 0;text-align:center}
.stats-bar-item strong{display:block;font-size:2rem;font-weight:900;color:var(--cyan)}
.stats-bar-item span{font-size:.8rem;color:rgba(255,255,255,.75);margin-top:.2rem;display:block}

/* CTA box inside article */
.article-cta-box{background:linear-gradient(135deg,var(--navy),#0d2240);border-radius:16px;padding:2rem;text-align:center;margin:2.5rem 0}
.article-cta-box h3{color:#fff;font-size:1.3rem;font-weight:800;margin-bottom:.5rem}
.article-cta-box p{color:rgba(255,255,255,.75);font-size:.92rem;margin-bottom:1.25rem}
.article-cta-box .btn-group{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}

/* Related articles */
.article-related{margin-top:4rem;padding-top:2.5rem;border-top:2px solid #f0f0f0}
.article-related h3{font-size:1.25rem;font-weight:800;color:var(--navy);margin-bottom:1.5rem}
.article-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}

/* Blog responsive */
@media(max-width:900px){
  .blog-featured-wrap{grid-template-columns:1fr}
  .blog-recent-grid{grid-template-columns:1fr 1fr}
  .article-related-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .blog-recent-grid{grid-template-columns:1fr}
  .article-related-grid{grid-template-columns:1fr}
  .numbered-grid{grid-template-columns:1fr}
  .stats-bar{grid-template-columns:1fr;gap:.75rem}
  .blog-secondary{gap:1rem}
  .article-page{padding:2rem 1rem 4rem}
}
