:root {
  --green: #4ed024;
  --green2: #3dbe1a;
  --green-glow: rgba(78,208,36,0.18);
  --navy: #0B101C;
  --navy2: #0C141F;
  --navy-mid: #131B2E;
  --gray: #EEF1F4;
  --gray2: #CBD2D9;
  --text: #17202A;
  --muted: #5A6572;
  --white: #FFFFFF;
  --surface: #F7F9FB;
  --card-border: rgba(78,208,36,0.15);
  --radius: 20px;
  --radius-sm: 12px;
  --radius-lg: 32px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--navy);
  color: var(--white);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; }
img { max-width: 100%; display: block; }
.container { width: min(1180px, calc(100% - 48px)); margin: 0 auto; }

/* TOPO / MENU */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(11,16,28,0.72);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(78,208,36,0.12);
  transition: all .25s ease;
}
.site-header.scrolled {
  background: rgba(11,16,28,0.94);
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
}
.topbar {
  width: min(1240px, calc(100% - 48px));
  margin: 0 auto;
  min-height: 82px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}
.brand { display: flex; align-items: center; text-decoration: none; }
.logo { height: 48px; width: auto; object-fit: contain; }
.logo-color { display: none; }
.main-menu { display: flex; align-items: center; gap: 26px; }
.main-menu a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(255,255,255,.74);
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .2px;
  transition: color .2s ease;
}
.main-menu a:hover { color: var(--green); }
.menu-dropdown { position: relative; display: inline-flex; align-items: center; }
.menu-dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.74);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .2px;
  cursor: pointer;
  transition: color .2s ease;
}
.menu-dropdown-toggle i { font-size: 10px; transition: transform .2s ease; }
.menu-dropdown:hover .menu-dropdown-toggle, .menu-dropdown:focus-within .menu-dropdown-toggle, .menu-dropdown-toggle.active { color: var(--green); }
.menu-dropdown:hover .menu-dropdown-toggle i, .menu-dropdown:focus-within .menu-dropdown-toggle i { transform: rotate(180deg); }
.menu-dropdown-panel {
  position: absolute;
  top: calc(100% + 18px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 250px;
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid rgba(78,208,36,.18);
  border-radius: 16px;
  background: rgba(11,16,28,.98);
  box-shadow: 0 22px 60px rgba(0,0,0,.38);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
}
.menu-dropdown-panel::before { content: ''; position: absolute; left: 0; right: 0; top: -20px; height: 20px; }
.menu-dropdown:hover .menu-dropdown-panel, .menu-dropdown:focus-within .menu-dropdown-panel { opacity: 1; visibility: visible; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.menu-dropdown-panel a { width: 100%; border-radius: 10px; padding: 11px 12px; color: rgba(255,255,255,.74); }
.menu-dropdown-panel a:hover, .menu-dropdown-panel a.active { background: rgba(78,208,36,.10); color: var(--green); }
.header-actions { display: flex; align-items: center; gap: 10px; }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 999px;
  padding: 11px 20px;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
  border: 1px solid transparent;
  transition: all .2s ease;
  cursor: pointer;
  white-space: nowrap;
}
.btn-green { background: var(--green); color: var(--navy); }
.btn-green:hover { background: var(--green2); transform: translateY(-2px); box-shadow: 0 12px 30px rgba(78,208,36,.30); }
.btn-outline { border-color: rgba(255,255,255,.18); color: rgba(255,255,255,.86); background: rgba(255,255,255,.04); }
.btn-outline:hover { border-color: rgba(78,208,36,.6); color: var(--green); }
.btn-glass { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18); color: var(--white); }
.btn-glass:hover { border-color: rgba(78,208,36,.6); background: rgba(78,208,36,.09); color: var(--green); }
.btn-lg { padding: 15px 26px; font-size: 15px; }
.menu-toggle { display: none; width: 44px; height: 44px; border: 0; background: rgba(255,255,255,.06); border-radius: 12px; cursor: pointer; }
.menu-toggle span { display: block; height: 2px; width: 21px; background: var(--white); margin: 5px auto; transition: all .2s ease; }
.menu-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle.open span:nth-child(2) { opacity: 0; }
.menu-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* HERO */
.hero-media {
  min-height: 100vh;
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: 140px 0 90px;
}
.hero-bg-img, .hero-video {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(11,16,28,.96) 0%, rgba(11,16,28,.76) 34%, rgba(11,16,28,.32) 72%, rgba(11,16,28,.44) 100%),
    linear-gradient(0deg, rgba(11,16,28,.75) 0%, transparent 45%);
}
.hero-content {
  position: relative;
  z-index: 2;
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
  max-width: 760px;
  margin-left: max(24px, calc((100vw - 1180px)/2));
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(78,208,36,0.12);
  border: 1px solid rgba(78,208,36,0.3);
  border-radius: 100px;
  padding: 7px 15px;
  font-size: 12px;
  font-weight: 700;
  color: var(--green);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.hero-eyebrow .dot { width: 7px; height: 7px; background: var(--green); border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .55; transform: scale(.82); } }
.hero h1 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(42px, 5.6vw, 78px);
  font-weight: 700;
  line-height: .98;
  letter-spacing: -2.4px;
  max-width: 860px;
  margin-bottom: 24px;
}
.hero h1 em { color: var(--green); font-style: normal; }
.hero-sub { font-size: 18px; line-height: 1.7; color: rgba(255,255,255,.72); max-width: 650px; margin-bottom: 34px; }
.hero-buttons { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 42px; }
.hero-stats { display: flex; gap: 16px; flex-wrap: wrap; }
.hero-stats div {
  min-width: 150px;
  background: rgba(11,16,28,.62);
  border: 1px solid rgba(78,208,36,.18);
  border-radius: 18px;
  padding: 18px 20px;
  backdrop-filter: blur(12px);
}
.hero-stats strong { display: block; font-family: 'Space Grotesk', sans-serif; font-size: 30px; color: var(--green); line-height: 1; }
.hero-stats span { display: block; margin-top: 5px; font-size: 12px; color: rgba(255,255,255,.55); }

/* SECTIONS */
.section { padding: 105px 0; }
.section-eyebrow { font-size: 11px; font-weight: 800; letter-spacing: 2.5px; text-transform: uppercase; color: var(--green); margin-bottom: 14px; }
.section-title { font-family: 'Space Grotesk', sans-serif; font-size: clamp(30px, 3.5vw, 50px); font-weight: 700; letter-spacing: -1.2px; line-height: 1.1; margin-bottom: 16px; }
.section-sub { font-size: 17px; color: rgba(255,255,255,0.63); line-height: 1.7; max-width: 680px; }
.section[style] .section-title,
.hero[style] h1,
.page-hero[style] h1 { color: var(--evgo-title-color); }
.section[style] .section-sub,
.section[style] .service-card p,
.section[style] .blog-card p,
.section[style] .value-card p,
.section[style] .process-card p,
.section[style] .service-detail-card p,
.section[style] .contact-card span,
.section[style] .feature-item,
.hero[style] .hero-sub,
.page-hero[style] p { color: var(--evgo-text-color); }
.section[style] .service-card i,
.section[style] .where-grid i,
.section[style] .section-eyebrow,
.hero[style] .hero-eyebrow,
.page-hero[style] .hero-eyebrow,
.hero[style] .hero-stats strong { color: var(--green); }
.section[style] .service-card,
.section[style] .blog-card,
.section[style] .value-card,
.section[style] .process-card,
.section[style] .service-detail-card,
.section[style] .contact-card,
.section[style] .where-grid span { background: var(--evgo-card-bg); }
.section[style] .service-card h3,
.section[style] .blog-card h3,
.section[style] .value-card h3,
.section[style] .process-card h3,
.section[style] .service-detail-card h3,
.section[style] .contact-card strong,
.section[style] .where-grid span { color: var(--evgo-card-title); }
.section[style] .service-card p,
.section[style] .blog-card p,
.section[style] .value-card p,
.section[style] .process-card p,
.section[style] .service-detail-card p,
.section[style] .contact-card span { color: var(--evgo-card-text); }
.section[style] .service-card i,
.section[style] .quick-info-card i,
.section[style] .where-grid i,
.section[style] .blog-card span,
.section[style] .blog-card a,
.section[style] .value-card i,
.section[style] .process-card span,
.section[style] .service-detail-card i,
.section[style] .contact-card i,
.section[style] .feature-item i,
.hero[style] .hero-stats strong { color: var(--evgo-card-icon); }
.section[style] .btn-green,
.hero[style] .btn-green,
.page-hero[style] .btn-green { background: var(--evgo-button-bg); color: var(--evgo-button-text); }
.section[style] .lead-form { background: var(--evgo-form-bg); color: var(--evgo-form-text); }
.section[style] .lead-form h3,
.section[style] .lead-form p,
.section[style] .lead-form .form-check { color: var(--evgo-form-text); }
.section[style] .lead-form input,
.section[style] .lead-form select,
.section[style] .lead-form textarea { background: var(--evgo-field-bg); color: var(--evgo-field-text); }
.section[style] .lead-form input::placeholder,
.section[style] .lead-form textarea::placeholder { color: color-mix(in srgb, var(--evgo-field-text) 62%, transparent); }
.section[style] .lead-form .btn-primary { background: var(--evgo-form-button-bg); color: var(--evgo-form-button-text); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; }
.align-center { align-items: center; }
.align-start { align-items: start; }

.about, .services, .blog { background: var(--navy); }
.about-card { position: relative; border-radius: var(--radius-lg); overflow: hidden; min-height: 460px; box-shadow: 0 30px 80px rgba(0,0,0,.36); }
.about-card img { width: 100%; height: 100%; object-fit: cover; }
.floating-badge { position: absolute; left: 22px; bottom: 22px; padding: 16px 18px; background: rgba(11,16,28,.88); border: 1px solid rgba(78,208,36,.3); border-radius: 16px; backdrop-filter: blur(12px); }
.floating-badge strong { display: block; color: var(--green); font-size: 24px; font-family: 'Space Grotesk', sans-serif; }
.floating-badge span { display: block; font-size: 12px; color: rgba(255,255,255,.65); }
.feature-list { display: flex; flex-direction: column; gap: 16px; margin-top: 36px; }
.feature-item { display: flex; gap: 12px; align-items: center; color: rgba(255,255,255,.84); font-size: 15px; }
.feature-item i { color: var(--green); }

.services, .where, .contact { background: var(--navy2); }
.cards-grid { display: grid; gap: 16px; margin-top: 56px; }
.services-grid { grid-template-columns: repeat(3, 1fr); }
.service-card, .blog-card {
  background: var(--navy-mid);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: var(--radius);
  padding: 32px 28px;
  transition: all .25s;
  position: relative;
  overflow: hidden;
}
.service-card::before, .blog-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(78,208,36,0.08) 0%, transparent 60%);
  opacity: 0; transition: opacity .25s;
}
.service-card:hover, .blog-card:hover { border-color: rgba(78,208,36,.35); transform: translateY(-5px); }
.service-card:hover::before, .blog-card:hover::before { opacity: 1; }
.service-card i { color: var(--green); font-size: 26px; margin-bottom: 22px; position: relative; }
.service-card h3, .blog-card h3 { position: relative; font-family: 'Space Grotesk', sans-serif; font-size: 20px; margin-bottom: 10px; }
.service-card p, .blog-card p { position: relative; color: rgba(255,255,255,.58); line-height: 1.62; font-size: 14px; }

#respostas-evgo {
  background:
    linear-gradient(180deg, rgba(11,16,28,.12), rgba(78,208,36,.035) 48%, rgba(11,16,28,.08));
}
.quick-info-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 34px;
}
.quick-info-card {
  min-height: 270px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 28px;
}
.quick-info-card i {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 22px;
  border-radius: 16px;
  color: var(--green);
  background: rgba(78,208,36,.10);
  border: 1px solid rgba(78,208,36,.20);
  font-size: 22px;
}
.quick-info-card h3 {
  min-height: 50px;
  display: flex;
  align-items: flex-end;
  margin-bottom: 12px;
}
.quick-info-card p {
  margin-top: auto;
  color: rgba(255,255,255,.66);
}

.franchise { background: linear-gradient(135deg, var(--navy) 0%, #101a2e 60%, #0c2317 100%); position: relative; overflow: hidden; }
.franchise::before { content:''; position:absolute; right:-160px; top:-160px; width:500px; height:500px; background: radial-gradient(circle, rgba(78,208,36,.13), transparent 70%); }
.lead-form {
  background: rgba(11,16,28,0.92);
  border: 1px solid rgba(78,208,36,0.25);
  border-radius: var(--radius-lg);
  padding: 34px;
  box-shadow: 0 32px 80px rgba(0,0,0,0.45), 0 0 0 1px rgba(78,208,36,0.08);
  position: relative;
}
.lead-form h3 { font-family: 'Space Grotesk', sans-serif; font-size: 24px; margin-bottom: 6px; }
.lead-form p { font-size: 13px; color: rgba(255,255,255,0.55); margin-bottom: 24px; line-height: 1.5; }
.form-row { display: grid; grid-template-columns: 1fr 110px; gap: 12px; }
.form-row.location-row { grid-template-columns: 150px minmax(0, 1fr); }
.form-group { margin-bottom: 12px; }
.form-group input, .form-group select, .form-group textarea {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-sm);
  padding: 13px 14px;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--white);
  outline: none;
  transition: border-color .2s;
}
.form-group input::placeholder { color: rgba(255,255,255,0.35); }
.form-group input:focus, .form-group select:focus { border-color: var(--green); background: rgba(78,208,36,0.06); }
.form-group select option { background: var(--navy); }
.phone-field {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: border-color .2s, background .2s;
}
.phone-field:focus-within {
  border-color: var(--green);
  background: rgba(78,208,36,0.06);
}
.phone-field:has(input.is-invalid) {
  border-color: rgba(255,93,93,.88);
  background: rgba(255,93,93,.08);
}
.form-group input.is-invalid {
  border-color: rgba(255,93,93,.88);
  background: rgba(255,93,93,.08);
}
.phone-prefix {
  display: inline-flex;
  align-items: center;
  align-self: stretch;
  padding: 0 12px;
  border-right: 1px solid rgba(255,255,255,.10);
  color: var(--green);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .3px;
  background: rgba(78,208,36,.08);
}
.form-group .phone-field input {
  border: 0;
  border-radius: 0;
  background: transparent;
  padding-left: 12px;
}
.form-group .phone-field input:focus {
  border-color: transparent;
  background: transparent;
}
.form-check { display: flex; align-items: flex-start; gap: 10px; margin: 4px 0 18px; cursor: pointer; }
.form-check input { margin-top: 2px; accent-color: var(--green); flex-shrink: 0; }
.form-check span { font-size: 11px; color: rgba(255,255,255,0.48); line-height: 1.55; }
.btn-primary { width: 100%; background: var(--green); color: var(--navy); border: 0; border-radius: var(--radius-sm); padding: 15px 20px; font-weight: 800; font-size: 15px; cursor: pointer; transition: all .2s ease; }
.btn-primary:hover { background: var(--green2); transform: translateY(-2px); box-shadow: 0 12px 30px rgba(78,208,36,0.35); }

.where-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; margin-top: 46px; }
.where-grid span { background: var(--navy-mid); border: 1px solid rgba(255,255,255,.06); border-radius: var(--radius-sm); padding: 18px 12px; display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; color: rgba(255,255,255,.72); font-size: 13px; transition: all .2s; }
.where-grid span:hover { background: rgba(78,208,36,.1); border-color: rgba(78,208,36,.36); color: var(--white); }
.where-grid i { color: var(--green); font-size: 21px; }

.blog-grid { grid-template-columns: repeat(3, 1fr); }
.blog-card span { position: relative; display: inline-block; color: var(--green); font-size: 11px; text-transform: uppercase; letter-spacing: 1.6px; font-weight: 800; margin-bottom: 16px; }
.blog-card a { position: relative; display: inline-flex; align-items: center; gap: 8px; margin-top: 20px; color: var(--green); font-weight: 700; text-decoration: none; font-size: 14px; }

.contact-list { display: flex; flex-direction: column; gap: 12px; margin-top: 36px; }
.contact-list a { text-decoration: none; color: rgba(255,255,255,.72); font-weight: 600; display: inline-flex; align-items: center; gap: 12px; }
.contact-list a:hover { color: var(--green); }
.contact-list i { color: var(--green); }

/* RODAPÉ */
.site-footer { background: #080d18; border-top: 1px solid rgba(255,255,255,.06); padding: 64px 0 30px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1.25fr 1.35fr; gap: 48px; }
.footer-brand img { height: 36px; margin-bottom: 18px; }
.footer-brand p { max-width: 330px; font-size: 13px; color: rgba(255,255,255,.48); line-height: 1.7; }
.footer-app-coming {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}
.footer-app-coming span {
  color: rgba(255,255,255,.72);
  font-size: 13px;
  font-weight: 800;
}
.footer-app-coming img {
  width: min(100%, 260px);
  height: auto;
  margin: 0;
  display: block;
}
.footer-social { display: flex; gap: 10px; margin-top: 22px; }
.footer-social a { width: 38px; height: 38px; border-radius: 10px; background: rgba(255,255,255,.06); display: inline-flex; align-items: center; justify-content: center; text-decoration: none; color: rgba(255,255,255,.62); transition: all .2s; }
.footer-social a:hover { background: rgba(78,208,36,.16); color: var(--green); }
.footer-col h4 { font-size: 12px; color: rgba(255,255,255,.4); text-transform: uppercase; letter-spacing: 1.6px; margin-bottom: 16px; }
.footer-col a { display: block; color: rgba(255,255,255,.62); text-decoration: none; font-size: 14px; margin-bottom: 10px; line-height: 1.45; }
.footer-col a:hover { color: var(--green); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.06); margin-top: 44px; padding-top: 22px; display: flex; align-items: center; justify-content: space-between; gap: 20px; color: rgba(255,255,255,.35); font-size: 12px; }
.footer-bottom div { display: flex; gap: 18px; }
.footer-bottom a { text-decoration: none; color: rgba(255,255,255,.42); }
.footer-bottom a:hover { color: var(--green); }

.wa-fab { position: fixed; right: 22px; bottom: 22px; z-index: 1001; width: 58px; height: 58px; border-radius: 50%; background: #25D366; color: #fff; display: inline-flex; align-items: center; justify-content: center; text-decoration: none; font-size: 28px; box-shadow: 0 16px 40px rgba(0,0,0,.35); transition: transform .2s ease; }
.wa-fab:hover { transform: translateY(-3px) scale(1.03); }

.fade-in { opacity: 0; transform: translateY(30px); transition: opacity .7s ease, transform .7s ease; }
.fade-in.visible { opacity: 1; transform: none; }

@media (max-width: 1120px) {
  .main-menu, .header-actions { display: none; }
  .menu-toggle { display: block; }
  .topbar { min-height: 74px; }
  .site-header.menu-open .main-menu,
  .site-header.menu-open .header-actions {
    display: flex;
  }
  .site-header.menu-open .main-menu {
    position: absolute;
    top: 74px; left: 0; right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: rgba(11,16,28,.98);
    border-top: 1px solid rgba(255,255,255,.06);
    padding: 12px 24px;
  }
  .site-header.menu-open .main-menu a { padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,.06); }
  .site-header.menu-open .menu-dropdown { display: block; border-bottom: 1px solid rgba(255,255,255,.06); }
  .site-header.menu-open .menu-dropdown-toggle { width: 100%; padding: 14px 0; justify-content: space-between; color: rgba(255,255,255,.74); }
  .site-header.menu-open .menu-dropdown-panel { position: static; min-width: 0; transform: none; opacity: 1; visibility: visible; pointer-events: auto; box-shadow: none; border: 0; border-radius: 12px; background: rgba(255,255,255,.04); padding: 4px 10px 10px; margin-bottom: 6px; }
  .site-header.menu-open .menu-dropdown-panel a { border-bottom: 0; padding: 11px 10px; }
  .site-header.menu-open .header-actions { position: absolute; top: 392px; left: 24px; right: 24px; flex-direction: column; align-items: stretch; background: rgba(11,16,28,.98); padding: 0 0 22px; }
  .grid-2, .services-grid, .blog-grid, .footer-grid { grid-template-columns: 1fr 1fr; }
  .quick-info-grid { grid-template-columns: 1fr 1fr; }
  .quick-info-card { min-height: 245px; }
  .where-grid { grid-template-columns: repeat(3, 1fr); }
  .hero h1 { font-size: clamp(38px, 8vw, 64px); }
  .hero-content { margin-left: 24px; }
}

@media (max-width: 700px) {
  .container, .topbar, .hero-content { width: min(100% - 34px, 1180px); }
  .logo { height: 38px; }
  .hero-media { padding: 120px 0 70px; min-height: 92vh; }
  .hero-overlay { background: linear-gradient(90deg, rgba(11,16,28,.96), rgba(11,16,28,.78)); }
  .hero h1 { letter-spacing: -1.2px; }
  .hero-buttons, .hero-stats { flex-direction: column; align-items: stretch; }
  .btn-lg { width: 100%; }
  .section { padding: 72px 0; }
  .grid-2, .services-grid, .blog-grid, .footer-grid, .where-grid, .quick-info-grid { grid-template-columns: 1fr; }
  .quick-info-grid { gap: 14px; }
  .quick-info-card { min-height: auto; padding: 24px; }
  .quick-info-card h3 { min-height: auto; }
  .quick-info-card p { margin-top: 0; }
  .form-row, .form-row.location-row { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
  .footer-bottom div { flex-direction: column; gap: 8px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .fade-in { opacity: 1 !important; transform: none !important; }
}


/* BOTÕES E LINKS ESPECIAIS */
button.btn { font-family: 'Inter', sans-serif; }
.footer-col a[data-open-modal], .footer-bottom a[data-open-modal], .footer-social a[data-open-whatsapp] { cursor: pointer; }

/* MODAIS */
.modal-lock { overflow: hidden; }
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(3,7,14,.78);
  backdrop-filter: blur(12px);
}
.modal-overlay[hidden] { display: none; }
.modal-box {
  width: min(100%, 460px);
  max-height: min(90vh, 760px);
  overflow: auto;
  background: rgba(11,16,28,.98);
  border: 1px solid rgba(78,208,36,.24);
  border-radius: var(--radius-lg);
  padding: 34px;
  box-shadow: 0 40px 100px rgba(0,0,0,.62), 0 0 0 1px rgba(78,208,36,.06);
  position: relative;
}
.modal-legal { width: min(100%, 760px); }
.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.78);
  cursor: pointer;
  transition: all .2s ease;
}
.modal-close:hover { color: var(--green); border-color: rgba(78,208,36,.42); background: rgba(78,208,36,.08); }
.modal-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: rgba(78,208,36,.12);
  border: 1px solid rgba(78,208,36,.24);
  color: var(--green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  margin-bottom: 18px;
}
.modal-box h2 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 28px;
  line-height: 1.12;
  margin-bottom: 8px;
}
.modal-subtitle { color: rgba(255,255,255,.58); font-size: 14px; line-height: 1.6; margin-bottom: 24px; }
.modal-login-portal {
  width: min(100%, 1040px);
  height: min(88vh, 760px);
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.modal-login-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-right: 48px;
}
.modal-login-head .modal-icon {
  flex: 0 0 auto;
  margin: 0;
}
.modal-login-head .modal-subtitle {
  margin-bottom: 0;
}
.login-portal-card {
  display: grid;
  gap: 16px;
  place-items: center;
  text-align: center;
  flex: 1 1 auto;
  min-height: 320px;
  padding: 42px 28px;
  border: 1px solid rgba(78,208,36,.20);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(78,208,36,.10), rgba(255,255,255,.04));
}
.login-portal-card i {
  display: grid;
  place-items: center;
  width: 68px;
  height: 68px;
  border-radius: 20px;
  color: var(--green);
  background: rgba(78,208,36,.12);
  border: 1px solid rgba(78,208,36,.26);
  font-size: 28px;
}
.login-portal-card p {
  max-width: 420px;
  color: rgba(255,255,255,.68);
  font-size: 15px;
  line-height: 1.65;
}
.login-portal-card .btn-primary {
  max-width: 320px;
}
.login-portal-fallback {
  margin: 0;
  color: rgba(255,255,255,.58);
  font-size: 12px;
  line-height: 1.5;
}
.login-portal-fallback a {
  color: var(--green);
  font-weight: 700;
  text-decoration: none;
}
.login-portal-fallback a:hover {
  text-decoration: underline;
}
.modal-form { margin-top: 10px; }
.login-row { display: flex; justify-content: flex-end; margin: 6px 0 18px; }
.forgot-link { color: var(--green); font-size: 13px; font-weight: 700; text-decoration: none; }
.forgot-link:hover { text-decoration: underline; }
.sac-modal-box {
  width: min(100%, 980px);
  padding: 28px;
}
.sac-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: start;
  padding-right: 48px;
  margin-bottom: 18px;
}
.sac-head .modal-icon { margin: 0; }
.sac-form { display: grid; gap: 16px; }
.sac-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.sac-routing {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  background: rgba(255,255,255,.035);
}
.sac-option {
  display: block;
  cursor: pointer;
}
.sac-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.sac-option span {
  min-height: 100%;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas:
    "icon title"
    "icon copy";
  column-gap: 12px;
  row-gap: 3px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(11,16,28,.70);
  transition: border-color .2s ease, background .2s ease, transform .2s ease;
}
.sac-option i {
  grid-area: icon;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  color: var(--green);
  background: rgba(78,208,36,.10);
  border: 1px solid rgba(78,208,36,.18);
}
.sac-option strong {
  grid-area: title;
  color: var(--white);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 15px;
  line-height: 1.2;
}
.sac-option small {
  grid-area: copy;
  color: rgba(255,255,255,.56);
  font-size: 12px;
  line-height: 1.45;
}
.sac-option:hover span {
  border-color: rgba(78,208,36,.28);
  background: rgba(78,208,36,.06);
  transform: translateY(-1px);
}
.sac-option input:checked + span {
  border-color: rgba(78,208,36,.62);
  background: linear-gradient(135deg, rgba(78,208,36,.16), rgba(255,255,255,.045));
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
}
.sac-option.priority input:checked + span {
  border-color: rgba(255,196,87,.66);
}
.sac-grid-bottom {
  grid-template-columns: 1fr 180px;
  align-items: stretch;
}
.sac-priority {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  min-height: 54px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(78,208,36,.20);
  background: rgba(78,208,36,.08);
}
.sac-priority span {
  color: rgba(255,255,255,.52);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.sac-priority strong {
  color: var(--green);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 20px;
}
.sac-priority strong[data-priority="alta"] { color: #ffc457; }
.sac-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  width: min(100%, 320px);
}
.modal-legal h3 {
  font-family: 'Space Grotesk', sans-serif;
  color: var(--green);
  font-size: 17px;
  margin: 22px 0 8px;
}
.modal-legal p { color: rgba(255,255,255,.66); font-size: 14px; line-height: 1.72; }

/* WHATSAPP MODAL CANTO */
.wa-fab {
  border: 0;
  cursor: pointer;
}
.whatsapp-panel {
  position: fixed;
  right: 22px;
  bottom: 92px;
  z-index: 2500;
  width: min(370px, calc(100vw - 32px));
  background: rgba(11,16,28,.98);
  border: 1px solid rgba(78,208,36,.28);
  border-radius: 24px;
  box-shadow: 0 28px 80px rgba(0,0,0,.52);
  overflow: hidden;
}
.whatsapp-panel[hidden] { display: none; }
.whatsapp-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 22px;
  background: linear-gradient(135deg, rgba(78,208,36,.20), rgba(78,208,36,.05));
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.whatsapp-panel-head strong { display: block; font-family: 'Space Grotesk', sans-serif; font-size: 20px; color: var(--white); }
.whatsapp-panel-head span { display: block; margin-top: 5px; color: rgba(255,255,255,.62); font-size: 12px; line-height: 1.45; }
.whatsapp-panel-head button {
  width: 34px;
  height: 34px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.78);
  cursor: pointer;
}
.whatsapp-form { padding: 20px 22px 22px; }
.whatsapp-form .btn-primary { display: inline-flex; align-items: center; justify-content: center; gap: 8px; }

.form-submit-alert {
  display: grid;
  gap: 3px;
  margin: 2px 0 12px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid transparent;
  font-size: 13px;
  line-height: 1.35;
}

.form-submit-alert strong {
  font-size: 13px;
  font-weight: 800;
}

.form-submit-alert span {
  color: inherit;
  opacity: .86;
}

.form-submit-alert.is-success {
  border-color: rgba(69, 210, 37, .42);
  background: rgba(69, 210, 37, .12);
  color: #d9ffd0;
}

.contact-form .form-submit-alert.is-success {
  color: #145c22;
}

.form-submit-alert.is-error {
  border-color: rgba(239, 68, 68, .42);
  background: rgba(239, 68, 68, .12);
  color: #ffd7d7;
}

.contact-form .form-submit-alert.is-error {
  color: #991b1b;
}

/* COOKIE BANNER */
.cookie-banner {
  position: fixed;
  left: 22px;
  right: 22px;
  bottom: 22px;
  z-index: 2400;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  width: min(1120px, calc(100% - 44px));
  margin: 0 auto;
  background: rgba(8,13,24,.97);
  border: 1px solid rgba(78,208,36,.24);
  border-radius: 22px;
  padding: 18px 20px;
  box-shadow: 0 22px 70px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
}
.cookie-banner[hidden] { display: none; }
.cookie-copy strong { display: block; font-family: 'Space Grotesk', sans-serif; color: var(--green); font-size: 17px; margin-bottom: 4px; }
.cookie-copy p { font-size: 12px; line-height: 1.55; color: rgba(255,255,255,.58); max-width: 720px; }
.cookie-copy a { color: var(--green); font-weight: 700; text-decoration: none; }
.cookie-copy a:hover { text-decoration: underline; }
.cookie-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.cookie-actions .btn { border: 0; font-family: 'Inter', sans-serif; padding: 10px 18px; }
.cookie-actions .btn-outline { border: 1px solid rgba(255,255,255,.16); }

@media (max-width: 700px) {
  .modal-box { padding: 28px 22px; border-radius: 24px; }
  .modal-login-portal { width: calc(100% - 18px); height: 88vh; padding: 18px; }
  .modal-login-head { align-items: flex-start; padding-right: 44px; }
  .modal-login-head .modal-icon { width: 48px; height: 48px; border-radius: 14px; }
  .login-portal-card { min-height: 300px; padding: 34px 20px; border-radius: 14px; }
  .modal-box h2 { font-size: 24px; }
  .sac-modal-box { padding: 22px; }
  .sac-head { grid-template-columns: 1fr; padding-right: 42px; }
  .sac-grid, .sac-routing, .sac-grid-bottom { grid-template-columns: 1fr; }
  .sac-option span { grid-template-columns: 1fr; grid-template-areas: "icon" "title" "copy"; }
  .sac-submit { width: 100%; }
  .whatsapp-panel { right: 16px; bottom: 86px; }
  .cookie-banner { flex-direction: column; align-items: stretch; left: 16px; right: 16px; bottom: 16px; width: auto; }
  .cookie-actions { flex-direction: column; align-items: stretch; }
  .cookie-actions .btn { width: 100%; }
  .wa-fab { right: 16px; bottom: 16px; }
}


/* =========================
   PÁGINAS INTERNAS EVGO
   ========================= */
.main-menu a.active { color: var(--green); }
.section-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 34px; }
.section-actions.center { justify-content: center; }
.page-text { margin-top: 18px; color: rgba(255,255,255,.62); line-height: 1.75; font-size: 16px; max-width: 680px; }
.page-hero {
  min-height: 62vh;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 150px 0 80px;
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}
.page-hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(90deg, rgba(11,16,28,.98) 0%, rgba(11,16,28,.78) 44%, rgba(11,16,28,.45) 100%), linear-gradient(0deg, rgba(11,16,28,.82) 0%, transparent 55%);
}
.page-hero-content { position: relative; z-index: 2; }
.page-hero h1 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.02;
  letter-spacing: -2px;
  max-width: 920px;
  margin-bottom: 22px;
}
.page-hero p { max-width: 720px; color: rgba(255,255,255,.72); font-size: 18px; line-height: 1.7; }
.page-image { border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 30px 90px rgba(0,0,0,.38); min-height: 460px; }
.page-image img { width: 100%; height: 100%; min-height: 460px; object-fit: cover; }
.values-section, .process-section, .contact-support { background: var(--navy2); }
.value-card, .process-card, .service-detail-card, .article-card, .contact-card {
  background: var(--navy-mid);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius);
  padding: 30px 28px;
  position: relative;
  overflow: hidden;
  transition: all .25s ease;
}
.value-card:hover, .process-card:hover, .service-detail-card:hover, .article-card:hover, .contact-card:hover {
  border-color: rgba(78,208,36,.34);
  transform: translateY(-4px);
}
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 52px; }
.value-card i { color: var(--green); font-size: 28px; margin-bottom: 20px; }
.value-card h3, .process-card h3, .service-detail-card h3, .article-card h3, .contact-card strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 21px;
  margin-bottom: 10px;
  display: block;
}
.value-card p, .process-card p, .service-detail-card p, .article-card p, .contact-card span { color: rgba(255,255,255,.60); line-height: 1.65; font-size: 14px; }
.service-detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 56px; }
.service-detail-card { min-height: 310px; display: flex; flex-direction: column; justify-content: space-between; gap: 24px; }
.service-detail-card i { color: var(--green); font-size: 30px; margin-bottom: 20px; }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 56px; }
.process-card span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: rgba(78,208,36,.12);
  border: 1px solid rgba(78,208,36,.24);
  color: var(--green);
  font-weight: 900;
  margin-bottom: 20px;
}
.cta-band { background: linear-gradient(135deg, var(--navy) 0%, #101a2e 60%, #0c2317 100%); text-align: center; }
.cta-band-inner { max-width: 850px; }
.cta-band h2 { font-family: 'Space Grotesk', sans-serif; font-size: clamp(32px, 4vw, 54px); line-height: 1.05; margin-bottom: 16px; }
.cta-band p { color: rgba(255,255,255,.65); font-size: 17px; line-height: 1.7; margin-bottom: 28px; }
.cta-band .hero-buttons { justify-content: center; margin-bottom: 0; }
.blog-filters { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 42px; }
.blog-filters span {
  border: 1px solid rgba(78,208,36,.22);
  background: rgba(78,208,36,.08);
  color: rgba(255,255,255,.78);
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
}
.article-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.article-card span { display: inline-block; color: var(--green); font-weight: 800; font-size: 11px; letter-spacing: 1.4px; text-transform: uppercase; margin-bottom: 14px; }
.article-card a, .blog-card a { display: inline-flex; align-items: center; gap: 8px; margin-top: 22px; color: var(--green); text-decoration: none; font-weight: 800; font-size: 14px; position: relative; }
.article-image { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: 14px; margin-bottom: 20px; position: relative; }
.article-body { max-width: 860px; margin: 0 auto; color: rgba(255,255,255,.74); font-size: 17px; line-height: 1.85; }
.article-body h2, .article-body h3 { color: var(--white); font-family: 'Space Grotesk', sans-serif; margin: 34px 0 12px; line-height: 1.2; }
.article-body p, .article-body ul, .article-body ol { margin-bottom: 18px; }
.article-body ul, .article-body ol { padding-left: 24px; }
.article-body a { color: var(--green); font-weight: 800; }
.page-charge-map .site-header .btn-primary { width: auto; }
.charge-hero .page-hero-content { max-width: 930px; }
.charge-hero-stats { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 34px; }
.charge-hero-stats span { display: inline-flex; align-items: center; gap: 10px; min-height: 54px; border: 1px solid rgba(78,208,36,.22); background: rgba(11,16,28,.66); color: rgba(255,255,255,.66); border-radius: 16px; padding: 12px 16px; font-size: 13px; font-weight: 700; backdrop-filter: blur(12px); }
.charge-hero-stats strong { color: var(--green); font-family: 'Space Grotesk', sans-serif; font-size: 22px; line-height: 1; }
.charge-map-section { background: radial-gradient(circle at 18% 0%, rgba(78,208,36,.10), transparent 34%), var(--navy2); }
.charge-search-panel { display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, 500px); gap: 34px; align-items: end; border: 1px solid rgba(78,208,36,.18); background: linear-gradient(135deg, rgba(19,27,46,.92), rgba(9,14,25,.96)); border-radius: var(--radius-lg); padding: 34px; box-shadow: 0 28px 90px rgba(0,0,0,.34); margin-bottom: 42px; }
.charge-search-panel h2 { font-family: 'Space Grotesk', sans-serif; font-size: clamp(28px, 3vw, 44px); line-height: 1.08; letter-spacing: -1px; max-width: 710px; }
.charge-search-panel p:not(.section-eyebrow) { color: rgba(255,255,255,.62); line-height: 1.7; margin-top: 12px; max-width: 650px; }
.charge-search { min-width: 0; }
.charge-search label { display: block; color: rgba(255,255,255,.52); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.4px; margin-bottom: 10px; }
.charge-search-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; min-height: 60px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.055); border-radius: 18px; padding: 7px 8px 7px 16px; }
.charge-search-row > i { color: var(--green); font-size: 18px; }
.charge-search input { min-width: 0; width: 100%; border: 0; background: transparent; color: var(--white); font: inherit; outline: none; }
.charge-search input::placeholder { color: rgba(255,255,255,.38); }
.charge-search button { height: 46px; border: 0; border-radius: 14px; background: var(--green); color: var(--navy); padding: 0 18px; font-weight: 900; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.charge-search button:hover { background: var(--green2); }
.google-map-panel { display: grid; grid-template-columns: minmax(280px, 390px) minmax(0, 1fr); gap: 18px; align-items: stretch; margin-bottom: 42px; border: 1px solid rgba(255,255,255,.07); background: rgba(19,27,46,.72); border-radius: var(--radius-lg); padding: 18px; box-shadow: 0 28px 90px rgba(0,0,0,.30); }
.google-map-copy { padding: 18px 16px; }
.google-map-copy h2 { font-family: 'Space Grotesk', sans-serif; font-size: clamp(26px, 2.7vw, 38px); line-height: 1.08; letter-spacing: -1px; margin-bottom: 12px; }
.google-map-copy p:not(.section-eyebrow) { color: rgba(255,255,255,.62); line-height: 1.7; font-size: 14px; }
.google-map-status { margin-top: 20px; border: 1px solid rgba(78,208,36,.22); background: rgba(78,208,36,.08); color: rgba(255,255,255,.78); border-radius: 14px; padding: 12px 14px; font-size: 13px; font-weight: 800; line-height: 1.45; }
.google-map-canvas { min-height: 460px; border-radius: 24px; overflow: hidden; background: #0f172a; border: 1px solid rgba(255,255,255,.08); }
.gm-style .gm-style-iw-c,
.gm-style .gm-style-iw-d { color: #17202A; }
.gm-style .gm-style-iw-d { overflow: auto !important; }
.gm-style .evgo-map-info { min-width: 190px; max-width: 260px; color: #17202A; font-family: 'Inter', Arial, sans-serif; line-height: 1.45; }
.gm-style .evgo-map-info strong { display: block; color: #0B101C; font-family: 'Space Grotesk', Arial, sans-serif; font-size: 15px; margin-bottom: 5px; }
.gm-style .evgo-map-info span { display: block; color: #5A6572; font-size: 12px; margin-bottom: 10px; }
.gm-style .evgo-map-info a { color: #2d9f12; font-size: 12px; font-weight: 900; text-decoration: none; }
.gm-style .evgo-map-info a:hover { text-decoration: underline; }
.charge-results-head { display: flex; align-items: end; justify-content: space-between; gap: 20px; margin-bottom: 22px; }
.charge-results-head h2 { font-family: 'Space Grotesk', sans-serif; font-size: clamp(26px, 3vw, 40px); letter-spacing: -1px; line-height: 1.1; }
.charge-results-head span { border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.04); border-radius: 999px; color: rgba(255,255,255,.55); padding: 10px 13px; font-size: 12px; font-weight: 800; white-space: nowrap; }
.charge-empty-state { display: flex; gap: 18px; align-items: flex-start; border: 1px solid rgba(78,208,36,.22); background: rgba(78,208,36,.08); border-radius: var(--radius); padding: 24px; color: rgba(255,255,255,.72); line-height: 1.7; }
.charge-empty-state > i { width: 46px; height: 46px; display: inline-flex; align-items: center; justify-content: center; border-radius: 14px; background: rgba(78,208,36,.14); color: var(--green); flex: 0 0 auto; }
.charge-empty-state strong { color: var(--white); display: block; margin-bottom: 4px; font-family: 'Space Grotesk', sans-serif; font-size: 20px; }
.fleet-search-row { grid-template-columns: 70px 1fr auto; }
.fleet-result { display: flex; gap: 18px; align-items: flex-start; border: 1px solid rgba(78,208,36,.20); background: rgba(19,27,46,.86); border-radius: var(--radius); padding: 24px; color: rgba(255,255,255,.72); line-height: 1.7; }
.fleet-result > i { width: 48px; height: 48px; display: inline-flex; align-items: center; justify-content: center; border-radius: 16px; background: rgba(78,208,36,.14); color: var(--green); flex: 0 0 auto; }
.fleet-result strong { color: var(--white); font-family: 'Space Grotesk', sans-serif; }
.fleet-result p { margin: 4px 0 10px; }
.fleet-result ul { margin: 8px 0 0; padding-left: 18px; color: rgba(255,255,255,.68); }
.charge-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.charge-card { background: linear-gradient(180deg, rgba(19,27,46,.98), rgba(13,20,34,.98)); border: 1px solid rgba(255,255,255,.07); border-radius: var(--radius); padding: 26px; transition: all .25s ease; box-shadow: 0 18px 50px rgba(0,0,0,.18); position: relative; overflow: hidden; }
.charge-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(78,208,36,.10), transparent 58%); opacity: 0; transition: opacity .25s ease; pointer-events: none; }
.charge-card:hover { border-color: rgba(78,208,36,.34); transform: translateY(-5px); box-shadow: 0 26px 70px rgba(0,0,0,.30); }
.charge-card:hover::before { opacity: 1; }
.charge-card > * { position: relative; }
.charge-card-top { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 18px; }
.charge-card-top span { color: var(--green); font-weight: 900; font-size: 11px; letter-spacing: 1.4px; text-transform: uppercase; }
.charge-card-top i { width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; border-radius: 14px; background: rgba(78,208,36,.12); color: var(--green); }
.charge-card h3 { font-family: 'Space Grotesk', sans-serif; font-size: 22px; line-height: 1.18; margin-bottom: 14px; }
.charge-card p { color: rgba(255,255,255,.60); line-height: 1.6; font-size: 14px; margin-bottom: 8px; }
.charge-town { display: inline-flex; align-items: center; gap: 8px; }
.charge-town i { color: var(--green); }
.charge-meta { display: flex; gap: 10px; flex-wrap: wrap; margin: 20px 0; }
.charge-meta span { border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.04); color: rgba(255,255,255,.72); border-radius: 999px; padding: 8px 10px; font-size: 12px; font-weight: 800; }
.charge-meta i { color: var(--green); }
.charge-card ul { padding-left: 18px; color: rgba(255,255,255,.62); font-size: 13px; line-height: 1.7; margin: 0 0 22px; }
.charge-card a { display: inline-flex; align-items: center; gap: 8px; color: var(--green); text-decoration: none; font-weight: 900; font-size: 14px; }
.contact-info-grid { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 34px; }
.contact-card { display: flex; flex-direction: column; text-decoration: none; gap: 2px; }
.contact-card i { color: var(--green); font-size: 24px; margin-bottom: 12px; }
.form-group textarea { resize: vertical; min-height: 130px; }
body.page-sobre .about-page, body.page-blog .blog-page, body.page-contato .contact-page { background: var(--navy); }

@media (max-width: 1120px) {
  .values-grid, .article-grid, .charge-grid { grid-template-columns: repeat(2, 1fr); }
  .charge-search-panel, .google-map-panel { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .service-detail-grid { grid-template-columns: 1fr; }
}

@media (max-width: 700px) {
  .page-hero { min-height: auto; padding: 128px 0 72px; }
  .page-hero h1 { letter-spacing: -1.2px; }
  .values-grid, .process-grid, .article-grid, .charge-grid { grid-template-columns: 1fr; }
  .charge-search-panel { padding: 22px; border-radius: 22px; }
  .charge-search-row { grid-template-columns: auto 1fr; }
  .fleet-search-row { grid-template-columns: 1fr; }
  .charge-search-row button { grid-column: 1 / -1; width: 100%; }
  .google-map-panel { padding: 12px; border-radius: 22px; }
  .google-map-canvas { min-height: 360px; border-radius: 18px; }
  .charge-results-head { align-items: flex-start; flex-direction: column; }
  .charge-hero-stats { flex-direction: column; }
  .section-actions { flex-direction: column; align-items: stretch; }
  .section-actions .btn { width: 100%; }
  .page-image, .page-image img { min-height: 320px; }
}
