/* ============================================================
   THE WILD NORTH — style.css
   ============================================================ */

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

/* ─── TOKENS DE COR ──────────────────────────────────────────────────────── */
:root {
  --mud:    #2c1e10;
  --bark:   #4a2e14;
  --earth:  #7a4e28;
  --ochre:  #a56828;
  --ochre-light: #c4803a; 
  --sand:   #e8c99a;
  --cream:  #f5eee2;
  --fog:    #d9cebc;
  --forest: #2a3d2e;
  --moss:   #4a6651;
  --sky:    #a8bdc4;
  --mist:   #f0ebe0;
  --white:  #fdfaf5;
}

/* ─── ACESSIBILIDADE: Skip-link ──────────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  background: var(--mud);
  color: var(--cream);
  padding: .6rem 1.2rem;
  border-radius: 0 0 4px 4px;
  font-family: "Barlow Condensed", sans-serif;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-decoration: none;
  z-index: 9999;
  transition: top .2s;
}
.skip-link:focus {
  top: 0;
  outline: 3px solid var(--ochre);
  outline-offset: 2px;
}

/* ─── HTML / BODY ────────────────────────────────────────────────────────── */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 90px;
  scrollbar-width: thin;
  scrollbar-color: var(--ochre) var(--forest);
}
h1, h2 { text-wrap: balance; }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--forest); }
::-webkit-scrollbar-thumb { background: var(--ochre); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--earth); }
body {
  font-family: Barlow, sans-serif;
  background: var(--white);
  color: var(--mud);
  font-size: 16px;
  line-height: 1.7;
  overflow-x: hidden;
}

/* ─── SELEÇÃO DE TEXTO ───────────────────────────────────────────────────── */
::selection { background: var(--ochre); color: var(--white); }
::-moz-selection { background: var(--ochre); color: var(--white); }

/* ─── TAP HIGHLIGHT (mobile) ─────────────────────────────────────────────── */
a, button, input, select, textarea, .nav-lang {
  -webkit-tap-highlight-color: transparent;
}

/* ─── NAV ────────────────────────────────────────────────────────────────── */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  padding: 1.2rem 4rem;
  background: rgba(44, 30, 16, .55);
  backdrop-filter: blur(4px);
  transition: background .4s, backdrop-filter .4s, transform .35s;
  gap: 2rem;
  overflow: visible; 
}
nav.scrolled  { background: rgba(44, 30, 16, .95); backdrop-filter: blur(8px); }
nav.nav-hidden { transform: translateY(-100%); }

.nav-logo {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1.55rem;
  font-weight: 700;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--cream);
  text-decoration: none;
  flex-shrink: 0;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 2.5rem;
  list-style: none;
  margin-left: auto; 
}

.nav-links a,
.nav-mobile-overlay a {
  color: var(--cream);
  text-decoration: none;
}
.nav-links a {
  font-size: .8rem;
  letter-spacing: .12em;
  font-weight: 500;
  text-transform: uppercase;
  transition: color .2s;
  position: relative;
}
.nav-links a:not(.nav-cta)::after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 50%; right: 50%;
  height: 1px;
  background: var(--ochre);
  transition: left .25s ease, right .25s ease;
}
.nav-links a:not(.nav-cta):hover::after { left: 0; right: 0; }
.nav-links a:hover { color: var(--ochre); }

/* ─── CTA BOTÃO DA NAV ───────────────────────────────────────────────────── */
.nav-cta,
.nav-mobile-overlay .nav-cta { color: var(--mud) !important; font-weight: 800; }
.nav-cta:hover,
.nav-mobile-overlay .nav-cta:hover { color: var(--white) !important; }
.nav-cta {
  background: var(--ochre);
  padding: .5rem 1.4rem;
  border-radius: 2px;
}
.nav-cta:hover { background: var(--earth); }
.nav-mobile-overlay .nav-cta {
  background: var(--ochre);
  padding: .8rem 2.5rem;
  border-radius: 2px;
  margin-top: 1rem;
}
.nav-mobile-overlay .nav-cta:hover { background: var(--earth); }

/* ─── GLOBO DE LÍNGUA (desktop) ─────────────────────────────────────────── */
.nav-lang {
  position: relative;
  display: flex;
  align-items: center;
  cursor: pointer;
  padding: .3rem;
  color: var(--cream);
  transition: color .2s;
  margin-left: .6rem;
  flex-shrink: 0;
}
.nav-lang:hover { color: var(--ochre); }
.lang-globe { width: 18px; height: 18px; flex-shrink: 0; }
.lang-dropdown {
  position: absolute;
  top: calc(100% + .8rem);
  right: 0;
  background: rgba(44, 30, 16, .97);
  border: 1px solid rgba(196, 128, 58, .25);
  border-radius: 3px;
  min-width: 80px;
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity .2s, transform .2s, visibility .2s;
  z-index: 200;
}
.nav-lang.open .lang-dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}
.lang-option {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .35rem .55rem;
  font-family: "Barlow Condensed", sans-serif;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--fog);
  text-decoration: none;
  transition: color .15s, background .15s;
  white-space: nowrap;
}
.lang-option:hover { color: var(--ochre); background: rgba(196, 128, 58, .08); }
.lang-option.lang-active { color: var(--ochre); }

/* Bandeiras SVG Cross-Browser Correctas */
.flag-icon {
  display: inline-flex;
  width: 18px;
  height: 13px;
  border-radius: 2px;
  flex-shrink: 0;
  overflow: hidden;
  vertical-align: middle;
}
.flag-icon svg {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* ─── HAMBURGER ──────────────────────────────────────────────────────────── */
.nav-hamburger {
  touch-action: manipulation;
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 4px;
  background: none;
  border: none;
  cursor: pointer;
}
.nav-hamburger span {
  display: block;
  width: 22px; height: 2px;
  background: var(--cream);
  border-radius: 2px;
  transition: transform .3s, opacity .3s;
}
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:first-child  { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ─── MOBILE OVERLAY ─────────────────────────────────────────────────────── */
.nav-mobile-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(44, 30, 16, .97);
  z-index: 99;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 2rem;
  display: flex;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .35s ease, visibility .35s ease;
}
.nav-mobile-overlay.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.nav-mobile-overlay a {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  transition: color .2s;
}
.nav-mobile-overlay a:hover { color: var(--ochre); }

/* ─── LÍNGUAS MOBILE (bandeiras + texto no overlay) ──────────────────────── */
.mobile-lang {
  display: flex;
  gap: 1.2rem;
  margin-top: 1rem;
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
  z-index: 110;
}
.mobile-lang-opt {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 1.1rem !important; 
  font-family: "Barlow Condensed", sans-serif !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  color: var(--fog) !important;
  text-transform: uppercase !important;
  opacity: .5;
  transition: opacity .2s, color .2s;
  text-decoration: none;
}
.mobile-lang-opt:hover,
.mobile-lang-opt.active { 
  opacity: 1; 
  color: var(--ochre) !important;
}

/* ─── HERO ───────────────────────────────────────────────────────────────── */
.hero {
  display: flex;
  min-height: 100vh;
  min-height: 100dvh;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0 4rem 5rem;
  position: relative;
  background: var(--mud);
  overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0;
  background:
    linear-gradient(to bottom, rgba(44,30,16,.15) 0, rgba(44,30,16,.65) 60%, rgba(44,30,16,.93) 100%),
    image-set(
      url("/img/hero.avif") type("image/avif"),
      url("/img/hero.webp") type("image/webp")
    ) center/cover no-repeat;
  animation: kenburns 20s ease-in-out infinite alternate;
  will-change: transform;
}
@keyframes kenburns {
  0%   { transform: scale(1) translate3d(0,0,0); }
  100% { transform: scale(1.06) translate3d(-1%,-1%,0); }
}
.hero-overline {
  position: relative;
  font-family: "Barlow Condensed", sans-serif;
  font-size: .8rem;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: #f5e6d0;
  margin-bottom: 1.2rem;
  font-weight: 700;
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
}
.hero h1, .hero-sub { color: var(--cream); position: relative; }
.hero h1 {
  font-family: "Playfair Display", serif;
  font-size: clamp(2.8rem, 6vw, 5rem);
  font-weight: 400;
  line-height: 1.1;
  max-width: 700px;
  margin-bottom: 1.5rem;
}
.hero h1 em { font-style: italic; color: var(--sand); }
.hero-sub {
  font-size: 1.05rem;
  max-width: 520px;
  margin-bottom: 2.5rem;
  font-weight: 400;
  line-height: 1.8;
  text-shadow: 0 1px 4px rgba(0,0,0,.35);
}
.hero-actions {
  position: relative;
  display: flex;
  gap: 1.2rem;
  align-items: center;
  flex-wrap: wrap;
}

/* ─── BOTÕES ─────────────────────────────────────────────────────────────── */
.btn-primary, .btn-ghost {
  font-size: .85rem;
  font-weight: 700;
  padding: .9rem 2.2rem;
  display: inline-block;
  font-family: "Barlow Condensed", sans-serif;
  text-transform: uppercase;
  letter-spacing: .18em;
  text-decoration: none;
}
.btn-primary {
  background: var(--ochre);
  color: var(--mud);
  border-radius: 2px;
  transition: background .2s, transform .15s, box-shadow .2s;
  border: none;
  cursor: pointer;
  font-weight: 800;
}
.btn-primary:hover {
  background: var(--earth);
  color: var(--white);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(196,128,58,.35);
}
.btn-arrow {
  display: inline-block;
  transition: transform .2s;
  margin-left: .3em;
}
.btn-primary:hover .btn-arrow { transform: translateX(4px); }
.btn-ghost {
  color: var(--cream);
  border: 1.5px solid rgba(255,255,255,.6);
  border-radius: 2px;
  transition: border-color .2s, color .2s, background .2s;
}
.btn-ghost:hover { border-color: var(--ochre); color: var(--ochre); }

/* ─── STRIP MARQUEE ──────────────────────────────────────────────────────── */
.strip {
  background: var(--forest);
  padding: .9rem 0;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  overflow: hidden;
  justify-content: flex-start;
  gap: 0;
}
.strip-inner {
  display: flex;
  will-change: transform;
}
.strip-item {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .3rem 1.2rem;
  color: var(--fog);
  font-size: .68rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 500;
  border-right: 1px solid rgba(255,255,255,.15);
  white-space: nowrap;
  border-radius: 2px;
  transition: color .2s, background .2s;
}
.strip-item:hover { color: var(--ochre-light); background: rgba(196,128,58,.08); }
.strip-dot { width: 4px; height: 4px; background: var(--ochre-light); border-radius: 50%; flex-shrink: 0; }

/* ─── SECÇÕES GENÉRICAS ──────────────────────────────────────────────────── */
section { padding: 6rem 4rem; }
.section-label {
  font-family: "Barlow Condensed", sans-serif;
  font-size: .72rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 1rem;
}
.section-title {
  font-family: "Playfair Display", serif;
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 400;
  line-height: 1.15;
  color: var(--mud);
  max-width: 600px;
  margin-bottom: 1.5rem;
}
.section-title em { font-style: italic; color: var(--earth); }

/* ─── ABOUT ──────────────────────────────────────────────────────────────── */
.about {
  background: var(--mist);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}
.about-image { position: relative; height: 520px; }
.about-image-main { width: 80%; height: 100%; object-fit: cover; border-radius: 2px; }
.about-image-accent {
  position: absolute;
  bottom: -2rem; right: 0;
  width: 52%; height: 55%;
  object-fit: cover;
  border-radius: 2px;
  border: 4px solid var(--white);
  box-shadow: 0 16px 48px rgba(44,30,16,.28), 0 4px 12px rgba(44,30,16,.18);
}
.about-body { font-size: 1.05rem; color: var(--bark); line-height: 1.85; max-width: 480px; }
.about-body p + p { margin-top: 1.2rem; }
.about-stat-row {
  display: flex;
  gap: 2rem;
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--fog);
}
.about-stat { flex: 1; }
.about-stat-num {
  font-family: "Playfair Display", serif;
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--ochre);
  display: block;
  line-height: 1;
}
.about-stat-label {
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--earth);
  margin-top: .3rem;
  font-weight: 500;
}

/* ─── EXPERIENCES ────────────────────────────────────────────────────────── */
.experiences { background: var(--white); }
.experiences-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1.5px;
  background: var(--fog);
  margin-top: 3rem;
  overflow: hidden;
  border: 1px solid var(--fog);
}
.exp-card {
  background: var(--white);
  padding: 2.5rem;
  position: relative;
  transition: background .3s, transform .3s, box-shadow .3s;
  cursor: default;
  grid-column: span 2;
  overflow: hidden;
}
.exp-card-04  { grid-column: span 3 !important; }
.exp-card-full {
  grid-column: span 3 !important;
  background: var(--cream);
  display: flex;
  align-items: center;
  gap: 3rem;
  padding: 2.5rem;
  flex-wrap: wrap;
}
.exp-card-full .exp-card-body { flex: 1; min-width: 260px; }
.exp-card-full .exp-card-cta  { flex-shrink: 0; }
.exp-card:hover {
  background: var(--cream);
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(44,30,16,.12);
}
.exp-card-num {
  font-family: "Playfair Display", serif;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1;
  color: var(--sand);
  margin-bottom: 1.2rem;
}
.exp-card-num--ochre { color: var(--ochre); }
.exp-card-title {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--mud);
  margin-bottom: .4rem;
}
.exp-card-duration {
  font-size: .78rem;
  letter-spacing: .12em;
  color: var(--ochre);
  margin-bottom: 1rem;
  font-weight: 600;
  text-transform: uppercase;
}
.exp-card-desc { font-size: .92rem; color: var(--bark); line-height: 1.75; margin-bottom: 1.5rem; }
.exp-card-price {
  font-family: "Playfair Display", serif;
  font-size: 1.6rem;
  color: var(--mud);
  font-weight: 400;
}
.exp-card-price span { font-family: Barlow, sans-serif; font-size: .78rem; color: var(--earth); font-weight: 400; }
.exp-card-price-label { font-family: "Playfair Display", serif; font-size: 1.1rem; color: var(--mud); margin-bottom: 1rem; }

/* ─── VEHICLE ────────────────────────────────────────────────────────────── */
/* Layout: conteúdo à esquerda, imagem à direita.
   A imagem dita a altura — o layout adapta-se a ela. */
.vehicle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--mud);
  align-items: center;
  /* Necessário para que a imagem aumentada (114% height) não vaze para fora */
  overflow: hidden;
}
.vehicle-content {
  padding: 5rem 4rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.vehicle-content .section-label { color: var(--sand); }
.vehicle-title { color: var(--cream); max-width: 440px; }
.vehicle-content .section-title em { color: var(--sand); }
.vehicle-body { color: var(--fog); font-size: 1rem; line-height: 1.85; max-width: 440px; font-weight: 300; margin-bottom: 2.5rem; }
.vehicle-features { display: flex; flex-direction: column; gap: .8rem; margin-top: 1.5rem; list-style: none; }
.vehicle-feature {
  display: flex;
  align-items: center;
  gap: 1rem;
  color: var(--sand);
  font-size: .88rem;
  letter-spacing: .05em;
}
.vehicle-feature::before { content: ""; display: block; width: 20px; height: 1px; background: var(--ochre); flex-shrink: 0; }

/* A imagem do UMM tem bordas do mesmo tom --mud incorporadas.
   align-self: stretch faz a coluna da imagem esticar até à altura do conteúdo.
   object-fit: cover preenche sem cortar o carro (as margens expandidas absorvem). */
.vehicle-image {
  display: block;
  width: 100%;
  /* Imagem começa normal, o JS expande ao scroll */
  height: 120%;
  min-height: 400px;
  object-fit: cover;
  object-position: center center;
  filter: sepia(20%) contrast(.95);
  align-self: stretch;
  transform: scale(1.0) translateY(0%);
  transform-origin: center center;
  will-change: transform;
}

/* ─── ROUTES ─────────────────────────────────────────────────────────────── */
.routes { background: var(--cream); }
.routes-note { color: var(--earth); max-width: 520px; margin-bottom: .5rem; }
.routes-map {
  margin-top: 3rem;
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--fog);
  border: 1px solid var(--fog);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.route-row {
  background: var(--white);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  align-items: center;
  padding: 1.4rem 1.8rem;
  gap: 1rem;
  min-width: 0;
  word-break: break-word;
}
.route-row:hover { background: var(--mist); }
.route-row.header, .route-row.header:hover { background: var(--forest); color: var(--sand); font-size: .7rem; letter-spacing: .18em; cursor: default; font-weight: 600; text-transform: uppercase; }
.route-row--highlight { background: var(--cream); }
.route-row--highlight:hover { background: var(--fog); }
.route-name { font-family: "Barlow Condensed", sans-serif; font-size: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--mud); }
.route-dest { font-size: .82rem; color: var(--earth); }
.route-duration { font-size: .85rem; color: var(--mud); font-weight: 500; }
.route-price-cell { font-family: "Playfair Display", serif; font-size: 1.2rem; color: var(--ochre); text-align: right; }
.route-price-header { text-align: right; }
.route-price-cell--muted { font-size: .9rem; font-family: Barlow, sans-serif; color: var(--earth); }

/* ─── PARTNERS ───────────────────────────────────────────────────────────── */
.partners { background: var(--forest); }
.partners .section-label { color: var(--sand); }
.partners .section-title { color: var(--cream); }
.partners .section-title em { color: var(--sand); }
.partners-body { color: var(--fog); font-weight: 300; line-height: 1.85; max-width: 560px; margin-bottom: 3rem; }
.partner-benefits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin-top: 3rem;
  background: rgba(255,255,255,.08);
}
.benefit-card {
  background: rgba(255,255,255,.04);
  padding: 2rem 1.8rem;
  border-top: 2px solid var(--ochre);
  transition: background .25s, transform .3s, box-shadow .3s !important;
}
.benefit-card:hover {
  transform: translateY(-4px) !important;
  background: rgba(255,255,255,.14) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
.benefit-card-header { display: flex; align-items: center; gap: .7rem; margin-bottom: .6rem; }
.benefit-icon { font-size: 1.3rem; flex-shrink: 0; }
.benefit-title {
  font-family: "Barlow Condensed", sans-serif;
  font-size: .95rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--sand);
  margin-bottom: 0;
}
.benefit-desc { font-size: .88rem; color: var(--fog); line-height: 1.7; font-weight: 300; }

/* ─── CONTACT ────────────────────────────────────────────────────────────── */
.contact { background: var(--cream); display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.contact-intro { color: var(--earth); line-height: 1.85; margin-bottom: 2.5rem; max-width: 400px; }
.contact-details { font-style: normal; }
.contact-detail { display: flex; flex-direction: column; gap: .2rem; margin-bottom: 1.8rem; }
.contact-detail-label { font-size: .72rem; text-transform: uppercase; font-weight: 600; letter-spacing: .18em; color: var(--ochre); }
.contact-detail-value { font-size: 1.05rem; color: var(--mud); font-weight: 400; text-decoration: none; }
.contact-detail-value:hover { color: var(--ochre); }

/* ─── FORMULÁRIO ─────────────────────────────────────────────────────────── */
.contact-form { 
  display: flex; 
  flex-direction: column; 
  gap: 1.2rem; 
  width: 100%;
}
.form-group { display: flex; flex-direction: column; gap: .4rem; }
.form-group label {
  font-size: .72rem;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: .15em;
  color: var(--earth);
}

/* FIX: width: 100% adicionado para impedir que inputs saiam do ecrã no mobile */
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  max-width: 100%;
  background: var(--white);
  border: 1.5px solid var(--fog);
  border-radius: 2px;
  padding: .8rem 1rem;
  font-family: Barlow, sans-serif;
  font-size: .95rem;
  color: var(--mud);
  outline: 0;
  transition: border-color .2s, box-shadow .2s;
  box-shadow: inset 0 1px 3px rgba(44,30,16,.06);
}
.form-group select {
  appearance: none;
  -webkit-appearance: none; cursor: pointer; }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--ochre);
  box-shadow: inset 0 1px 3px rgba(44,30,16,.06), 0 0 0 3px rgba(196,128,58,.12);
}

/* ─── FOCO DE TECLADO (ACESSIBILIDADE) ───────────────────────────────────── */
a:focus-visible,
button:focus-visible {
  outline: 3px solid var(--ochre);
  outline-offset: 4px;
}
.form-group input:focus-visible,
.form-group select:focus-visible,
.form-group textarea:focus-visible {
  outline: 3px solid var(--ochre);
  outline-offset: 1px;
}
.form-group textarea { resize: vertical; min-height: 110px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-honeypot { display: none; }
.form-hint { font-size: .72rem; color: var(--earth); line-height: 1.4; opacity: .8; }
.form-required { color: #b84040; font-size: .9em; margin-left: .15em; }
.form-optional { color: var(--earth); font-weight: 400; font-size: .85em; margin-left: .25em; }
.form-required-note { font-size: .72rem; color: var(--earth); opacity: .75; margin-top: -.4rem; }
.btn-submit { align-self: flex-start; font-size: .85rem; }

/* ─── FOOTER ─────────────────────────────────────────────────────────────── */
footer {
  background: var(--mud);
  padding: 3rem 4rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--bark);
}
.footer-logo {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--cream);
}
.footer-tagline { font-size: .8rem; color: var(--fog); margin-top: .3rem; letter-spacing: .05em; }
.footer-links { display: flex; gap: 2rem; list-style: none; }
.footer-links a {
  color: var(--cream);
  text-decoration: none;
  font-size: .8rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: color .2s;
}
.footer-links a:hover { color: var(--ochre); }
.footer-copy { font-size: .75rem; color: var(--fog); }

/* ─── ANIMAÇÕES REVEAL ───────────────────────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s, transform .7s; }
.reveal.visible { opacity: 1; transform: none; }
.exp-card, .benefit-card { opacity: 0; transform: translateY(20px); transition: opacity .5s, transform .5s, background .3s, box-shadow .3s; }
.exp-card.stagger-visible, .benefit-card.stagger-visible { opacity: 1; transform: translateY(0); }
.exp-card:hover { transform: translateY(-5px) !important; }

/* ─── RESPONSIVE 1100px ──────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .strip { padding: 0 2rem; }
  .strip-item { font-size: .62rem; letter-spacing: .06em; }
}

/* ─── RESPONSIVE 1050px — NAV/FOOTER INTERMÉDIÁRIO ──────────────────────── */
@media (max-width: 1050px) {
  nav { padding: 1.2rem 2.5rem; gap: 1rem; }
  .nav-links { gap: 1.6rem; }
  .nav-links a { font-size: .72rem; letter-spacing: .08em; }
  .nav-lang { margin-left: .8rem; }
  footer { padding: 2.5rem 2.5rem; gap: 1.5rem; }
  .footer-links { gap: 1.4rem; }
  .footer-links a { font-size: .72rem; }
}

/* ─── RESPONSIVE 900px ───────────────────────────────────────────────────── */
@media (max-width: 900px) {
  nav { padding: 1.2rem 2rem; gap: 1rem; }
  nav .nav-links { display: none; }
  .nav-lang { display: none; }
  .nav-hamburger {
  touch-action: manipulation; display: flex; margin-left: auto; }

  section { padding: 4rem 2rem; }
  .hero { padding: 0 2rem 4rem; }
  .hero h1 { font-size: 2.5rem; }
  .hero-overline { font-size: .6rem; letter-spacing: .22em; margin-bottom: .9rem; }
  .hero-sub { font-size: .68rem; line-height: 1.65; margin-bottom: 2rem; }
  .about, .vehicle { grid-template-columns: 1fr; gap: 3rem; }
  .contact { grid-template-columns: 1fr; gap: 2.5rem; }
  .contact-intro { max-width: 100%; margin-bottom: 1.5rem; }
  .contact-details { margin-bottom: .5rem; }
  .about-image { height: 320px; }
  .vehicle-image { order: -1; width: 100%; height: auto; object-fit: cover; transform: none !important; }
  .vehicle-content { padding: 3rem 2rem; }
  .vehicle-title { font-size: clamp(1.8rem, 7vw, 2.6rem); }
  .vehicle-body { font-size: .85rem; }
  .experiences-grid { grid-template-columns: 1fr; gap: 1px; }
  .exp-card, .exp-card-04, .exp-card-priv, .exp-card-full { grid-column: 1 / -1 !important; }
  .exp-card-full { flex-direction: column; }
  .form-row, .partner-benefits { grid-template-columns: 1fr; }
  .strip { padding: 0; flex-wrap: nowrap; overflow: hidden; }
  .strip-item { border-right: 1px solid rgba(255,255,255,.15); border-bottom: none; padding: .6rem 1.2rem; font-size: .62rem; letter-spacing: .08em; white-space: nowrap; }
  .strip-item:last-child { border-right: 1px solid rgba(255,255,255,.15); }
  .strip-inner { animation-duration: 18s; }
  .strip-dot { display: inline-block; }
  footer { flex-direction: column; gap: 1.5rem; text-align: center; padding: 2rem 1.5rem; }
  .footer-links { flex-wrap: wrap; justify-content: center; gap: 1rem; }
  .footer-copy { order: 3; }
}

/* ─── RESPONSIVE 540px ───────────────────────────────────────────────────── */
@media (max-width: 540px) {
  section { padding: 3rem 1.5rem; }
  .hero { padding: 0 1.5rem 3.5rem; }
  .experiences-grid { grid-template-columns: 1fr; }
  .exp-card { grid-column: span 1; }
  .exp-card-04, .exp-card-priv, .exp-card-full { grid-column: 1 / -1 !important; }
  .strip-item { padding: .5rem .8rem; font-size: .62rem; }

  .contact { padding: 3rem 1.5rem; gap: 2rem; overflow: hidden; }
  .contact .section-title { font-size: clamp(1.6rem, 7vw, 2.4rem); }
  .contact-intro { font-size: .9rem; }
  .contact-detail { margin-bottom: 1.2rem; }
  .contact-detail-value { font-size: .95rem; word-break: break-all; }
  .form-group input, .form-group select, .form-group textarea { font-size: .9rem; }
  .btn-submit { width: 100%; text-align: center; }

  .route-row.header { display: none; }
  .routes-map { gap: .6rem; background: transparent; border: none; }
  .route-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: .4rem .8rem;
    padding: 1.2rem 1.4rem;
    border: 1px solid var(--fog);
    border-radius: 4px;
    text-align: left;
    align-items: start;
    background: var(--white);
    box-shadow: 0 2px 8px rgba(44,30,16,.06);
  }
  .route-row:last-child { border: 1px solid var(--fog); }
  .route-price-cell { text-align: right; font-size: 1.1rem; grid-row: 1; grid-column: 2; align-self: center; }
  .route-dest, .route-duration { font-size: .78rem; color: var(--earth); grid-column: 1 / -1; }
}

/* ─── LIGHTHOUSE 100/100: TAP TARGETS (ÁREAS DE TOQUE) ──────────────────── */
.nav-hamburger {
  touch-action: manipulation;
  padding: 14px;
  margin-right: -14px;
}
.nav-lang, .mobile-lang-opt {
  padding: 12px;
}
.lang-option {
  padding: .8rem 1rem;
}
.footer-links a, .contact-detail-value {
  display: inline-block;
  padding: 8px 0;
}

/* ─── PREFERÊNCIA DE MOVIMENTO REDUZIDO ──────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .hero-bg { animation: none; }
  .reveal, .exp-card, .benefit-card { transition: none; }
  .strip-inner { animation-play-state: paused; }
}

/* ─── FORM SUCCESS (movido do <style> inline) ────────────────────────────── */
.form-success {
  text-align: center;
  padding: 3rem 1rem;
}
.form-success-icon {
  font-size: 3rem;
  color: var(--ochre);
  margin-bottom: 1rem;
}
.form-success h3 {
  font-family: "Playfair Display", serif;
  font-size: 1.8rem;
  margin-bottom: .75rem;
  color: var(--mud);
}
.form-success p {
  color: var(--bark);
  font-size: 1rem;
  line-height: 1.6;
}



/* ─── FIX ARIA: article[role="listitem"] → usar role correto via CSS hint ── */
/* Os elementos com role="listitem" dentro de role="list" estão corretos;
   o erro do Lighthouse refere-se a <article> não ser permitido com role="listitem".
   A solução semântica é substituir <article> por <div> nos cards, mas como
   não podemos alterar o HTML aqui, adicionamos uma nota visual de depuração
   comentada. A correção real é feita nos ficheiros HTML (ver instruções). */

/* ─── ROUTE MAP TOOLTIP (mini-mapa SVG no hover) ────────────────────────── */
#route-map-tooltip {
  /* Estilos base definidos via JS; aqui garantimos a transição suave */
  will-change: opacity, transform;
}
#route-map-tooltip svg {
  display: block;
}

/* Indicador visual de que o card tem mapa disponível no hover */
.exp-card:hover .exp-card-title {
  color: var(--ochre);
}

/* ─── TESTIMONIALS SECTION ─────────────────────────────────────────────── */
.testimonials {
  background: var(--cream);
}

.testimonials-intro {
  max-width: 580px;
  color: var(--earth);
  font-size: 1rem;
  line-height: 1.75;
  margin-bottom: 3rem;
}

.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--fog);
  border: 1px solid var(--fog);
  margin-top: 3rem;
  margin-bottom: 2rem;
  overflow: hidden;
}

.testimonial-card {
  background: var(--white);
  padding: 2.2rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: background .25s;
}

.testimonial-card:hover {
  background: var(--mist);
}

.testimonial-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.testimonial-stars {
  color: var(--ochre);
  font-size: 1rem;
  letter-spacing: 3px;
  opacity: 0.45;
}

.testimonial-badge {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--earth);
  border: 1px solid var(--fog);
  padding: 0.2rem 0.6rem;
  border-radius: 20px;
}

.testimonial-quote {
  font-family: "Playfair Display", serif;
  font-size: 1.1rem;
  font-style: italic;
  color: var(--bark);
  opacity: 0.4;
  line-height: 1.6;
  flex: 1;
}

.testimonial-meta {
  border-top: 1px solid var(--fog);
  padding-top: 0.85rem;
}

.testimonial-name {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--earth);
  opacity: 0.6;
}

.testimonials-note {
  font-size: 0.85rem;
  color: var(--earth);
  max-width: 520px;
  line-height: 1.65;
  opacity: 0.7;
  margin-top: 0.5rem;
}

/* Staggered card reveal delays */
.reveal--delay-1 { transition-delay: 0.1s; }
.reveal--delay-2 { transition-delay: 0.25s; }
.reveal--delay-3 { transition-delay: 0.4s; }

@media (max-width: 768px) {
  .testimonials-grid {
    grid-template-columns: 1fr;
    gap: 0.5rem;
    background: transparent;
    border: none;
  }
  .testimonial-card {
    border: 1px solid var(--fog);
    border-radius: 4px;
  }
}

/* ─── FORM ERROR MESSAGE (substitui alert()) ─────────────────────────────── */
.form-error-msg {
  margin-top: .75rem;
  padding: .75rem 1rem;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 4px;
  color: #991b1b;
  font-size: .85rem;
  line-height: 1.5;
}

.nav-logo-img {
  height: 2.75rem;
  width: auto;
  display: block;
}

/* ─── RESPONSIVE 400px — Cards de preço + Imagem UMM ──────────────────────
   Isola todas as correções ≤ 400 px para não tocar em desktop/tablet.
   Estratégia:
     • Cards: padding reduzido, tipografia dinâmica via clamp(), botão 100%.
     • UMM: object-fit:contain para mostrar o carro inteiro (sem corte).
   ────────────────────────────────────────────────────────────────────────── */
@media (max-width: 400px) {

  /* ── Experiences grid ── */
  .experiences-grid {
    gap: 1.5px;           /* mantém as linhas separadoras (fundo fog visível entre cards) */
  }

  /* ── Todos os exp-cards ── */
  .exp-card {
    padding: 1.5rem 1.2rem;   /* era 2.5rem — liberta ~2.6rem de largura */
    grid-column: 1 / -1 !important;
    overflow: visible;         /* evita corte de texto longo */
  }

  /* ── Número grande (01, 02 … 05) ── */
  .exp-card-num {
    font-size: clamp(2.4rem, 11vw, 4rem);  /* escala suave de 320 a 400 */
    margin-bottom: .8rem;
  }

  /* ── Título do card (texto potencialmente longo em DE/FR) ── */
  .exp-card-title {
    font-size: clamp(.82rem, 4.5vw, 1.15rem);
    letter-spacing: .04em;   /* ligeiramente menos condensado em ecrãs muito estreitos */
    word-break: break-word;   /* permite hifenização forçada em palavras longas */
    hyphens: auto;
  }

  /* ── Linha de duração ── */
  .exp-card-duration {
    font-size: clamp(.65rem, 3vw, .78rem);
    letter-spacing: .06em;
    white-space: normal;       /* impede transbordamento horizontal */
    word-break: break-word;
  }

  /* ── Preço (ex: "150€–220€ / pessoa") ── */
  .exp-card-price {
    font-size: clamp(1.1rem, 5vw, 1.6rem);
    white-space: normal;
    word-break: break-word;
  }

  /* ── Card privado (exp-card-full) — disposição em coluna ── */
  .exp-card-full {
    flex-direction: column;
    gap: 1.4rem;
    padding: 1.5rem 1.2rem;
    align-items: flex-start;
  }

  /* Corpo do card privado ocupa toda a largura */
  .exp-card-full .exp-card-body {
    min-width: 0;              /* remove o min-width: 260px que causava overflow */
    width: 100%;
  }

  /* ── Label de preço ("Preço fechado por grupo") ── */
  .exp-card-price-label {
    font-size: clamp(.92rem, 4vw, 1.1rem);
    margin-bottom: .75rem;
    white-space: normal;
  }

  /* ── CTA do card privado ── */
  .exp-card-full .exp-card-cta {
    width: 100%;               /* ocupa toda a largura disponível */
    flex-shrink: 0;
  }

  /* ── Botão "PEDIR ORÇAMENTO" ── */
  .exp-card-full .exp-card-cta .btn-primary {
    display: block;            /* full-width centrado */
    width: 100%;
    text-align: center;
    box-sizing: border-box;
    padding: .9rem 1rem;       /* reduz padding horizontal em ecrãs estreitos */
    font-size: clamp(.72rem, 3.5vw, .85rem);
    letter-spacing: .12em;
    white-space: normal;       /* permite quebra se o texto for longo */
    word-break: break-word;
  }

  /* ─── Imagem UMM ──────────────────────────────────────────────────────── */
  /* Em mobile, a secção .vehicle está já em coluna (via 900px breakpoint).
     Aqui garantimos que a imagem mostra o carro completo, sem corte,
     usando object-fit:contain com letterboxing nas laterais.
     O background var(--mud) preenche os espaços vazios, mantendo coerência
     com o tom da secção. */
  .vehicle-image {
    width: 100%;
    height: auto;               /* altura ditada pela proporção real */
    min-height: 0;              /* anula o min-height: 400px do CSS base */
    aspect-ratio: 6 / 5;       /* proporção aproximada da foto original (2400×2000) */
    object-fit: contain;        /* carro sempre visível, sem corte */
    object-position: center center;
    background-color: var(--mud); /* preenche letterbox com o mesmo fundo */
    order: -1;                  /* mantém imagem antes do texto */
  }
}


/* ─── ESTILOS DA PÁGINA 404 ─────────────────────────────────────────────── */

.e404-hero {
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0 4rem 5rem;
  position: relative;
  background: var(--mud);
  overflow: hidden;
}
.e404-bg {
  position: absolute; inset: 0;
  background:
    linear-gradient(to bottom, rgba(44,30,16,.10) 0, rgba(44,30,16,.55) 45%, rgba(44,30,16,.97) 100%),
    image-set(
      url("/img/hero.avif") type("image/avif"),
      url("/img/hero.webp") type("image/webp")
    ) center/cover no-repeat;
  animation: kenburns 20s ease-in-out infinite alternate;
  will-change: transform;
}
.e404-content {
  position: relative;
  max-width: 680px;
}
.e404-code {
  font-family: "Barlow Condensed", sans-serif;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: #f5e6d0;
  margin-bottom: 1.2rem;
  display: block;
}
.e404-title {
  font-family: "Playfair Display", serif;
  font-size: clamp(2.4rem, 5.5vw, 4.2rem);
  font-weight: 400;
  line-height: 1.1;
  color: var(--cream);
  margin-bottom: 1.4rem;
}
.e404-title em {
  font-style: italic;
  color: var(--sand);
}
.e404-sub {
  font-size: 1rem;
  color: var(--sand);
  line-height: 1.8;
  margin-bottom: 2.8rem;
  max-width: 480px;
  font-weight: 300;
}
.e404-actions {
  display: flex;
  gap: 1.2rem;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 3.5rem;
}
@media (max-width: 900px) {
  .e404-hero { padding: 0 2rem 4rem; }
}
@media (max-width: 540px) {
  .e404-hero { padding: 0 1.5rem 3.5rem; }
}

/* ─── HOVER: apenas em dispositivos com rato real ────────────────────────── */
@media (hover: hover) and (pointer: fine) {
  .exp-card:hover {
    background: var(--cream);
    transform: translateY(-5px);
    box-shadow: 0 12px 32px rgba(44,30,16,.12);
  }
  .btn-primary:hover {
    background: var(--earth);
    color: var(--white);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(196,128,58,.35);
  }
  .btn-primary:hover .btn-arrow { transform: translateX(4px); }
  .btn-ghost:hover { border-color: var(--ochre); color: var(--ochre); }
  .benefit-card:hover {
    transform: translateY(-4px) !important;
    background: rgba(255,255,255,.14) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.25);
  }
  .testimonial-card:hover { background: var(--mist); }
  .route-row:hover { background: var(--mist); }
  .nav-links a:not(.nav-cta):hover::after { left: 0; right: 0; }
  .nav-links a:hover { color: var(--ochre); }
  .nav-cta:hover { background: var(--earth); color: var(--white) !important; }
  .nav-lang:hover { color: var(--ochre); }
  .lang-option:hover { color: var(--ochre); background: rgba(196,128,58,.08); }
  .strip-item:hover { color: var(--ochre-light); background: rgba(196,128,58,.08); }
  .footer-links a:hover { color: var(--ochre); }
  .contact-detail-value:hover { color: var(--ochre); }
  .nav-mobile-overlay a:hover { color: var(--ochre); }
}

/* ─── IMPRESSÃO ─────────────────────────────────────────────────────────── */
@media print {
  nav, footer, .hero-bg, .e404-bg {
    display: none !important;
  }
  body, .hero, section {
    background: white !important;
    color: black !important;
    padding: 0 !important;
  }
  .section-title, .exp-card-title {
    color: black !important;
  }
}