/* ===========================================
   BEL CANTO LODGE  –  Folha de Estilos
   Paleta extraída das fotos do lodge:
   Azul petróleo #0b7ea4 · Azul céu #3db5d0
   Terracota #9e6e3a · Areia #ede8dc
   Verde jardim #4e7a40
   =========================================== */

:root {
  --petrol:       #0b7ea4;
  --petrol-dk:    #075f7c;
  --petrol-lt:    #3db5d0;
  --terra:        #9e6e3a;
  --terra-lt:     #c49560;
  --verde:        #4e7a40;
  --areia:        #ede8dc;
  --areia-mid:    #d8d0be;
  --cream:        #f8f5ef;
  --castanho:     #5a4530;
  --txt:          #28200e;
  --txt-light:    #7a6a50;
  --white:        #ffffff;
  --gold:         #d4a630;
  --gold-lt:      #f0c84a;

  --serif:  'Cormorant Garamond', Georgia, serif;
  --sans:   'Jost', Arial, sans-serif;

  --nav-h:  72px;
  --r:      8px;
  --sombra: 0 4px 28px rgba(7,95,124,.13);
  --sombra-lg: 0 16px 56px rgba(7,95,124,.22);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--txt);background:var(--cream);overflow-x:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}

/* ─── NAVBAR ──────────────────────────────── */
.navbar{
  position:fixed;top:0;left:0;right:0;
  height:var(--nav-h);z-index:1000;
  transition:background .35s,box-shadow .35s;
}
.navbar.scrolled{
  background:var(--petrol-dk);
  box-shadow:0 2px 20px rgba(0,0,0,.35);
}
.nav-wrap{
  max-width:1240px;margin:0 auto;padding:0 28px;
  height:100%;display:flex;align-items:center;justify-content:space-between;
}
.logo{display:flex;flex-direction:column;line-height:1;gap:2px}
.logo-top{font-family:var(--serif);font-size:25px;font-style:italic;color:#fff}
.logo-top span{font-style:normal;font-weight:300;color:var(--gold)}
.logo-sub{font-size:9px;letter-spacing:3.5px;color:rgba(255,255,255,.45);text-transform:uppercase}
.nav-links{display:flex;align-items:center;list-style:none;gap:2px}
.nav-links a{
  font-size:13px;font-weight:400;letter-spacing:.4px;
  color:rgba(255,255,255,.88);padding:8px 13px;
  border-radius:4px;transition:color .2s;
}
.nav-links a:hover,.nav-links a.ativo{color:var(--gold)}
.nav-cta{
  background:var(--gold)!important;
  color:var(--petrol-dk)!important;
  font-weight:600!important;
  padding:9px 22px!important;
  margin-left:10px;
  border-radius:var(--r)!important;
  transition:background .2s,transform .2s!important;
}
.nav-cta:hover{background:var(--gold-lt)!important;transform:translateY(-1px)!important}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s}

/* ─── HERO ────────────────────────────────── */
.hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  overflow:hidden;
}
.hero-foto{
  position:absolute;inset:0;
  background:url('/images/hero.jpg') center 40%/cover no-repeat;
  transform:scale(1.06);
  transition:transform 7s ease;
}
.hero-foto.carregado{transform:scale(1)}
.hero-grad{
  position:absolute;inset:0;
  background:
    linear-gradient(170deg,rgba(7,95,124,.84) 0%,rgba(11,126,164,.55) 55%,rgba(4,50,65,.7) 100%);
}
.hero-grad::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:220px;
  background:linear-gradient(to top,rgba(4,50,65,.55),transparent);
}
.hero-onda{position:absolute;bottom:0;left:0;right:0;opacity:.25}
.hero-onda svg{width:100%;height:70px}

.hero-corpo{
  position:relative;text-align:center;
  padding:calc(var(--nav-h) + 48px) 24px 140px;
  max-width:820px;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);margin-bottom:22px;
  animation:fadeUp .8s ease both;
}
.hero-tag::before,.hero-tag::after{content:'';width:30px;height:1px;background:var(--gold);opacity:.55}
.hero-h1{
  font-family:var(--serif);
  font-size:clamp(50px,9vw,92px);
  font-weight:300;color:#fff;line-height:1.04;
  margin-bottom:22px;
  animation:fadeUp .8s .1s ease both;
}
.hero-h1 em{font-style:italic;color:var(--petrol-lt)}
.hero-h1 span{display:block}
.hero-p{
  font-size:17px;color:rgba(255,255,255,.72);
  max-width:520px;margin:0 auto 40px;line-height:1.75;
  animation:fadeUp .8s .2s ease both;
}
.hero-btns{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
  animation:fadeUp .8s .3s ease both;
}
.hero-scroll{
  position:absolute;bottom:96px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:7px;
  animation:fadeUp .8s .5s ease both;
}
.hero-scroll small{font-size:10px;letter-spacing:2px;color:rgba(255,255,255,.38)}
.linha-scroll{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:pulso 2s ease infinite}

.hero-stats{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;
  background:rgba(7,95,124,.5);backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.14);border-bottom:none;
  border-radius:12px 12px 0 0;
  padding:22px 44px;min-width:540px;justify-content:center;
}
.stat{text-align:center;padding:0 32px}
.stat-n{display:block;font-family:var(--serif);font-size:30px;font-weight:600;color:var(--gold)}
.stat-l{font-size:11px;letter-spacing:1px;color:rgba(255,255,255,.6)}
.stat-div{width:1px;height:42px;background:rgba(255,255,255,.18)}

/* ─── AMENIDADES FAIXA ────────────────────── */
.faixa-amenidades{
  background:var(--petrol-dk);
  padding:18px 24px;
  border-bottom:3px solid var(--gold);
}
.faixa-inner{
  max-width:900px;margin:0 auto;
  display:flex;align-items:center;justify-content:center;
  gap:44px;flex-wrap:wrap;
}
.amen{
  display:flex;align-items:center;gap:10px;
  color:rgba(255,255,255,.84);font-size:13px;letter-spacing:.3px;
}
.amen svg{width:20px;height:20px;stroke:var(--petrol-lt);flex-shrink:0}

/* ─── BOTÕES ──────────────────────────────── */
.btn-p{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gold);color:var(--petrol-dk);
  font-family:var(--sans);font-size:13px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  padding:14px 32px;border-radius:var(--r);border:none;cursor:pointer;
  transition:all .25s;
}
.btn-p:hover{background:var(--gold-lt);transform:translateY(-2px);box-shadow:0 8px 24px rgba(212,166,48,.38)}
.btn-p.grande{padding:18px 48px;font-size:14px}
.btn-g{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:#fff;
  font-family:var(--sans);font-size:13px;font-weight:500;
  letter-spacing:1px;text-transform:uppercase;
  padding:14px 32px;border-radius:var(--r);
  border:1px solid rgba(255,255,255,.4);cursor:pointer;
  transition:all .25s;
}
.btn-g:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}

/* ─── BARRA RESERVA RÁPIDA ────────────────── */
.barra-reserva{
  background:#fff;
  border-bottom:1px solid var(--areia-mid);
  padding:32px 24px;
  box-shadow:0 4px 18px rgba(11,126,164,.07);
}
.barra-reserva-wrap{max-width:980px;margin:0 auto}
.barra-reserva h3{
  font-family:var(--serif);font-size:22px;font-weight:400;
  color:var(--petrol-dk);margin-bottom:20px;text-align:center;
}
.form-rapido{
  display:grid;grid-template-columns:1fr 1fr 1fr auto;
  gap:16px;align-items:end;
}
.campo-rapido{display:flex;flex-direction:column;gap:6px}
.campo-rapido label{
  font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--txt-light);
}
.campo-rapido input,
.campo-rapido select{
  height:48px;padding:0 16px;
  border:1.5px solid var(--areia-mid);border-radius:var(--r);
  font-family:var(--sans);font-size:14px;color:var(--txt);
  background:var(--areia);cursor:pointer;
  transition:border-color .2s;
}
.campo-rapido input:focus,
.campo-rapido select:focus{outline:none;border-color:var(--petrol)}
.btn-buscar{
  height:48px;padding:0 26px;
  background:var(--petrol-dk);color:#fff;
  font-family:var(--sans);font-size:13px;font-weight:500;
  border:none;border-radius:var(--r);cursor:pointer;
  display:flex;align-items:center;gap:8px;
  transition:all .25s;white-space:nowrap;
}
.btn-buscar svg{width:16px;height:16px}
.btn-buscar:hover{background:var(--petrol);transform:translateY(-1px)}

/* ─── SECÇÕES COMUNS ──────────────────────── */
.secao{padding:100px 24px}
.secao-wrap{max-width:1220px;margin:0 auto}
.secao-topo{text-align:center;margin-bottom:64px}
.tag{
  display:inline-block;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--petrol);margin-bottom:14px;
}
.secao-topo h2{
  font-family:var(--serif);
  font-size:clamp(32px,5vw,54px);
  font-weight:300;color:var(--petrol-dk);line-height:1.15;
}
.secao-topo h2 em{font-style:italic;color:var(--terra)}
.secao-topo p{
  max-width:560px;margin:18px auto 0;
  color:var(--txt-light);line-height:1.75;
}

/* ─── ACOMODAÇÕES ─────────────────────────── */
.acom-sec{background:var(--areia)}
.acom-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:32px;align-items:start;
}
.acom-card{
  background:#fff;border-radius:14px;
  overflow:hidden;box-shadow:var(--sombra);
  position:relative;transition:transform .3s,box-shadow .3s;
}
.acom-card:hover{transform:translateY(-7px);box-shadow:var(--sombra-lg)}
.badge-pop{
  position:absolute;top:18px;right:18px;
  background:var(--gold);color:var(--petrol-dk);
  font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:5px 14px;border-radius:100px;z-index:2;
}
.acom-img-wrap{overflow:hidden;position:relative}
.acom-img{
  height:290px;
  background-size:cover;background-position:center;
  transition:transform .6s ease;
}
.acom-card:hover .acom-img{transform:scale(1.05)}

/* FOTOS REAIS */
.foto-premium  { background-image:url('/images/casas.jpg');  background-position:center top }
.foto-standard { background-image:url('/images/casas_geminadas.jpg'); background-position:center 25% }

.acom-corpo{padding:28px}
.acom-corpo h3{
  font-family:var(--serif);font-size:25px;font-weight:400;
  color:var(--petrol-dk);margin-bottom:10px;
}
.acom-corpo>p{color:var(--txt-light);line-height:1.65;margin-bottom:20px;font-size:14px}
.feat-list{
  list-style:none;display:grid;
  grid-template-columns:1fr 1fr;gap:9px;margin-bottom:22px;
}
.feat-list li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--castanho)}
.feat-list li svg{width:16px;height:16px;stroke:var(--petrol);flex-shrink:0}
.acom-rodape{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:18px;border-top:1px solid var(--areia-mid);
}
.preco-de{display:block;font-size:11px;color:var(--txt-light)}
.preco-val{
  font-family:var(--serif);font-size:28px;
  color:var(--petrol-dk);font-weight:600;
}
.preco-val small{font-size:13px;font-weight:300;color:var(--txt-light)}
.btn-acom{
  display:inline-flex;align-items:center;
  background:var(--petrol-dk);color:#fff;
  font-size:13px;font-weight:500;padding:12px 24px;
  border-radius:var(--r);transition:all .25s;
}
.btn-acom:hover{background:var(--petrol);transform:translateY(-1px)}

/* ─── GALERIA ─────────────────────────────── */
.galeria-sec{background:var(--cream)}
.gal-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:310px 250px;
  gap:12px;
}
.gal-item{
  position:relative;border-radius:10px;
  overflow:hidden;cursor:pointer;
}
.gal-item.g-tall{grid-row:span 2}
.gal-item.g-wide{grid-column:span 2}
.gal-foto{
  width:100%;height:100%;
  background-size:cover;background-position:center;
  transition:transform .6s ease;
}
.gal-item:hover .gal-foto{transform:scale(1.07)}
.gal-over{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(7,95,124,.72) 0%,transparent 55%);
  opacity:0;transition:opacity .35s;
  display:flex;align-items:flex-end;padding:18px;
}
.gal-item:hover .gal-over{opacity:1}
.gal-label{color:#fff;font-size:13px;letter-spacing:.4px}

/* FOTOS REAIS NA GALERIA */
.gf1{background-image:url('/images/jardim.jpg');      background-position:center}
.gf2{background-image:url('/images/quarto_casal.jpg');background-position:center top}
.gf3{background-image:url('/images/frente.jpg');      background-position:center}
.gf4{background-image:url('/images/ferias_piscina.jpg');background-position:center 35%}
.gf5{background-image:url('/images/quartos_twin.jpg');background-position:center top}

/* ─── BILENE STRIP ────────────────────────── */
.bilene-strip{position:relative;height:360px;overflow:hidden}
.bilene-foto{
  position:absolute;inset:0;
  background:url('/images/bilene_praia.jpg') center 55%/cover no-repeat;
}
.bilene-over{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(7,95,124,.88) 0%,rgba(7,60,80,.6) 60%,rgba(7,95,124,.25) 100%);
  display:flex;align-items:center;padding:0 90px;
}
.bilene-txt h3{
  font-family:var(--serif);font-size:38px;font-weight:300;
  color:#fff;margin-bottom:12px;line-height:1.2;
}
.bilene-txt h3 em{font-style:italic;color:var(--petrol-lt)}
.bilene-txt p{
  color:rgba(255,255,255,.72);line-height:1.75;
  margin-bottom:28px;font-size:15px;max-width:460px;
}

/* ─── SOBRE ───────────────────────────────── */
.sobre-sec{background:#fff}
.sobre-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.sobre-fotos{position:relative}
.sobre-foto-main{
  height:500px;
  background:url('/images/frente.jpg') center/cover no-repeat;
  border-radius:12px;box-shadow:var(--sombra-lg);
  position:relative;
}
.sobre-foto-main::before{
  content:'';position:absolute;inset:-10px;
  border:1.5px solid var(--petrol-lt);
  border-radius:14px;opacity:.35;
}
.sobre-foto-mini{
  position:absolute;bottom:-28px;right:-28px;
  width:190px;height:190px;
  background:url('/images/quarto_casal.jpg') center top/cover no-repeat;
  border-radius:10px;border:4px solid #fff;
  box-shadow:var(--sombra-lg);
}
.sobre-pill{
  position:absolute;top:22px;left:-18px;
  background:var(--petrol-dk);color:#fff;
  padding:10px 18px;border-radius:100px;
  display:flex;align-items:center;gap:8px;
  font-size:12px;font-weight:500;box-shadow:var(--sombra);
}
.sobre-pill svg{width:15px;height:15px;stroke:var(--gold)}

.sobre-txt .tag{display:block;margin-bottom:12px}
.sobre-txt h2{
  font-family:var(--serif);font-size:clamp(28px,4vw,46px);
  font-weight:300;color:var(--petrol-dk);margin-bottom:20px;line-height:1.15;
}
.sobre-txt h2 em{font-style:italic;color:var(--terra)}
.sobre-txt>p{color:var(--txt-light);line-height:1.75;margin-bottom:14px;font-size:15px}
.destaques{margin:28px 0;display:flex;flex-direction:column;gap:18px}
.dest{display:flex;gap:14px;align-items:flex-start}
.dest-icon{
  width:44px;height:44px;flex-shrink:0;
  background:rgba(11,126,164,.1);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
}
.dest-icon svg{width:20px;height:20px;stroke:var(--petrol)}
.dest h4{font-size:15px;font-weight:600;color:var(--petrol-dk);margin-bottom:3px}
.dest p{font-size:13px;color:var(--txt-light)}

/* ─── CONTACTOS ───────────────────────────── */
.contactos-sec{background:var(--areia)}
.contatos-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:22px;margin-bottom:56px;
}
.ctt-card{
  background:#fff;border-radius:var(--r);padding:30px 20px;
  text-align:center;box-shadow:var(--sombra);transition:transform .3s;
}
.ctt-card:hover{transform:translateY(-4px)}
.ctt-icon{
  width:56px;height:56px;background:rgba(11,126,164,.1);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;
}
.ctt-icon svg{width:24px;height:24px;stroke:var(--petrol)}
.ctt-card h4{
  font-family:var(--serif);font-size:18px;font-weight:400;
  color:var(--petrol-dk);margin-bottom:10px;
}
.ctt-card a,.ctt-card p{
  display:block;font-size:14px;color:var(--castanho);
  line-height:1.8;transition:color .2s;
}
.ctt-card a:hover{color:var(--petrol)}
.cta-box{
  background:var(--petrol-dk);border-radius:12px;
  padding:48px;display:flex;align-items:center;
  justify-content:space-between;gap:32px;
}
.cta-box-txt h3{
  font-family:var(--serif);font-size:30px;font-weight:300;
  color:#fff;margin-bottom:8px;
}
.cta-box-txt p{color:rgba(255,255,255,.6)}

/* ─── PÁGINA RESERVAS ─────────────────────── */
.res-hero{
  position:relative;
  padding:calc(var(--nav-h) + 64px) 24px 60px;
  text-align:center;overflow:hidden;
}
.res-hero-foto{
  position:absolute;inset:0;
  background:url('/images/jardim.jpg') center 35%/cover no-repeat;
}
.res-hero-over{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(4,50,65,.9) 0%,rgba(11,126,164,.78) 100%);
}
.res-hero-txt{position:relative}
.res-hero-txt .tag{display:block;margin-bottom:10px}
.res-hero-txt h1{
  font-family:var(--serif);font-size:clamp(38px,6vw,68px);
  font-weight:300;color:#fff;margin-bottom:14px;
}
.res-hero-txt h1 em{font-style:italic;color:var(--gold)}
.res-hero-txt p{color:rgba(255,255,255,.65);font-size:16px}

.res-sec{padding:60px 24px 100px}
.res-grid{
  max-width:1120px;margin:0 auto;
  display:grid;grid-template-columns:1fr 380px;
  gap:40px;align-items:start;
}
.form-card{
  background:#fff;border-radius:14px;
  padding:40px;box-shadow:var(--sombra);
}
.form-card h2{
  font-family:var(--serif);font-size:28px;font-weight:400;
  color:var(--petrol-dk);margin-bottom:30px;
}
.ftitle{
  display:flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--petrol);margin:26px 0 18px;font-weight:500;
}
.ftitle svg{width:15px;height:15px}
.ftitle::after{content:'';flex:1;height:1px;background:var(--areia-mid)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fgrupo{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.fgrupo label{font-size:13px;font-weight:500;color:var(--castanho)}
.fgrupo .req{color:var(--terra)}
.fgrupo input,
.fgrupo select,
.fgrupo textarea{
  width:100%;padding:12px 16px;
  border:1.5px solid var(--areia-mid);border-radius:var(--r);
  font-family:var(--sans);font-size:14px;color:var(--txt);
  background:var(--cream);transition:border-color .2s,box-shadow .2s;
}
.fgrupo input:focus,
.fgrupo select:focus,
.fgrupo textarea:focus{
  outline:none;border-color:var(--petrol);
  box-shadow:0 0 0 3px rgba(11,126,164,.1);background:#fff;
}
.fgrupo input.err,
.fgrupo select.err{border-color:#d9534f}
.ferr{font-size:12px;color:#d9534f}
.icon-input{position:relative}
.icon-input svg{
  position:absolute;left:13px;top:50%;transform:translateY(-50%);
  width:16px;height:16px;stroke:var(--txt-light);pointer-events:none;
}
.icon-input input{padding-left:42px;cursor:pointer}
.noites-aviso{
  display:flex;align-items:center;gap:10px;
  background:rgba(11,126,164,.08);
  border:1px solid rgba(11,126,164,.2);
  border-radius:var(--r);padding:11px 15px;
  margin:-2px 0 18px;font-size:13px;
  color:var(--petrol-dk);font-weight:500;
}
.noites-aviso svg{width:16px;height:16px;stroke:var(--petrol);flex-shrink:0}
.politica-txt{
  display:flex;gap:11px;align-items:flex-start;
  background:var(--areia);border-radius:var(--r);
  padding:15px;margin-bottom:22px;
  font-size:12px;color:var(--txt-light);line-height:1.65;
}
.politica-txt svg{width:15px;height:15px;flex-shrink:0;margin-top:2px;stroke:var(--petrol)}
.btn-enviar{
  width:100%;padding:16px;
  background:var(--petrol-dk);color:#fff;
  font-family:var(--sans);font-size:15px;font-weight:500;
  letter-spacing:.8px;border:none;border-radius:var(--r);
  cursor:pointer;display:flex;align-items:center;
  justify-content:center;gap:10px;transition:all .25s;
}
.btn-enviar svg{width:18px;height:18px}
.btn-enviar:hover{background:var(--petrol);transform:translateY(-2px);box-shadow:var(--sombra-lg)}

/* Sidebar */
.res-sidebar{
  display:flex;flex-direction:column;gap:22px;
  position:sticky;top:calc(var(--nav-h) + 20px);
}
.side-card{
  background:#fff;border-radius:12px;
  padding:26px;box-shadow:var(--sombra);
}
.side-card h3{
  font-family:var(--serif);font-size:20px;font-weight:400;
  color:var(--petrol-dk);margin-bottom:18px;
}
.sum-item{
  display:flex;gap:13px;align-items:flex-start;
  padding:11px 0;border-bottom:1px solid var(--areia-mid);
}
.sum-item:last-child{border:none}
.sum-item svg{width:17px;height:17px;stroke:var(--petrol);flex-shrink:0;margin-top:2px}
.sum-lbl{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--txt-light);margin-bottom:3px}
.sum-val{font-size:14px;color:var(--txt);font-weight:500}
.sum-noites{
  text-align:center;padding:11px;
  background:rgba(11,126,164,.08);border-radius:var(--r);
  font-family:var(--serif);font-size:18px;color:var(--petrol-dk);
  margin-top:8px;
}
.side-ctt p{font-size:13px;color:var(--txt-light);margin-bottom:14px;line-height:1.6}
.ctt-link{
  display:flex;align-items:center;gap:9px;
  font-size:13px;color:var(--castanho);
  padding:7px 0;transition:color .2s;
}
.ctt-link svg{width:15px;height:15px;stroke:var(--petrol);flex-shrink:0}
.ctt-link:hover{color:var(--petrol)}
.side-pol ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.side-pol li{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--castanho)}
.side-pol li svg{width:15px;height:15px;stroke:var(--petrol);flex-shrink:0}

/* ─── PÁGINA SUCESSO ──────────────────────── */
.sucesso-sec{
  min-height:calc(100vh - var(--nav-h));
  display:flex;align-items:center;justify-content:center;
  padding:calc(var(--nav-h) + 40px) 24px 80px;
  background:var(--areia);
}
.sucesso-box{
  max-width:560px;width:100%;
  background:#fff;border-radius:16px;
  padding:56px 48px;text-align:center;
  box-shadow:var(--sombra-lg);
}
.sucesso-ico{
  width:80px;height:80px;
  background:rgba(11,126,164,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 26px;
}
.sucesso-ico svg{width:40px;height:40px;stroke:var(--petrol)}
.sucesso-box h1{
  font-family:var(--serif);font-size:42px;font-weight:300;
  color:var(--petrol-dk);margin-bottom:14px;
}
.sucesso-box h1 em{font-style:italic;color:var(--gold)}
.sucesso-msg{color:var(--txt-light);margin-bottom:30px;line-height:1.65}
.det-grid{
  background:var(--areia);border-radius:var(--r);
  padding:22px;margin-bottom:22px;text-align:left;
}
.det-row{
  display:flex;justify-content:space-between;
  padding:8px 0;border-bottom:1px solid var(--areia-mid);
}
.det-row:last-child{border:none}
.det-l{font-size:12px;color:var(--txt-light)}
.det-v{font-size:13px;font-weight:600;color:var(--petrol-dk)}
.sucesso-nota{
  display:flex;gap:11px;align-items:flex-start;
  background:rgba(11,126,164,.06);border-radius:var(--r);
  padding:14px;margin-bottom:30px;
  font-size:13px;color:var(--castanho);line-height:1.65;text-align:left;
}
.sucesso-nota svg{width:17px;height:17px;stroke:var(--petrol);flex-shrink:0;margin-top:2px}
.sucesso-btns{display:flex;gap:14px;justify-content:center}
.btn-sec{
  display:inline-flex;align-items:center;gap:7px;
  background:transparent;color:var(--petrol-dk);
  font-family:var(--sans);font-size:13px;font-weight:500;
  letter-spacing:.8px;text-transform:uppercase;
  padding:13px 26px;border-radius:var(--r);
  border:1px solid var(--areia-mid);cursor:pointer;
  transition:all .25s;
}
.btn-sec:hover{border-color:var(--petrol);background:var(--areia)}

/* ─── RODAPÉ ──────────────────────────────── */
.rodape{background:var(--petrol-dk);color:#fff;padding:80px 24px 0}
.rodape-grid{
  max-width:1220px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1.5fr 1.5fr;
  gap:48px;padding-bottom:60px;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.rodape-marca .r-logo{margin-bottom:18px}
.r-logo .logo-top{font-family:var(--serif);font-size:22px;font-style:italic;color:#fff}
.r-logo .logo-top span{font-style:normal;color:var(--gold)}
.r-logo small{display:block;font-size:9px;letter-spacing:3px;color:rgba(255,255,255,.38);margin-top:3px}
.rodape-marca p{font-size:13px;color:rgba(255,255,255,.52);line-height:1.7;margin-bottom:18px}
.r-social{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;color:var(--gold);transition:color .2s;
}
.r-social svg{width:18px;height:18px}
.r-social:hover{color:var(--gold-lt)}
.rodape-nav h4,
.rodape-ctt h4,
.rodape-book h4{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.38);margin-bottom:18px;
}
.rodape-nav ul{list-style:none}
.rodape-nav li{margin-bottom:9px}
.rodape-nav a{font-size:14px;color:rgba(255,255,255,.62);transition:color .2s}
.rodape-nav a:hover{color:var(--gold)}
.rodape-ctt ul{list-style:none}
.rodape-ctt li{
  display:flex;align-items:flex-start;gap:9px;
  font-size:13px;color:rgba(255,255,255,.62);
  margin-bottom:11px;line-height:1.5;
}
.rodape-ctt li svg{width:15px;height:15px;stroke:var(--gold);flex-shrink:0;margin-top:2px}
.rodape-ctt a{color:rgba(255,255,255,.62);transition:color .2s}
.rodape-ctt a:hover{color:var(--gold)}
.rodape-book p{font-size:13px;color:rgba(255,255,255,.52);margin-bottom:14px}
.r-btn-booking,.r-btn-directo{
  display:flex;align-items:center;gap:9px;
  font-size:13px;font-weight:500;padding:11px 18px;
  border-radius:var(--r);margin-bottom:10px;transition:all .25s;
}
.r-btn-booking{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.18)}
.r-btn-booking:hover{background:rgba(255,255,255,.18)}
.r-btn-directo{background:var(--gold);color:var(--petrol-dk);font-weight:700;justify-content:center}
.r-btn-directo:hover{background:var(--gold-lt)}
.rodape-baixo{max-width:1220px;margin:0 auto;padding:22px 0;text-align:center}
.rodape-baixo p{font-size:12px;color:rgba(255,255,255,.28)}

/* ─── ALERTAS ─────────────────────────────── */
.alerta{
  position:fixed;top:calc(var(--nav-h) + 14px);right:22px;
  z-index:999;max-width:400px;
  display:flex;align-items:center;gap:11px;
  padding:15px 20px;border-radius:var(--r);
  font-size:14px;animation:slideIn .4s ease;
  box-shadow:var(--sombra-lg);
}
.alerta svg{width:20px;height:20px;flex-shrink:0}
.alerta-ok{background:var(--petrol-dk);color:#fff}
.alerta-err{background:#c0392b;color:#fff}

/* ─── FLATPICKR ───────────────────────────── */
.flatpickr-calendar{border-radius:var(--r)!important;box-shadow:var(--sombra-lg)!important;border:1px solid var(--areia-mid)!important}
.flatpickr-day.selected,.flatpickr-day.selected:hover{background:var(--petrol-dk)!important;border-color:var(--petrol-dk)!important}
.flatpickr-day.inRange{background:rgba(11,126,164,.13)!important;border-color:rgba(11,126,164,.13)!important}
.flatpickr-day:hover{background:var(--areia)!important}
.flatpickr-months .flatpickr-month{background:var(--petrol-dk)!important}
.flatpickr-current-month,.flatpickr-monthDropdown-months{color:#fff!important}
.flatpickr-weekday{color:var(--txt-light)!important}
.flatpickr-day.today{border-color:var(--gold)!important}

/* ─── ANIMAÇÕES ───────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulso{0%,100%{opacity:.4}50%{opacity:1}}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ─── RESPONSIVO ──────────────────────────── */
@media(max-width:1024px){
  .acom-grid{grid-template-columns:1fr;max-width:600px;margin:0 auto}
  .sobre-grid{grid-template-columns:1fr;gap:48px}
  .contatos-grid{grid-template-columns:1fr 1fr}
  .rodape-grid{grid-template-columns:1fr 1fr}
  .res-grid{grid-template-columns:1fr}
  .res-sidebar{position:static}
  .form-rapido{grid-template-columns:1fr 1fr}
  .btn-buscar{grid-column:span 2}
  .bilene-over{padding:0 40px}
}
@media(max-width:768px){
  .nav-links{
    display:none;flex-direction:column;
    position:fixed;inset:var(--nav-h) 0 0;
    background:var(--petrol-dk);
    padding:30px 22px;gap:6px;overflow-y:auto;
  }
  .nav-links.aberto{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:13px 15px;font-size:16px}
  .nav-cta{text-align:center;margin:8px 0 0!important}
  .hamburger{display:flex}
  .hero-stats{min-width:auto;width:calc(100% - 32px);padding:15px 18px}
  .stat{padding:0 10px}
  .stat-n{font-size:24px}
  .faixa-inner{gap:20px}
  .form-rapido{grid-template-columns:1fr}
  .btn-buscar{grid-column:1}
  .gal-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gal-item.g-tall{grid-column:span 2}
  .gf1{height:240px}
  .gf2,.gf3,.gf5{height:200px}
  .contatos-grid{grid-template-columns:1fr 1fr}
  .cta-box{flex-direction:column;text-align:center;padding:30px 22px}
  .rodape-grid{grid-template-columns:1fr;gap:28px}
  .sobre-foto-mini,.sobre-pill{display:none}
  .bilene-over{padding:0 22px}
  .bilene-txt h3{font-size:28px}
  .frow{grid-template-columns:1fr}
  .form-card{padding:22px}
  .sucesso-box{padding:38px 22px}
  .sucesso-btns{flex-direction:column}
}