/* =========================================================
   2 DESTINOS — Landing Page
   Sistema visual baseado no Documento de Identidade de Marca 2025
   ========================================================= */

:root{
  /* Paleta oficial */
  --verde:   #1A3A2E;   /* Verde Mata — cor principal */
  --verde-2: #142C22;   /* Verde mais profundo p/ overlays */
  --dourado: #C8A96E;   /* Dourado — alma da marca / acento */
  --dourado-claro:#D9C094;
  --areia:   #D6CFBE;   /* Fundo clean (nunca branco puro) */
  --caramelo:#C8B89A;
  --cacau:   #4A3520;
  --tinta:   #1A1A1A;   /* "Preto" da marca (nunca #000) */

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 64px);

  --serif: Georgia, 'Times New Roman', serif;          /* exclusivo do "2" */
  --sans: 'Inter', system-ui, -apple-system, sans-serif;

  --shadow: 0 24px 60px -28px rgba(20,44,34,.45);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  color:var(--verde);
  background:var(--areia);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- Tipografia base ---------- */
h1,h2,h3{ font-weight:500; line-height:1.08; margin:0; letter-spacing:-.01em; }
.eyebrow{
  font-size:.74rem; font-weight:400; letter-spacing:.28em;
  text-transform:uppercase; color:var(--dourado);
}
.note{ font-style:italic; opacity:.78; font-size:.92rem; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
section{ position:relative; }

/* ---------- Logo lockup ---------- */
.logo{ display:inline-flex; align-items:baseline; gap:.34em; line-height:1; }
.logo .num{
  font-family:var(--serif); font-weight:700;
  color:var(--dourado); font-size:1.55em; line-height:.8;
}
.logo .word{
  font-weight:200; letter-spacing:.34em; text-transform:none;
  font-size:.96em;
}
.logo--light .word{ color:var(--verde); }
.logo--dark .word{ color:var(--areia); }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:50;
  background:transparent;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  padding:18px 0;
}
.site-header.scrolled{
  background:rgba(20,44,34,.92);
  backdrop-filter:saturate(140%) blur(10px);
  box-shadow:0 1px 0 rgba(200,169,110,.25);
  padding:10px 0;
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.nav .logo{ font-size:1.12rem; color:var(--areia); }
.nav-links{ display:flex; align-items:center; gap:30px; list-style:none; margin:0; padding:0; }
.nav-links a{
  color:var(--areia); font-size:.86rem; letter-spacing:.04em;
  position:relative; padding:4px 0; opacity:.85; transition:opacity .25s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1px;
  background:var(--dourado); transition:right .3s var(--ease);
}
.nav-links a:hover{ opacity:1; }
.nav-links a:hover::after{ right:0; }

.btn{
  display:inline-flex; align-items:center; gap:.5em;
  font-weight:500; font-size:.88rem; letter-spacing:.02em;
  padding:.82em 1.5em; border-radius:999px; cursor:pointer; border:1px solid transparent;
  transition:transform .25s var(--ease), background .25s, color .25s, box-shadow .25s;
  white-space:nowrap;
}
.btn--gold{ background:var(--dourado); color:var(--verde); }
.btn--gold:hover{ background:var(--dourado-claro); transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(200,169,110,.7); }
.btn--ghost{ border-color:rgba(245,240,232,.5); color:var(--areia); }
.btn--ghost:hover{ border-color:var(--dourado); color:var(--dourado); }
.btn--lg{ padding:1em 1.9em; font-size:.95rem; }

.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--areia); margin:5px 0; transition:.3s; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; overflow:hidden;
  min-height:100svh; display:flex; align-items:center;
  color:var(--areia); text-align:center;
  background:var(--verde) url('assets/img/hero.jpg') center/cover no-repeat;
  padding:140px 0 90px;
}
/* Camada de cor entre foto e texto (regra do manual): leve, para a imagem brilhar.
   Reforço verde no topo (atrás do header) e na base; suave no centro. */
.hero::before{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(20,44,34,.94) 0%, rgba(20,44,34,.34) 32%, rgba(20,44,34,.41) 60%, rgba(20,44,34,.98) 100%);
}
/* Scrim sutil atrás do bloco de texto central para legibilidade sem apagar a foto */
.hero::after{
  content:""; position:absolute; left:50%; top:50%; translate:-50% -50%; z-index:1;
  width:min(720px,92%); height:min(58%,520px);
  background:radial-gradient(ellipse at center, rgba(20,44,34,.55), rgba(20,44,34,0) 72%);
  pointer-events:none;
}
.hero__inner{ position:relative; z-index:3; max-width:820px; margin-inline:auto; }
.hero .logo{ font-size:clamp(2.4rem,7vw,4.6rem); }
/* No tamanho gigante do hero o Light 200 fica fino demais e some sobre a foto:
   sobe o peso para 300 e reduz um pouco o tracking, mantendo a leveza da marca. */
.hero .logo .word{ font-weight:300; letter-spacing:.22em; }
.hero .logo .num{ text-shadow:0 2px 24px rgba(20,44,34,.45); }
.hero__slogan{
  margin:22px 0 30px; font-size:clamp(.72rem,2.2vw,.92rem);
  letter-spacing:.42em; text-transform:uppercase; color:var(--dourado);
}
.hero h1{
  font-size:clamp(1.9rem,5.2vw,3.4rem); font-weight:500;
  max-width:16ch; margin-inline:auto; text-wrap:balance;
}
.hero__sub{
  margin:22px auto 0; max-width:46ch; font-size:clamp(1rem,2.4vw,1.18rem);
  opacity:.9; font-weight:300;
}
.hero__cta{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-top:38px; }
.hero__divider{
  width:54px; height:2px; background:var(--dourado); margin:0 auto 26px; opacity:.9;
}
.scroll-cue{
  position:absolute; left:50%; bottom:26px; translate:-50% 0;
  color:var(--dourado); font-size:.7rem; letter-spacing:.3em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:10px; opacity:.85;
}
.scroll-cue .line{ width:1px; height:42px; background:linear-gradient(var(--dourado),transparent); animation:cue 2.2s var(--ease) infinite; }
@keyframes cue{ 0%{transform:scaleY(0);transform-origin:top;} 50%{transform:scaleY(1);transform-origin:top;} 51%{transform-origin:bottom;} 100%{transform:scaleY(0);transform-origin:bottom;} }

/* =========================================================
   SEÇÃO: CONCEITO
   ========================================================= */
.section{ padding:clamp(72px,11vw,140px) 0; }
.bg-areia{ background:var(--areia); color:var(--verde); }
.bg-areia .eyebrow{ color:var(--cacau); }
.bg-verde{ background:var(--verde); color:var(--areia); }
.bg-cacau{ background:var(--cacau); color:var(--areia); }

.section-head{ max-width:62ch; }
.section-head h2{ font-size:clamp(1.7rem,4.4vw,2.7rem); margin:.5em 0 .4em; }
.section-head p{ font-size:1.06rem; }

.concept{ position:relative; }
.concept .ghost-2{
  position:absolute; right:-2vw; top:-6vw; font-family:var(--serif); font-weight:700;
  font-size:min(46vw,640px); line-height:.8; color:rgba(26,58,46,.045); pointer-events:none; z-index:0;
}
.concept .wrap{ position:relative; z-index:1; }
.lead{ font-size:clamp(1.25rem,3vw,1.7rem); font-weight:300; max-width:24ch; color:var(--verde); }
.lead b{ font-weight:600; color:var(--cacau); }

.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:34px; margin-top:60px; }
.step{ position:relative; padding-top:26px; }
.step::before{ content:""; position:absolute; top:0; left:0; width:46px; height:2px; background:var(--dourado); }
.step .k{ font-family:var(--serif); font-weight:700; color:var(--dourado); font-size:1.1rem; }
.step h3{ font-size:1.18rem; font-weight:600; margin:.5em 0 .4em; }
.step p{ font-size:.97rem; margin:0; }

/* =========================================================
   SEÇÃO: ROTAS
   ========================================================= */
.routes .section-head h2{ color:var(--areia); }

/* Abas de filtro */
.routes-tabs{
  display:flex; gap:8px; flex-wrap:wrap; margin-top:36px;
}
.routes-tab{
  padding:.55em 1.25em; border-radius:999px; cursor:pointer;
  border:1px solid rgba(200,169,110,.35); background:transparent;
  color:rgba(245,240,232,.7); font-family:var(--sans);
  font-size:.82rem; letter-spacing:.03em;
  transition:background .22s, border-color .22s, color .22s;
}
.routes-tab:hover{ border-color:var(--dourado); color:var(--areia); }
.routes-tab.active{
  background:var(--dourado); border-color:var(--dourado);
  color:var(--verde); font-weight:500;
}

.routes-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:30px; margin-top:32px; }
.route{
  background:rgba(245,240,232,.04); border:1px solid rgba(200,169,110,.22);
  border-radius:16px; overflow:hidden; transition:transform .4s var(--ease), border-color .4s;
}
.route:hover{ transform:translateY(-6px); border-color:rgba(200,169,110,.6); }
.route__imgs{ position:relative; display:flex; height:276px; }
.route__img{ flex:1; background-size:cover; background-position:center; transition:flex .55s var(--ease), filter .55s; filter:saturate(1.05) contrast(1.02); }
.route__img:first-child{ filter:saturate(1.05) sepia(.06); }
.route:hover .route__img:first-child{ flex:1.25; }
.route__imgs::after{ content:""; position:absolute; top:0; bottom:0; left:50%; width:2px; translate:-50% 0; background:var(--dourado); z-index:2; box-shadow:0 0 18px rgba(200,169,110,.5); transition:left .55s var(--ease); }
.route:hover .route__imgs::after{ left:55%; }
.route__plus{
  position:absolute; top:50%; left:50%; translate:-50% -50%; z-index:3;
  width:42px; height:42px; border-radius:50%; background:var(--verde);
  border:1px solid var(--dourado); color:var(--dourado);
  display:grid; place-items:center; font-family:var(--serif); font-weight:700; font-size:1.3rem;
  transition:left .55s var(--ease);
}
.route:hover .route__plus{ left:55%; }
.route__body{ padding:24px 26px 28px; color:var(--areia); }
.route__tag{ font-size:.68rem; letter-spacing:.24em; text-transform:uppercase; color:var(--dourado); }
.route__title{ font-size:1.45rem; font-weight:600; margin:.35em 0 .35em; }
.route__title span{ color:var(--dourado); font-family:var(--serif); font-weight:700; margin:0 .12em; }
.route__desc{ font-size:.96rem; opacity:.82; margin:0 0 .8em; font-weight:300; }
.route__price{
  display:flex; align-items:baseline; gap:6px; flex-wrap:wrap;
  margin-top:18px; padding-top:16px;
  border-top:1px solid rgba(200,169,110,.2);
}
.route__price-label{ font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; opacity:.6; }
.route__price-value{ font-family:Georgia,'Times New Roman',serif; font-weight:700; font-size:1.45rem; color:var(--dourado); line-height:1; }
.route__price-suffix{ font-size:.74rem; opacity:.55; }
.route__cta{ display:inline-block; margin-top:14px; }
.routes-region{
  grid-column:1 / -1; display:flex; align-items:center; gap:18px;
  padding:14px 0 4px; margin-top:18px;
  font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--dourado);
  border-top:1px solid rgba(200,169,110,.2);
}
.routes-region:first-child{ margin-top:0; border-top:none; }
.routes-region .flag{ font-size:1.1rem; letter-spacing:0; }

/* =========================================================
   SEÇÃO: QUEM SOMOS
   ========================================================= */
.quem-somos{ position:relative; }
.qs-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,7vw,110px);
  align-items:start;
}
.qs-numbers{
  border-left:1px solid rgba(200,169,110,.35);
  padding-left:clamp(28px,4vw,56px);
  display:flex;
  flex-direction:column;
}
.qs-num{
  padding:clamp(22px,3vw,36px) 0;
  border-bottom:1px solid rgba(26,58,46,.1);
}
.qs-num:last-child{ border-bottom:none; }
.qs-n{
  display:block;
  font-family:var(--serif);
  font-weight:700;
  font-size:clamp(2.8rem,5vw,4.2rem);
  color:var(--dourado);
  line-height:1;
}
.qs-label{
  display:block;
  font-size:.92rem;
  opacity:.65;
  margin-top:.35em;
  font-weight:300;
  max-width:22ch;
}

/* =========================================================
   SEÇÃO: VALORES
   ========================================================= */
.values{ margin-top:54px; border-top:1px solid rgba(200,169,110,.35); }
.value{
  display:grid;
  grid-template-columns:clamp(54px,7vw,104px) minmax(0,1fr) minmax(0,1.5fr);
  gap:clamp(16px,4vw,56px); align-items:baseline;
  padding:clamp(26px,3.4vw,42px) 0;
  border-bottom:1px solid rgba(245,240,232,.1);
  transition:padding-left .4s var(--ease);
}
.value:hover{ padding-left:clamp(4px,1.2vw,16px); }
.value .n{
  font-family:var(--serif); font-weight:700; color:var(--dourado);
  font-size:clamp(2rem,5vw,3.1rem); line-height:.85;
}
.value h3{ font-size:clamp(1.18rem,2.4vw,1.55rem); font-weight:500; color:var(--areia); }
.value p{ font-size:1rem; opacity:.72; margin:0; font-weight:300; max-width:46ch; }

@media (max-width:720px){
  .value{ grid-template-columns:auto 1fr; gap:18px 22px; }
  .value p{ grid-column:1 / -1; }
}

/* =========================================================
   CONTATO
   ========================================================= */
.contact{ text-align:center; }
.contact h2{ font-size:clamp(1.9rem,5vw,3rem); max-width:18ch; margin:.4em auto .5em; color:var(--verde); }
.contact p{ max-width:48ch; margin:0 auto 36px; font-weight:300; color:var(--verde); }
.contact-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.contact .btn--ghost{ border-color:rgba(26,58,46,.35); color:var(--verde); }
.contact .btn--ghost:hover{ border-color:var(--dourado); color:var(--cacau); }
.contact-meta{ margin-top:44px; display:flex; gap:14px 34px; justify-content:center; flex-wrap:wrap; font-size:.9rem; color:var(--verde); }
.contact-meta a:hover{ color:var(--dourado); opacity:1; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--verde-2); color:var(--areia); padding:54px 0 40px; }
.footer-in{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.site-footer .logo{ font-size:1.4rem; }
.site-footer .slogan{ font-size:.72rem; letter-spacing:.34em; text-transform:uppercase; color:var(--dourado); margin-top:10px; }
.footer-meta{ text-align:right; font-size:.85rem; opacity:.75; }
.footer-rule{ height:1px; background:rgba(200,169,110,.25); margin:34px 0 22px; }
.footer-fine{ font-size:.76rem; opacity:.55; }

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } .hero{ background-attachment:scroll; } }

/* =========================================================
   RESPONSIVO
   ========================================================= */
@media (max-width:880px){
  .steps{ grid-template-columns:1fr; gap:30px; }
  .routes-grid{ grid-template-columns:1fr; }
  .route__imgs{ flex-direction:column; height:auto; }
  .route__img{ flex:none; height:150px; }
  .route__imgs::after{ top:50%; left:0; right:0; bottom:auto; width:100%; height:2px; translate:0 -50%; transition:none; }
  .route__plus{ top:50%; left:50%; transition:none; }
  .route:hover .route__imgs::after{ left:0; }
  .route:hover .route__plus{ left:50%; }
  .qs-grid{ grid-template-columns:1fr; }
  .qs-numbers{ border-left:none; border-top:1px solid rgba(200,169,110,.35); padding-left:0; padding-top:28px; flex-direction:row; flex-wrap:wrap; gap:0 40px; }
  .qs-num{ flex:1; min-width:120px; border-bottom:none; border-right:1px solid rgba(26,58,46,.1); padding-right:24px; }
  .qs-num:last-child{ border-right:none; }
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px);
    background:var(--verde); flex-direction:column; align-items:flex-start;
    justify-content:center; gap:28px; padding:0 40px;
    transform:translateX(100%); transition:transform .4s var(--ease); box-shadow:var(--shadow);
  }
  .nav-links.open{ transform:none; }
  .nav-links a{ font-size:1.1rem; }
  .nav-toggle{ display:block; z-index:60; }
  .nav-cta{ display:none; }
}

/* ── MODAL CAPTURA DE LEAD ───────────────────────────── */
button.btn { font-family: var(--sans); font-size: inherit; }
.lead-modal {
  display: none;
  position: fixed; inset: 0; z-index: 300;
  align-items: center; justify-content: center;
}
.lead-modal.open { display: flex; }
.lead-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.7);
  cursor: pointer;
}
.lead-modal__box {
  position: relative; z-index: 1;
  background: var(--verde-2);
  border: 1px solid rgba(200,169,110,.25);
  border-radius: 16px;
  padding: clamp(32px, 6vw, 52px) clamp(28px, 5vw, 48px);
  max-width: 460px; width: 92%;
  transform: translateY(24px);
  transition: transform .3s var(--ease);
}
.lead-modal.open .lead-modal__box { transform: translateY(0); }
.lead-modal__close {
  position: absolute; top: 16px; right: 18px;
  background: none; border: none;
  color: rgba(245,240,232,.45); font-size: 1.1rem;
  cursor: pointer; line-height: 1; padding: 4px 8px;
  transition: color .2s;
}
.lead-modal__close:hover { color: var(--areia); }
.lead-modal__box .eyebrow { color: var(--dourado); }
.lead-modal__box h2 {
  font-size: clamp(1.4rem, 4vw, 1.9rem);
  font-weight: 500; color: var(--areia);
  margin: .3em 0 .5em;
}
.lead-modal__box p {
  font-size: .95rem; color: rgba(245,240,232,.7);
  line-height: 1.6; margin: 0 0 28px;
}
.lead-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.lead-field label {
  font-size: .72rem; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(245,240,232,.55);
}
.lead-field input {
  background: rgba(245,240,232,.07);
  border: 1px solid rgba(200,169,110,.2);
  border-radius: 8px; padding: 13px 16px;
  color: var(--areia); font-size: .97rem;
  font-family: var(--sans); outline: none;
  transition: border-color .2s;
}
.lead-field input::placeholder { color: rgba(245,240,232,.3); }
.lead-field input:focus { border-color: var(--dourado); }
.lead-modal__submit { width: 100%; margin-top: 8px; font-size: 1rem; }
