:root{
  --bg:#f7f3ee;
  --paper:#fbf8f4;
  --ink:#241e18;
  --muted:#6f6257;
  --line:rgba(36,30,24,.12);
  --gold:#b99563;
  --gold2:rgba(185,149,99,.35);
  --shadow: 0 18px 40px rgba(36,30,24,.10);
  --radius: 18px;
  --radius2: 26px;
  --container: 1120px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-serif, Georgia, "Times New Roman", Times, serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.45;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{
  width:min(var(--container), calc(100% - 40px));
  margin-inline:auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(247,243,238,.88);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}

.navbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:14px;
}

.brand{
  font-weight:700;
  letter-spacing:.08em;
  font-size:20px;
}

.navlinks{
  display:flex;
  align-items:center;
  gap:18px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:14px;
}

.navlinks a{
  opacity:.85;
  padding:8px 8px;
  border-radius:999px;
}
.navlinks a:hover{opacity:1;background:rgba(185,149,99,.10)}
.navlinks a.active{opacity:1;background:rgba(185,149,99,.14)}

.nav-cta{
  border:1px solid rgba(185,149,99,.40);
  background:rgba(185,149,99,.10);
}

.menu-btn{
  display:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.35);
  border-radius:999px;
  padding:10px 12px;
  cursor:pointer;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.mobile-nav{
  display:none;
  border-top:1px solid var(--line);
  padding:10px 0 14px;
}
.mobile-nav a{
  display:block;
  padding:10px 10px;
  border-radius:12px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:14px;
  opacity:.9;
}
.mobile-nav a:hover{background:rgba(185,149,99,.10);opacity:1}
.mobile-nav a.active{background:rgba(185,149,99,.14);opacity:1}

.hero{
  background-size:cover;
  background-position:center;
  position:relative;
  border-bottom:1px solid var(--line);
}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background: radial-gradient(70% 80% at 25% 15%, rgba(255,255,255,.80), rgba(255,255,255,.12) 60%, rgba(0,0,0,.10));
}
.hero-inner{
  position:relative;
  padding:74px 0 60px;
  display:flex;
  align-items:flex-end;
  min-height:72vh;
}
.hero-card{
  background:rgba(251,248,244,.86);
  border:1px solid rgba(185,149,99,.22);
  border-radius:var(--radius2);
  padding:22px 22px;
  box-shadow: var(--shadow);
}

.kicker{
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:12px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:rgba(36,30,24,.70);
  margin:0;
}

h1,h2,h3,h4{margin:0}
h1{font-size:48px;line-height:1.05}
h2{font-size:36px;line-height:1.1}
h3{font-size:26px;line-height:1.2}
h4{font-size:18px;line-height:1.25}
p{margin:0}

.section{padding:48px 0}
.sep{
  border:none;
  border-top:1px solid var(--line);
}

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

.card{
  background:rgba(251,248,244,.90);
  border:1px solid rgba(185,149,99,.18);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow: 0 10px 25px rgba(36,30,24,.06);
}

.card-body{padding:14px 14px 16px}
.card-body p{font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-size:14px}

.panel{
  background:rgba(251,248,244,.90);
  border:1px solid rgba(185,149,99,.18);
  border-radius:var(--radius2);
  padding:18px 18px;
  box-shadow: 0 10px 25px rgba(36,30,24,.06);
}

.split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  align-items:start;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:11px 14px;
  border-radius:999px;
  border:1px solid rgba(185,149,99,.40);
  background:rgba(185,149,99,.16);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:14px;
  cursor:pointer;
  transition: transform .08s ease, background .18s ease, border-color .18s ease;
}
.btn:hover{transform: translateY(-1px); background:rgba(185,149,99,.22); border-color:rgba(185,149,99,.55)}
.btn.secondary{
  background: rgba(255,255,255,.35);
  border-color: rgba(36,30,24,.14);
}
.btn.secondary:hover{background: rgba(255,255,255,.52)}

.form{
  display:grid;
  gap:12px;
  margin-top:12px;
}
.field label{
  display:block;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:13px;
  color:rgba(36,30,24,.78);
  margin-bottom:6px;
}
.field input,.field textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(36,30,24,.14);
  background:rgba(255,255,255,.55);
  outline:none;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:14px;
}
.field textarea{min-height:120px;resize:vertical}

.notice{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:14px;
  color:var(--muted);
  margin-top:8px;
}
.notice.ok{color:#1f6f3d}
.notice.err{color:#a11d1d}

.footer{
  border-top:1px solid var(--line);
  padding:18px 0;
  background:rgba(247,243,238,.88);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:14px;
  color:rgba(36,30,24,.85);
}

.whats-float{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:60;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  border:1px solid rgba(185,149,99,.35);
  background:rgba(251,248,244,.92);
  box-shadow: 0 14px 28px rgba(36,30,24,.12);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:14px;
}
.whats-dot{
  width:10px;height:10px;border-radius:50%;
  background:#22c55e;
  box-shadow:0 0 0 6px rgba(34,197,94,.14);
}

.fade-in{
  animation: fadeIn .55s ease both;
}
@keyframes fadeIn{
  from{opacity:0; transform: translateY(8px)}
  to{opacity:1; transform: translateY(0)}
}

@media (max-width: 980px){
  h1{font-size:40px}
  h2{font-size:30px}
  .grid{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
}

@media (max-width: 720px){
  .navlinks{display:none}
  .menu-btn{display:inline-flex}
  .mobile-nav.open{display:block}
  .hero-inner{min-height:62vh; padding:58px 0 44px}
  .grid{grid-template-columns:1fr}
}

/* Roteiro (Visão editorial) - mais compacto */
.roteiro-card .card-body{
  padding: 14px;
}

.roteiro-text{
  color: var(--muted);
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.45;
}

/* Limita a altura do conteúdo e cria scroll interno suave */
.roteiro-card .roteiro-text{
  max-height: 210px;
  overflow: auto;
  padding-right: 6px;
}

/* Listas mais “finas” */
.roteiro-text ul{
  margin: 8px 0 12px 18px;
}
.roteiro-text li{
  margin: 6px 0;
}

/* No celular: ainda mais compacto */
@media (max-width: 900px){
  .roteiro-text{ font-size: 13px; }
  .roteiro-card .roteiro-text{ max-height: 190px; }
}

/* Roteiro: cada card com altura do próprio conteúdo (sem esticar / sem scroll) */
.roteiro-compacto{
  align-items: start;         /* não estica os cards na linha */
}

.roteiro-card{
  height: auto;
  align-self: start;          /* garante que não estique */
}

.roteiro-card .roteiro-text{
  max-height: none !important; /* remove limite */
  overflow: visible !important;/* remove scrollbar */
  padding-right: 0 !important;
}

/* Roteiro: grid mais editorial (sem buracos feios) */
.roteiro-compacto{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)); /* 2 colunas no desktop */
  gap: 18px;                                       /* espaço entre cards */
  align-items: start;
}

/* Mobile: 1 coluna */
@media (max-width: 900px){
  .roteiro-compacto{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* Garante que cada card não fique “estreito” e mantenha consistência */
.roteiro-card{
  width: 100%;
}

/* (Opcional) um espacinho melhor entre título e texto dentro do card */
.roteiro-card h4{
  margin-bottom: 6px;
}

/* Galeria Uruguai — cards sem "espaço em branco" */
.galeria-grid .card {
  height: 230px;           /* ajuste aqui: 210–280 fica ótimo */
  padding: 0;
  overflow: hidden;
}

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

/* Galeria Uruguai — cards sem "espaço em branco" */
.galeria-grid .card {
  height: 230px;           /* ajuste aqui: 210–280 fica ótimo */
  padding: 0;
  overflow: hidden;
}

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

/* ROTEIRO — cards com altura automática + espaçamento consistente */
.roteiro-compacto{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;                 /* espaço entre cards */
  align-items: start;         /* NÃO estica cards */
}

/* no mobile: 1 coluna */
@media (max-width: 860px){
  .roteiro-compacto{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* garante que o card cresça conforme o conteúdo */
.roteiro-card{
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
}

/* melhora o “respiro” interno do texto */
.roteiro-text{
  margin-top: 8px;
  line-height: 1.55;
}

/* listas do roteiro mais compactas e bonitas */
.roteiro-text ul{
  margin: 8px 0 0 18px;
  padding: 0;
}
.roteiro-text li{
  margin: 6px 0;
}

/* =========================================================
   ROTEIRO (Visão editorial) — cards com altura automática
   Cole este bloco no FINAL do style.css
   ========================================================= */

/* Grade do roteiro: 2 colunas no desktop, 1 no mobile */
.roteiro-compacto{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  align-items: start; /* IMPORTANTÍSSIMO: impede “esticar” cards */
}

/* Mobile */
@media (max-width: 860px){
  .roteiro-compacto{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* Card do roteiro sempre cresce conforme o conteúdo */
.roteiro-card{
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}

/* Se alguém colocou overflow no .card geral, garantimos aqui */
.roteiro-card .card-body{
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
}

/* Texto do roteiro */
.roteiro-text{
  margin-top: 8px;
  line-height: 1.55;
}

/* Parágrafos dentro do roteiro (evita espaçamentos “quebrados”) */
.roteiro-text p{
  margin: 10px 0;
}

/* Títulos fortes (ex: Tour à Bodega...) */
.roteiro-text strong{
  font-weight: 700;
}

/* Listas do roteiro mais compactas e bonitas */
.roteiro-text ul{
  margin: 8px 0 0 18px;
  padding: 0;
}

.roteiro-text li{
  margin: 6px 0;
}

/* Opcional: deixa os subtítulos (h4) do roteiro mais “editorial” */
.roteiro-card h4{
  margin-bottom: 6px;
}

/* Opcional: evita que a grid geral do site force alinhamento/altura */
.roteiro-compacto > *{
  align-self: start;
}

/* =========================================================
   ROTEIRO (Visão editorial) — layout “masonry” (colunas)
   Cole no FINAL do style.css
   ========================================================= */

/* Container vira colunas (masonry) */
.roteiro-compacto{
  column-count: 2;
  column-gap: 22px;
}

/* No mobile vira 1 coluna */
@media (max-width: 860px){
  .roteiro-compacto{
    column-count: 1;
    column-gap: 14px;
  }
}

/* Cada card vira “bloco” dentro das colunas */
.roteiro-compacto .roteiro-card{
  display: inline-block;
  width: 100%;
  margin: 0 0 22px;
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;

  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}

/* Ajuste de espaçamento no mobile */
@media (max-width: 860px){
  .roteiro-compacto .roteiro-card{
    margin-bottom: 14px;
  }
}

/* Tipografia/espacinho do texto dentro */
.roteiro-card .roteiro-text{
  margin-top: 8px;
  line-height: 1.55;
}

.roteiro-card .roteiro-text p{
  margin: 10px 0;
}

.roteiro-card .roteiro-text ul{
  margin: 8px 0 0 18px;
  padding: 0;
}

.roteiro-card .roteiro-text li{
  margin: 6px 0;
}

/* =========================================================
   ROTEIRO — “masonry” (encaixe) sem buracos
   ========================================================= */
.roteiro-masonry{
  column-count: 2;
  column-gap: 22px;
}

@media (max-width: 860px){
  .roteiro-masonry{
    column-count: 1;
    column-gap: 14px;
  }
}

.roteiro-masonry .roteiro-card{
  display: inline-block;
  width: 100%;
  margin: 0 0 22px;
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
}

/* garante que nenhum CSS antigo force altura / grid / scroll */
.roteiro-masonry .roteiro-card,
.roteiro-masonry .roteiro-card .card-body,
.roteiro-masonry .roteiro-text{
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

/* =========================
   DICAS — cards sem “vazio”
   ========================= */

.dicas-grid{
  align-items: start;
}

.dicas-grid .card{
  height: auto !important;
  align-self: start;
}

.dicas-grid .card-body{
  height: auto !important;
}

/* Mantém as imagens bonitas e consistentes */
.dicas-grid .card img{
  width: 100%;
  height: 240px;     /* pode ajustar: 200–280 */
  object-fit: cover;
  display: block;
}

<p class="valor-line" style="margin-top:10px; color:var(--ink); font-size:22px; line-height:1.25; font-style:italic;">
  Em quarto duplo – <strong>R$ 10.262,07</strong> | Em quarto single – <strong>R$ 11.667,07</strong>
</p>


@media (max-width: 520px){
  .hero-title{ white-space: normal; }
}

/* VALOR: mantém tudo em 1 linha */
.valor-line{
  white-space: nowrap;
}

@media (max-width: 520px){
  .valor-line{ white-space: normal; }
}


/* HERO — título sempre em 1 linha e sem estourar o card */
.hero-title{
  white-space: nowrap;
  font-size: clamp(26px, 3.6vw, 48px);
  line-height: 1.05;
  max-width: 100%;
}

/* garante que o card não permita overflow “vazar” */
.hero-card{
  overflow: hidden;
}

/* A experiência — lista bem separadinha */
.exp-list{
  margin: 10px 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.6;
}

.exp-list li{
  margin: 10px 0;  /* espaçamento entre itens */
}

/* HERO title: mobile = 2 linhas, desktop = 1 linha quando couber */
.hero-title{
  font-size: 48px;        /* mantém o tamanho atual (ajuste se necessário) */
  line-height: 1.05;
  margin: 0;
}

/* Faz a parte depois do título quebrar para a linha de baixo por padrão */
.hero-title span{
  display: block;        /* mobile -> quebra em 2 linhas */
  font-weight: 700;
}

/* Desktop: tenta manter tudo em ONE-LINE */
@media (min-width: 860px){
  .hero-title{
    white-space: nowrap;  /* força tentativa de 1 linha (se couber) */
    font-size: 48px;      /* ajusta conforme seu layout, se quiser maior/diminuir) */
  }
  .hero-title span{
    display: inline;      /* volta a ficar na mesma linha no desktop */
  }
}

/* Ajuste fino para tablets e pequenas larguras (opcional) */
@media (max-width: 460px){
  .hero-title{ font-size: 30px; } /* reduz um pouco no celular bem estreito */
}

.inclui-lista{
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.55;
}
.inclui-lista li{
  margin: 8px 0;
}
