/* ====================================================
   CANAL DO PANAMÁ - Estilos Globales
   ==================================================== */

/* ---------- Google Fonts ----------
   Display/Serif: Playfair Display (títulos elegantes)
   Sans (cuerpo y menú): Poppins
   Importadas en el <head> del HTML
*/

:root {
  /* Colores */
  --color-dark-navy: #1c2b4a;      /* Azul oscuro - footer CTA, iconos */
  --color-navy-darker: #16213a;
  --color-gold: #b8893f;            /* Dorado/mostaza - botones, acentos */
  --color-gold-light: #c9a25c;
  --color-cream: #f7f4ee;           /* Fondo crema general */
  --color-cream-soft: #f1ede3;
  --color-white: #ffffff;
  --color-text-dark: #1f2733;       /* Texto principal oscuro */
  --color-text-gray: #6b7177;       /* Texto secundario gris */
  --color-text-light: #8a8f94;
  --color-border: #e3ddd0;

  /* Tipografía */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Poppins', 'Helvetica Neue', Arial, sans-serif;

  /* Espaciados */
  --max-width: 1200px;
  --section-padding: 90px 24px;
}

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

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  color: var(--color-text-dark);
  background-color: var(--color-cream);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

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

a {
  text-decoration: none;
  color: inherit;
}

ul {
  list-style: none;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
}

/* ---------- Utilidades ---------- */

.eyebrow {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: 12px;
  display: block;
}

.section-title {
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: 600;
  color: var(--color-text-dark);
  line-height: 1.3;
}

.divider-star {
  display: inline-block;
  width: 60px;
  margin-top: 14px;
  position: relative;
  text-align: center;
}

.divider-star::before,
.divider-star::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 22px;
  height: 1px;
  background-color: var(--color-gold);
}

.divider-star::before {
  left: -22px;
}

.divider-star::after {
  right: -22px;
}

.divider-star span {
  color: var(--color-gold);
  font-size: 14px;
}

/* ---------- Botones ---------- */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 14px 28px;
  border-radius: 30px;
  transition: all 0.25s ease;
  white-space: nowrap;
}

.btn-gold {
  background-color: var(--color-gold);
  color: var(--color-white);
}

.btn-gold:hover {
  background-color: var(--color-gold-light);
  transform: translateY(-1px);
}

.btn-outline {
  background-color: transparent;
  color: var(--color-text-dark);
  border: 1px solid var(--color-border);
}

.btn-outline:hover {
  background-color: var(--color-white);
}

.btn-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* ---------- Header / Navbar ---------- */

.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background-color: rgba(247, 244, 238, 0.97);
  border-bottom: 1px solid var(--color-border);
}

.navbar {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  gap: 24px;
}

.logo {
  display: flex;
  align-items: center;
  gap: 14px;
}

.logo-icon {
  width: 110px;
  height: auto;
  flex-shrink: 0;
}

.logo-text {
  font-family: var(--font-display);
  line-height: 1.1;
}

.logo-text .logo-title {
  font-size: 19px;
  font-weight: 700;
  color: var(--color-text-dark);
  letter-spacing: 0.5px;
  display: block;
}

.logo-text .logo-subtitle {
  font-family: var(--font-body);
  font-size: 8.5px;
  font-weight: 500;
  letter-spacing: 1.5px;
  color: var(--color-text-gray);
  display: block;
  margin-top: 2px;
}

.nav-menu {
  display: flex;
  align-items: center;
  gap: 32px;
}

.nav-menu a {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--color-text-dark);
  display: flex;
  align-items: center;
  gap: 4px;
  transition: color 0.2s;
}

.nav-menu a.is-active-link {
  color: var(--color-gold);
}

.nav-menu a:hover {
  color: var(--color-gold);
}

.nav-menu .chevron {
  font-size: 9px;
  margin-top: 1px;
  display: inline-block;
  transition: transform 0.25s ease;
}

.has-dropdown.is-open .chevron {
  transform: rotate(180deg);
}

.nav-cta {
  display: flex;
  align-items: center;
}

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  z-index: 1100;
}

.nav-toggle span {
  width: 26px;
  height: 2px;
  background-color: var(--color-text-dark);
  transition: 0.3s;
}

/* ---------- Dropdown: Serviços ---------- */

.has-dropdown {
  position: relative;
}

.dropdown-menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
  min-width: 300px;
  padding: 8px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
  z-index: 1100;
}

.has-dropdown:hover .dropdown-menu,
.has-dropdown.is-open .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.dropdown-menu li {
  list-style: none;
}

.dropdown-menu a {
  display: block;
  padding: 11px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-dark);
  border-radius: 4px;
  line-height: 1.4;
  white-space: normal;
}

.dropdown-menu a:hover {
  background-color: var(--color-cream-soft);
  color: var(--color-gold);
}

/* ---------- Hero ---------- */

.hero {
  position: relative;
  overflow: hidden;
  min-height: 620px;
  display: flex;
  align-items: stretch;
}

/* Imagem de fundo ocupando 100% da seção */
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-bg img,
.hero-image-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 68% 30%;
  display: block;
}

.hero-image-placeholder {
  background: linear-gradient(135deg, #cfd9e3, #9fb1c2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #46546b;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  padding: 20px;
}

/* Degradê para garantir legibilidade do texto sobre a imagem */
.hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    var(--color-cream) 0%,
    rgba(247, 244, 238, 0.92) 28%,
    rgba(247, 244, 238, 0.55) 45%,
    rgba(247, 244, 238, 0.05) 62%,
    rgba(247, 244, 238, 0) 100%
  );
}

.hero-inner {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  padding: 60px 24px 50px;
}

.hero-content {
  max-width: 560px;
}

.hero-content h1 {
  font-family: var(--font-display);
  font-size: 42px;
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-text-dark);
  margin-bottom: 22px;
}

.hero-content p {
  font-size: 15.5px;
  color: var(--color-text-gray);
  max-width: 420px;
  margin-bottom: 28px;
}

.hero-features {
  display: flex;
  align-items: center;
  gap: 22px;
  margin-top: 36px;
  flex-wrap: wrap;
}

.hero-feature {
  display: flex;
  align-items: center;
  gap: 10px;
}

.hero-feature .feat-icon {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-gold);
  border-radius: 50%;
  color: var(--color-gold);
  font-size: 13px;
}

.hero-feature span.feat-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--color-text-dark);
  line-height: 1.3;
}

.hero-feature-divider {
  width: 1px;
  height: 28px;
  background-color: var(--color-border);
}

/* ---------- Services / Solutions Section ---------- */

.solutions {
  padding: var(--section-padding);
  background-color: var(--color-cream);
  text-align: center;
}

.solutions-header {
  max-width: 650px;
  margin: 0 auto 50px;
}

.solutions-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 18px;
  max-width: var(--max-width);
  margin: 0 auto;
}

.solution-card {
  background-color: var(--color-white);
  border-radius: 4px;
  overflow: hidden;
  text-align: left;
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
}

.solution-card-img {
  width: 100%;
  height: 110px;
  object-fit: cover;
  background: linear-gradient(135deg, #d8d2c2, #b9ad8f);
}

.solution-card-body {
  padding: 20px 16px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.solution-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background-color: var(--color-dark-navy);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  margin-bottom: 14px;
}

.solution-card-body h3 {
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  margin-bottom: 10px;
  line-height: 1.4;
}

.solution-card-body p {
  font-size: 12.5px;
  color: var(--color-text-gray);
  flex: 1;
  margin-bottom: 14px;
}

.solution-link {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-gold);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

/* ---------- Content / Video Section ---------- */

.content-video {
  position: relative;
  background-color: var(--color-cream-soft);
  padding: 90px 0;
  overflow: hidden;
  min-height: 520px;
}

.content-video-inner {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  align-items: center;
  height: 100%;
}

.content-video-text {
  padding: 0 24px;
  max-width: 420px;
}

.content-video-text h2 {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 18px;
}

.content-video-text p {
  font-size: 14.5px;
  color: var(--color-text-gray);
  margin-bottom: 26px;
  max-width: 380px;
}

.video-wrap {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 57%;
  z-index: 2;
  overflow: hidden;
}

.video-wrap img,
.video-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.video-placeholder {
  background: linear-gradient(135deg, #2c3e58, #4a5f7e);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 14px;
  text-align: center;
  padding: 20px;
}

/* ---------- Results / Testimonials Section ---------- */

.results {
  padding: var(--section-padding);
  background-color: var(--color-cream);
  text-align: center;
}

.results-header {
  max-width: 650px;
  margin: 0 auto 50px;
}

.results-carousel {
  max-width: var(--max-width);
  margin: 0 auto;
}

.results-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.result-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 40px 28px;
  text-align: center;
  box-shadow: 0 8px 24px rgba(28, 43, 74, 0.06);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.result-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 36px rgba(28, 43, 74, 0.12);
}

.result-icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background-color: var(--color-dark-navy);
  color: var(--color-gold-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  margin: 0 auto 18px;
}

.result-number {
  display: block;
  font-family: var(--font-display);
  font-size: 42px;
  font-weight: 700;
  color: var(--color-gold);
  line-height: 1.1;
  margin-bottom: 14px;
}

.result-card p {
  font-size: 14.5px;
  color: var(--color-text-dark);
  line-height: 1.6;
}

/* ---------- CTA Final Section ---------- */

.cta-final {
  position: relative;
  background-color: var(--color-dark-navy);
  color: var(--color-white);
  overflow: hidden;
  min-height: 280px;
}

.cta-final-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.cta-final-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
  display: block;
}

/* Overlay escuro para garantir contraste do texto e elementos sobre a imagem */
.cta-final-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    rgba(15, 22, 38, 0.92) 0%,
    rgba(15, 22, 38, 0.82) 35%,
    rgba(15, 22, 38, 0.7) 60%,
    rgba(15, 22, 38, 0.55) 100%
  );
}

.cta-final-inner {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr auto;
  gap: 40px;
  align-items: center;
  padding: 70px 24px;
}

.cta-final-text h2 {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 600;
  line-height: 1.35;
  margin-bottom: 18px;
}

.cta-final-text .mini-divider {
  width: 40px;
  height: 1px;
  background-color: var(--color-gold);
  margin-bottom: 18px;
}

.cta-final-text p {
  font-size: 14px;
  color: rgba(255,255,255,0.75);
  max-width: 340px;
}

.cta-final-contacts {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cta-contact-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 13.5px;
}

.cta-contact-item .ci-icon {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid var(--color-gold-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}

/* ---------- Footer ---------- */

.site-footer {
  background-color: var(--color-cream);
  padding: 36px 24px;
  border-top: 1px solid var(--color-border);
}

.footer-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}

.footer-socials {
  display: flex;
  gap: 14px;
}

.footer-socials a {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: var(--color-text-dark);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  transition: 0.2s;
}

.footer-socials a:hover {
  background-color: var(--color-gold);
}

.footer-links {
  display: flex;
  gap: 26px;
  align-items: center;
}

.footer-links a {
  font-size: 12.5px;
  color: var(--color-text-gray);
}

.footer-links a:hover {
  color: var(--color-gold);
}

.footer-copy {
  font-size: 12px;
  color: var(--color-text-light);
}

.footer-credit {
  font-size: 10.5px;
  color: var(--color-text-light);
  opacity: 0.7;
}

/* ====================================================
   PÁGINAS DE SERVIÇO (Imobiliário, Jurídico, Bancos, etc.)
   ==================================================== */

/* Usa exatamente a mesma paleta de cores do index (--color-gold,
   --color-dark-navy, etc.) para manter consistência visual total. */

/* ---------- Service Hero ---------- */

.service-hero {
  padding: 50px 24px 0;
  background-color: var(--color-cream);
}

.service-hero-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 50px;
  align-items: center;
}

.service-hero-content h1 {
  font-family: var(--font-display);
  font-size: 38px;
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-text-dark);
}

.service-hero-content h1 .highlight {
  color: var(--color-gold);
}

.divider-star-left {
  margin-left: 0;
  text-align: left;
  margin-top: 18px;
  margin-bottom: 18px;
}

.divider-star-left::before {
  display: none;
}

.divider-star-left::after {
  left: 30px;
  right: auto;
}

.service-hero-content p {
  font-size: 15px;
  color: var(--color-text-gray);
  max-width: 380px;
}

.service-hero-image-wrap {
  border-radius: 6px;
  overflow: hidden;
}

.service-hero-image-wrap img {
  width: 100%;
  height: 460px;
  object-fit: cover;
  display: block;
}

.service-hero-image-wrap img[src=""] {
  display: none;
}

/* ---------- Service Features (3 ícones com divisores) ---------- */

.service-features {
  padding: 50px 24px;
  background-color: var(--color-cream);
}

.service-features-inner {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 36px;
  padding-top: 30px;
  border-top: 1px solid var(--color-border);
  position: relative;
  flex-wrap: wrap;
}

.service-features-inner::before {
  content: '★';
  position: absolute;
  top: -11px;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--color-cream);
  color: var(--color-gold);
  font-size: 14px;
  padding: 0 14px;
}

.service-feature {
  display: flex;
  align-items: center;
  gap: 12px;
}

.service-feature-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1.5px solid var(--color-gold);
  color: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}

.service-feature-label {
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--color-text-dark);
  text-transform: uppercase;
}

.service-feature-divider {
  width: 1px;
  height: 26px;
  background-color: var(--color-border);
}

/* ---------- Golden Visa (card destaque) ---------- */

.golden-visa {
  padding: 0 24px 60px;
  background-color: var(--color-cream);
}

.golden-visa-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: 6px;
  overflow: hidden;
}

.golden-visa-text {
  background-color: var(--color-dark-navy);
  color: var(--color-white);
  display: grid;
  grid-template-columns: 240px 1fr;
  align-items: stretch;
}

.golden-visa-passport {
  height: 100%;
}

.golden-visa-passport img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 15% center;
  display: block;
  border-radius: 0;
  box-shadow: none;
}

.golden-visa-content {
  padding: 40px 32px;
}

.golden-visa-passport img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 180px;
  background: linear-gradient(135deg, #2c3e58, #4a5f7e);
  color: rgba(255, 255, 255, 0.7);
  font-size: 10px;
  text-align: center;
  padding: 10px;
}

.eyebrow-light {
  color: var(--color-gold);
}

.golden-visa-content h2 {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 14px;
}

.mini-divider-gold {
  width: 36px;
  height: 1px;
  background-color: var(--color-gold);
  margin-bottom: 18px;
}

.golden-visa-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.golden-visa-list li {
  font-size: 13.5px;
  color: rgba(255, 255, 255, 0.9);
  display: flex;
  align-items: center;
  gap: 10px;
}

.golden-visa-list li i {
  color: var(--color-gold);
  font-size: 14px;
}

.golden-visa-image img {
  width: 100%;
  height: 100%;
  min-height: 340px;
  object-fit: cover;
  display: block;
}

.golden-visa-image img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #2c3e58, #4a5f7e);
  color: rgba(255, 255, 255, 0.75);
  font-size: 13px;
  text-align: center;
  padding: 20px;
}

/* ---------- Service CTA Final (2 botões) ---------- */

.service-cta {
  padding: 60px 24px;
  background-color: var(--color-cream-soft);
}

.service-cta-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 40px;
}

.service-cta-text {
  display: flex;
  align-items: center;
  gap: 26px;
}

.service-cta-plant {
  width: 150px;
  flex-shrink: 0;
}

.service-cta-plant img {
  width: 100%;
}

.service-cta-plant img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100px;
  background-color: var(--color-cream-soft);
  border-radius: 50%;
  color: var(--color-text-light);
  font-size: 10px;
}

.service-cta-content h2 {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 600;
  line-height: 1.35;
  margin-bottom: 10px;
}

.service-cta-content p {
  font-size: 14px;
  color: var(--color-text-gray);
}

.service-cta-actions {
  display: flex;
  gap: 16px;
}

.cta-action-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 220px;
  padding: 24px 22px;
  border-radius: 6px;
  color: var(--color-white);
}

.cta-action-navy {
  background-color: var(--color-dark-navy);
}

.cta-action-gold {
  background-color: var(--color-gold);
}

.cta-action-icon {
  font-size: 20px;
  margin-bottom: 14px;
}

.cta-action-title {
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  line-height: 1.4;
  margin-bottom: 10px;
}

.cta-action-desc {
  font-size: 12px;
  line-height: 1.5;
  opacity: 0.85;
  margin-bottom: 18px;
}

.cta-action-arrow {
  font-size: 16px;
  margin-top: auto;
}

/* ====================================================
   SERVIÇO: ESTRUTURAS JURÍDICAS INTERNACIONAIS
   ==================================================== */

/* Hero com título em duas cores (dourado + escuro) */

.service-hero-title-gold {
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-gold);
  text-transform: uppercase;
  margin-bottom: 0;
}

.service-hero-title-dark {
  color: var(--color-text-dark);
}

.service-hero-subtitle {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--color-text-dark);
  line-height: 1.4;
  margin-bottom: 16px;
}

/* ---------- Jurisdições Internacionais ---------- */

.jurisdictions {
  padding: 50px 24px 40px;
  background-color: var(--color-cream);
}

.jurisdictions-header {
  max-width: 700px;
  margin: 0 auto 40px;
  display: flex;
  align-items: center;
  gap: 18px;
}

.jurisdictions-line {
  flex: 1;
  height: 1px;
  background-color: var(--color-border);
}

.jurisdictions-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--color-gold);
  text-transform: uppercase;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 8px;
}

.jurisdictions-list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 28px;
  max-width: var(--max-width);
  margin: 0 auto;
  flex-wrap: wrap;
}

.jurisdiction-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--color-text-dark);
}

.jurisdiction-icon {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1.5px solid var(--color-gold);
  color: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}

.jurisdiction-divider {
  width: 1px;
  height: 22px;
  background-color: var(--color-border);
}

/* ---------- Estruturas utilizadas para ---------- */

.structures-uses {
  padding: 50px 24px 60px;
  background-color: var(--color-cream);
  text-align: center;
}

.structures-uses-title {
  font-size: 28px;
}

.structures-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
  max-width: var(--max-width);
  margin: 40px auto 0;
}

.structure-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.structure-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gold);
  font-size: 26px;
}

.structure-label {
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--color-text-dark);
  line-height: 1.5;
}

/* ---------- Aviso Importante ---------- */

.legal-notice-wrap {
  padding: 60px 24px 50px;
  background-color: var(--color-cream);
}

.legal-notice {
  max-width: var(--max-width);
  margin: 0 auto;
  background-color: var(--color-cream-soft);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 32px;
  display: flex;
  align-items: flex-start;
  gap: 28px;
}

.legal-notice-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  border: 1.5px solid var(--color-gold);
  color: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  flex-shrink: 0;
}

.legal-notice-title {
  display: block;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--color-gold);
  text-transform: uppercase;
  margin-bottom: 10px;
}

.legal-notice-text p {
  font-size: 13.5px;
  color: var(--color-text-gray);
  margin-bottom: 8px;
  line-height: 1.6;
}

.legal-notice-text p:last-child {
  margin-bottom: 0;
}

/* ====================================================
   SERVIÇO: SERVIÇOS FINANCEIROS INTERNACIONAIS
   ==================================================== */

/* Hero full-bleed: imagem ocupa 100% da seção, texto em overlay.
   A imagem já vem com degradê claro incorporado do lado esquerdo
   (fundo desta página é claro, diferente do hero escuro de outras). */

.financial-hero {
  position: relative;
  overflow: hidden;
  min-height: 560px;
  display: flex;
  align-items: stretch;
  background-color: var(--color-cream);
}

.financial-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.financial-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Variante para imagens que NÃO trazem degradê incorporado —
   adiciona overlay para garantir legibilidade do texto. */
.financial-hero-needs-overlay .financial-hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    var(--color-cream) 0%,
    rgba(247, 244, 238, 0.92) 28%,
    rgba(247, 244, 238, 0.55) 45%,
    rgba(247, 244, 238, 0.05) 62%,
    rgba(247, 244, 238, 0) 100%
  );
}

.financial-hero-inner {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  padding: 60px 24px;
}

.financial-hero-content {
  max-width: 480px;
}

/* Hero com título em 3 linhas, linha do meio em dourado */

.service-hero-title-stack {
  font-family: var(--font-display);
  font-size: 40px;
  font-weight: 600;
  line-height: 1.2;
  color: var(--color-text-dark);
}

.service-hero-title-accent {
  color: var(--color-gold);
}

.service-hero-lead {
  font-size: 15px;
  color: var(--color-text-dark);
  max-width: 380px;
  margin-bottom: 16px;
}

/* ---------- Soluções que conectam (fila de 5 com divisores) ---------- */

.financial-solutions {
  padding: 50px 24px 60px;
  background-color: var(--color-cream);
  text-align: center;
}

.financial-solutions-title {
  font-size: 26px;
}

.financial-solutions-row {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  max-width: var(--max-width);
  margin: 40px auto 0;
}

.financial-solution-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  flex: 1;
  padding: 0 16px;
}

.financial-solution-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gold);
  font-size: 26px;
}

.financial-solution-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--color-text-dark);
  line-height: 1.5;
}

.financial-solution-divider {
  width: 1px;
  align-self: stretch;
  background-color: var(--color-border);
  margin-top: 28px;
}

/* ====================================================
   SERVIÇO: INVESTIMENTOS E GESTÃO PATRIMONIAL
   ==================================================== */

/* ---------- Header escuro (exclusivo desta página) ---------- */

.site-header-dark {
  background-color: var(--color-dark-navy);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.site-header-dark .logo-title {
  color: var(--color-white);
}

.site-header-dark .logo-subtitle {
  color: rgba(255, 255, 255, 0.6);
}

@media (min-width: 769px) {
  .site-header-dark .nav-menu a {
    color: var(--color-white);
  }

  .site-header-dark .nav-menu a:hover {
    color: var(--color-gold-light);
  }
}

.site-header-dark .dropdown-menu a {
  color: var(--color-text-dark);
}

.site-header-dark .nav-toggle span {
  background-color: var(--color-white);
}

/* ---------- Hero escuro com imagem de fundo ---------- */

.dark-hero {
  position: relative;
  overflow: hidden;
  min-height: 560px;
  background-color: var(--color-dark-navy);
  display: flex;
  align-items: stretch;
}

.dark-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.dark-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.dark-hero-bg img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #16213a, #2c3e58);
  color: rgba(255, 255, 255, 0.6);
  font-size: 14px;
  text-align: center;
  padding: 20px;
}

/* Nota: a imagem enviada já vem com o degradê escuro incorporado do lado
   esquerdo, então não aplicamos overlay adicional aqui (evita escurecer demais). */

.dark-hero-inner {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  padding: 60px 24px;
}

.dark-hero-content {
  max-width: 480px;
}

.dark-hero-content h1 {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-white);
  margin-bottom: 20px;
}

.dark-hero-content h1 .highlight {
  color: var(--color-gold-light);
}

.dark-hero-content p {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 14px;
}

.divider-star-dark::after {
  background-color: var(--color-gold-light);
}

.divider-star-dark span {
  color: var(--color-gold-light);
}

/* ---------- Soluções para investidores (fila de 4 com divisores) ---------- */

.investor-solutions {
  padding: 50px 24px 60px;
  background-color: var(--color-cream);
  text-align: center;
}

.investor-solutions-title {
  font-size: 26px;
}

.investor-solutions-row {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  max-width: 900px;
  margin: 40px auto 0;
}

.investor-solution-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  flex: 1;
  padding: 0 16px;
}

.investor-solution-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gold);
  font-size: 26px;
}

.investor-solution-label {
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--color-text-dark);
  line-height: 1.5;
}

.investor-solution-divider {
  width: 1px;
  align-self: stretch;
  background-color: var(--color-border);
  margin-top: 28px;
}

/* ---------- Gestão Patrimonial (imagem + texto) ---------- */

.wealth-management {
  padding: 0 24px 60px;
  background-color: var(--color-cream-soft);
  padding-top: 60px;
}

.wealth-management-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.wealth-management-image img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  border-radius: 6px;
  display: block;
}

.wealth-management-image img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #2c3e58, #4a5f7e);
  color: rgba(255, 255, 255, 0.75);
  font-size: 13px;
  text-align: center;
  padding: 20px;
}

.wealth-management-text h2 {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-text-dark);
  margin-bottom: 16px;
}

.wealth-management-text p {
  font-size: 14.5px;
  color: var(--color-text-gray);
  margin-top: 20px;
}

/* ---------- Variante do ícone de aviso (warning) ---------- */

.legal-notice-icon-warning {
  font-size: 22px;
}

/* ---------- Variante compacta do CTA (sem descrição) ---------- */

.cta-action-compact {
  flex-direction: row;
  align-items: center;
  gap: 16px;
  width: auto;
  padding: 18px 26px;
}

.cta-action-compact .cta-action-icon {
  margin-bottom: 0;
  font-size: 22px;
}

.cta-action-compact .cta-action-title {
  margin-bottom: 0;
  font-size: 13px;
}

/* ====================================================
   SERVIÇO: ZONAS FRANCAS E MERCOSUL (EXPORTAÇÃO)
   ==================================================== */

/* ---------- Header sólido (cor navy) sobre o hero ---------- */

.site-header-transparent {
  background-color: var(--color-dark-navy);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  position: absolute;
  width: 100%;
}

.btn-outline-gold {
  background-color: transparent;
  border: 1px solid var(--color-gold-light);
  color: var(--color-white);
}

.btn-outline-gold:hover {
  background-color: var(--color-gold);
  border-color: var(--color-gold);
}

/* ---------- Hero de exportação ---------- */

.export-hero {
  position: relative;
  overflow: hidden;
  min-height: 560px;
  background-color: var(--color-dark-navy);
}

.export-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.export-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.export-hero-bg img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #16213a, #2c3e58);
  color: rgba(255, 255, 255, 0.6);
  font-size: 14px;
  text-align: center;
  padding: 20px;
}

/* Nota: a imagem enviada já vem com o degradê escuro incorporado do lado
   esquerdo, então não aplicamos overlay adicional aqui (evita escurecer demais). */

.export-hero-inner {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 140px 24px 90px;
}

.export-hero-content {
  max-width: 480px;
}

.export-hero-content h1 {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-white);
  margin-bottom: 18px;
}

.export-hero-content h1 .highlight {
  color: var(--color-gold-light);
}

.export-hero-content p {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.8);
}

/* ---------- Card de estatísticas (sobreposto) ---------- */
/* Usa margin-top negativo em vez de position:absolute — assim a altura
   real do conteúdo nunca é cortada, independente do breakpoint. */

.stats-card {
  position: relative;
  z-index: 2;
  padding: 0 24px;
  margin-top: -70px;
}

.stats-grid {
  max-width: var(--max-width);
  margin: 0 auto;
  background-color: var(--color-white);
  border-radius: 8px;
  box-shadow: 0 24px 50px rgba(0, 0, 0, 0.18);
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  padding: 32px 20px;
}

.stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 4px;
  padding: 0 12px;
  border-right: 1px solid var(--color-border);
}

.stat-item:last-child {
  border-right: none;
}

.stat-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1.5px solid var(--color-gold);
  color: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  margin-bottom: 8px;
}

.stat-label-top {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--color-text-gray);
  letter-spacing: 0.3px;
}

.stat-number {
  font-family: var(--font-display);
  font-size: 30px;
  font-weight: 700;
  color: var(--color-gold);
  line-height: 1.1;
}

.stat-number-small {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--color-gold);
}

.stat-number-inline {
  font-size: 13px;
  color: var(--color-text-dark);
  font-weight: 500;
}

.stat-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--color-text-dark);
  line-height: 1.4;
  margin-top: 2px;
}

.stat-mini-divider {
  width: 22px;
  height: 1px;
  background-color: var(--color-border);
  margin: 6px 0;
}

.stat-desc {
  font-size: 11px;
  color: var(--color-text-gray);
  line-height: 1.5;
  margin-top: 4px;
}

/* ---------- CTA + imagem da ponte ---------- */

.export-cta {
  position: relative;
  background-color: var(--color-cream-soft);
  padding: 60px 24px;
  overflow: hidden;
  min-height: 600px;
}

.export-cta-map {
  position: absolute;
  top: 0;
  left: 0;
  width: 45%;
  height: 100%;
  background-color: var(--color-dark-navy);
  opacity: 0.04;
  z-index: 0;
}

/* Imagem full-bleed: cobre todo o lado direito da seção, do topo até a base,
   sem respeitar o max-width do conteúdo central. */
.export-cta-image {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 55%;
  z-index: 0;
}

.export-cta-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.export-cta-image img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #2c3e58, #4a5f7e);
  color: rgba(255, 255, 255, 0.75);
  font-size: 13px;
  text-align: center;
  padding: 20px;
}

.export-cta-inner {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin: 0 auto;
}

.export-cta-actions {
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 460px;
}

.export-cta-actions .cta-action-card {
  width: 100%;
}

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

@media (max-width: 1024px) {
  .solutions-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .results-grid {
    grid-template-columns: 1fr;
  }

  .cta-final-inner {
    grid-template-columns: 1fr;
    text-align: left;
  }

  .content-video {
    min-height: 0;
    padding: 60px 24px;
  }

  .content-video-inner {
    grid-template-columns: 1fr;
    height: auto;
  }

  .content-video-text {
    padding: 0;
    max-width: 100%;
  }

  .video-wrap {
    position: relative;
    width: 100%;
    height: 320px;
    margin-top: 36px;
    border-radius: 4px;
    inset: auto;
  }

  .hero {
    min-height: 0;
    display: block;
  }

  .hero-bg {
    position: relative;
    height: 360px;
  }

  .hero-bg::after {
    background: linear-gradient(
      180deg,
      rgba(247, 244, 238, 0.15) 0%,
      rgba(247, 244, 238, 0.55) 65%,
      var(--color-cream) 100%
    );
  }

  .hero-inner {
    position: static;
    align-items: flex-start;
    padding: 28px 24px 50px;
  }

  .hero-content {
    max-width: 100%;
  }

  .hero-content h1 {
    font-size: 26px;
    margin-bottom: 14px;
  }

  .hero-content p {
    font-size: 14px;
    margin-bottom: 22px;
  }
}

@media (max-width: 768px) {
  .btn {
    white-space: normal;
    text-align: center;
    padding: 13px 22px;
    font-size: 12px;
  }

  .nav-menu {
    position: fixed;
    top: 0;
    right: -100%;
    height: 100vh;
    width: 300px;
    max-width: 85vw;
    background-color: var(--color-cream);
    flex-direction: column;
    align-items: flex-start;
    padding: 100px 28px 32px;
    transition: right 0.3s ease;
    box-shadow: -4px 0 20px rgba(0,0,0,0.08);
    z-index: 1200;
    overflow-y: auto;
  }

  .nav-menu.is-open {
    right: 0;
  }

  /* Bloqueia o scroll do body quando o menu está aberto */
  body.nav-is-open {
    overflow: hidden;
  }

  .nav-toggle {
    display: flex;
  }

  .nav-cta {
    display: none;
  }

  /* Dropdown em mobile: expande verticalmente dentro do menu */
  .has-dropdown {
    width: 100%;
  }

  .nav-menu li {
    width: 100%;
  }

  .dropdown-menu {
    position: static;
    transform: none;
    box-shadow: none;
    border: none;
    background-color: var(--color-cream);
    min-width: 0;
    width: 100%;
    padding: 0;
    margin: 0;
    opacity: 1;
    visibility: visible;
    display: none;
  }

  .has-dropdown.is-open .dropdown-menu {
    display: block;
    padding-top: 4px;
    padding-bottom: 6px;
    transform: none;
  }

  .dropdown-menu li {
    width: 100%;
  }

  .dropdown-menu a {
    display: block;
    padding: 10px 0 10px 16px;
    font-size: 12.5px;
    color: var(--color-text-gray);
    background-color: transparent;
    border-left: 2px solid var(--color-border);
    white-space: normal;
    line-height: 1.4;
  }

  .dropdown-menu a:hover {
    color: var(--color-gold);
    border-left-color: var(--color-gold);
    background-color: transparent;
  }

  .solutions-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .hero-content h1 {
    font-size: 32px;
  }

  .section-title {
    font-size: 28px;
  }

  .footer-inner {
    flex-direction: column;
    text-align: center;
  }
}

@media (max-width: 480px) {
  .navbar {
    padding: 14px 16px;
    gap: 12px;
  }

  .logo-icon {
    width: 90px;
  }

  .logo-text .logo-title {
    font-size: 16px;
  }

  .logo-text .logo-subtitle {
    font-size: 7px;
    letter-spacing: 1px;
  }

  .solutions-grid {
    grid-template-columns: 1fr;
  }

  .hero-bg {
    height: 300px;
  }

  .hero-content h1 {
    font-size: 24px;
  }

  .hero-features {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: nowrap;
  }

  .hero-feature {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    flex: 1;
    min-width: 0;
  }

  .hero-feature .feat-icon {
    width: 26px;
    height: 26px;
    font-size: 11px;
  }

  .hero-feature span.feat-label {
    font-size: 9.5px;
    line-height: 1.25;
  }

  .hero-feature-divider {
    display: none;
  }
}

/* ---------- Responsive: Páginas de Serviço ---------- */

@media (max-width: 1024px) {
  .service-hero-inner {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .service-hero-image-wrap img {
    height: 360px;
  }

  .golden-visa-inner {
    grid-template-columns: 1fr;
  }

  .golden-visa-text {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .golden-visa-passport {
    height: 280px;
  }

  .golden-visa-image img {
    min-height: 280px;
  }

  .service-cta-inner {
    grid-template-columns: 1fr;
  }

  .service-cta-actions {
    width: 100%;
  }

  .cta-action-card {
    flex: 1;
    width: auto;
  }

  .export-cta-actions .cta-action-card {
    width: 100%;
    flex: none;
  }
}

@media (max-width: 768px) {
  .service-hero-content h1 {
    font-size: 30px;
  }

  .service-features-inner {
    flex-direction: column;
    gap: 20px;
  }

  .service-feature-divider {
    display: none;
  }

  .golden-visa-content {
    padding: 32px 22px;
  }

  .service-cta-text {
    flex-direction: column;
    text-align: center;
  }

  .service-cta-actions {
    flex-direction: column;
  }
}

@media (max-width: 480px) {
  .service-hero-image-wrap img {
    height: 260px;
  }

  .golden-visa-passport {
    height: 220px;
  }
}

/* ---------- Responsive: Estruturas Jurídicas ---------- */

@media (max-width: 1024px) {
  .structures-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
  }

  .jurisdictions-list {
    gap: 18px;
  }
}

@media (max-width: 768px) {
  .service-hero-title-gold {
    font-size: 28px;
  }

  .service-hero-subtitle {
    font-size: 19px;
  }

  .jurisdictions-header {
    flex-direction: column;
    gap: 12px;
  }

  .jurisdictions-line {
    display: none;
  }

  .jurisdiction-divider {
    display: none;
  }

  .jurisdictions-list {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    padding-left: 10%;
  }

  .structures-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .legal-notice {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
}

@media (max-width: 480px) {
  .structures-grid {
    grid-template-columns: 1fr;
  }

  .legal-notice {
    padding: 24px 18px;
  }
}

/* ---------- Responsive: Serviços Financeiros Internacionais ---------- */

@media (max-width: 1024px) {
  .financial-solutions-row {
    flex-wrap: wrap;
    gap: 30px;
  }

  .financial-solution-item {
    flex: 0 0 calc(33.333% - 20px);
    padding: 0;
  }

  .financial-solution-divider {
    display: none;
  }
}

@media (max-width: 768px) {
  .service-hero-title-stack {
    font-size: 30px;
  }

  .financial-solution-item {
    flex: 0 0 calc(50% - 15px);
  }
}

@media (max-width: 480px) {
  .financial-solution-item {
    flex: 0 0 100%;
  }
}

/* ---------- Responsive: Investimentos e Gestão Patrimonial ---------- */

@media (max-width: 1024px) {
  .dark-hero {
    min-height: 480px;
  }

  .investor-solutions-row {
    flex-wrap: wrap;
    gap: 30px;
  }

  .investor-solution-item {
    flex: 0 0 calc(50% - 15px);
    padding: 0;
  }

  .investor-solution-divider {
    display: none;
  }

  .wealth-management-inner {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}

@media (max-width: 768px) {
  .dark-hero-content h1 {
    font-size: 26px;
  }

  /* Em mobile a imagem é recortada de forma mais vertical, então
     reforçamos a legibilidade com um overlay sutil adicional. */
  .dark-hero-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
      180deg,
      rgba(16, 24, 42, 0.45) 0%,
      rgba(16, 24, 42, 0.65) 50%,
      rgba(16, 24, 42, 0.85) 85%
    );
  }

  .dark-hero-inner {
    align-items: flex-end;
    padding-bottom: 40px;
  }

  .cta-action-compact {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .investor-solution-item {
    flex: 0 0 100%;
  }

  .wealth-management-image img {
    height: 260px;
  }
}

/* ---------- Responsive: Zonas Francas e Mercosul (Exportação) ---------- */

@media (max-width: 1200px) {
  .stats-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .stat-item {
    gap: 10px;
    padding: 28px 16px;
    border-right: none;
    border-bottom: 1px solid var(--color-border);
  }

  .stat-icon {
    margin-bottom: 4px;
  }

  .stat-number {
    font-size: 32px;
  }

  .stat-label {
    font-size: 12px;
  }

  .stat-desc {
    font-size: 12px;
    line-height: 1.6;
  }

  .stat-mini-divider {
    margin: 10px 0;
  }

  .stat-desc {
    margin-top: 8px;
  }
}

@media (max-width: 1024px) {
  .export-cta {
    min-height: 0;
    padding-bottom: 0;
  }

  .export-cta-image {
    position: relative;
    width: 100%;
    height: 360px;
    margin-top: 40px;
    margin-bottom: 24px;
    inset: auto;
  }

  .export-cta-image img {
    border-radius: 6px;
  }

  .export-cta-actions {
    max-width: 100%;
  }
}

@media (max-width: 768px) {
  .site-header-transparent {
    position: relative;
    background-color: var(--color-dark-navy);
  }

  .export-hero-content h1 {
    font-size: 26px;
  }

  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .stats-card {
    margin-top: -40px;
  }
}

@media (max-width: 480px) {
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .stat-item {
    padding: 26px 20px;
  }
}

/* ---------- Responsive: Hero full-bleed (Serviços/Imobiliário/Jurídico) ---------- */

@media (max-width: 768px) {
  .financial-hero {
    min-height: 480px;
  }

  /* Imagens com degradê próprio (globo, escritório): reforço sutil em mobile,
     já que o recorte vertical reduz a área escura/clara natural da imagem. */
  .financial-hero-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
      180deg,
      rgba(247, 244, 238, 0.25) 0%,
      rgba(247, 244, 238, 0.6) 55%,
      var(--color-cream) 90%
    );
  }

  /* Imagens sem degradê próprio (ex: imóvel): overlay mais forte para
     garantir legibilidade total do texto. */
  .financial-hero-needs-overlay .financial-hero-bg::after {
    background: linear-gradient(
      180deg,
      rgba(247, 244, 238, 0.4) 0%,
      rgba(247, 244, 238, 0.8) 55%,
      var(--color-cream) 90%
    );
  }

  .service-hero-title-stack {
    font-size: 28px;
  }
}

/* ====================================================
   PÁGINA: SOBRE
   ==================================================== */

/* ---------- Hero (full-bleed, imagem à esquerda / texto à direita) ---------- */

.about-hero {
  position: relative;
  min-height: 620px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background-color: var(--color-cream-soft);
}

.about-hero-image {
  position: relative;
  overflow: hidden;
}

.about-hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-hero-image img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #2c3e58, #4a5f7e);
  color: rgba(255, 255, 255, 0.75);
  font-size: 13px;
  text-align: center;
  padding: 20px;
}

.about-hero-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 70px;
}

.about-hero-content .eyebrow {
  font-size: 14.5px;
}

.about-hero-content h1 {
  font-family: var(--font-display);
  font-size: 38px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-text-dark);
  margin-bottom: 24px;
}

.about-hero-content p {
  font-size: 16px;
  color: var(--color-text-gray);
  margin-bottom: 16px;
  max-width: 520px;
  line-height: 1.7;
}

.about-hero-features {
  display: flex;
  gap: 40px;
  margin-top: 32px;
}

.about-hero-feature {
  display: flex;
  align-items: center;
  gap: 12px;
}

.about-hero-feature .feat-icon {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-gold);
  border-radius: 50%;
  color: var(--color-gold);
  font-size: 16px;
}

.about-hero-feature .feat-label {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--color-text-dark);
  line-height: 1.4;
}

/* ---------- Mini consulting cards (dentro do hero) ---------- */

.mini-consulting-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 28px;
}

.mini-consulting-card {
  border-radius: 8px;
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
}

.mini-consulting-card-dark {
  background-color: var(--color-dark-navy);
}

.mini-consulting-card-light {
  background-color: var(--color-cream-soft);
  border: 1px solid var(--color-border);
}

.mini-consulting-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1.5px solid var(--color-gold);
  color: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  margin-bottom: 10px;
}

.mini-consulting-card .eyebrow {
  font-size: 10.5px;
  margin-bottom: 2px;
}

.mini-consulting-card-dark .eyebrow-light {
  color: var(--color-gold-light);
}

.mini-consulting-card-dark h3 {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 8px;
}

.mini-consulting-card-light h3 {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 700;
  color: var(--color-text-dark);
  margin-bottom: 8px;
}

.mini-consulting-card-dark p {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 14px;
  line-height: 1.5;
}

.mini-consulting-card-light p {
  font-size: 12px;
  color: var(--color-text-gray);
  margin-bottom: 14px;
  line-height: 1.5;
}

.mini-consulting-card .btn {
  font-size: 11px;
  padding: 10px 18px;
  align-self: flex-start;
}

/* ---------- Chegar ao Panamá + Consultorias ---------- */

.about-consulting {
  padding: 70px 24px 0;
  background-color: var(--color-cream);
}

.about-consulting-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 50px;
  align-items: start;
}

.about-consulting-text {
  border-left: 3px solid var(--color-gold);
  padding-left: 28px;
}

.about-consulting-text h2 {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 600;
  line-height: 1.35;
  color: var(--color-text-dark);
}

.about-consulting-text h2 .highlight {
  color: var(--color-gold);
}

.about-consulting-text p {
  font-size: 14px;
  color: var(--color-text-gray);
  margin-top: 18px;
}

.about-consulting-bold {
  font-weight: 700;
  color: var(--color-text-dark) !important;
}

/* ---------- Consulting cards (imagem full-bleed, header/footer flutuando) ---------- */

.consulting-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.consulting-card {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  min-height: 640px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.consulting-card-dark {
  background-color: var(--color-dark-navy);
}

.consulting-card-light {
  background-color: var(--color-cream-soft);
  border: 1px solid var(--color-border);
}

/* Imagem cobre toda a área entre o header e o footer (não a tarjeta inteira),
   já que header e footer têm fundo transparente e flutuam por cima dela. */
.consulting-card-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.consulting-card-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.consulting-card-dark .consulting-card-bg img {
  object-position: center 15%;
}

.consulting-card-header {
  position: relative;
  z-index: 1;
  padding: 28px 26px 0;
}

.consulting-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--color-gold);
  color: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  margin-bottom: 14px;
  background-color: rgba(0, 0, 0, 0.15);
  backdrop-filter: blur(2px);
}

.consulting-card-light .consulting-card-icon {
  background-color: rgba(255, 255, 255, 0.5);
}

.consulting-card-dark .eyebrow-light {
  color: var(--color-gold-light);
}

.consulting-card-dark h3 {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--color-white);
  margin-top: 2px;
}

.consulting-card-light h3 {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--color-text-dark);
  margin-top: 2px;
}

.consulting-card .mini-divider-gold {
  margin: 14px 0 0;
}

.consulting-card-footer {
  position: relative;
  z-index: 1;
  padding: 16px 26px 28px;
}

.consulting-card-dark .consulting-card-footer {
  background: linear-gradient(180deg, transparent 0%, rgba(10, 16, 30, 0.5) 30%, rgba(10, 16, 30, 0.95) 100%);
  padding-top: 70px;
  margin-top: -70px;
}

.consulting-card-light .consulting-card-footer {
  background: linear-gradient(180deg, transparent 0%, rgba(241, 237, 227, 0.65) 30%, var(--color-cream-soft) 100%);
  padding-top: 70px;
  margin-top: -70px;
}

.consulting-card-dark .consulting-card-footer p {
  font-size: 13.5px;
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 20px;
  line-height: 1.6;
}

.consulting-card-light .consulting-card-footer p {
  font-size: 13.5px;
  color: var(--color-text-dark);
  margin-bottom: 20px;
  line-height: 1.6;
}

.consulting-card-footer .btn {
  width: 100%;
  justify-content: center;
}

/* ---------- Fila final de 4 ícones ---------- */

.about-final-features {
  max-width: var(--max-width);
  margin: 60px auto 0;
  padding: 36px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  border-top: 1px solid var(--color-border);
}

.about-final-feature {
  display: flex;
  align-items: center;
  gap: 12px;
}

.about-final-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1.5px solid var(--color-dark-navy);
  color: var(--color-dark-navy);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}

.about-final-label {
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--color-text-dark);
  line-height: 1.4;
}

.about-final-divider {
  width: 1px;
  height: 28px;
  background-color: var(--color-border);
}

/* ---------- Responsive: Sobre ---------- */

@media (max-width: 1024px) {
  .about-hero {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .about-hero-image {
    height: 420px;
  }

  .about-hero-content {
    padding: 48px 40px;
  }

  .about-consulting-inner {
    grid-template-columns: 1fr;
  }

  .consulting-cards {
    max-width: 600px;
    margin: 0 auto;
  }

  .about-final-features {
    flex-wrap: wrap;
    gap: 24px;
  }
}

@media (max-width: 768px) {
  .about-hero-content {
    padding: 40px 24px;
  }

  .about-hero-content h1 {
    font-size: 26px;
  }

  .about-hero-features {
    flex-wrap: wrap;
    gap: 18px;
  }

  .mini-consulting-cards {
    grid-template-columns: 1fr;
  }

  .about-consulting {
    padding-top: 50px;
  }

  .about-consulting-text {
    padding-left: 18px;
  }

  .about-consulting-text h2 {
    font-size: 24px;
  }

  .consulting-cards {
    grid-template-columns: 1fr;
  }

  .about-final-features {
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
  }

  .about-final-divider {
    display: none;
  }
}

@media (max-width: 480px) {
  .about-hero-image {
    height: 300px;
  }

  .about-hero-content {
    padding: 32px 20px;
  }

  .consulting-card {
    min-height: 500px;
  }
}

/* ====================================================
   PÁGINA: CONTEÚDOS
   ==================================================== */

.ebooks {
  padding: 70px 24px;
  background-color: var(--color-cream);
}

.ebooks-header {
  max-width: 650px;
  margin: 0 auto 50px;
  text-align: center;
}

.ebooks-header .divider-star {
  margin-bottom: 18px;
}

.ebooks-header p {
  font-size: 14.5px;
  color: var(--color-text-gray);
  margin-top: 16px;
}

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

.ebook-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.ebook-card-image {
  position: relative;
  width: 100%;
  height: 220px;
}

.ebook-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ebook-card-image img[src=""] {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #2c3e58, #4a5f7e);
  color: rgba(255, 255, 255, 0.75);
  font-size: 12px;
  text-align: center;
  padding: 16px;
}

.ebook-card-icon {
  position: absolute;
  bottom: -22px;
  left: 24px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background-color: var(--color-gold);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  border: 4px solid var(--color-white);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
}

.ebook-card-body {
  padding: 40px 24px 26px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.ebook-card-body h3 {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--color-text-dark);
  margin-bottom: 14px;
}

.ebook-card-body h3 .highlight {
  color: var(--color-gold);
  display: block;
  margin-top: 2px;
}

.ebook-card-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}

.ebook-card-list li {
  font-size: 13px;
  color: var(--color-text-dark);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.5;
}

.ebook-card-list li i {
  color: var(--color-gold);
  font-size: 12px;
  margin-top: 3px;
  flex-shrink: 0;
}

.ebook-card-body p {
  font-size: 13px;
  color: var(--color-text-gray);
  flex: 1;
  margin-bottom: 20px;
  line-height: 1.6;
}

.ebook-card-body .btn {
  align-self: flex-start;
  width: 100%;
  justify-content: center;
}

/* ---------- Responsive: Conteúdos ---------- */

@media (max-width: 1024px) {
  .ebooks-grid {
    grid-template-columns: 1fr;
    max-width: 500px;
  }
}

@media (max-width: 480px) {
  .ebook-card-image {
    height: 200px;
  }

  .ebook-card-icon {
    width: 48px;
    height: 48px;
    font-size: 18px;
    left: 18px;
  }

  .ebook-card-body {
    padding: 34px 18px 22px;
  }
}

/* ====================================================
   ANIMAÇÃO: Fade-in ao rolar a página
   ==================================================== */

/* Estado inicial (oculto) — aplicado via JS para não afetar
   usuários sem JavaScript habilitado (graceful degradation). */
.fade-in-up,
.fade-in-left,
.fade-in-right {
  opacity: 0;
  transition: opacity 0.7s ease, transform 0.7s ease;
  will-change: opacity, transform;
}

.fade-in-up {
  transform: translateY(28px);
}

.fade-in-left {
  transform: translateX(-32px);
}

.fade-in-right {
  transform: translateX(32px);
}

/* Estado final (visível) — adicionado pelo JS quando o elemento
   entra na viewport. */
.fade-in-up.is-visible,
.fade-in-left.is-visible,
.fade-in-right.is-visible {
  opacity: 1;
  transform: none;
}

/* Respeita a preferência do usuário por menos movimento */
/* Stagger: pequeno atraso escalonado para grids de cards, criando
   um efeito de cascata em vez de tudo aparecer ao mesmo tempo. */
.solutions-grid .fade-in-up:nth-child(1) { transition-delay: 0s; }
.solutions-grid .fade-in-up:nth-child(2) { transition-delay: 0.08s; }
.solutions-grid .fade-in-up:nth-child(3) { transition-delay: 0.16s; }
.solutions-grid .fade-in-up:nth-child(4) { transition-delay: 0.24s; }
.solutions-grid .fade-in-up:nth-child(5) { transition-delay: 0.32s; }
.solutions-grid .fade-in-up:nth-child(6) { transition-delay: 0.4s; }

.results-grid .fade-in-up:nth-child(1) { transition-delay: 0s; }
.results-grid .fade-in-up:nth-child(2) { transition-delay: 0.1s; }
.results-grid .fade-in-up:nth-child(3) { transition-delay: 0.2s; }

.structures-grid .fade-in-up:nth-child(1) { transition-delay: 0s; }
.structures-grid .fade-in-up:nth-child(2) { transition-delay: 0.08s; }
.structures-grid .fade-in-up:nth-child(3) { transition-delay: 0.16s; }
.structures-grid .fade-in-up:nth-child(4) { transition-delay: 0.24s; }
.structures-grid .fade-in-up:nth-child(5) { transition-delay: 0.32s; }

.financial-solutions-row .fade-in-up:nth-child(1) { transition-delay: 0s; }
.financial-solutions-row .fade-in-up:nth-child(2) { transition-delay: 0.08s; }
.financial-solutions-row .fade-in-up:nth-child(3) { transition-delay: 0.16s; }
.financial-solutions-row .fade-in-up:nth-child(4) { transition-delay: 0.24s; }
.financial-solutions-row .fade-in-up:nth-child(5) { transition-delay: 0.32s; }

.investor-solutions-row .fade-in-up:nth-child(1) { transition-delay: 0s; }
.investor-solutions-row .fade-in-up:nth-child(2) { transition-delay: 0.1s; }
.investor-solutions-row .fade-in-up:nth-child(3) { transition-delay: 0.2s; }
.investor-solutions-row .fade-in-up:nth-child(4) { transition-delay: 0.3s; }

.stats-grid .fade-in-up:nth-child(1) { transition-delay: 0s; }
.stats-grid .fade-in-up:nth-child(2) { transition-delay: 0.06s; }
.stats-grid .fade-in-up:nth-child(3) { transition-delay: 0.12s; }
.stats-grid .fade-in-up:nth-child(4) { transition-delay: 0.18s; }
.stats-grid .fade-in-up:nth-child(5) { transition-delay: 0.24s; }
.stats-grid .fade-in-up:nth-child(6) { transition-delay: 0.3s; }
.stats-grid .fade-in-up:nth-child(7) { transition-delay: 0.36s; }

.consulting-cards .fade-in-up:nth-child(1) { transition-delay: 0s; }
.consulting-cards .fade-in-up:nth-child(2) { transition-delay: 0.12s; }

.about-final-features .fade-in-up:nth-child(1) { transition-delay: 0s; }
.about-final-features .fade-in-up:nth-child(3) { transition-delay: 0.1s; }
.about-final-features .fade-in-up:nth-child(5) { transition-delay: 0.2s; }
.about-final-features .fade-in-up:nth-child(7) { transition-delay: 0.3s; }

.ebooks-grid .fade-in-up:nth-child(1) { transition-delay: 0s; }
.ebooks-grid .fade-in-up:nth-child(2) { transition-delay: 0.1s; }
.ebooks-grid .fade-in-up:nth-child(3) { transition-delay: 0.2s; }

@media (prefers-reduced-motion: reduce) {
  .fade-in-up,
  .fade-in-left,
  .fade-in-right {
    transition: opacity 0.4s ease;
    transform: none;
  }
}