@charset "UTF-8";
/* ============================================
   Fontes locais - Menda (títulos) e Grift (UI e corpo)
   ============================================ */
@font-face {
  font-family: "griftmedium";
  src: url("../fonts/grift-medium-webfont.woff2") format("woff2"), url("../fonts/grift-medium-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "griftregular";
  src: url("../fonts/grift-regular-webfont.woff2") format("woff2"), url("../fonts/grift-regular-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "mendabold";
  src: url("../fonts/menda_bold-webfont.woff2") format("woff2"), url("../fonts/menda_bold-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
/* ============================================
   GB Topografia - Variables & Base (Figma)
   Figma: Marrom, Laranja Principal, Amarelo Queimado,
   Verde escuro, Verde Médio, Verde claro, Bege Escuro, Bege Claro, Chumbo
   ============================================ */
:root {
  /* Cores do projeto (Figma) */
  --color-brown: #a35239; /* Marrom */
  --color-orange: #f0531c; /* Laranja Principal */
  --color-burnt-yellow: #eda35f; /* Amarelo Queimado */
  --color-green-dark: #0a332d; /* Verde escuro */
  --color-green-medium: #2f4b3c; /* Verde Médio */
  --color-green-light: #3e635e; /* Verde claro */
  --color-beige-dark: #f7dfb9; /* Bege Escuro */
  --color-beige-light: #f8eddb; /* Bege Claro */
  --color-chumbo: #2e2d2c; /* Chumbo */
  /* Neutros e utilitários */
  --color-white: #ffffff;
  --color-black: #000000;
  --color-whatsapp: #25d366;
  /* Texto (baseado no chumbo) */
  --color-text: var(--color-chumbo);
  --color-text-muted: #5a5958;
  /* Overlay hero (verde escuro com transparência) */
  --color-hero-overlay: rgba(10, 51, 45, 0.85);
  /* Utilitários */
  --color-bg-placeholder: #e8e8e8;
  --color-bg-form: #f9f9f9;
  --color-border: #ddd;
  --color-border-light: #eee;
  --color-dot-inactive: #ccc;
  /* Menda = títulos | Grift Medium = links, menus, botões (500) | Grift Regular = parágrafos (400) */
  --font-title: "mendabold", sans-serif;
  --font-body: "griftregular", sans-serif;
  --font-ui: "griftmedium", sans-serif;
  --font-family: var(--font-body);
  --shadow-card: 0 16px 40px 0 rgba(0, 0, 0, 0.25);
  --shadow-header: 0 2px 20px rgba(46, 45, 44, 0.1);
  --transition-fast: 0.2s ease;
  --transition-normal: 0.3s ease;
  --container-max: 1200px;
  --header-height: 72px;
  /* Padrões de hover: botão/link vs card/box */
  --hover-link-color: var(--color-brown);
  --hover-button-opacity: 0.85;
  --hover-card-lift: -4px;
  --hover-card-image-scale: 1.05;
  --hover-icon-scale: 1.1;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-family);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-text);
  background-color: var(--color-white);
  overflow-x: hidden;
  -webkit-tap-highlight-color: transparent;
}

/* ============================================
   Tipografia – Títulos (Menda) e Parágrafos (Grift)
   Padrão único com breakpoints e strong
   ============================================ */
h1,
h2,
h3,
h4,
h5,
h6,
.section-title,
.hero-title {
  font-family: var(--font-title);
  color: var(--color-text);
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.3px;
  font-style: normal;
}

h1 strong,
h2 strong,
h3 strong,
h4 strong,
h5 strong,
h6 strong {
  font-weight: 700;
}

h1 {
  font-size: 56px;
}

@media (max-width: 1366px) {
  h1 {
    font-size: 50.4px;
  }
}
@media (max-width: 1100px) {
  h1 {
    font-size: 44.8px;
  }
}
@media (max-width: 900px) {
  h1 {
    font-size: 39.2px;
  }
}
@media (max-width: 600px) {
  h1 {
    font-size: 33.6px;
  }
}
@media (max-width: 450px) {
  h1 {
    font-size: 30.8px;
  }
}
h1 {
  margin-bottom: 40px;
}

@media (max-width: 650px) {
  h1 {
    margin-bottom: 20px;
  }
}
h2 {
  font-size: 42px;
}

@media (max-width: 1366px) {
  h2 {
    font-size: 37.8px;
  }
}
@media (max-width: 1100px) {
  h2 {
    font-size: 33.6px;
  }
}
@media (max-width: 900px) {
  h2 {
    font-size: 29.4px;
  }
}
@media (max-width: 600px) {
  h2 {
    font-size: 25.2px;
  }
}
@media (max-width: 450px) {
  h2 {
    font-size: 23.1px;
  }
}
h2 {
  margin-bottom: 30px;
}

@media (max-width: 650px) {
  h2 {
    margin-bottom: 20px;
  }
}
h3 {
  font-size: 32px;
}

@media (max-width: 1366px) {
  h3 {
    font-size: 28.8px;
  }
}
@media (max-width: 1100px) {
  h3 {
    font-size: 25.6px;
  }
}
@media (max-width: 900px) {
  h3 {
    font-size: 22.4px;
  }
}
@media (max-width: 600px) {
  h3 {
    font-size: 19.2px;
  }
}
@media (max-width: 450px) {
  h3 {
    font-size: 17.6px;
  }
}
h3 {
  margin-bottom: 30px;
}

@media (max-width: 650px) {
  h3 {
    margin-bottom: 20px;
  }
}
h4 {
  font-size: 28px;
}

@media (max-width: 1366px) {
  h4 {
    font-size: 25.2px;
  }
}
@media (max-width: 1100px) {
  h4 {
    font-size: 22.4px;
  }
}
@media (max-width: 900px) {
  h4 {
    font-size: 19.6px;
  }
}
@media (max-width: 600px) {
  h4 {
    font-size: 16.8px;
  }
}
@media (max-width: 450px) {
  h4 {
    font-size: 15.4px;
  }
}
h4 {
  margin-bottom: 30px;
}

@media (max-width: 650px) {
  h4 {
    margin-bottom: 20px;
  }
}
h5 {
  font-size: 24px;
}

@media (max-width: 1366px) {
  h5 {
    font-size: 22.8px;
  }
}
@media (max-width: 1100px) {
  h5 {
    font-size: 21.6px;
  }
}
@media (max-width: 900px) {
  h5 {
    font-size: 20.4px;
  }
}
@media (max-width: 600px) {
  h5 {
    font-size: 19.2px;
  }
}
@media (max-width: 450px) {
  h5 {
    font-size: 18px;
  }
}
h5 {
  margin-bottom: 30px;
}

@media (max-width: 650px) {
  h5 {
    margin-bottom: 20px;
  }
}
h6 {
  font-size: 20px;
  margin-bottom: 20px;
}

p {
  font-family: var(--font-body);
  color: var(--color-text-muted);
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 160%;
  display: block;
  margin-bottom: 20px;
}

@media (max-width: 650px) {
  p {
    font-size: 16px;
    line-height: 140%;
  }
}
p strong {
  font-size: 20px;
  font-weight: 700;
}

@media (max-width: 1000px) {
  p strong {
    font-size: 18px;
  }
}
@media (max-width: 450px) {
  p strong {
    font-size: 16px;
  }
}
/* Links, menus, botões: Grift Medium (500) */
a,
.nav-link,
button,
[type=button],
[type=submit],
.call-to-action-button,
.hero-dot,
.carousel-nav-arrow,
.whatsapp-float-button {
  font-family: var(--font-ui);
  font-weight: 500;
}

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

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast), opacity var(--transition-fast);
}

ul {
  list-style: none;
}

/* ============================================
   Header
   ============================================ */
.main-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  transition: background-color var(--transition-normal), box-shadow var(--transition-normal);
}

.main-header.is-scrolled {
  background-color: var(--color-white);
  box-shadow: var(--shadow-header);
}

.main-header.is-scrolled .nav-link {
  color: var(--color-text);
}

/* Logo: branco no topo, laranja após scroll */
.logo {
  position: relative;
  display: block;
}

.logo .logo-img {
  display: block;
  transition: opacity 0.2s ease;
}

.logo .logo-img--orange {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
}

.main-header.is-scrolled .logo .logo-img--white {
  opacity: 0;
}

.main-header.is-scrolled .logo .logo-img--orange {
  opacity: 1;
}

.main-header.is-scrolled .nav-link:hover {
  color: var(--color-orange);
}

.main-header.is-scrolled .social-icon {
  color: var(--color-orange);
}

.main-header.is-scrolled .hamburger-line {
  background-color: var(--color-orange);
}

/* Header for internal pages - always white bg, black menu */
.main-header.header-inner {
  background-color: var(--color-white);
  box-shadow: var(--shadow-header);
}

/* No inner, só existe o logo laranja: tirar do absolute para o link ter tamanho e o logo aparecer */
.main-header.header-inner .logo .logo-img--orange.logo-img--single,
.main-header.header-inner .logo.logo--inner .logo-img--orange {
  position: static;
  opacity: 1;
}

.main-header.header-inner .logo,
.main-header.header-inner .nav-link {
  color: var(--color-text);
}

.main-header.header-inner .social-icon {
  color: var(--color-orange);
}

.main-header.header-inner .nav-link:hover,
.main-header.header-inner .nav-link.active {
  color: var(--color-orange);
  border-bottom-color: var(--color-orange);
}

.main-header.header-inner .hamburger-line {
  background-color: var(--color-text);
}

.header-container {
  padding-top: 40px !important;
  padding-bottom: 40px !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: padding var(--transition-fast);
}

.main-header.is-scrolled .header-container {
  padding-top: 30px !important;
  padding-bottom: 30px !important;
}

.nav-list {
  display: flex;
  align-items: center;
  gap: 40px;
}

.nav-link {
  color: var(--color-white);
  text-align: center;
  font-size: 18px;
  font-style: normal;
  line-height: 140%;
  border-bottom: 4px solid transparent;
  transition: border-color var(--transition-fast);
  padding-bottom: 4px;
  font-family: var(--font-body);
  font-weight: 400;
}

.nav-link:hover,
.nav-link.active {
  border-bottom: 4px solid var(--color-orange);
}

.main-header.is-scrolled .nav-link.active {
  color: var(--color-orange);
  border-bottom-color: var(--color-orange);
}

.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 10px;
  min-width: 44px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
}

.hamburger-line {
  width: 24px;
  height: 2px;
  background-color: var(--color-white);
  transition: var(--transition-fast);
}

.main-header .social-links {
  width: 207px;
  margin-bottom: 0;
}

.main-header .social-icon {
  color: var(--color-white);
}

/* ============================================
   Hero Section (Banner Slider)
   ============================================ */
.hero-section {
  position: relative;
  min-height: 100vh;
  width: 100%;
}

.hero-slider {
  position: relative;
  min-height: 100vh;
  width: 100%;
}

.hero-viewport {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

/* Slick: hero-viewport vira .slick-slider; list/track preenchem altura */
.hero-viewport--slick.slick-initialized .slick-list,
.hero-viewport--slick.slick-initialized .slick-track {
  height: 100%;
}

.hero-viewport--slick.slick-initialized .slick-slide {
  height: 100%;
}

.hero-viewport--slick.slick-initialized .slick-slide > div {
  height: 100%;
}

.hero-slide {
  flex: 0 0 100%;
  width: 100%;
  min-height: 100vh;
  position: relative;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
}

.hero-slide .hero-container {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 100%;
  display: flex;
  align-items: center;
  padding-top: 0;
  padding-bottom: 0;
}

.hero-slide .hero-content {
  position: relative;
  z-index: 1;
}

.hero-dots {
  position: absolute;
  bottom: 40px;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  z-index: 10;
  list-style: none;
  margin: 0;
  padding: 0;
  pointer-events: none;
}

.hero-dots .slick-dots {
  pointer-events: auto;
  position: static;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  width: auto;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hero-dots .slick-dots li {
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
}

.hero-dots .slick-dots li button {
  width: 14px;
  height: 14px;
  padding: 0;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.6);
  background-color: rgba(255, 255, 255, 0.4);
  transition: background-color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  cursor: pointer;
  display: block;
}

.hero-dots .slick-dots li button:hover {
  background-color: rgba(255, 255, 255, 0.8);
  border-color: rgba(255, 255, 255, 0.9);
}

.hero-dots .slick-dots li.slick-active button {
  background-color: var(--color-white);
  border-color: var(--color-orange);
  transform: scale(1.1);
}

.hero-dots .slick-dots li button::before {
  display: none !important;
}

.hero-content {
  position: relative;
  z-index: 1;
  background-color: var(--color-hero-overlay);
  padding: 30px 60px 50px;
  max-width: 645px;
  border-radius: 64px;
  background: linear-gradient(270deg, rgba(10, 51, 45, 0) 20%, var(--color-green-dark) 100%);
}

.hero-title {
  margin-bottom: 40px;
  color: #f8eddb;
  font-size: 48px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.25;
}

@media (max-width: 1100px) {
  .hero-title {
    font-size: 40px;
    margin-bottom: 32px;
  }
}
@media (max-width: 768px) {
  .hero-title {
    font-size: 32px;
    line-height: 1.2;
    margin-bottom: 24px;
  }
}
.hero-description {
  color: #f8eddb;
  font-size: 24px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px; /* 108.333% */
  margin-bottom: 40px;
}

/* Mídia do hero: vídeo em 100% largura/altura (como a imagem de fundo) */
.hero-media {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.hero-media--video {
  z-index: 0;
}

.hero-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%);
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.2);
  z-index: 1;
}

/* ============================================
   Botões (.btn e call-to-action)
   ============================================ */
.btn,
.call-to-action-button {
  padding: 14px 32px;
  background: var(--color-orange);
  text-align: center;
  border: none;
  cursor: pointer;
  max-width: 100%;
  transition: opacity 0.2s ease;
  font-family: var(--font-body);
  display: table;
  color: #fff;
  font-weight: 500;
}

.btn:hover,
.call-to-action-button:hover {
  opacity: var(--hover-button-opacity);
}

.call-to-action-button--outline {
  background: transparent;
  color: var(--color-green-dark);
  border: 2px solid var(--color-green-dark);
}

.call-to-action-button--outline:hover {
  background: var(--color-green-dark);
  color: var(--color-white);
}

.btn strong,
.call-to-action-button strong {
  color: #fff;
  text-align: center;
  font-family: var(--font-body);
  font-size: 17px;
  font-style: normal;
  font-weight: 400 !important;
  line-height: 17px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

/* ============================================
   WhatsApp Float Button
   ============================================ */
.whatsapp-float-button {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 56px;
  height: 56px;
  background-color: var(--color-whatsapp);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.5);
  z-index: 999;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.whatsapp-float-button:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(37, 211, 102, 0.6);
}

.whatsapp-icon {
  width: 28px;
  height: 28px;
  color: var(--color-white);
}

/* ============================================
   Container (limite de conteúdo das seções)
   ============================================ */
.container {
  width: 100%;
  max-width: 1560px;
  padding: 0 120px;
  box-sizing: border-box;
  margin: 0 auto;
}

@media (max-width: 1366px) {
  .container {
    padding-left: 80px;
    padding-right: 80px;
  }
}
@media (max-width: 1200px) {
  .container {
    padding-left: 60px;
    padding-right: 60px;
  }
}
@media (max-width: 1000px) {
  .container {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media (max-width: 600px) {
  .container {
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media (max-width: 450px) {
  .container {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media (max-width: 350px) {
  .container {
    padding-left: 15px;
    padding-right: 15px;
  }
}
/* Padding vertical somente na section (container não tem padding vertical) */
section:not(.hero-section) {
  padding-top: 100px;
  padding-bottom: 100px;
}

/* ============================================
   Section Common
   ============================================ */
.section-title {
  text-align: center;
  margin-bottom: 50px;
}

/* ============================================
   Carousel Section (home) + Listing Card (padrão único)
   ============================================ */
.carousel-section {
  background-color: var(--color-white);
}

.carousel-cards-wrapper {
  position: relative;
}

.carousel-nav-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 48px;
  height: 48px;
  background-color: var(--color-orange);
  color: var(--color-white);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--transition-fast), transform var(--transition-fast);
}

.carousel-nav-arrow.carousel-prev,
.carousel-nav-arrow.gallery-prev {
  left: -80px;
}

.carousel-nav-arrow.carousel-next,
.carousel-nav-arrow.gallery-next {
  right: -80px;
}

.carousel-nav-arrow:hover {
  background-color: var(--color-brown);
  transform: translateY(-50%) scale(1.05);
}

.carousel-nav-arrow:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.carousel-nav-arrow svg {
  width: 24px;
  height: 24px;
}

.carousel-cards {
  width: 100%;
  display: flex;
  gap: 30px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding-bottom: 100px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

/* Slick no carrossel de cards: espaçamento entre slides e sombra visível */
.carousel-cards.slick-initialized {
  display: block;
  overflow: visible;
  gap: 0;
  scroll-snap-type: none;
  padding-bottom: 0;
}

.carousel-cards.slick-initialized .slick-list {
  margin: 0 -20px;
  padding: 0 0 60px;
}

.carousel-cards.slick-initialized .slick-slide {
  margin: 0 20px;
  height: auto;
}

.carousel-cards.slick-initialized .slick-slide > div {
  height: 100%;
  padding-bottom: 4px;
}

.carousel-cards.slick-initialized .listing-card {
  height: 100%;
  box-shadow: var(--shadow-card);
  border-radius: 12px;
}

.carousel-cards::-webkit-scrollbar {
  display: none;
}

/* Wrapper do link: card inteiro clicável (Serviços e Projetos) */
.listing-card-wrapper {
  display: block;
  text-decoration: none;
  color: inherit;
}

.carousel-cards .listing-card-wrapper {
  flex: 0 0 calc(33.333% - 30px);
  min-width: 280px;
  display: flex;
}

.carousel-cards .listing-card-wrapper .listing-card {
  flex: 1 1 auto;
  min-width: 0;
}

.listing-card-wrapper:hover .listing-card {
  transform: translateY(var(--hover-card-lift));
}

/* Listing card: padrão único (home carousel + páginas de listagem) */
.listing-card {
  flex: 0 0 calc(33.333% - 30px);
  min-width: 280px;
  background: #fff;
  box-shadow: 0 16px 40px 0 rgba(0, 0, 0, 0.25);
  overflow: hidden;
  scroll-snap-align: start;
  transition: transform var(--transition-fast);
  position: relative;
}

.carousel-cards .listing-card {
  flex: 0 0 calc(33.333% - 30px);
  min-width: 280px;
}

.listing-card:hover {
  transform: translateY(var(--hover-card-lift));
}

.listing-card-image-wrapper {
  position: relative;
  /* 420×210 → proporção 2:1 */
  aspect-ratio: 2/1;
  background-color: var(--color-bg-placeholder);
}

.listing-card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-normal);
}

.listing-card-wrapper:hover .listing-card-image {
  transform: scale(var(--hover-card-image-scale));
}

.listing-card-icon {
  position: absolute;
  width: 80px;
  height: 80px;
  color: var(--color-white);
  background-color: var(--color-orange);
  display: flex;
  align-items: center;
  justify-content: center;
  left: 50%;
  transform: translateX(-50%);
  bottom: -20px;
  z-index: 99;
}

.listing-card-icon img,
.listing-card-icon svg {
  width: 40px;
  height: 40px;
}

.listing-card-content {
  text-align: center;
  padding: 50px 10px 25px;
  padding-bottom: 25px !important;
  z-index: 1;
}

.listing-card-title {
  color: var(--color-green-medium);
  font-size: 26px;
  font-style: normal;
  font-weight: 500;
  line-height: 40px;
  font-family: var(--font-ui);
  margin-bottom: 15px;
}

.listing-card-link {
  display: inline-block;
  color: #757575;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  text-align: center;
  margin: 0 auto;
  display: table;
  font-family: var(--font-ui);
  transition: color var(--transition-fast);
}

.listing-card-wrapper:hover .listing-card-link,
.listing-card-link:hover,
.a-link:hover {
  color: var(--hover-link-color);
}

.a-link {
  display: inline-block;
  color: #757575;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  text-align: center;
  margin: 0 auto;
  display: table;
  transition: color var(--transition-fast);
}

/* ============================================
   Statistics Section
   ============================================ */
.statistics-section {
  background-color: var(--color-beige-light);
  padding: 60px !important;
}

.statistics-grid {
  max-width: var(--container-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  padding: 0;
}

.statistic-item {
  text-align: center;
  padding: 0 16px;
}

.statistic-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  color: var(--color-orange);
  margin-bottom: 16px;
}

.statistic-icon-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.statistic-number {
  display: block;
  margin-bottom: 10px;
  color: #0a332d;
  text-align: center;
  font-family: var(--font-title);
  font-size: 48px;
  font-style: normal;
  font-weight: 700;
  line-height: 48px;
}

.statistic-description {
  color: #0a332d;
  text-align: center;
  font-family: var(--font-body);
  font-size: 20px;
  font-style: normal;
  font-weight: 500;
  line-height: 26px; /* 130% */
}

/* ============================================
   About Section
   ============================================ */
.about-section {
  background-color: var(--color-white);
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 40px;
  align-items: center;
}

.about-content .a-link {
  margin-top: 30px;
  margin-left: 0;
  margin-right: 0;
  float: right;
}

.about-title {
  margin-bottom: 24px;
  line-height: 1.2;
}

.about-text {
  color: #2e2d2c;
  /* Paragrafo */
  font-family: var(--font-body);
  font-size: 17px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px; /* 152.941% */
  margin-bottom: 0;
}

.about-image {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  background-color: var(--color-bg-placeholder);
}

/* ============================================
   Footer
   ============================================ */
.main-footer {
  background-color: var(--color-orange);
  color: var(--color-white);
  padding: 50px 0;
}

.footer-container {
  margin: 0 auto;
  text-align: center;
}

.footer-logo {
  display: block;
  width: 207px;
  display: block;
  margin: 0 auto 30px;
}

.footer-nav {
  margin-bottom: 50px;
}

.footer-nav-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 40px;
}

.footer-link:hover {
  opacity: var(--hover-button-opacity);
}

.social-links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  margin-bottom: 30px;
}

.social-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  transition: transform var(--transition-fast);
}

.social-icon:hover {
  transform: scale(var(--hover-icon-scale));
}

.social-icon svg {
  width: 20px;
  height: 20px;
}

.contact-info {
  color: #fffcfc;
  text-align: center;
  font-family: var(--font-body);
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px;
}

.footer-divider {
  border: none;
  border-top: 1px solid #fff;
  margin: 20px auto;
  max-width: 90%;
}

.footer-bottom-text,
.footer-link {
  color: #fffcfc;
  text-align: center;
  font-family: var(--font-body);
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px;
  margin-bottom: 0;
}

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 1100px) {
  .main-header .social-links {
    display: none;
  }
}
@media (max-width: 1024px) {
  .statistics-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .about-grid {
    grid-template-columns: 1fr;
  }
  .about-image-wrapper {
    order: -1;
  }
  .listing-card {
    flex: 0 0 calc(50% - 12px);
    min-width: 260px;
  }
  .carousel-cards .listing-card-wrapper {
    flex: 0 0 calc(50% - 12px);
    min-width: 260px;
  }
  .carousel-cards .listing-card {
    flex: 0 0 calc(50% - 12px);
    min-width: 260px;
  }
  .carousel-nav-arrow.carousel-prev,
  .carousel-nav-arrow.gallery-prev {
    left: 4px;
  }
  .carousel-nav-arrow.carousel-next,
  .carousel-nav-arrow.gallery-next {
    right: 4px;
  }
}
@media (max-width: 768px) {
  .nav-menu {
    position: fixed;
    top: var(--header-height);
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--color-white);
    padding: 24px;
    padding-bottom: max(24px, env(safe-area-inset-bottom));
    box-shadow: var(--shadow-header);
    transform: translateY(-100%);
    opacity: 0;
    visibility: hidden;
    transition: transform var(--transition-normal), opacity var(--transition-normal), visibility var(--transition-normal);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .nav-menu.is-open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
  .nav-menu .nav-list {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
  }
  .nav-menu .nav-link {
    color: var(--color-text);
    display: block;
    padding: 14px 0;
    min-height: 48px;
    line-height: 1.4;
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--color-border-light);
  }
  .nav-menu .nav-link:hover,
  .nav-menu .nav-link.active {
    color: var(--color-orange);
    border-bottom-color: var(--color-border-light);
  }
  .mobile-menu-toggle {
    display: flex;
  }
  .main-header .logo {
    max-width: 180px;
  }
  .main-header .logo .logo-img {
    max-height: 48px;
    width: auto;
    object-fit: contain;
  }
  .header-container {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }
  .main-header.is-scrolled .header-container {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
  }
  .hero-content {
    margin-left: 0;
    margin-right: 24px;
    padding: 28px 24px 36px;
    border-radius: 32px;
    max-width: calc(100% - 32px);
  }
  .hero-dots {
    bottom: max(24px, env(safe-area-inset-bottom));
  }
  section:not(.hero-section) {
    padding-top: 64px;
    padding-bottom: 64px;
  }
  .section-title {
    margin-bottom: 32px;
    font-size: 31.5px;
  }
  .carousel-nav-arrow.carousel-prev,
  .carousel-nav-arrow.gallery-prev {
    left: 4px;
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
  }
  .carousel-nav-arrow.carousel-next,
  .carousel-nav-arrow.gallery-next {
    right: 4px;
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
  }
  .carousel-nav-arrow svg {
    width: 18px;
    height: 18px;
  }
  .carousel-cards {
    padding-bottom: 48px;
    padding-left: 0;
    padding-right: 0;
    gap: 16px;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
  }
  .carousel-cards.slick-initialized .slick-list {
    margin: 0;
  }
  .carousel-cards.slick-initialized .slick-slide {
    margin: 0 8px;
  }
  .carousel-cards-wrapper {
    padding-left: 0;
    padding-right: 0;
  }
  .listing-card,
  .carousel-cards .listing-card {
    flex: 0 0 85%;
    min-width: 240px;
    scroll-snap-align: start;
  }
  .carousel-cards .listing-card-wrapper {
    flex: 0 0 85%;
    min-width: 240px;
    scroll-snap-align: start;
  }
  .listing-card-content {
    padding: 40px 12px 20px;
    padding-bottom: 20px !important;
  }
  .listing-card-title {
    font-size: 22px;
    line-height: 1.35;
  }
  .listing-card-icon {
    width: 64px;
    height: 64px;
    bottom: -16px;
  }
  .listing-card-icon img,
  .listing-card-icon svg {
    width: 32px;
    height: 32px;
  }
  .statistics-section {
    padding: 40px 24px !important;
  }
  .statistics-grid {
    gap: 24px;
  }
  .statistic-icon {
    width: 72px;
    height: 72px;
    margin-bottom: 12px;
  }
  .statistic-number {
    font-size: 2rem;
  }
  .statistic-description {
    font-size: 18px;
  }
  .footer-nav-list {
    gap: 20px;
  }
  .footer-divider {
    max-width: 100%;
  }
  .main-footer {
    padding: 40px 0;
    padding-bottom: max(40px, env(safe-area-inset-bottom));
  }
  .about-section .about-grid {
    gap: 24px;
  }
  .about-content .a-link {
    float: none;
    display: inline-block;
    margin-top: 20px;
  }
  .about-title {
    font-size: 29.4px;
    line-height: 1.2;
  }
  .about-text {
    font-size: 16px;
  }
}
@media (max-width: 480px) {
  section:not(.hero-section) {
    padding-top: 48px;
    padding-bottom: 48px;
  }
  .hero-content {
    padding: 24px 20px 28px;
    margin-left: 16px;
    margin-right: 16px;
    max-width: calc(100% - 32px);
    border-radius: 24px;
  }
  .hero-title {
    font-size: 24px;
    line-height: 1.2;
    margin-bottom: 20px;
  }
  .hero-description {
    font-size: 16px;
    line-height: 1.4;
    margin-bottom: 24px;
  }
  .section-title {
    margin-bottom: 24px;
    font-size: 25.2px;
  }
  .statistics-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .statistics-section {
    padding: 32px 20px !important;
  }
  .statistic-number {
    font-size: 1.75rem;
  }
  .carousel-nav-arrow {
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
    left: 4px;
    right: auto;
  }
  .carousel-nav-arrow.carousel-next,
  .carousel-nav-arrow.gallery-next {
    left: auto;
    right: 4px;
  }
  .carousel-nav-arrow.carousel-prev,
  .carousel-nav-arrow.gallery-prev {
    left: 4px;
  }
  .carousel-nav-arrow svg {
    width: 16px;
    height: 16px;
  }
  .listing-card,
  .carousel-cards .listing-card {
    flex: 0 0 88%;
    min-width: 220px;
  }
  .carousel-cards .listing-card-wrapper {
    flex: 0 0 88%;
    min-width: 220px;
  }
  .listing-card-content {
    padding: 36px 10px 18px;
    padding-bottom: 18px !important;
  }
  .listing-card-title {
    font-size: 20px;
  }
  .listing-card-link,
  .a-link {
    font-size: 16px;
  }
  .btn,
  .call-to-action-button {
    padding: 14px 24px;
    width: 100%;
    max-width: 100%;
  }
  .btn strong,
  .call-to-action-button strong {
    font-size: 16px;
  }
  .footer-nav-list {
    flex-direction: column;
    gap: 8px;
  }
  .footer-logo {
    width: 160px;
    max-width: 100%;
  }
  .main-footer {
    padding: 32px 0;
    padding-bottom: max(32px, env(safe-area-inset-bottom));
  }
  .whatsapp-float-button {
    bottom: max(20px, env(safe-area-inset-bottom));
    right: max(20px, env(safe-area-inset-right));
    width: 52px;
    height: 52px;
  }
  .whatsapp-icon {
    width: 26px;
    height: 26px;
  }
}
@media (max-width: 360px) {
  .container {
    padding-left: 16px;
    padding-right: 16px;
  }
  .hero-content {
    padding: 20px 16px 24px;
    border-radius: 20px;
  }
  .hero-title {
    font-size: 22px;
    margin-bottom: 16px;
  }
  .listing-card,
  .carousel-cards .listing-card {
    min-width: 200px;
  }
  .carousel-cards .listing-card-wrapper {
    min-width: 200px;
  }
}
#footer-lgpd {
  position: fixed;
  z-index: 9999;
  max-width: 1230px;
  transition: 0.3s ease-in-out;
  background: var(--color-white);
  bottom: 25px;
  left: 10px;
  right: 10px;
  padding: 20px;
  box-shadow: 0 0 10px var(--color-text-muted);
  border-radius: 12px;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-transform: translateY(300px);
  -ms-transform: translateY(300px);
  transform: translateY(300px);
  margin: 0 auto;
  opacity: 0.9;
}

#footer-lgpd p {
  padding: 0;
  margin: 0;
  border: 0;
  font-size: 16px;
  line-height: 22px;
  color: var(--color-text-muted);
}

#footer-lgpd #lgpd-accept-link {
  white-space: nowrap;
  color: var(--color-orange);
  text-decoration: underline;
}

#footer-lgpd #lgpd-accept {
  background: #1a1a1a 0 0 no-repeat padding-box;
  color: #ffffff;
  border: none;
  text-align: center;
  font-size: 16px;
  border-radius: 8px;
  background: var(--color-orange) !important;
  display: table;
  text-align: center;
  padding: 18px 22px;
  letter-spacing: 0;
  margin-left: 15px;
  cursor: pointer;
  white-space: nowrap;
  font-family: var(--font-body) !important;
  line-height: 16px;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  display: block;
  color: #fff;
  text-align: center;
}

#footer-lgpd #lgpd-accept:hover {
  transition: 0.3s ease-in-out;
  opacity: 0.6;
}

#footer-lgpd.footer-lgpd-opened {
  transition: 0.5s ease-in-out;
  -webkit-transform: translate(0);
  -ms-transform: translate(0);
  transform: translate(0);
}

@media (max-width: 600px) {
  #footer-lgpd {
    flex-flow: column;
  }
  #footer-lgpd p {
    text-align: center;
  }
  #footer-lgpd #lgpd-accept {
    margin-left: 0;
    margin-top: 20px;
  }
}
.grecaptcha-badge {
  visibility: hidden;
}

.hidden {
  opacity: 0;
  filter: blur(10px);
  -webkit-transition: all 0.5s ease-in-out;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
}
.hidden.to-left {
  -webkit-transform: translateX(5vw);
  -moz-transform: translateX(5vw);
  -ms-transform: translateX(5vw);
  -o-transform: translateX(5vw);
  transform: translateX(5vw);
}
.hidden.to-right {
  -webkit-transform: translateX(-5vw);
  -moz-transform: translateX(-5vw);
  -ms-transform: translateX(-5vw);
  -o-transform: translateX(-5vw);
  transform: translateX(-5vw);
}
.hidden.to-top {
  -webkit-transform: translateY(5vh);
  -moz-transform: translateY(5vh);
  -ms-transform: translateY(5vh);
  -o-transform: translateY(5vh);
  transform: translateY(5vh);
}
.hidden.to-bottom {
  -webkit-transform: translateY(-5vh);
  -moz-transform: translateY(-5vh);
  -ms-transform: translateY(-5vh);
  -o-transform: translateY(-5vh);
  transform: translateY(-5vh);
}

.show {
  opacity: 1;
  filter: blur(0);
  -webkit-transition: all 0.5s ease-in-out;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
  -webkit-transform: translateX(0) translateY(0) !important;
  -moz-transform: translateX(0) translateY(0) !important;
  -ms-transform: translateX(0) translateY(0) !important;
  -o-transform: translateX(0) translateY(0) !important;
  transform: translateX(0) translateY(0) !important;
}

/* ============================================
   About Page Styles
   ============================================ */
/* About Intro Section */
.about-intro-section {
  background-color: var(--color-white);
  text-align: center;
}

.about-intro-title {
  font-family: var(--font-title);
  font-size: 36px;
  font-weight: 700;
  color: var(--color-green-medium);
  line-height: 48px;
  margin-bottom: 32px;
}

.about-intro-text {
  max-width: 1090px;
  margin: 0 auto;
  font-family: var(--font-body);
  font-size: 17px;
  color: var(--color-chumbo);
  line-height: 26px;
  margin-bottom: 32px;
}

/* Timeline Section */
.timeline-section {
  background-color: var(--color-white);
  padding-top: 0 !important;
  padding-bottom: 100px !important;
}

.timeline-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  margin-bottom: 80px;
}

.timeline-item:last-child {
  margin-bottom: 0;
}

.timeline-item-reverse {
  direction: rtl;
}
.timeline-item-reverse .timeline-content {
  text-align: right;
}

.timeline-item-reverse > * {
  direction: ltr;
}

.timeline-image {
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.timeline-image img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  background-color: var(--color-bg-placeholder);
  display: block;
}

.timeline-content {
  padding: 16px 0;
  width: 100%;
  max-width: 540px;
}

.timeline-title {
  font-family: var(--font-ui);
  font-size: 26px;
  font-weight: 500;
  color: #0a332d;
  margin-bottom: 16px;
  line-height: 40px;
}

.timeline-text {
  font-family: var(--font-body);
  font-size: 16px;
  color: #2e2d2c;
  line-height: 26px;
}

/* Technologies Section */
.technologies-section {
  background-color: var(--color-white);
}

.technologies-section .section-title {
  color: var(--color-green-dark);
  margin-bottom: 64px;
}

.technology-row {
  display: grid;
  grid-template-columns: 533fr 570fr;
  gap: 80px;
  align-items: center;
  margin-bottom: 80px;
}

.technology-row:last-child {
  margin-bottom: 0;
}

.technology-row-reverse {
  direction: rtl;
}
.technology-row-reverse .technology-text-block {
  text-align: right;
}

.technology-row-reverse > * {
  direction: ltr;
}

.technology-image-block {
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.technology-img {
  width: 100%;
  aspect-ratio: 533/370;
  object-fit: cover;
  background-color: var(--color-bg-placeholder);
  display: block;
}

.technology-text-block {
  padding: 16px 0;
}

.technology-item-title {
  font-family: var(--font-ui);
  font-size: 26px;
  font-weight: 500;
  color: var(--color-green-dark);
  margin-bottom: 20px;
  line-height: 40px;
}

.technology-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.technology-list li {
  font-family: var(--font-body);
  font-size: 17px;
  color: var(--color-chumbo);
  line-height: 26px;
  position: relative;
  margin-bottom: 5px;
}

/* Feature Cards Section (Diferenciais + Benefícios) */
.feature-cards-section {
  padding-top: 100px;
  padding-bottom: 100px;
}

.feature-cards-section--beige {
  background-color: #f8f8f8;
}

.feature-cards-section--white {
  background-color: var(--color-white);
}

.feature-cards-section .section-title {
  color: var(--color-green-dark);
  margin-bottom: 64px;
  font-family: var(--font-title);
  font-size: 36px;
  font-style: normal;
  font-weight: 700;
  line-height: 48px; /* 133.333% */
}

.feature-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px 80px;
}

.feature-card-item {
  display: flex;
  flex-direction: column;
}

.feature-card-icon {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 70px;
  height: 90px;
  background-color: rgba(254, 86, 36, 0.1);
  margin-bottom: 30px;
  flex-shrink: 0;
  position: relative;
}

.feature-card-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  max-width: 60px;
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.feature-card-title {
  font-family: var(--font-ui);
  font-size: 26px;
  font-weight: 500;
  color: var(--color-green-dark);
  margin-bottom: 12px;
  line-height: 40px;
}

.feature-card-description {
  font-family: var(--font-body);
  font-size: 17px;
  color: var(--color-chumbo);
  line-height: 26px;
  margin-bottom: 0;
}

/* CTA Section */
.cta-section {
  background-color: var(--color-white);
  text-align: center;
  padding: 0 !important;
  padding-bottom: 100px !important;
}

.cta-section .call-to-action-button {
  padding: 14px 48px;
  font-size: 26px;
  font-family: var(--font-ui);
  line-height: 40px;
  margin: 0 auto;
}

/* ============================================
   Responsive - About Page
   ============================================ */
@media (max-width: 1200px) {
  .feature-cards-grid {
    gap: 40px 48px;
  }
  .timeline-item,
  .technology-row {
    gap: 48px;
  }
}
@media (max-width: 1024px) {
  .feature-cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .technology-row {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 768px) {
  .about-intro-section {
    padding-bottom: 48px !important;
  }
  .about-intro-title {
    font-size: 28px;
    line-height: 1.3;
    margin-bottom: 24px;
  }
  .about-intro-text {
    margin-bottom: 24px;
    font-size: 16px;
  }
  .timeline-section {
    padding-bottom: 64px !important;
  }
  .timeline-item,
  .timeline-item-reverse {
    grid-template-columns: 1fr;
    gap: 24px;
    direction: ltr;
    margin-bottom: 48px;
  }
  .timeline-item-reverse > * {
    direction: ltr;
  }
  .timeline-content {
    max-width: 100%;
    padding: 0;
  }
  .technology-row,
  .technology-row-reverse {
    grid-template-columns: 1fr;
    gap: 24px;
    direction: ltr;
    margin-bottom: 48px;
  }
  .technology-row-reverse > * {
    direction: ltr;
  }
  .technologies-section .section-title {
    margin-bottom: 40px;
  }
  .feature-cards-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .cta-section {
    padding: 64px 0 !important;
  }
}
@media (max-width: 480px) {
  .about-intro-section {
    padding: 32px 0 40px !important;
  }
  .about-intro-title {
    font-size: 22px;
    line-height: 1.3;
  }
  .about-intro-text {
    font-size: 15px;
    margin-bottom: 20px;
  }
  .timeline-section {
    padding-bottom: 48px !important;
  }
  .timeline-item,
  .timeline-item-reverse {
    gap: 20px;
    margin-bottom: 40px;
  }
  .timeline-image img {
    aspect-ratio: 16/10;
  }
  .timeline-title,
  .technology-item-title,
  .feature-card-title {
    font-size: 20px;
    line-height: 1.3;
  }
  .timeline-text,
  .technology-item-text,
  .feature-card-text {
    font-size: 15px;
  }
  .technologies-section .section-title {
    margin-bottom: 32px;
  }
  .technology-row,
  .technology-row-reverse {
    margin-bottom: 40px;
    gap: 20px;
  }
  .cta-section {
    padding: 48px 0 !important;
  }
  .cta-section .call-to-action-button {
    font-size: 16px;
    padding: 14px 24px;
    width: 100%;
    max-width: 100%;
    display: block;
    text-align: center;
  }
}
@media (max-width: 360px) {
  .about-intro-title {
    font-size: 20px;
  }
  .timeline-title,
  .technology-item-title,
  .feature-card-title {
    font-size: 18px;
  }
}
/* ============================================
   Contact Page
   ============================================ */
/* Bloco de informações (caixa verde) - centralizado, um por linha */
.contact-info-section {
  background-color: var(--color-white);
  padding: 0 !important;
  padding-bottom: 100px !important;
}

.contact-info-block {
  background-color: var(--color-green-dark);
  color: var(--color-white);
  padding: 32px 40px;
  max-width: 870px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  gap: 20px;
}

.contact-info-item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: nowrap;
  gap: 20px;
  color: var(--color-white);
  text-decoration: none;
  transition: opacity var(--transition-fast);
  width: 100%;
  padding-left: 200px;
  color: #f8eddb;
  font-family: var(--font-body);
  font-size: 17px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px; /* 152.941% */
}

a.contact-info-item:hover {
  opacity: var(--hover-button-opacity, 0.85);
}

.contact-info-address {
  cursor: default;
}

.contact-info-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.contact-info-icon svg {
  width: 30px;
  height: 30px;
}

.contact-info-text {
  font-family: var(--font-body);
  font-size: 17px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px; /* 152.941% */
}

/* Seção Entre em contato - fundo cinza */
.contact-form-section {
  background-color: #f9f9f9;
  padding: 120px 0px !important;
}

.contact-form-title {
  color: #0a332d;
  text-align: center;
  /* GB Título */
  font-family: var(--font-title);
  font-size: 36px;
  font-style: normal;
  font-weight: 700;
  line-height: 48px; /* 133.333% */
  margin-bottom: 32px;
  text-align: center;
}

.contact-form-message {
  max-width: 1090px;
  margin: 0 auto 24px;
  padding: 16px 24px;
  border-radius: 8px;
}

.contact-form-message--success {
  background: rgba(34, 139, 34, 0.12);
  color: #1a6b1a;
  border: 1px solid #2e8b2e;
}

.contact-form-message--error {
  background: rgba(220, 53, 69, 0.12);
  color: #b02a37;
  border: 1px solid #dc3545;
}

.contact-form-message p {
  margin: 0;
  font-family: var(--font-body);
  font-size: 17px;
}

.contact-form {
  max-width: 1090px;
  margin: 0 auto;
}

/* Contact Form 7: mantém o layout quando o plugin envolve os campos em <p> */
.contact-form .wpcf7-form .contact-form-group p {
  margin: 0;
}

.contact-form .wpcf7-form .contact-form-submit p {
  margin: 0;
}

/* Contact Form 7: retorno alinhado à linha visual do site (em qualquer contexto) */
.wpcf7 form .wpcf7-response-output,
.contact-form .wpcf7-response-output {
  margin: 0 0 24px;
  max-width: 1090px;
  padding: 16px 24px;
  border-radius: 0;
  border: 1px solid rgba(15, 27, 36, 0.1);
  background: var(--color-white);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.5;
  box-sizing: border-box;
}

/* Contact Form 7: sucesso = verde */
.wpcf7 form .wpcf7-response-output.wpcf7-mail-sent-ok,
.contact-form .wpcf7-response-output.wpcf7-mail-sent-ok {
  background: rgba(34, 139, 34, 0.12);
  color: #1a6b1a;
  border-color: #2e8b2e;
}

/* Contact Form 7: erro (validação, falha no envio, spam) = vermelho */
.wpcf7 form .wpcf7-response-output.wpcf7-validation-errors,
.wpcf7 form .wpcf7-response-output.wpcf7-mail-sent-ng,
.wpcf7 form .wpcf7-response-output.wpcf7-spam-blocked,
.contact-form .wpcf7-response-output.wpcf7-validation-errors,
.contact-form .wpcf7-response-output.wpcf7-mail-sent-ng,
.contact-form .wpcf7-response-output.wpcf7-spam-blocked {
  background: rgba(220, 53, 69, 0.12);
  color: #b02a37;
  border-color: #dc3545;
}

.contact-form .wpcf7-not-valid-tip {
  font-size: 14px;
  margin-top: 6px;
  color: #b02a37;
}

.contact-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  margin-bottom: 30px;
}

.contact-form-group-full {
  grid-column: 1/-1;
}

/* Sem labels, só placeholder. Inputs não arredondados */
.contact-form-input,
.contact-form-textarea {
  border: 1px solid rgba(15, 27, 36, 0.1);
  background: #fff;
  width: 100%;
  padding: 20px 30px;
  color: #2e2d2c;
  /* Paragrafo */
  font-family: var(--font-body);
  font-size: 17px;
  font-style: normal;
  font-weight: 400;
  line-height: 22px; /* 152.941% */
  border-radius: 0;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-form-input:focus,
.contact-form-textarea:focus {
  outline: none;
  border-color: var(--color-orange);
  box-shadow: 0 0 0 2px rgba(240, 83, 28, 0.15);
}

.contact-form-input::placeholder,
.contact-form-textarea::placeholder {
  color: var(--color-text-muted);
}

.contact-form-textarea {
  resize: vertical;
  min-height: 120px;
}

.contact-form-submit {
  margin-top: 40px;
  text-align: center;
}

.contact-form-submit .call-to-action-button {
  border: none;
  cursor: pointer;
  padding: 14px 48px;
  font-size: 1rem;
  margin: 0 auto;
}

/* Links do footer na página de contato */
.footer-contact-link {
  color: var(--color-white);
  text-decoration: none;
  opacity: 0.95;
}

.footer-contact-link:hover {
  opacity: var(--hover-button-opacity, 0.85);
  text-decoration: underline;
}

/* Responsivo */
@media (max-width: 768px) {
  .contact-info-section {
    padding-bottom: 64px !important;
  }
  .contact-info-block {
    padding: 28px 24px;
    max-width: 100%;
  }
  .contact-info-item {
    padding-left: 0;
    flex-wrap: nowrap;
    gap: 16px;
  }
  .contact-info-text {
    min-width: 0;
    word-break: break-word;
  }
  .contact-form-section {
    padding: 64px 0 !important;
  }
  .contact-form-title {
    font-size: 28px;
    line-height: 1.3;
    margin-bottom: 24px;
  }
  .contact-form-row {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-bottom: 20px;
  }
}
@media (max-width: 480px) {
  .contact-info-block {
    padding: 24px 20px;
    gap: 24px;
  }
  .contact-info-item {
    padding: 8px 0;
    gap: 12px;
    flex-wrap: nowrap;
  }
  .contact-info-icon {
    flex-shrink: 0;
  }
  .contact-info-icon svg {
    width: 24px;
    height: 24px;
  }
  .contact-info-text {
    font-size: 0.9375rem;
    min-width: 0;
  }
  .contact-form-section {
    padding: 48px 0 !important;
  }
  .contact-form-title {
    font-size: 24px;
    line-height: 1.3;
  }
  .contact-form {
    padding: 0;
  }
  .contact-form-row {
    gap: 16px;
    margin-bottom: 16px;
  }
  .contact-form-input,
  .contact-form-textarea {
    padding: 16px 20px;
    font-size: 16px;
    min-height: 48px;
  }
  .contact-form-textarea {
    min-height: 100px;
  }
  .contact-form-submit {
    margin-top: 24px;
  }
  .contact-form-submit .call-to-action-button {
    width: 100%;
    max-width: 100%;
    padding: 14px 24px;
  }
}
/* ============================================
   Listing Pages (Serviços, Projetos)
   Shared layout: hero + intro + grid of cards
   ============================================ */
/* Page Hero */
.page-hero {
  position: relative;
  height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-size: cover;
  background-position: center;
  background-color: var(--color-chumbo);
  margin-top: var(--header-height);
  margin-top: 116px;
}
@media (max-width: 1100px) {
  .page-hero {
    margin-top: 106px;
  }
}
@media (max-width: 768px) {
  .page-hero {
    margin-top: 84px;
  }
}

.page-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, #0f1b24 12.45%, rgba(15, 27, 36, 0.2) 100%);
}

.page-hero-content {
  position: relative;
  z-index: 1;
  text-align: center;
}

.page-hero-title {
  color: #fff;
  text-align: center;
  font-size: 48px;
  font-style: normal;
  font-weight: 700;
  line-height: 48px;
  margin-bottom: 15px;
}

/* Breadcrumb */
.breadcrumb {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  font-family: var(--font-body);
  font-size: 17px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px; /* 152.941% */
}

.breadcrumb-link {
  color: var(--color-white);
  transition: color var(--transition-fast);
}

.breadcrumb-link:hover {
  color: var(--color-orange);
}

.breadcrumb-separator {
  color: var(--color-white);
}

.breadcrumb-current {
  color: var(--color-orange);
}

/* Listing Intro */
.listing-intro-section {
  padding: 80px 0 0 !important;
}

.listing-intro-text {
  max-width: 1090px;
  margin: 0 auto;
  text-align: center;
  color: #0f1b24;
  text-align: center;
  /* Paragrafo */
  font-size: 17px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px; /* 152.941% */
}

/* Listing Grid */
.listing-grid-section {
  background-color: var(--color-white);
  padding-top: 60px !important;
}

.listing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  max-width: var(--container-max);
  margin: 0 auto;
}

.listing-grid .listing-card-wrapper {
  display: block;
  height: 100%;
}

.listing-grid .listing-card-wrapper .listing-card {
  height: 100%;
}

/* Card padrão definido em _styles.scss (.listing-card) */
/* ============================================
   Responsive
   ============================================ */
@media (max-width: 1024px) {
  .listing-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
}
@media (max-width: 768px) {
  .listing-intro-section {
    padding-top: 48px !important;
  }
  .page-hero {
    height: 240px;
  }
  .page-hero-title {
    font-size: 36px;
    line-height: 1.2;
  }
  .breadcrumb,
  .internal-breadcrumb {
    font-size: 15px;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
  }
  .listing-grid {
    grid-template-columns: 1fr;
    max-width: 100%;
    gap: 20px;
    padding-top: 40px !important;
  }
  .listing-intro-text {
    font-size: 0.9375rem;
  }
}
@media (max-width: 480px) {
  .page-hero {
    height: 200px;
  }
  .page-hero-title {
    font-size: 28px;
  }
  .page-hero-content {
    padding: 0 16px;
  }
  .listing-intro-section {
    padding-top: 32px !important;
  }
  .listing-grid-section {
    padding-top: 40px !important;
    padding-bottom: 48px !important;
  }
  .listing-grid {
    gap: 16px;
  }
  .listing-card-content {
    padding: 40px 12px 20px;
  }
  .listing-card-title {
    font-size: 20px;
    line-height: 1.35;
  }
}
@media (max-width: 360px) {
  .page-hero {
    height: 180px;
  }
  .page-hero-title {
    font-size: 24px;
  }
}
/* ============================================
   Internal Service Page Styles
   ============================================ */
/* Page Hero - internal banner */
.internal-page-hero {
  position: relative;
  height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-size: cover;
  background-position: center;
  background-color: var(--color-chumbo);
  margin-top: var(--header-height);
  margin-top: 116px;
}
@media (max-width: 1100px) {
  .internal-page-hero {
    margin-top: 106px;
  }
}
@media (max-width: 768px) {
  .internal-page-hero {
    margin-top: 84px;
  }
}

.internal-page-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, #0f1b24 12.45%, rgba(15, 27, 36, 0.2) 100%);
}

.internal-page-hero-content {
  position: relative;
  z-index: 1;
  text-align: center;
}

.internal-page-hero-title {
  color: #fff;
  text-align: center;
  font-size: 48px;
  font-style: normal;
  font-weight: 700;
  line-height: 48px;
  margin-bottom: 15px;
}

/* Breadcrumb */
.internal-breadcrumb {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  font-family: var(--font-body);
  font-size: 17px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px; /* 152.941% */
}

.internal-breadcrumb-link {
  color: var(--color-white);
  transition: opacity var(--transition-fast);
}

.internal-breadcrumb-link:hover {
  color: var(--color-orange);
}

.internal-breadcrumb-separator {
  color: var(--color-white);
}

.internal-breadcrumb-current {
  color: var(--color-orange);
}

/* Content sections */
.internal-intro-section {
  background-color: var(--color-white);
  padding: 80px 0 60px !important;
}

.internal-intro-text {
  max-width: 1090px;
  margin: 0 auto;
  color: #2e2d2c;
  text-align: center;
  /* Paragrafo */
  font-family: var(--font-body);
  font-size: 17px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px;
}

/* Main image block */
.internal-main-image-section {
  background-color: var(--color-white);
  padding: 0 !important;
  padding-bottom: 100px !important;
}

.internal-main-image-wrapper {
  position: relative;
  max-width: 1090px;
  margin: 0 auto;
  box-shadow: var(--shadow-card);
  cursor: pointer;
}

.internal-main-image-wrapper:hover .internal-main-image {
  transform: scale(var(--hover-card-image-scale, 1.05));
}

.internal-main-image {
  width: 100%;
  display: block;
  aspect-ratio: 16/10;
  object-fit: cover;
  background-color: var(--color-bg-placeholder);
  transition: transform var(--transition-normal);
}

.internal-main-image-icon {
  position: absolute;
  bottom: -40px;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 80px;
  background-color: var(--color-orange);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.internal-main-image-icon img {
  width: 40px;
  height: 40px;
}

/* Second description */
.internal-description-section {
  background-color: var(--color-white);
  padding: 0 !important;
  padding-bottom: 100px !important;
}

.internal-description-text {
  max-width: 1090px;
  margin: 0 auto;
  text-align: center;
  font-size: 1rem;
  color: var(--color-text-muted);
  line-height: 1.8;
}

/* Gallery */
.internal-gallery-section {
  background-color: var(--color-white);
  padding: 0 !important;
  padding-bottom: 100px !important;
}

.internal-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1090px;
  margin: 0 auto;
}

.internal-gallery-item {
  cursor: pointer;
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.internal-gallery-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.internal-gallery-item img {
  width: 100%;
  aspect-ratio: 2/1;
  object-fit: cover;
  display: block;
  background-color: var(--color-bg-placeholder);
  transition: transform var(--transition-normal);
}

.internal-gallery-item:hover img {
  transform: scale(1.05);
}

/* ============================================
   Lightbox / Popup
   ============================================ */
.lightbox-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.9);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-normal), visibility var(--transition-normal);
}

.lightbox-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.lightbox-content {
  position: relative;
  max-width: 95vw;
  max-height: 90vh;
}

.lightbox-content img {
  max-width: 100%;
  max-height: 90vh;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

.lightbox-close {
  position: absolute;
  top: -40px;
  right: 0;
  width: 36px;
  height: 36px;
  background-color: var(--color-white);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  transition: background-color var(--transition-fast), color var(--transition-fast);
  z-index: 2;
}

.lightbox-close:hover {
  background-color: var(--color-orange);
  color: var(--color-white);
}

.lightbox-close svg {
  width: 20px;
  height: 20px;
}

.lightbox-prev,
.lightbox-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  background-color: rgba(255, 255, 255, 0.9);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  transition: background-color var(--transition-fast), color var(--transition-fast);
  z-index: 2;
}

.lightbox-prev:hover,
.lightbox-next:hover {
  background-color: var(--color-orange);
  color: var(--color-white);
}

.lightbox-prev {
  left: 24px;
}

.lightbox-next {
  right: 24px;
}

.lightbox-prev svg,
.lightbox-next svg {
  width: 24px;
  height: 24px;
}

/* Gallery Carousel (slide mode - 1 item visible) */
.gallery-carousel-wrapper {
  position: relative;
  max-width: var(--container-max);
  margin: 0 auto;
}

.gallery-carousel-viewport {
  width: 100%;
  overflow: hidden;
  box-shadow: var(--shadow-card);
  position: relative;
}

.gallery-carousel-track {
  display: flex;
  width: 100%;
  transition: transform var(--transition-normal);
  will-change: transform;
}

.gallery-carousel-track .carousel-slide {
  min-width: 0;
  width: 100%;
  position: relative;
  cursor: pointer;
}

.gallery-carousel-track .carousel-slide img {
  width: 100%;
  width: 100%;
  display: block;
  object-fit: cover;
  background-color: var(--color-bg-placeholder);
  pointer-events: none;
}

/* Slick na galeria: list/track/slide preenchem altura */
.gallery-carousel-track.slick-initialized .slick-list,
.gallery-carousel-track.slick-initialized .slick-track {
  width: 100%;
}

.gallery-carousel-track.slick-initialized .slick-slide {
  width: 100%;
}

.gallery-carousel-track.slick-initialized .slick-slide > div {
  width: 100%;
}

/* Setas 50px para fora do viewport */
.carousel-nav-arrow.gallery-prev,
.carousel-nav-arrow.gallery-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
}

.carousel-nav-arrow.gallery-prev {
  left: -80px; /* 50px de gap até o viewport (padding 98 = 48 seta + 50 gap) */
}

.carousel-nav-arrow.gallery-next {
  right: -80px;
}

.carousel-nav-arrow:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* Bolinhas = hero-dots da home: flutuando 40px do bottom */
.carousel-dots {
  position: absolute;
  bottom: 40px;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  gap: 10px;
  z-index: 2;
  list-style: none;
  margin: 0;
  padding: 0;
  pointer-events: none;
}

.carousel-dots .carousel-dot {
  pointer-events: auto;
}

/* Slick dots na galeria – mesmo visual que .carousel-dot */
.gallery-carousel-wrapper .carousel-dots .slick-dots {
  position: static;
  display: flex;
  justify-content: center;
  gap: 10px;
  width: auto;
  margin: 0;
  padding: 0;
  list-style: none;
  pointer-events: auto;
}

.gallery-carousel-wrapper .carousel-dots .slick-dots li {
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
}

.gallery-carousel-wrapper .carousel-dots .slick-dots li button {
  width: 12px;
  height: 12px;
  padding: 0;
  border-radius: 50%;
  border: 2px solid transparent;
  background-color: rgba(255, 255, 255, 0.5);
  transition: background-color var(--transition-fast);
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
}

.gallery-carousel-wrapper .carousel-dots .slick-dots li button:hover {
  background-color: rgba(255, 255, 255, 0.8);
}

.gallery-carousel-wrapper .carousel-dots .slick-dots li.slick-active button {
  background-color: var(--color-white);
  border-color: var(--color-orange);
}

.gallery-carousel-wrapper .carousel-dots .slick-dots li button:before {
  display: none;
}

.carousel-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid transparent;
  background-color: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.carousel-dot:hover {
  background-color: rgba(255, 255, 255, 0.8);
}

.carousel-dot.is-active {
  background-color: var(--color-white);
  border-color: var(--color-orange);
}

@media (max-width: 768px) {
  .gallery-carousel-wrapper {
    padding-left: 0;
    padding-right: 0;
  }
  .carousel-nav-arrow.gallery-prev {
    left: 4px;
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
  }
  .carousel-nav-arrow.gallery-next {
    right: 4px;
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
  }
  .gallery-carousel-wrapper .carousel-nav-arrow svg {
    width: 18px;
    height: 18px;
  }
  .internal-page-hero {
    height: 240px;
  }
  .internal-page-hero-title {
    font-size: 32px;
    line-height: 1.2;
  }
  .internal-intro-section {
    padding: 48px 0 40px !important;
  }
  .internal-intro-text {
    font-size: 16px;
    padding: 0 8px;
  }
  .internal-main-image-section {
    padding-bottom: 64px !important;
  }
  .internal-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .internal-gallery-item {
    aspect-ratio: 4/3;
  }
  .lightbox-close {
    top: max(16px, env(safe-area-inset-top));
    right: max(16px, env(safe-area-inset-right));
    width: 44px;
    height: 44px;
  }
}
@media (max-width: 480px) {
  .gallery-carousel-wrapper {
    padding-left: 0;
    padding-right: 0;
  }
  .carousel-nav-arrow.gallery-prev {
    left: 4px;
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
  }
  .carousel-nav-arrow.gallery-next {
    right: 4px;
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
  }
  .gallery-carousel-wrapper .carousel-nav-arrow svg {
    width: 16px;
    height: 16px;
  }
  .internal-page-hero {
    height: 200px;
  }
  .internal-page-hero-title {
    font-size: 26px;
  }
  .internal-intro-section {
    padding: 32px 0 32px !important;
  }
  .internal-intro-text {
    font-size: 15px;
  }
  .internal-main-image-section {
    padding-bottom: 48px !important;
  }
  .internal-gallery-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .carousel-dots {
    bottom: max(16px, env(safe-area-inset-bottom));
  }
}
@media (max-width: 360px) {
  .internal-page-hero {
    height: 180px;
  }
  .internal-page-hero-title {
    font-size: 22px;
  }
}
/* ============================================
   Página 404
   ============================================ */
.error-404-section {
  padding-bottom: 100px !important;
}

.error-404-title {
  font-family: var(--font-title);
  font-size: 36px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-green-dark);
  text-align: center;
  margin-bottom: 16px;
}

.error-404-section .internal-intro-text {
  margin-bottom: 12px;
}

.error-404-text {
  text-align: center;
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--color-text-muted);
  max-width: 640px;
  margin: 0 auto 32px;
}

.error-404-text a {
  color: var(--color-green-medium);
  text-decoration: underline;
}

.error-404-text a:hover {
  color: var(--color-orange);
}

.error-404-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
}

.error-404-actions .call-to-action-button {
  display: inline-block;
  text-decoration: none;
}

@media (max-width: 480px) {
  .error-404-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .error-404-actions .call-to-action-button {
    text-align: center;
  }
}