/* ============================================================
   LDL VIAGENS · Site Institucional
   CSS Consolidado — versão final
   ============================================================ */

/* ── Variáveis ── */
:root {
  --navy:      #12294a;
  --navy-deep: #0C1C36;
  --linen:     #f7f4ef;
  --gold:      #b89a5c;
  --gold-soft: #c9a84c;
  --gold2:     #b8973a;
  --white:     #f8f8f6;
  --ink:       #444444;
  --mist:      #6b6b6b;
  --serif:     'Cormorant Garamond', Georgia, serif;
  --sans:      'Jost', system-ui, sans-serif;
  --max:       1120px;
}

/* ── Reset ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--sans); font-weight: 300; color: var(--ink); background: var(--white); line-height: 1.75; font-size: 17px; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ── Layout ── */
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 28px; }
section { padding: 6.5rem 0; }
.linen { background: var(--linen); }
.navybg { background: var(--navy); color: #fff; }
.navybg p { color: rgba(255,255,255,.82); }
.center { text-align: center; }

/* ── Tipografia ── */
h1, h2, h3 { font-family: var(--serif); font-weight: 500; letter-spacing: -.01em; line-height: 1.22; color: var(--navy); }
.on-dark h1, .on-dark h2, .on-dark h3 { color: var(--white); }
h1 { font-size: clamp(2.2rem, 5vw, 3.7rem); }
h2 { font-size: clamp(1.8rem, 3.6vw, 2.6rem); }
h3 { font-size: 1.55rem; }
.eyebrow { font-family: var(--sans); font-size: 11px; letter-spacing: .4em; text-transform: uppercase; color: #D8BC73; font-weight: 400; display: block; margin-bottom: 14px; }
.navybg .eyebrow, .on-dark .eyebrow, .news .eyebrow { color: rgba(184,154,92,.85); }
.lead { font-size: 1.12rem; color: var(--mist); max-width: 660px; }
.on-dark .lead { color: rgba(255,255,255,.78); }
.star { color: var(--gold); font-size: 1rem; }
.manifesto p { font-family: var(--serif); font-size: clamp(1.25rem, 2.4vw, 1.65rem); line-height: 1.65; color: var(--navy); max-width: 780px; margin: 0 auto 1.4rem; font-style: italic; }
.manifesto .who { font-size: .72rem; letter-spacing: .3em; text-transform: uppercase; color: var(--mist); font-style: normal; font-family: var(--sans); }

/* ── Linha decorativa ── */
.fio { width: 48px; height: 1px; background: var(--gold); margin: 1.6rem 0; transform-origin: left; transform: scaleX(0); transition: transform 1.1s cubic-bezier(.22,1,.36,1); }
.center .fio, .fio.c { margin-left: auto; margin-right: auto; transform-origin: center; }
.inview .fio, .fio.inview { transform: scaleX(1); }

/* ── Botões ── */
.btn { display: inline-block; font-family: var(--sans); font-weight: 400; font-size: 11px; letter-spacing: .3em; text-transform: uppercase; transition: all .3s; cursor: pointer; border: none; text-align: center; text-decoration: none; white-space: nowrap; }
.btn-solid { background: var(--gold); color: var(--navy); padding: 17px 40px; }
.btn-solid:hover { background: var(--gold-soft); }
.btn-ghost { border: 1px solid rgba(18,41,74,.35); color: var(--navy); padding: 16px 40px; background: transparent; }
.btn-ghost:hover { border-color: var(--gold2); color: var(--gold2); }
.btn-light { border: 1px solid rgba(248,248,246,.4); color: #f8f8f6; padding: 16px 40px; background: transparent; }
.btn-light:hover { border-color: var(--gold); color: var(--gold); }
.btn-gold-outline { border: 1px solid rgba(184,154,92,.55); color: var(--gold2); padding: 16px 40px; background: transparent; }
.btn-gold-outline:hover { border-color: var(--gold2); background: rgba(184,154,92,.08); color: var(--gold2); }
.btn + .btn { margin-left: .9rem; }
.textlink { font-size: .8rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500; color: var(--gold); border-bottom: 1px solid transparent; transition: .3s; }
.textlink:hover { border-color: var(--gold); }

/* ── Header ── */
header { position: fixed; inset: 0 0 auto 0; z-index: 50; transition: .45s; background: linear-gradient(rgba(12,28,54,.55), transparent); }
header.scrolled { background: var(--navy); box-shadow: 0 8px 30px rgba(12,28,54,.25); }
.nav { display: flex; align-items: center; justify-content: space-between; gap: 1rem; height: 88px; }
header.scrolled .nav { height: 74px; }
.logo img { height: 76px; width: auto; transition: .4s; }
header.scrolled .logo img { height: 60px; }
nav.menu { display: flex; gap: 1.8rem; align-items: center; }
nav.menu a { color: rgba(255,255,255,.85); font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 400; padding-bottom: 4px; border-bottom: 1px solid transparent; transition: .3s; }
nav.menu a:hover, nav.menu a.active { color: var(--white); border-color: var(--gold); }
/* Botão do header — padrão retangular, alinhado com landing */
.nav .btn-cta { font-family: var(--sans); font-size: 11px; letter-spacing: .3em; text-transform: uppercase; font-weight: 400; color: var(--navy); background: var(--gold); padding: 14px 28px; border: none; transition: background .3s; cursor: pointer; display: inline-block; text-decoration: none; white-space: nowrap; }
.nav .btn-cta:hover { background: var(--gold-soft); }
.burger { display: none; background: none; border: none; color: #fff; font-size: 1.7rem; cursor: pointer; line-height: 1; }

/* ── Hero principal ── */
.hero { min-height: 92vh; display: flex; align-items: center; position: relative; overflow: hidden; color: #fff; }
.hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; animation: ken 30s ease-in-out infinite alternate; }
@keyframes ken { from { transform: scale(1); } to { transform: scale(1.07); } }
.hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(160deg, rgba(12,28,54,.72) 0%, rgba(18,41,74,.45) 55%, rgba(12,28,54,.78) 100%); }
.hero .wrap { position: relative; z-index: 2; padding-top: 7rem; padding-bottom: 4rem; }
.hero h1 { max-width: 780px; color: #fff; }
.hero .lead { margin: 1.6rem 0 2.6rem; color: rgba(255,255,255,.85); }
.hero .btn { white-space: nowrap; }

/* ── Hero interno (páginas) ── */
.page-hero { min-height: 54vh; display: flex; align-items: flex-end; position: relative; color: #fff; padding-bottom: 4rem; overflow: hidden; }
.page-hero .ph-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.page-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(170deg, rgba(12,28,54,.82), rgba(18,41,74,.55)); }
.page-hero .wrap { position: relative; z-index: 2; padding-top: 9rem; }
.page-hero h1 { color: #fff; max-width: 760px; }

/* ── Grids de cards ── */
.grid4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.6rem; margin-top: 3.2rem; }
.card { background: var(--white); border: 1px solid rgba(18,41,74,.08); transition: .4s; display: flex; flex-direction: column; }
.card:hover { transform: translateY(-6px); box-shadow: 0 24px 50px rgba(12,28,54,.13); }
.card .photo { aspect-ratio: 4/5; overflow: hidden; }
.card .photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.card:hover .photo img { transform: scale(1.05); }
.card .body { padding: 1.7rem 1.6rem 2rem; display: flex; flex-direction: column; gap: .8rem; flex: 1; }
.card h3 { font-size: 1.22rem; }
.card p { font-size: .93rem; color: var(--mist); flex: 1; }

/* ── Jornada (steps) — padrão editorial ── */
.steps { max-width: 860px; margin: 3rem auto 0; }
.step { display: grid; grid-template-columns: 90px 1fr; gap: 1.6rem; padding: 1.8rem 0; border-bottom: 1px solid rgba(18,41,74,.1); align-items: start; }
.step:last-child { border-bottom: none; }
.step .num { font-family: var(--serif); font-size: 2.2rem; color: var(--gold); line-height: 1; }
.step h3 { color: var(--navy); margin-bottom: .35rem; font-size: 1.2rem; }
.step p { font-size: .97rem; color: var(--mist); line-height: 1.8; margin: 0; }
/* Variante sobre fundo navy */
.navybg .step { border-bottom-color: rgba(255,255,255,.12); }
.navybg .step h3 { color: #fff; }
.navybg .step p { color: rgba(255,255,255,.72); }
.navybg .step .num { color: var(--gold); }

/* ── Stats ── */
.stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 2rem; margin-top: 3rem; text-align: center; }
.stat .n { font-family: var(--serif); font-size: 2.6rem; color: var(--gold); line-height: 1.1; }
.stat p { font-size: .82rem; letter-spacing: .1em; text-transform: uppercase; margin-top: .5rem; }

/* ── Diferenciais ── */
.diffs { display: grid; grid-template-columns: repeat(5,1fr); gap: 2rem; margin-top: 3rem; }
.diff { text-align: center; }
.diff .star { display: block; margin-bottom: .9rem; font-size: 1.1rem; }
.diff h3 { font-size: 1rem; margin-bottom: .5rem; }
.diff p { font-size: .87rem; color: var(--mist); }

/* ── Depoimentos ── */
.quotes { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.8rem; margin-top: 3rem; }
.quote { background: var(--linen); border: 1px solid rgba(184,154,92,.18); border-top: 2px solid rgba(184,154,92,.45); position: relative; overflow: hidden; padding: 2.2rem 2rem; box-shadow: 0 14px 40px rgba(12,28,54,.07); display: flex; flex-direction: column; }
.quote::before { content: '\201C'; font-family: var(--serif); font-size: 100px; color: var(--gold); opacity: .12; position: absolute; top: -8px; left: 20px; line-height: 1; pointer-events: none; }
.quote .qphoto { margin: -2.2rem -2rem 1.6rem; aspect-ratio: 5/4; height: auto; overflow: hidden; }
.quote .qphoto img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
/* Posicionamentos individuais */
.quote .qphoto img.dep-amir { object-position: center top; }
.quote .qphoto img.dep-weberth { object-position: center top; }
.quote .qphoto img.dep-vanessa { object-position: center 20%; }
.quote .qphoto img.dep-james { object-position: center top; }
.quote .stars { color: var(--gold); letter-spacing: .25em; font-size: .8rem; margin-bottom: 1rem; }
.quote p { font-family: var(--serif); font-style: italic; color: var(--navy); font-size: 19px; line-height: 1.6; flex: 1; }
.quote .tag { margin-top: 1.4rem; font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); font-weight: 600; font-style: normal; font-family: var(--sans); }
.quote .who { font-size: .82rem; color: var(--ink); font-weight: 500; font-style: normal; font-family: var(--sans); margin-top: .2rem; }
.quote .src { font-size: .7rem; color: var(--mist); font-family: var(--sans); font-style: normal; }

/* ── Banner CTA com imagem ── */
.banner { position: relative; overflow: hidden; text-align: center; padding: 9rem 0; color: #fff; }
.banner-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.banner::after { content: ""; position: absolute; inset: 0; background: rgba(12,28,54,.68); }
.banner .wrap { position: relative; z-index: 2; }
.banner h2 { color: #fff; max-width: 720px; margin: 0 auto 1.2rem; }
.banner p { color: rgba(255,255,255,.8); max-width: 560px; margin: 0 auto 2.4rem; }

/* ── Split ── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 4.2rem; align-items: center; }
.split .photo { overflow: hidden; }
.split .photo img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/5; }
.split p { margin-bottom: 1.1rem; }
.list { list-style: none; margin: 1.2rem 0 2rem; }
.list li { padding-left: 1.6rem; position: relative; margin-bottom: .6rem; font-size: .97rem; }
.list li::before { content: "✦"; position: absolute; left: 0; color: var(--gold); font-size: .8rem; top: .25rem; }

/* ── Fundadores ── */
.partners { display: grid; grid-template-columns: 1fr 1fr; gap: 2.4rem; margin-top: 3rem; }
.partner { background: var(--white); padding: 2.4rem; border: 1px solid rgba(18,41,74,.08); }
.partner .photo { max-width: 280px; margin-bottom: 1.6rem; overflow: hidden; }
.partner .photo img { width: 100%; aspect-ratio: 1/1; object-fit: cover; object-position: top; }
.partner h3 { margin-bottom: .2rem; }
.partner .role { font-size: .7rem; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); font-weight: 600; display: block; margin-bottom: 1rem; }
.partner p { font-size: .94rem; color: var(--mist); }

/* ── Contato — caminhos ── */
.paths { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 3rem; }
.path { background: var(--white); border: 1px solid rgba(18,41,74,.08); padding: 2.8rem 2.4rem; text-align: center; display: flex; flex-direction: column; gap: 1rem; }
.path .num { font-family: var(--serif); font-size: 1.6rem; color: var(--gold); }
.path p { font-size: .95rem; color: var(--mist); flex: 1; }

/* ── Formulário — refinado ── */
.form-wrap { max-width: 640px; margin: 2.8rem auto 0; }
.form-wrap form { display: flex; flex-direction: column; gap: 1.6rem; }
.form-field { display: flex; flex-direction: column; }
.form-label { font-family: var(--sans); font-size: 10px; letter-spacing: .32em; text-transform: uppercase; color: var(--gold2); font-weight: 400; margin-bottom: .6rem; display: block; line-height: 1.4; }
.form-input,
.form-select,
.form-textarea { font-family: var(--sans); font-size: .97rem; color: var(--ink); background: #fff; border: 1px solid rgba(18,41,74,.16); padding: .95rem 1.1rem; width: 100%; border-radius: 0; -webkit-appearance: none; appearance: none; transition: border-color .25s, box-shadow .25s; }
.form-input:focus,
.form-select:focus,
.form-textarea:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(184,154,92,.12); }
.form-select { background-image: linear-gradient(45deg, transparent 50%, var(--gold2) 50%), linear-gradient(135deg, var(--gold2) 50%, transparent 50%); background-position: calc(100% - 20px) 50%, calc(100% - 14px) 50%; background-size: 6px 6px, 6px 6px; background-repeat: no-repeat; color: var(--ink); -webkit-text-fill-color: var(--ink); }
.form-select:invalid { color: #8a8a8a; -webkit-text-fill-color: #8a8a8a; }
.form-textarea { resize: vertical; min-height: 120px; }
.phone-row { display: grid; grid-template-columns: 148px 1fr; gap: .8rem; align-items: stretch; }
.phone-row .form-select { height: 100%; }
.form-submit-row { display: flex; align-items: center; gap: 1.4rem; flex-wrap: wrap; margin-top: .4rem; }
.form-note { font-family: var(--sans); font-size: .74rem; color: var(--mist); }

/* ── Newsletter ── */
.news { position: relative; }
.news-form { display: flex; gap: .9rem; max-width: 560px; margin: 2.2rem auto 0; }
.news-form input { flex: 1; padding: 1rem 1.2rem; border: 1px solid rgba(18,41,74,.18); font-family: var(--sans); font-size: .95rem; background: var(--white); color: var(--ink); }
.news-form input:focus { outline: 2px solid var(--gold); outline-offset: 1px; }
.news small { display: block; margin-top: 1rem; font-size: .74rem; color: var(--mist); }

/* ── CTA final ── */
.final { text-align: center; }
.final h2 { max-width: 660px; margin: 0 auto 2.2rem; }

/* ── FAQ ── */
.faq-list { max-width: 760px; margin: 42px auto 0; }
.faq-item { border-bottom: 1px solid rgba(18,41,74,.1); }
.faq-q { width: 100%; background: none; border: none; padding: 20px 0; display: flex; align-items: center; justify-content: space-between; gap: 20px; cursor: pointer; text-align: left; font-family: var(--serif); font-size: 20px; color: var(--navy); font-weight: 400; line-height: 1.35; }
.faq-q .icon { width: 27px; height: 27px; border: 1px solid #ccc; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 16px; color: var(--gold2); transition: transform .3s; }
.faq-q.open .icon { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .4s ease, padding .3s; }
.faq-a.open { max-height: 420px; padding-bottom: 22px; }
.faq-a p { font-size: 15px; color: var(--mist); line-height: 1.82; font-weight: 300; }

/* ── Footer ── */
footer { background: var(--navy-deep); color: rgba(255,255,255,.7); padding: 3.2rem 0 1.8rem; }
.fgrid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
footer .flogo img { height: 72px; margin-bottom: 1rem; }
footer h4 { font-family: var(--sans); font-size: .7rem; letter-spacing: .24em; text-transform: uppercase; color: var(--gold); font-weight: 600; margin-bottom: 1.1rem; }
footer a { display: block; margin-bottom: .35rem; font-size: .88rem; line-height: 1.7; transition: .3s; }
footer a:hover { color: #fff; }
footer p { font-size: .84rem; }
.fstars { letter-spacing: .6em; color: var(--gold); margin: 1.2rem 0; font-size: .78rem; }
.footer-tagline { font-size: .78rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.55); }
.fbottom { border-top: 1px solid rgba(255,255,255,.12); padding-top: 1.4rem; font-size: .74rem; letter-spacing: .06em; color: rgba(255,255,255,.45); text-align: center; line-height: 2; }

/* ── Sede ── */
.sede-final img { width: 100%; display: block; }
.sede-final figcaption { font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--mist); margin-top: 1rem; text-align: center; }

/* ── WhatsApp flutuante ── */
.wa-float { position: fixed; bottom: 28px; right: 28px; z-index: 200; display: flex; align-items: center; gap: 10px; background: #25d366; color: #fff; text-decoration: none; padding: 14px 24px; border-radius: 999px; box-shadow: 0 4px 24px rgba(37,211,102,.35), 0 1px 8px rgba(0,0,0,.1); transition: all .35s; border: 1px solid rgba(255,255,255,.15); }
.wa-float:hover { background: #20bc5a; transform: translateY(-3px); }
.wa-float svg { width: 20px; height: 20px; flex-shrink: 0; }
.wa-float span { font-family: var(--sans); font-size: 12px; font-weight: 400; letter-spacing: .08em; white-space: nowrap; }

/* ── Reveal (scroll animation) ── */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity .9s ease, transform .9s ease; }
.reveal.inview { opacity: 1; transform: none; }

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
  .fio { transform: scaleX(1); }
}

/* ── Tablet (≤ 980px) ── */
@media (max-width: 980px) {
  .grid4, .stats { grid-template-columns: repeat(2,1fr); }
  .diffs { grid-template-columns: repeat(2,1fr); }
  .quotes { grid-template-columns: 1fr; }
  .split, .partners, .paths, .fgrid { grid-template-columns: 1fr; }
  nav.menu { position: fixed; inset: 0; background: var(--navy); flex-direction: column; justify-content: center; gap: 2.2rem; transform: translateY(-105%); transition: .5s; z-index: 55; }
  nav.menu.open { transform: none; }
  .burger { display: block; z-index: 60; position: relative; }
  /* Botão CTA visível no mobile — posicionado no menu aberto */
  .nav .btn-cta { display: none; }
  .split .photo { order: -1; }
}

/* ── Mobile (≤ 768px) ── */
@media (max-width: 768px) {
  .nav { height: 74px; }
  header.scrolled .nav { height: 64px; }
  .logo img { height: 60px; }
  header.scrolled .logo img { height: 52px; }
  /* Botão CTA no header mobile — visível */
  .nav .btn-cta { display: inline-block; font-size: 10px; letter-spacing: .22em; padding: 11px 18px; }
  .partner { text-align: center; }
  .partner .photo { max-width: 160px; margin: 0 auto 1.3rem; }
  .wa-float { padding: 12px 18px; bottom: 20px; right: 16px; }
  .wa-float span { font-size: 11px; }
}

/* ── Mobile pequeno (≤ 600px) ── */
@media (max-width: 600px) {
  section { padding: 4.5rem 0; }
  .grid4, .diffs, .stats { grid-template-columns: 1fr; }
  .btn + .btn { margin-left: 0; margin-top: .8rem; }
  .hero .btn { display: block; width: 100%; letter-spacing: .18em; }
  .news-form { flex-direction: column; }
  .phone-row { grid-template-columns: 118px 1fr; }
  /* Overflow fix: garantir que nada ultrapasse a margem direita */
  .wrap { padding: 0 20px; }
  .split { gap: 2.4rem; }
  .btn-gold-outline { width: 100%; text-align: center; box-sizing: border-box; }
  .form-wrap { width: 100%; }
}

/* ── Mobile mínimo (≤ 480px) ── */
@media (max-width: 480px) {
  .wa-float span { display: none; }
  .wa-float { padding: 13px; }
}


/* ============================================================
   ChatGPT Final Polish — Site Institucional
   ============================================================ */
.form-wrap { max-width: 760px; margin-top: 2.2rem; }
.form-wrap form.contact-form-grid { display: grid; grid-template-columns: 1fr 1fr; column-gap: 1.1rem; row-gap: 1.05rem; }
.form-field-full { grid-column: 1 / -1; }
.form-label { font-size: 12px; letter-spacing: .10em; color: var(--navy); font-weight: 400; margin-bottom: .32rem; line-height: 1.25; }
.form-input, .form-select, .form-textarea { min-height: 52px; padding: .82rem .95rem; font-size: .96rem; border-color: rgba(18,41,74,.18); background: rgba(255,255,255,.86); }
.form-textarea { min-height: 105px; }
.form-submit-row { gap: 1rem; margin-top: .2rem; }
.form-note { font-size: .78rem; line-height: 1.55; max-width: 320px; }
.phone-row { display: block; }

@media (max-width: 768px) {
  .wrap { padding-left: 22px; padding-right: 22px; }
  .page-hero .wrap { padding-left: 22px; padding-right: 22px; }
  .form-wrap { margin-top: 1.8rem; }
  .form-wrap form.contact-form-grid { grid-template-columns: 1fr; row-gap: .95rem; }
  .form-input, .form-select, .form-textarea { min-height: 50px; }
  .form-submit-row .btn { width: 100%; }
  .form-note { max-width: none; text-align: center; width: 100%; }
  footer { padding: 2.1rem 0 1.25rem; }
  .fgrid { grid-template-columns: 1fr; gap: 1.2rem; margin-bottom: 1.5rem; }
  .fgrid > div:nth-child(2) { display: none; }
  footer .flogo img { height: 54px; margin-bottom: .55rem; }
  footer h4 { margin-bottom: .55rem; }
  footer p, footer a { font-size: .80rem; line-height: 1.55; margin-bottom: .15rem; }
  .fbottom { font-size: .72rem; line-height: 1.55; padding-top: 1rem; }
}

@media (max-width: 600px) {
  .wrap { padding-left: 20px; padding-right: 20px; }
  .nav .btn-cta { max-width: 230px; overflow: hidden; text-overflow: ellipsis; }
  .page-hero { min-height: 48vh; padding-bottom: 3rem; }
}

/* ============================================================
   ChatGPT Final Mobile Alignment Patch — Experiências, Contato e Jornada
   ============================================================ */
@media (max-width: 768px) {
  html, body { width: 100%; max-width: 100%; overflow-x: hidden; }
  body { position: relative; }
  header, main, section, footer { width: 100%; max-width: 100%; }

  /* Margens móveis unificadas em todas as páginas internas */
  .wrap,
  .page-hero .wrap,
  footer .wrap {
    width: 100%;
    max-width: 100%;
    padding-left: 26px !important;
    padding-right: 26px !important;
    margin-left: auto;
    margin-right: auto;
  }

  /* Corrige desalinhamentos de seções com imagem/texto nas páginas Experiências e Contato */
  .split,
  .paths,
  .partners,
  .fgrid {
    width: 100%;
    max-width: 100%;
  }

  .split {
    grid-template-columns: 1fr !important;
    gap: 2.15rem !important;
  }

  .split > *,
  .paths > *,
  .partners > *,
  .fgrid > * {
    min-width: 0;
    width: 100%;
  }

  .split .photo {
    width: 100%;
    max-width: 100%;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .split .photo img {
    width: 100%;
    max-width: 100%;
    height: auto;
    object-fit: cover;
  }

  /* Botões sem extrapolar a largura útil do mobile */
  .btn,
  .btn-ghost,
  .btn-solid,
  .btn-light,
  .btn-gold-outline {
    max-width: 100%;
    box-sizing: border-box;
  }

  /* Jornada: aproxima o texto dos numerais no mobile */
  .steps {
    max-width: 100%;
    margin-top: 2rem;
  }

  .step {
    grid-template-columns: 52px 1fr !important;
    gap: .85rem !important;
    padding: 1.55rem 0;
  }

  .step .num {
    font-size: 2rem;
  }

  .step h3 {
    margin-bottom: .25rem;
  }

  .step p {
    font-size: .95rem;
    line-height: 1.68;
  }
}

@media (max-width: 480px) {
  .wrap,
  .page-hero .wrap,
  footer .wrap {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  .step {
    grid-template-columns: 44px 1fr !important;
    gap: .75rem !important;
  }
}


/* ============================================================
   ChatGPT Final Button Alignment Patch — mantém espaçamento original
   ============================================================ */
@media (max-width: 768px) {
  .btn,
  .btn-ghost,
  .btn-solid,
  .btn-light,
  .btn-gold-outline {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    text-align: center !important;
    line-height: 1.2;
    box-sizing: border-box;
    max-width: 100%;
  }

  .nav .btn-cta {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    text-align: center !important;
  }

  /* Ajuste seletivo apenas para CTAs longos que não cabem bem no mobile */
  .btn-mobile-tight {
    letter-spacing: .22em !important;
  }
}

@media (max-width: 430px) {
  .btn-mobile-tight {
    letter-spacing: .18em !important;
  }
}


/* ============================================================
   Ajustes finais LDL — botões mobile e página Experiências
   ============================================================ */
@media (max-width: 768px) {
  .split .btn,
  .split .btn-ghost,
  .split .btn-solid,
  .split .btn-light,
  .split .btn-gold-outline {
    width: 100%;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    text-align: center !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box;
  }

  .contact-actions .btn,
  .contact-actions .btn-ghost,
  .contact-actions .btn-solid,
  .form-actions .btn,
  .form-actions .btn-ghost,
  .form-actions .btn-solid,
  .contact-card .btn,
  .form-wrap .btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    text-align: center !important;
  }

  .contact-card .btn,
  .form-wrap .btn,
  a[href*="planejamento"].btn,
  a[href*="planejar"].btn {
    line-height: 1.2;
  }
}

@media (max-width: 430px) {
  .split .btn-mobile-tight,
  .split .btn-ghost.btn-mobile-tight {
    letter-spacing: .18em !important;
  }
}


/* ============================================================
   LDL Final Fix — publicação
   ============================================================ */
@media (max-width: 768px) {
  /* Botões: centralização definitiva sem alterar o padrão editorial geral */
  .btn, .btn-ghost, .btn-solid, .btn-light, .btn-gold-outline, .nav .btn-cta {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }

  /* Página experiências: CTAs ocupam a largura útil da coluna de texto */
  .split .btn, .split .btn-ghost, .split .btn-solid, .split .btn-light, .split .btn-gold-outline {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Contato: ajuste cirúrgico apenas no botão longo */
  .btn-contact-plan {
    width: 100% !important;
    letter-spacing: .22em !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
    white-space: nowrap !important;
  }
}

@media (max-width: 430px) {
  .btn-contact-plan { letter-spacing: .18em !important; font-size: 10px !important; }
}

/* Mensagens de sucesso/erro dos formulários Netlify */
.form-feedback {
  display: none;
  margin-top: 1rem;
  padding: .95rem 1.1rem;
  border: 1px solid rgba(184,154,92,.35);
  background: rgba(184,154,92,.08);
  color: var(--navy);
  font-family: var(--sans);
  font-size: .9rem;
  line-height: 1.55;
}
.form-feedback.show { display: block; }
.form-feedback.error {
  border-color: rgba(158,67,67,.35);
  background: rgba(158,67,67,.08);
}
.news-form .form-feedback { flex-basis: 100%; width: 100%; text-align: center; }
.btn.is-loading { opacity: .72; cursor: wait; }

/* Mensagens de confirmação dos formulários - fallback sem AJAX */
.target-feedback{
  display:none;
  margin-top:1rem;
  padding:1rem 1.1rem;
  border:1px solid rgba(38,122,112,.24);
  border-radius:16px;
  background:rgba(38,122,112,.08);
  color:#1f5f57;
  font-weight:600;
  line-height:1.5;
}
.target-feedback:target, .target-feedback.show{display:block;}
.target-feedback strong{display:block;margin-bottom:.2rem;color:#123c37;}
