/* =====================================================================
   POUSADA LAGOA DO CASSANGE — "Onde a Lagoa Beija o Mar"
   Slow-cinema eco-luxo barefoot · Península de Maraú, Bahia
   Design: Impero Solutions · cor-âncora #F5A21D (logo) + teal profundo
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  /* Base escura — lagoa, mata, noite */
  --ink:#0A1F1E;            /* quase-preto esverdeado */
  --deep:#0C2E2B;           /* teal profundo (seções dark) */
  --deep-2:#0F3A35;         /* teal alt */
  --lagoa:#15564E;          /* esmeralda lagoa */
  --mata:#1C6E63;           /* esmeralda mata */
  --turq:#2FB6A8;           /* turquesa piscina natural */
  --turq-soft:#7FD8C8;      /* água rasa clara */

  /* Acento — âmbar do logo / pôr do sol */
  --amber:#F5A21D;          /* COR-ÂNCORA da marca */
  --amber-2:#E98A4B;        /* coral pôr-do-sol */
  --amber-deep:#C9621E;     /* âmbar profundo */
  --gold:#D8B98C;           /* areia molhada / dourado */

  /* Claros — areia, papel */
  --sand:#E9DCC3;           /* areia */
  --paper:#F4EFE6;          /* off-white casca de ovo */
  --cream:#FAF7EF;          /* creme */

  /* Texto */
  --on-dark:#F4EFE6;
  --on-dark-mute:rgba(244,239,230,.70);
  --on-dark-faint:rgba(244,239,230,.56);
  --ink-text:#1A2B28;       /* texto sobre claro */
  --mute:#5C6B66;           /* texto mudo claro */
  --rule-dark:rgba(244,239,230,.16);
  --rule-light:rgba(26,43,40,.14);

  /* Tipografia */
  --serif:"Fraunces","Fraunces Fallback",Georgia,"Times New Roman",serif;
  --sans:"Inter","Inter Fallback",system-ui,-apple-system,"Segoe UI",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",monospace;

  /* Espaço / container */
  --container:1280px;
  --narrow:760px;
  --pad:clamp(20px,5vw,72px);

  /* Easing cinema */
  --e-cine:cubic-bezier(.76,0,.24,1);
  --e-out:cubic-bezier(.2,.7,.2,1);
}

/* ---------- Fallbacks com métricas ajustadas (anti-CLS de webfont) ---------- */
@font-face{font-family:"Inter Fallback";src:local("Arial");ascent-override:90.49%;descent-override:22.56%;line-gap-override:0%;size-adjust:107.06%}
@font-face{font-family:"Fraunces Fallback";src:local("Georgia");ascent-override:90%;descent-override:23%;line-gap-override:0%;size-adjust:102%}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--deep);
  color:var(--on-dark);
  line-height:1.6;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1;text-wrap:balance}
p{text-wrap:pretty}
::selection{background:var(--amber);color:var(--ink)}

/* ---------- Acessibilidade ---------- */
.skip{position:absolute;left:-9999px;top:0}
.skip:focus{left:12px;top:12px;z-index:9999;background:var(--amber);color:var(--ink);
  padding:10px 16px;border-radius:8px;font-weight:600}
:focus-visible{outline:2px solid var(--amber);outline-offset:3px}

/* =====================================================================
   Utilitários de layout
   ===================================================================== */
.container{width:min(92vw,var(--container));margin-inline:auto}
.section{position:relative;padding-block:clamp(80px,12vw,170px)}
.eyebrow{font-family:var(--mono);font-size:clamp(11px,1.05vw,12.5px);
  letter-spacing:.34em;text-transform:uppercase;font-weight:500}
.sec-num{font-family:var(--mono);font-size:12px;letter-spacing:.2em;opacity:.78}

/* Light / Dark surfaces */
.s-paper{background:var(--paper);color:var(--ink-text)}
.s-sand{background:var(--sand);color:var(--ink-text)}
.s-deep{background:var(--deep);color:var(--on-dark)}
.s-ink{background:var(--ink);color:var(--on-dark)}
.s-paper .eyebrow,.s-sand .eyebrow{color:#9c4a0e}
.s-deep .eyebrow,.s-ink .eyebrow{color:var(--amber)}

/* =====================================================================
   Loader cinematográfico (cortina creme → revela hero)
   ===================================================================== */
.loader{position:fixed;inset:0;z-index:10000;background:var(--paper);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
  animation:loaderOut .62s var(--e-cine) .12s forwards}
@keyframes loaderOut{to{transform:translateY(-101%);visibility:hidden}}
.loader.done{transform:translateY(-101%)}
.no-js .loader{display:none}
.loader__logo{width:min(46vw,260px);opacity:0;transform:translateY(10px) scale(.985);
  animation:loaderIn .5s var(--e-out) 0s forwards}
@keyframes loaderIn{to{opacity:1;transform:none}}
.loader__bar{width:min(64vw,300px);height:2px;background:rgba(26,43,40,.14);overflow:hidden;border-radius:2px}
.loader__bar i{display:block;height:100%;width:0;background:var(--amber);
  animation:loaderBar .5s var(--e-out) .05s forwards}
@keyframes loaderBar{to{width:100%}}
.loader__cap{font-family:var(--mono);font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--mute);opacity:0;animation:loaderIn .45s ease .15s forwards}

/* ---------- Grão de filme ---------- */
.grain{position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- Barra de progresso ---------- */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--amber);z-index:8000;
  box-shadow:0 0 12px rgba(245,162,29,.6)}

/* ---------- Cursor custom ---------- */
.cursor{position:fixed;top:0;left:0;width:34px;height:34px;border:1.5px solid var(--amber);
  border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:9500;
  transition:width .25s var(--e-out),height .25s var(--e-out),background .25s,border-color .25s;
  mix-blend-mode:difference;display:none}
.cursor__label{position:fixed;top:0;left:0;transform:translate(-50%,-50%);pointer-events:none;
  z-index:9500;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);background:var(--amber);padding:5px 9px;border-radius:100px;
  opacity:0;transition:opacity .25s;display:none;white-space:nowrap}
.cursor.is-grow{width:64px;height:64px;background:rgba(245,162,29,.12)}
@media (hover:hover) and (pointer:fine){
  .cursor,.cursor__label{display:block}
}

/* =====================================================================
   Navegação
   ===================================================================== */
.nav{position:fixed;top:0;left:0;width:100%;z-index:7000;
  transition:background .45s var(--e-out),box-shadow .45s,padding .45s,backdrop-filter .45s}
.nav__wrap{width:min(94vw,1440px);margin-inline:auto;display:flex;align-items:center;gap:24px;
  padding:22px 0}
.nav__brand{display:flex;align-items:center;gap:12px;z-index:2}
.nav__brand img{width:38px;height:auto;transition:transform .5s var(--e-cine)}
.nav__brand:hover img{transform:rotate(-12deg)}
.nav__brand b{font-family:var(--serif);font-weight:500;font-size:18px;letter-spacing:.01em;
  color:var(--on-dark);line-height:1.05;transition:color .45s}
.nav__brand b small{display:block;font-family:var(--mono);font-size:8.5px;letter-spacing:.3em;
  text-transform:uppercase;opacity:.7;font-weight:500;margin-top:2px}
.nav__links{display:flex;gap:30px;margin-left:auto;align-items:center}
.nav__links a{font-size:13.5px;letter-spacing:.02em;color:var(--on-dark);opacity:.9;
  position:relative;padding:4px 0;transition:opacity .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--amber);transition:width .35s var(--e-out)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__cta{margin-left:8px;padding:11px 22px;border-radius:100px;background:var(--amber);
  color:var(--ink)!important;font-weight:600;font-size:13.5px;opacity:1!important;
  transition:transform .25s var(--e-out),box-shadow .3s}
.nav__cta::after{display:none}
.nav__cta:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(245,162,29,.4)}
.nav__burger{display:none;flex-direction:column;gap:5px;width:30px;z-index:2;margin-left:auto}
.nav__burger span{display:block;height:2px;width:100%;background:var(--on-dark);
  border-radius:2px;transition:transform .4s var(--e-cine),opacity .3s,background .45s}

/* estado scrolled */
.nav.is-scrolled{background:rgba(10,31,30,.78);backdrop-filter:blur(16px) saturate(1.4);
  box-shadow:0 1px 0 var(--rule-dark)}
.nav.is-scrolled .nav__wrap{padding:13px 0}

@media (max-width:920px){
  .nav__links{position:fixed;inset:0;background:var(--deep);flex-direction:column;
    justify-content:center;gap:30px;transform:translateY(-100%);transition:transform .6s var(--e-cine);
    margin:0;padding:80px 24px}
  .nav__links a{font-size:24px;font-family:var(--serif)}
  .nav__links.open{transform:none}
  .nav__cta{margin:18px 0 0}
  .nav__burger{display:flex}
  .nav.is-open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.is-open .nav__burger span:nth-child(2){opacity:0}
  .nav.is-open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  overflow:hidden;background:var(--ink)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;
  animation:kenburns 26s ease-in-out infinite alternate;will-change:transform}
@keyframes kenburns{from{transform:scale(1.06) translate(0,0)}to{transform:scale(1.18) translate(-1.5%,-2%)}}
.hero__veil{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(to top,rgba(10,31,30,.92) 0%,rgba(10,31,30,.28) 42%,rgba(10,31,30,.10) 70%,rgba(10,31,30,.45) 100%),
    radial-gradient(120% 80% at 80% 10%,rgba(245,162,29,.16),transparent 55%)}
.hero__inner{position:relative;z-index:2;width:min(94vw,1440px);margin-inline:auto;
  padding-bottom:clamp(40px,8vh,90px);padding-top:140px;width:100%}
.hero__eyebrow{color:var(--amber);margin-bottom:26px;display:flex;align-items:center;gap:14px}
.hero__eyebrow::before{content:"";width:42px;height:1px;background:var(--amber)}
.hero h1{font-size:clamp(3.2rem,11.5vw,11rem);line-height:.86;letter-spacing:-.03em;
  color:var(--on-dark);font-weight:300}
.hero h1 em{font-style:italic;color:var(--amber);font-weight:400}
.hero__sub{max-width:46ch;margin-top:30px;font-size:clamp(1rem,1.5vw,1.22rem);
  color:var(--on-dark-mute);font-weight:300}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;margin-top:38px}
.hero__meta{position:absolute;right:0;bottom:clamp(40px,8vh,90px);z-index:2;text-align:right;
  display:flex;flex-direction:column;gap:16px;padding-right:max(3vw,calc((100vw - 1440px)/2 + 0px))}
.hero__metaitem{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--on-dark-mute);
  text-transform:uppercase}
.hero__metaitem b{display:block;font-family:var(--serif);font-size:24px;letter-spacing:0;
  color:var(--on-dark);text-transform:none;font-weight:400;margin-bottom:2px}
.hero__metaitem .stars{color:var(--amber);letter-spacing:.05em}
.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--on-dark-mute)}
.hero__scroll span{font-family:var(--mono);font-size:9.5px;letter-spacing:.3em;text-transform:uppercase}
.hero__scroll i{width:1px;height:42px;background:linear-gradient(var(--amber),transparent);
  animation:scrolly 2.2s ease-in-out infinite}
@keyframes scrolly{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}
@media(max-width:920px){
  .hero__meta{display:none}
  .hero h1{font-size:clamp(2.9rem,15vw,5rem)}
}

/* ---------- Botões ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 30px;border-radius:100px;font-weight:600;font-size:14px;letter-spacing:.01em;
  min-height:52px;transition:transform .25s var(--e-out),box-shadow .3s,background .3s,color .3s,border-color .3s}
.btn--amber{background:var(--amber);color:var(--ink)}
.btn--amber:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(245,162,29,.42)}
.btn--ghost{border:1.5px solid rgba(244,239,230,.45);color:var(--on-dark)}
.btn--ghost:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-3px)}
.btn--ink{background:var(--ink);color:var(--on-dark)}
.btn--ink:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(10,31,30,.3)}
.btn--ghost-dark{border:1.5px solid var(--rule-light);color:var(--ink-text)}
.btn--ghost-dark:hover{border-color:var(--amber-deep);color:var(--amber-deep)}
.btn svg{width:16px;height:16px}

/* =====================================================================
   Reveals / movimentos
   ===================================================================== */
.no-js .reveal{opacity:1;transform:none}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--e-out),transform .9s var(--e-out);
  transition-delay:var(--d,0ms)}
.reveal.is-in{opacity:1;transform:none}

/* line reveal (máscara) */
.ln{display:block;overflow:hidden;padding-bottom:.04em}
.ln>span{display:block;transform:translateY(112%);transition:transform 1.05s var(--e-cine);
  transition-delay:var(--d,0ms)}
.is-in .ln>span,.ready .ln>span{transform:translateY(0)}

/* clip-reveal de imagem */
.clip{clip-path:inset(0 0 100% 0);transition:clip-path 1.2s var(--e-cine);will-change:clip-path}
.clip.is-in{clip-path:inset(0 0 0 0)}
.no-js .clip{clip-path:none}

/* parallax */
.parallax{will-change:transform}

/* =====================================================================
   Marquee
   ===================================================================== */
.marquee{background:var(--ink);color:var(--on-dark);overflow:hidden;
  border-block:1px solid var(--rule-dark);padding:18px 0;white-space:nowrap}
.marquee__track{display:inline-flex;gap:0;animation:marq 38s linear infinite;will-change:transform}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee span{font-family:var(--serif);font-size:clamp(1.3rem,2.6vw,2.1rem);font-style:italic;
  padding:0 28px;display:inline-flex;align-items:center;gap:28px}
.marquee span::after{content:"✦";font-style:normal;color:var(--amber);font-size:.6em}
@keyframes marq{to{transform:translateX(-50%)}}

/* =====================================================================
   Intro / Manifesto
   ===================================================================== */
.intro__head{display:flex;justify-content:space-between;align-items:baseline;
  border-bottom:1px solid var(--rule-light);padding-bottom:18px;margin-bottom:clamp(40px,6vw,72px)}
.intro__statement{font-family:var(--serif);font-size:clamp(2rem,5.4vw,4.6rem);line-height:1.02;
  letter-spacing:-.02em;font-weight:300;max-width:18ch}
.intro__statement em{font-style:italic;color:var(--amber-deep)}
.intro__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);
  margin-top:clamp(40px,5vw,64px);align-items:end}
.intro__lede{font-size:clamp(1.02rem,1.4vw,1.18rem);color:var(--mute);max-width:50ch}
.intro__lede strong{color:var(--ink-text);font-weight:600}
/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.5vw,40px);
  margin-top:clamp(54px,7vw,96px);border-top:1px solid var(--rule-light);padding-top:clamp(36px,4vw,56px)}
.stat__num{font-family:var(--serif);font-size:clamp(2.4rem,5.5vw,4.4rem);line-height:1;
  color:var(--ink-text);font-weight:300;display:block}
.stat__num em{font-style:normal;color:var(--amber-deep)}
.stat__lbl{font-size:13px;color:var(--mute);margin-top:12px;display:block;line-height:1.45;max-width:24ch}
.s-deep .stat__num,.s-ink .stat__num{color:var(--on-dark)}
.s-deep .stat__lbl,.s-ink .stat__lbl{color:var(--on-dark-mute)}
.s-deep .stats,.s-ink .stats{border-color:var(--rule-dark)}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr;gap:30px 20px}.intro__grid{grid-template-columns:1fr}}

/* =====================================================================
   Story editorial (Quem somos)
   ===================================================================== */
.story{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,90px);align-items:center}
.story__media{position:relative}
.story__media img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:3px}
.story__media .badge{position:absolute;bottom:-26px;left:-26px;background:var(--amber);color:var(--ink);
  padding:22px 26px;border-radius:3px;max-width:230px;box-shadow:0 24px 50px rgba(10,31,30,.3)}
.story__media .badge b{font-family:var(--serif);font-size:30px;font-weight:400;display:block;line-height:1}
.story__media .badge span{font-size:12px;line-height:1.4;display:block;margin-top:8px}
.story h2{font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.02;letter-spacing:-.02em;margin-bottom:26px;font-weight:300}
.story h2 em{font-style:italic;color:var(--amber-deep)}
.story p{color:var(--mute);margin-bottom:18px;font-size:1.04rem}
.story .sig{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--ink-text);margin-top:24px}
.story .sig small{display:block;font-family:var(--mono);font-style:normal;font-size:11px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-top:6px}
@media(max-width:860px){.story{grid-template-columns:1fr;gap:60px}
  .story__media .badge{left:0;bottom:-20px}}

/* =====================================================================
   Pilares (por que escolher)
   ===================================================================== */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule-dark);
  border:1px solid var(--rule-dark);margin-top:clamp(40px,5vw,64px)}
.pillar{background:var(--deep);padding:clamp(28px,3vw,44px);transition:background .5s var(--e-out)}
.pillar:hover{background:var(--deep-2)}
.pillar__n{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--amber);opacity:.8}
.pillar h3{font-family:var(--serif);font-size:1.5rem;margin:18px 0 12px;font-weight:400;color:var(--on-dark)}
.pillar p{color:var(--on-dark-mute);font-size:.97rem;line-height:1.6}
@media(max-width:860px){.pillars{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pillars{grid-template-columns:1fr}}

/* =====================================================================
   Acomodações
   ===================================================================== */
.rooms__intro{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:30px;
  margin-bottom:clamp(40px,5vw,64px)}
.rooms__intro h2{font-size:clamp(2.2rem,5.6vw,4.6rem);line-height:.98;letter-spacing:-.02em;font-weight:300;
  color:var(--on-dark)}
.rooms__intro h2 em{font-style:italic;color:var(--amber)}
.rooms__intro p{max-width:36ch;color:var(--on-dark-mute)}
.rooms{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,34px)}
.room{position:relative;overflow:hidden;border-radius:4px;background:var(--ink);
  border:1px solid var(--rule-dark)}
.room__img{position:relative;overflow:hidden;aspect-ratio:16/11}
.room__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--e-cine);filter:saturate(1.02)}
.room:hover .room__img img{transform:scale(1.06)}
.room__tag{position:absolute;top:16px;left:16px;z-index:2;font-family:var(--mono);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;background:rgba(10,31,30,.6);backdrop-filter:blur(8px);
  color:var(--on-dark);padding:7px 13px;border-radius:100px;border:1px solid var(--rule-dark)}
.room__body{padding:clamp(24px,2.4vw,34px)}
.room__body h3{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:400;
  color:var(--on-dark);margin-bottom:10px}
.room__cap{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--amber);
  text-transform:uppercase;margin-bottom:16px}
.room__body p{color:var(--on-dark-mute);font-size:.98rem;margin-bottom:20px}
.room__amen{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.room__amen span{font-size:11.5px;color:var(--on-dark-mute);border:1px solid var(--rule-dark);
  padding:5px 11px;border-radius:100px}
.room__link{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:13.5px;color:var(--amber);
  transition:gap .3s}
.room__link:hover{gap:15px}
@media(max-width:760px){.rooms{grid-template-columns:1fr}}

/* =====================================================================
   Banner full-bleed (cinemático)
   ===================================================================== */
.banner{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden;background:var(--ink)}
.banner__media{position:absolute;inset:0;z-index:0}
.banner__media img{width:100%;height:120%;object-fit:cover}
.banner__veil{position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(10,31,30,.78) 0%,rgba(10,31,30,.35) 50%,rgba(10,31,30,.55) 100%)}
.banner__inner{position:relative;z-index:2;width:min(92vw,var(--container));margin-inline:auto}
.banner__inner .eyebrow{color:var(--amber);margin-bottom:24px}
.banner blockquote{font-family:var(--serif);font-size:clamp(2rem,5.6vw,5rem);line-height:1.02;
  letter-spacing:-.02em;font-weight:300;max-width:18ch;color:var(--on-dark)}
.banner blockquote em{font-style:italic;color:var(--amber)}
.banner cite{display:block;margin-top:26px;font-family:var(--mono);font-size:12px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--on-dark-mute);font-style:normal}

/* =====================================================================
   Experiências
   ===================================================================== */
.exp__head{margin-bottom:clamp(40px,5vw,64px);max-width:60ch}
.exp__head h2{font-size:clamp(2.2rem,5.4vw,4.4rem);line-height:1;letter-spacing:-.02em;font-weight:300;margin-top:18px}
.exp__head h2 em{font-style:italic;color:var(--amber-deep)}
.exp__head p{color:var(--mute);margin-top:22px;font-size:1.05rem}
.exp{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.2vw,30px)}
.exp__card{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:3/2.1;
  display:flex;align-items:flex-end;background:var(--ink)}
.exp__card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s var(--e-cine);filter:saturate(1.03)}
.exp__card:hover img{transform:scale(1.07)}
.exp__card::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(10,31,30,.9) 0%,rgba(10,31,30,.18) 55%,transparent 100%)}
.exp__txt{position:relative;z-index:2;padding:clamp(24px,2.6vw,38px);color:var(--on-dark)}
.exp__dur{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--amber);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.exp__txt h3{font-family:var(--serif);font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:400;margin-bottom:10px}
.exp__txt p{color:var(--on-dark-mute);font-size:.96rem;max-width:46ch}
.exp__card--free .exp__dur{color:var(--turq-soft)}
@media(max-width:760px){.exp{grid-template-columns:1fr}}

/* =====================================================================
   Gastronomia (split)
   ===================================================================== */
.gastro{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;min-height:70vh}
.gastro__media{position:relative;overflow:hidden}
.gastro__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.gastro__body{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,6vw,110px) var(--pad)}
.gastro__body h2{font-size:clamp(2rem,4vw,3.4rem);line-height:1.02;letter-spacing:-.02em;font-weight:300;margin:18px 0 24px}
.gastro__body h2 em{font-style:italic;color:var(--amber)}
.gastro__body p{color:var(--on-dark-mute);font-size:1.05rem;margin-bottom:16px;max-width:48ch}
@media(max-width:860px){.gastro{grid-template-columns:1fr}.gastro__media{aspect-ratio:4/3;min-height:300px}}

/* =====================================================================
   Sustentabilidade
   ===================================================================== */
.sust__top{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:center;
  margin-bottom:clamp(50px,6vw,90px)}
.sust__top h2{font-size:clamp(2.1rem,5vw,4.2rem);line-height:1.02;letter-spacing:-.02em;font-weight:300;color:var(--on-dark)}
.sust__top h2 em{font-style:italic;color:var(--amber)}
.sust__top p{color:var(--on-dark-mute);font-size:1.06rem;margin-top:22px}
.sust__list{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule-dark);
  border:1px solid var(--rule-dark)}
.sust__item{background:var(--ink);padding:clamp(22px,2.4vw,34px)}
.sust__item .ic{font-family:var(--serif);font-size:2rem;color:var(--amber);line-height:1}
.sust__item h3{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--on-dark);margin:14px 0 8px}
.sust__item p{color:var(--on-dark-mute);font-size:.92rem;line-height:1.55}
.sust__feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,32px);margin-top:clamp(36px,4vw,56px)}
.sust__feature figure{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:16/10}
.sust__feature img{width:100%;height:100%;object-fit:cover}
.sust__feature figcaption{position:absolute;left:0;bottom:0;z-index:2;padding:24px;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark);
  background:linear-gradient(to top,rgba(10,31,30,.85),transparent)}
@media(max-width:860px){.sust__top,.sust__feature{grid-template-columns:1fr}.sust__list{grid-template-columns:1fr}}

/* =====================================================================
   Avaliações
   ===================================================================== */
.rev__head{text-align:center;max-width:60ch;margin:0 auto clamp(44px,5vw,70px)}
.rev__head h2{font-size:clamp(2.1rem,5vw,4rem);line-height:1.02;letter-spacing:-.02em;font-weight:300}
.rev__head h2 em{font-style:italic;color:var(--amber-deep)}
.rev__badges{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 28px;margin-top:26px}
.rev__badge{display:inline-flex;align-items:center;gap:10px;font-size:14px;color:var(--mute)}
.rev__badge b{font-family:var(--serif);font-size:26px;color:var(--ink-text);font-weight:400}
.rev__badge .stars{color:var(--amber);letter-spacing:.04em;font-size:15px}
.rev__grid{columns:3;column-gap:clamp(18px,2vw,28px)}
.rev__q{break-inside:avoid;background:var(--cream);border:1px solid var(--rule-light);
  border-radius:4px;padding:clamp(22px,2vw,30px);margin-bottom:clamp(18px,2vw,28px)}
.rev__q .stars{color:var(--amber);font-size:14px;letter-spacing:.06em;margin-bottom:14px;display:block}
.rev__q p{font-family:var(--serif);font-size:1.12rem;line-height:1.45;color:var(--ink-text);font-style:italic}
.rev__q cite{display:block;margin-top:16px;font-style:normal;font-family:var(--mono);font-size:11px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--mute)}
.rev__cta{text-align:center;margin-top:clamp(30px,4vw,48px)}
@media(max-width:920px){.rev__grid{columns:2}}
@media(max-width:600px){.rev__grid{columns:1}}

/* =====================================================================
   Como Chegar
   ===================================================================== */
.arrive{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,5vw,80px);align-items:center}
.arrive h2{font-size:clamp(2.1rem,4.6vw,3.6rem);line-height:1.02;letter-spacing:-.02em;font-weight:300;
  color:var(--on-dark);margin-bottom:26px}
.arrive h2 em{font-style:italic;color:var(--amber)}
.arrive__steps{margin-top:30px}
.arrive__step{display:flex;gap:18px;padding:20px 0;border-top:1px solid var(--rule-dark)}
.arrive__step b{font-family:var(--mono);font-size:12px;color:var(--amber);letter-spacing:.1em;
  min-width:48px;padding-top:4px}
.arrive__step h3{font-family:var(--serif);font-size:1.2rem;font-weight:400;color:var(--on-dark);margin-bottom:6px}
.arrive__step p{color:var(--on-dark-mute);font-size:.95rem}
.arrive__map{position:relative;border-radius:4px;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--rule-dark)}
.arrive__map iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.05)}
.arrive__coords{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--on-dark-faint);
  margin-top:14px;text-transform:uppercase}
@media(max-width:860px){.arrive{grid-template-columns:1fr}}

/* =====================================================================
   CTA / Reserva + Form
   ===================================================================== */
.cta{position:relative;overflow:hidden}
.cta__veil{position:absolute;inset:0;z-index:0;background:
   radial-gradient(120% 90% at 15% 10%,rgba(245,162,29,.16),transparent 50%),var(--ink)}
.cta__grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:start}
.cta__l h2{font-size:clamp(2.4rem,5.4vw,4.6rem);line-height:.98;letter-spacing:-.025em;font-weight:300;color:var(--on-dark)}
.cta__l h2 em{font-style:italic;color:var(--amber)}
.cta__l p{color:var(--on-dark-mute);margin-top:24px;font-size:1.08rem;max-width:42ch}
.cta__contacts{margin-top:40px;display:flex;flex-direction:column;gap:4px}
.cta__contact{display:flex;align-items:center;gap:16px;padding:16px 0;border-top:1px solid var(--rule-dark);
  color:var(--on-dark);transition:color .3s}
.cta__contact:last-child{border-bottom:1px solid var(--rule-dark)}
.cta__contact:hover{color:var(--amber)}
.cta__contact .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--on-dark-faint);min-width:110px}
.cta__contact .v{font-size:1.05rem}
/* form */
.form{background:rgba(244,239,230,.04);border:1px solid var(--rule-dark);border-radius:6px;
  padding:clamp(26px,3vw,42px);backdrop-filter:blur(4px)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form label{display:block;margin-bottom:16px}
.form .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--on-dark-mute);display:block;margin-bottom:8px}
.form input,.form select,.form textarea{width:100%;background:rgba(10,31,30,.4);
  border:1px solid var(--rule-dark);border-radius:4px;padding:14px 16px;color:var(--on-dark);
  font-family:inherit;font-size:16px;transition:border-color .3s,background .3s}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--amber);
  background:rgba(10,31,30,.7)}
.form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23F5A21D' stroke-width='1.6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center}
.form textarea{resize:vertical;min-height:90px}
.form__lgpd{display:flex!important;gap:10px;align-items:flex-start;font-size:12.5px;
  color:var(--on-dark-mute);margin:6px 0 22px;line-height:1.5}
.form__lgpd input{width:auto;margin-top:2px;accent-color:var(--amber)}
.form__lgpd a{color:var(--amber);text-decoration:underline}
.form button{width:100%}
@media(max-width:980px){.cta__grid{grid-template-columns:1fr}}
@media(max-width:520px){.form__row{grid-template-columns:1fr}}

/* =====================================================================
   Footer
   ===================================================================== */
.footer{background:var(--ink);color:var(--on-dark);padding-top:clamp(60px,7vw,100px);position:relative;overflow:hidden}
.footer__word{font-family:var(--serif);font-weight:300;font-size:clamp(3rem,16vw,15rem);line-height:.8;
  letter-spacing:-.04em;color:rgba(244,239,230,.06);white-space:nowrap;padding:0 var(--pad);
  margin-bottom:-.06em;pointer-events:none;user-select:none;overflow:hidden}
.footer__word::after{content:"Lagoa do Cassange"}
.footer__grid{width:min(92vw,var(--container));margin-inline:auto;display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-block:clamp(40px,5vw,64px)}
.footer__brand img{width:46px;margin-bottom:18px}
.footer__brand p{color:var(--on-dark-mute);font-size:.95rem;max-width:34ch;margin-top:14px}
.footer__col h3{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--amber);font-weight:500;margin-bottom:18px}
.footer__col a,.footer__col p{display:block;color:var(--on-dark-mute);font-size:.95rem;padding:5px 0;
  transition:color .3s}
.footer__col a:hover{color:var(--amber)}
.footer__bar{border-top:1px solid var(--rule-dark);margin-top:20px}
.footer__bar div{width:min(92vw,var(--container));margin-inline:auto;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:12px;padding:24px 0;font-size:12px;color:var(--on-dark-mute)}
.footer__bar em{font-style:italic;opacity:.85}
.footer__bar a{color:var(--amber)}
@media(max-width:860px){.footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}

/* =====================================================================
   WhatsApp FAB
   ===================================================================== */
.fab{position:fixed;right:18px;bottom:18px;z-index:6500;display:inline-flex;align-items:center;gap:10px;
  background:#25D366;color:#fff;font-weight:600;font-size:14px;padding:14px 20px;border-radius:100px;
  box-shadow:0 12px 30px rgba(0,0,0,.28);opacity:0;transform:translateY(16px);
  transition:opacity .5s var(--e-out),transform .5s var(--e-out)}
.fab.is-in{opacity:1;transform:none}
.fab:hover{transform:translateY(-3px)}
.fab svg{width:22px;height:22px;flex:none}
@media(max-width:560px){.fab span{display:none}.fab{padding:15px}}

/* ---------- Cookie LGPD ---------- */
.cookie{position:fixed;left:18px;bottom:18px;z-index:6400;max-width:380px;background:var(--deep-2);
  border:1px solid var(--rule-dark);border-radius:10px;padding:20px 22px;
  box-shadow:0 20px 50px rgba(0,0,0,.4);transform:translateY(20px);opacity:0;
  transition:opacity .5s,transform .5s;pointer-events:none}
.cookie.show{opacity:1;transform:none;pointer-events:auto}
.cookie p{font-size:12.5px;color:var(--on-dark-mute);line-height:1.5;margin-bottom:14px}
.cookie a{color:var(--amber)}
.cookie button{background:var(--amber);color:var(--ink);font-weight:600;font-size:12.5px;
  padding:9px 18px;border-radius:100px}
@media(max-width:560px){.cookie{left:12px;right:12px;bottom:84px;max-width:none}}

/* =====================================================================
   Galeria (mosaico cinematográfico)
   ===================================================================== */
.gallery__head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;
  margin-bottom:clamp(34px,4vw,52px)}
.gallery__head h2{font-size:clamp(2rem,5vw,4rem);line-height:1;letter-spacing:-.02em;font-weight:300;color:var(--on-dark)}
.gallery__head h2 em{font-style:italic;color:var(--amber)}
.gallery__head p{color:var(--on-dark-mute);max-width:32ch}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:185px;gap:10px;grid-auto-flow:dense}
.gallery a{position:relative;overflow:hidden;border-radius:4px;display:block;background:var(--deep)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--e-cine);filter:saturate(1.03)}
.gallery a:hover img{transform:scale(1.07)}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,31,30,.45),transparent 55%);opacity:0;transition:opacity .4s}
.gallery a:hover::after{opacity:1}
.gallery a figcaption{position:absolute;left:0;bottom:0;z-index:2;padding:16px 18px;font-family:var(--mono);
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark);
  opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s}
.gallery a:hover figcaption{opacity:1;transform:none}
.g-w{grid-column:span 2}
.g-t{grid-row:span 2}
.g-b{grid-column:span 2;grid-row:span 2}
@media(max-width:860px){.gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .g-b{grid-column:span 2;grid-row:span 2}.g-w{grid-column:span 2}.g-t{grid-row:span 2}}
@media(max-width:520px){.gallery{grid-auto-rows:128px}.g-t{grid-row:span 1}}

/* =====================================================================
   FAQ
   ===================================================================== */
.faq{max-width:860px;margin-inline:auto}
.faq__item{border-top:1px solid var(--rule-light)}
.faq__item:last-child{border-bottom:1px solid var(--rule-light)}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:24px 0;font-family:var(--serif);font-size:clamp(1.15rem,2.1vw,1.5rem);color:var(--ink-text);font-weight:400}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{color:var(--amber-deep);font-family:var(--sans);font-weight:300;font-size:1.7rem;line-height:1;
  flex:none;transition:transform .35s var(--e-out)}
.faq details[open] summary .plus{transform:rotate(135deg)}
.faq__a{padding:0 0 28px;color:var(--mute);max-width:66ch;font-size:1.04rem;line-height:1.65}

/* =====================================================================
   Reduced motion — desliga tudo
   ===================================================================== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .ln>span{transform:none!important}
  .clip{clip-path:none!important}
  .loader{display:none!important}
  .hero__media img{animation:none!important;transform:scale(1.04)!important}
  .cursor,.cursor__label{display:none!important}
}
