/* ── Overflow & Scrollbar ────────────────────────────────────────── */
html{overflow-x:hidden;scrollbar-color:rgba(176,133,68,.35) var(--black);scrollbar-width:thin}
body{overflow-x:hidden}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:rgba(176,133,68,.35);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--gold-soft)}

/* =====================================================================
   Bali Atins — identidade visual (alinhada aos mockups)
   Paleta: preto fosco · verde oliva · areia · dourado envelhecido · linho
   ===================================================================== */
:root{
    --black:#16120d;
    --ink:#1c1812;
    --olive:#2f3024;
    --sand:#e9e1d3;
    --linen:#f1ece2;
    --gold:#b08544;
    --gold-soft:#c9a87c;
    --terra:#a8643f;
    --text-light:#ece4d7;
    --text-dim:#a89c89;
    --text-dark:#2a2420;
    --line-dark:rgba(201,168,124,.18);
    --serif:'Cormorant Garamond',Georgia,serif;
    --sans:'Jost',system-ui,sans-serif;
    --maxw:1320px;
    --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);font-weight:300;background:var(--black);color:var(--text-light);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2{font-family:var(--serif);font-weight:400;line-height:1.07;letter-spacing:.005em}
h1{font-size:clamp(2.6rem,5.2vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.4vw,3rem)}
p{font-weight:300;color:var(--text-dim);max-width:42ch}
.tag{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-soft);display:inline-block;margin-bottom:1.3rem}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:.9rem clamp(1.2rem,3.5vw,3.2rem);transition:background .5s var(--ease),padding .4s var(--ease)}
.site-header.scrolled{background:rgba(22,18,13,.9);backdrop-filter:blur(10px);padding:.9rem clamp(1.2rem,3.5vw,3.2rem)}
.brand{font-family:var(--serif);font-size:1.45rem;letter-spacing:.1em;color:var(--text-light)}
.brand span{color:var(--gold-soft);margin-left:.3em;font-size:.62em;letter-spacing:.3em;vertical-align:middle}
.main-nav{display:flex;gap:2rem}
.main-nav a{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;opacity:.82;transition:opacity .3s,color .3s}
.main-nav a:hover{opacity:1;color:var(--gold-soft)}
.header-actions{display:flex;align-items:center;gap:1.4rem}
.lang-switch{font-size:.74rem;letter-spacing:.1em;color:var(--text-dim);display:flex;gap:.35rem}
.lang-switch a.is-active{color:var(--gold-soft)}
.btn-book{border:1px solid rgba(236,228,215,.4);padding:.65rem 1.6rem;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;transition:all .35s var(--ease)}
.btn-book:hover{background:var(--gold);border-color:var(--gold);color:var(--black)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:6px}
.nav-toggle span{width:24px;height:1px;background:var(--text-light);display:block}

/* ---------- Hero ---------- */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(22,18,13,.7) 0%,rgba(22,18,13,.25) 45%,transparent 70%),linear-gradient(to top,rgba(22,18,13,.6),transparent 40%)}
.hero-content{position:relative;z-index:2;padding:0 clamp(1.5rem,6vw,6.5rem);max-width:820px}
.hero-content h1{margin-bottom:1.4rem}
.hero-sub{font-size:1rem;color:var(--sand);letter-spacing:.02em;margin-bottom:2.4rem;opacity:.9}
.hero-badge{position:absolute;left:clamp(1.5rem,6vw,6.5rem);bottom:-7rem;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;line-height:2;color:var(--sand);opacity:.85}
.scroll-cue{position:absolute;right:2.4rem;top:50%;z-index:2;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--text-dim);writing-mode:vertical-rl}
.scroll-cue::after{content:"";display:block;width:1px;height:50px;background:linear-gradient(var(--gold-soft),transparent);margin:.9rem auto 0}
.btn-ghost{display:inline-flex;align-items:center;gap:.8rem;border:1px solid rgba(236,228,215,.45);padding:.85rem 2.1rem;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;transition:all .4s var(--ease)}
.btn-ghost span{transition:transform .4s var(--ease)}
.btn-ghost:hover{background:var(--text-light);color:var(--black)}
.btn-ghost:hover span{transform:translateX(5px)}

/* ---------- Faixa de diferenciais ---------- */
.features{display:grid;grid-template-columns:repeat(5,1fr);background:var(--ink);border-bottom:1px solid var(--line-dark)}
.feature{padding:2.6rem 1.6rem;text-align:left;border-right:1px solid var(--line-dark)}
.feature:last-child{border-right:0}
.feature .ico{color:var(--gold-soft);margin-bottom:1.1rem}
.feature h4{font-family:var(--sans);font-weight:400;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-light);margin-bottom:.5rem}
.feature p{font-size:.82rem;color:var(--text-dim)}

/* ---------- Suítes ---------- */
.suites-block{display:grid;grid-template-columns:.85fr 1.6fr;align-items:stretch;background:var(--black)}
.suites-text{padding:clamp(3rem,6vw,6rem) clamp(2rem,4vw,4rem);display:flex;flex-direction:column;justify-content:center}
.suites-text h2{margin-bottom:1.4rem}
.suites-text p{margin-bottom:2rem}
.suites-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.suites-grid img{width:100%;height:100%;object-fit:cover;min-height:460px}
.suites-stack{display:grid;grid-template-rows:1fr 1fr}
.suites-stack img{min-height:0}

/* ---------- Split (Atins / Restaurante) ---------- */
.split{display:grid;grid-template-columns:1fr 1.25fr;align-items:stretch}
.split--reverse .split-text{order:2}
.split-text{padding:clamp(3rem,6vw,6rem) clamp(2rem,5vw,5rem);display:flex;flex-direction:column;justify-content:center}
.split-text h2{margin-bottom:1.3rem}
.split-text p{margin-bottom:1.9rem}
.split-media img{width:100%;height:100%;object-fit:cover;min-height:520px}

/* ---------- Blocos claro/escuro ---------- */
.block--dark{background:var(--black)}
.block--light{background:var(--linen);color:var(--text-dark)}
.block--light .tag{color:var(--terra)}
.block--light p{color:#6b6151}
.link-arrow{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;border-bottom:1px solid currentColor;padding-bottom:.4rem;transition:color .3s,letter-spacing .3s;color:var(--gold-soft)}
.block--light .link-arrow{color:var(--terra)}
.link-arrow::after{content:" →"}
.link-arrow:hover{letter-spacing:.3em}

/* ---------- Micro-narrativa ---------- */
.beats{display:grid;grid-template-columns:1.6fr .9fr;background:var(--olive);border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}
.beats-list{display:flex;flex-wrap:wrap;align-items:center;gap:2.4rem;padding:2.4rem clamp(2rem,4vw,4rem)}
.beat{display:flex;align-items:center;gap:.7rem;font-size:.8rem;color:var(--sand);max-width:14rem}
.beat .ico{color:var(--gold-soft);flex-shrink:0}
.beats-media img{width:100%;height:100%;object-fit:cover;min-height:150px}

/* ---------- Experiências ---------- */
.exp{padding:clamp(3.5rem,7vw,7rem) clamp(1.5rem,5vw,5rem)}
.exp-head{margin-bottom:3rem}
.exp-head h2{margin-top:.4rem}
.exp-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.exp-card img{width:100%;aspect-ratio:4/3;object-fit:cover;margin-bottom:1.1rem}
.exp-card h4{font-family:var(--sans);font-weight:400;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dark);margin-bottom:.4rem}
.exp-card p{font-size:.86rem;color:#6b6151}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);padding:clamp(3rem,6vw,5rem) clamp(1.5rem,5vw,5rem) 2rem;border-top:1px solid var(--line-dark)}
.footer-top{display:grid;grid-template-columns:1.3fr 2fr;gap:2rem;padding-bottom:3rem}
.footer-tagline{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--sand);margin-top:1rem;line-height:1.5}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.footer-cols h4{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:.9rem;font-weight:400}
.footer-cols a,.footer-cols span{display:block;color:var(--text-dim);font-size:.88rem;line-height:2}
.footer-cols a:hover{color:var(--text-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.76rem;color:var(--text-dim)}
.footer-legal a{margin-left:1.6rem}
.footer-legal a:hover{color:var(--text-light)}
.footer-made{color:var(--text-dim);font-size:.72rem;opacity:.7}
.footer-made a{color:var(--gold-soft);text-decoration:none;transition:opacity .2s}
.footer-made a:hover{opacity:.75}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}

/* ---------- Páginas internas ---------- */
.page-hero{position:relative;height:62vh;min-height:440px;display:flex;align-items:flex-end;overflow:hidden}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero .hero-overlay{background:linear-gradient(to top,rgba(22,18,13,.85),transparent 60%)}
.page-hero-content{position:relative;z-index:2;padding:0 clamp(1.5rem,6vw,6rem) clamp(2.5rem,5vw,4rem);max-width:820px}
.page-section{padding:clamp(3rem,6vw,6rem) clamp(1.5rem,6vw,6rem);max-width:var(--maxw);margin:0 auto}
.page-section.narrow{max-width:760px}
.page-section h2{margin-bottom:1.4rem}
.page-section p{max-width:60ch;margin-bottom:1.2rem;color:var(--text-dim)}
.page-lead{font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,2.4vw,1.9rem);color:var(--sand);max-width:24ch}
.media-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2rem}
.media-row img{width:100%;aspect-ratio:3/4;object-fit:cover}

/* ---------- Reserva ---------- */
.book-page{padding:9rem clamp(1.5rem,6vw,6rem) 6rem;max-width:var(--maxw);margin:0 auto}
.book-head{margin-bottom:1.6rem}
.date-shortcuts{display:flex;flex-wrap:wrap;align-items:center;gap:.8rem;margin-bottom:1.4rem}
.date-chip{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:.45rem 1.1rem;border:1px solid rgba(236,228,215,.3);color:var(--text-dim);transition:all .3s var(--ease)}
.date-chip:hover,.date-chip.is-active{background:var(--gold);border-color:var(--gold);color:var(--black)}
.book-head h1{font-size:clamp(2.4rem,5vw,3.6rem);margin:.4rem 0 .8rem}
.book-form{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:end;padding:2rem;background:var(--olive);border-radius:3px;margin-bottom:3rem}
.book-form label{display:flex;flex-direction:column;gap:.5rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim)}
.book-form input{background:transparent;border:0;border-bottom:1px solid rgba(236,228,215,.35);color:var(--text-light);padding:.6rem 0;font-family:var(--sans);font-size:1rem;min-width:160px}
.btn-submit{cursor:pointer;background:var(--gold);border-color:var(--gold);color:var(--black)}
.book-msg{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--sand);padding:2rem 0}
.book-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}
.suite-card{background:var(--ink);border:1px solid var(--line-dark);border-radius:3px;overflow:hidden}
.suite-card>img{width:100%;aspect-ratio:4/3;object-fit:cover}
.suite-card-body{padding:1.8rem}
.suite-card-body h3{font-family:var(--serif);font-size:1.7rem;margin-bottom:.6rem}
.suite-card-meta{display:flex;justify-content:space-between;align-items:center;margin:1.4rem 0;font-size:.85rem;color:var(--text-dim)}
.suite-card-meta strong{color:var(--gold-soft);font-weight:400}

/* ---------- Checkout / Pagamento ---------- */
.checkout{display:grid;grid-template-columns:.9fr 1.1fr;gap:2.5rem;align-items:start}
.checkout-summary{background:var(--ink);border:1px solid var(--line-dark);border-radius:3px;overflow:hidden}
.checkout-summary img{width:100%;aspect-ratio:16/10;object-fit:cover}
.checkout-summary h3{font-family:var(--serif);font-size:1.6rem;padding:1.4rem 1.6rem 0}
.checkout-summary ul{list-style:none;padding:1rem 1.6rem}
.checkout-summary li{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.88rem;color:var(--text-dim);border-bottom:1px solid rgba(255,255,255,.05)}
.checkout-summary li strong{color:var(--text-light);font-weight:400}
.checkout-total{display:flex;justify-content:space-between;padding:1.2rem 1.6rem;background:var(--olive);font-size:1rem}
.checkout-total strong{color:var(--gold-soft);font-weight:400;font-size:1.2rem}
.checkout-form{display:flex;flex-direction:column;gap:1.1rem}
.checkout-form h3{font-family:var(--serif);font-size:1.5rem;margin-bottom:.4rem}
.checkout-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim)}
.checkout-form input,.checkout-form select{background:transparent;border:0;border-bottom:1px solid rgba(236,228,215,.3);color:var(--text-light);padding:.6rem 0;font-family:var(--sans);font-size:1rem}
.checkout-form select option{background:var(--ink)}
.checkout-form .btn-submit{margin-top:1rem;text-align:center}
.checkout-note{font-size:.8rem;color:var(--text-dim);letter-spacing:0;text-transform:none}
.pix-code{width:100%;min-height:90px;background:var(--ink);border:1px solid var(--line-dark);color:var(--gold-soft);padding:1rem;font-family:monospace;font-size:.78rem;border-radius:3px;resize:none}
.pay-confirmed{font-family:var(--serif);font-size:1.6rem;color:var(--gold-soft)}
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.8rem;margin-bottom:.6rem}
.slot{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:1rem;border:1px solid var(--line-dark);border-radius:3px;cursor:pointer;transition:border-color .3s,background .3s}
.slot span{font-family:var(--serif);font-size:1.3rem;color:var(--text-light)}
.slot small{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}
.slot input{position:absolute;opacity:0}
.slot:has(input:checked){border-color:var(--gold);background:rgba(176,133,68,.12)}
.slot.is-full{opacity:.4;cursor:not-allowed}
.cart-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:1.2rem;padding:1.1rem 0;border-bottom:1px solid var(--line-dark)}
.cart-row strong{display:block;font-weight:400;font-size:1rem}
.cart-row small{color:var(--text-dim);font-size:.78rem}
.cart-qty{width:64px;background:transparent;border:1px solid var(--line-dark);color:var(--text-light);padding:.4rem;text-align:center;font-family:var(--sans)}
.cart-sub{color:var(--gold-soft);min-width:90px;text-align:right}
.footer-cols{grid-template-columns:repeat(4,1fr)}

/* ---------- Responsivo ---------- */
@media(max-width:980px){
    .features{grid-template-columns:repeat(2,1fr)}
    .feature:nth-child(odd){border-right:1px solid var(--line-dark)}
    .feature{border-bottom:1px solid var(--line-dark)}
    .exp-cards{grid-template-columns:repeat(2,1fr)}
    .footer-top{grid-template-columns:1fr}
}
@media(max-width:880px){
    .nav-toggle{display:flex}
    .header-actions .btn-book{display:none}
    .suites-block,.split,.split--reverse .split-text,.beats{grid-template-columns:1fr}
    .split--reverse .split-text{order:0}
    .suites-grid{grid-template-columns:repeat(2,1fr)}
    .suites-grid img{min-height:260px}
    .hero-badge{position:static;margin-top:2.5rem}
    .scroll-cue{display:none}
    .media-row{grid-template-columns:1fr 1fr}
    .checkout{grid-template-columns:1fr}
}
@media(max-width:560px){
    .features,.exp-cards{grid-template-columns:1fr}
    .footer-cols{grid-template-columns:1fr}
}

/* ── Páginas legais (privacidade / termos) ───────────────────────── */
.legal-page{max-width:760px;margin:0 auto;padding:5rem 1.5rem 6rem}
.legal-head{margin-bottom:3.5rem}
.legal-head h1{font-family:var(--serif);font-size:clamp(2rem,5vw,3rem);font-weight:400;margin:.6rem 0 0}
.legal-updated{font-size:.78rem;letter-spacing:.12em;color:var(--text-dim);margin-top:.8rem}
.legal-body h2{font-family:var(--serif);font-size:1.25rem;font-weight:400;color:var(--gold-soft);margin:2.4rem 0 .7rem}
.legal-body p{font-size:.93rem;line-height:1.85;color:var(--text-dim);margin-bottom:1rem}
.legal-body ul{padding-left:1.3rem;margin-bottom:1rem}
.legal-body li{font-size:.93rem;line-height:1.85;color:var(--text-dim);margin-bottom:.35rem}
.legal-body a{color:var(--gold-soft);text-underline-offset:3px}
.legal-body a:hover{opacity:.75}
.legal-body strong{color:var(--text-light);font-weight:500}

/* ===================================================================
   WOW LAYER — Bali Atins v2
   Grain · Preloader · Cursor · Scroll · Parallax · Transições
   =================================================================== */

/* ── Grain cinematográfico ───────────────────────────────────────── */
body::after{
    content:'';
    position:fixed;
    inset:0;
    width:100%;height:100%;
    z-index:9000;
    pointer-events:none;
    opacity:0.055;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
    animation:grain .6s steps(1) infinite;
}
@keyframes grain{
    0%  {transform:translate(0,0)}
    20% {transform:translate(-2%,-2%)}
    40% {transform:translate(2%,-1%)}
    60% {transform:translate(-1%,2%)}
    80% {transform:translate(2%,1%)}
    100%{transform:translate(-1%,-1%)}
}

/* ── Preloader ───────────────────────────────────────────────────── */
.preloader{
    position:fixed;inset:0;z-index:9999;
    background:var(--black);
    display:flex;align-items:center;justify-content:center;
    transition:opacity .85s cubic-bezier(.22,1,.36,1),visibility .85s;
}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader__inner{text-align:center;min-width:280px}
.preloader__text{
    display:flex;align-items:baseline;justify-content:center;
    gap:.4em;overflow:hidden;
}
.preloader__word{
    font-family:var(--serif);
    font-size:clamp(2.8rem,8vw,5.5rem);
    font-weight:400;letter-spacing:.15em;
    color:var(--text-light);
    display:inline-block;
    transform:translateY(110%);
    animation:preWordUp .7s cubic-bezier(.16,1,.3,1) forwards;
}
.preloader__word:nth-child(2){
    font-style:italic;color:var(--gold-soft);
    animation-delay:.13s;
}
@keyframes preWordUp{to{transform:translateY(0)}}
.preloader__bar{
    height:1px;background:rgba(201,168,124,.15);
    margin-top:1.8rem;position:relative;overflow:hidden;
}
.preloader__bar::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(90deg,var(--gold),var(--gold-soft));
    transform:scaleX(0);transform-origin:left;
    animation:preBar 1.25s cubic-bezier(.22,1,.36,1) .2s forwards;
}
@keyframes preBar{to{transform:scaleX(1)}}

/* ── Barra de progresso de scroll ───────────────────────────────── */
.scroll-bar{
    position:fixed;top:0;left:0;height:2px;
    background:linear-gradient(90deg,var(--gold) 0%,var(--gold-soft) 100%);
    z-index:9001;width:0%;pointer-events:none;
    transition:width .08s linear;
}

/* ── Cortina de transição de página ─────────────────────────────── */
.page-curtain{
    position:fixed;inset:0;z-index:8999;
    background:var(--black);
    transform:scaleY(0);transform-origin:bottom;
    pointer-events:none;
    transition:transform .55s cubic-bezier(.76,0,.24,1);
}
.page-curtain.active{transform:scaleY(1);pointer-events:all}

/* ── Cursor personalizado (dispositivos com mouse fino) ─────────── */
@media(pointer:fine){
    body,body a,body button,body [role="button"],body input,
    body label,body select,body textarea{cursor:none}
    .cursor-dot{
        position:fixed;top:0;left:0;
        width:4px;height:4px;
        background:var(--gold);border-radius:50%;
        opacity:.75;
        pointer-events:none;z-index:9990;
        will-change:transform;
    }
    .cursor-ring{
        position:fixed;top:0;left:0;
        width:30px;height:30px;
        border:1px solid rgba(201,168,124,.45);border-radius:50%;
        pointer-events:none;z-index:9989;
        will-change:transform;
        transition:width .4s cubic-bezier(.16,1,.3,1),
                   height .4s cubic-bezier(.16,1,.3,1),
                   border-color .4s ease,opacity .3s ease;
    }
    .cursor-ring.is-hovering{width:52px;height:52px;border-color:var(--gold-soft)}
    .cursor-ring.is-hidden{opacity:0}
}

/* ── Nav mobile — overlay full-screen ───────────────────────────── */
@media(max-width:880px){
    .main-nav{
        display:flex !important;
        position:fixed;inset:0;
        background:rgba(22,18,13,.97);
        backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
        flex-direction:column;align-items:flex-start;justify-content:center;
        padding:2rem clamp(2rem,8vw,4rem) 3rem;
        gap:0;z-index:150;
        visibility:hidden;opacity:0;
        transition:opacity .4s ease,visibility .4s;
        pointer-events:none;
    }
    .main-nav.open{visibility:visible;opacity:1;pointer-events:auto}
    .main-nav a{
        font-family:var(--serif);
        font-size:clamp(2.2rem,8vw,3.5rem);
        letter-spacing:.02em;text-transform:none;
        opacity:0;display:block;width:100%;
        padding:.45rem 0;
        border-bottom:1px solid rgba(201,168,124,.08);
        transform:translateX(-1.5rem);
        transition:opacity .4s ease,transform .5s var(--ease),color .3s;
    }
    .main-nav.open a{opacity:1;transform:none}
    .main-nav.open a:nth-child(1){transition-delay:.05s}
    .main-nav.open a:nth-child(2){transition-delay:.10s}
    .main-nav.open a:nth-child(3){transition-delay:.15s}
    .main-nav.open a:nth-child(4){transition-delay:.20s}
    .main-nav.open a:nth-child(5){transition-delay:.25s}
    .main-nav.open a:nth-child(6){transition-delay:.30s}
    .main-nav a:hover{color:var(--gold-soft);opacity:1}
}

/* ── Hambúrguer → X ─────────────────────────────────────────────── */
.nav-toggle{
    position:relative;z-index:200;
    gap:5px;
}
.nav-toggle span{
    transition:transform .35s ease,opacity .25s ease;
    transform-origin:center;
}
.nav-toggle.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ── Hero — parallax + reveal em camadas ────────────────────────── */
.hero-img{will-change:transform}
.hero-content.reveal{transform:none}   /* override: sem translateY */

/* Palavras do título — animadas por JS após preloader */
@keyframes wordUp{
    from{transform:translateY(105%)}
    to  {transform:translateY(0)}
}
.hero-content h1 .word{
    display:inline-block;overflow:hidden;
    vertical-align:bottom;line-height:1.1;
}
.hero-content h1 .word em{
    display:inline-block;font-style:normal;
    will-change:transform;
}

/* Subtítulo e CTA: fade-in com delay */
.hero-content .hero-sub{
    opacity:0;transform:translateY(14px);
    transition:opacity .8s ease,transform .8s var(--ease);
}
.hero-content.is-visible .hero-sub{
    opacity:.9;transform:none;transition-delay:.45s;
}
.hero-content .btn-ghost{
    opacity:0;transform:translateY(10px);
    transition:opacity .6s ease,transform .6s var(--ease),
               background .4s var(--ease),color .4s var(--ease);
}
.hero-content.is-visible .btn-ghost{
    opacity:1;transform:none;transition-delay:.7s;
}
.hero-content .hero-badge{
    opacity:0;
    transition:opacity .6s ease;
    animation:none; /* override floatUp até is-visible */
}
.hero-content.is-visible .hero-badge{
    opacity:.85;transition-delay:.95s;
    animation:floatUp 3.5s ease-in-out 1.6s infinite alternate;
}
@keyframes floatUp{
    from{transform:translateY(0)}
    to  {transform:translateY(-6px)}
}

/* ── Reveal direccionais extras ─────────────────────────────────── */
.reveal--left {transform:translateX(-36px)!important}
.reveal--right{transform:translateX(36px)!important}
.reveal--scale{transform:scale(.93)!important;opacity:0}
.reveal--left.is-visible,.reveal--right.is-visible,.reveal--scale.is-visible{
    transform:none!important
}

/* ── Hover zoom nas imagens ──────────────────────────────────────── */
.split-media,.exp-card,.suite-card,.page-hero,.beats-media{overflow:hidden}
.split-media img,
.exp-card img,
.suite-card>img,
.beats-media img{
    transition:transform .8s var(--ease),filter .8s ease;
    will-change:transform;
}
.split-media:hover img,
.exp-card:hover img,
.suite-card:hover>img,
.beats-media:hover img{
    transform:scale(1.05);
    filter:brightness(1.06) saturate(1.08);
}

/* ── Pop dos ícones de diferenciais ─────────────────────────────── */
@keyframes iconPop{
    0%  {transform:scale(.4) rotate(-15deg);opacity:0}
    70% {transform:scale(1.18) rotate(3deg)}
    100%{transform:scale(1) rotate(0);opacity:1}
}
.feature .ico{opacity:0}
.feature.is-visible .ico{
    animation:iconPop .65s var(--ease) backwards;
}
.feature:nth-child(1).is-visible .ico{animation-delay:.00s}
.feature:nth-child(2).is-visible .ico{animation-delay:.07s}
.feature:nth-child(3).is-visible .ico{animation-delay:.14s}
.feature:nth-child(4).is-visible .ico{animation-delay:.21s}
.feature:nth-child(5).is-visible .ico{animation-delay:.28s}

/* ── Link underline slide no footer ─────────────────────────────── */
.footer-cols a{position:relative}
.footer-cols a::after{
    content:'';position:absolute;bottom:-1px;left:0;
    width:0;height:1px;background:var(--gold-soft);
    transition:width .35s var(--ease);
}
.footer-cols a:hover::after{width:100%}

/* ── Botões: brilho de hover ─────────────────────────────────────── */
.btn-book,.btn-ghost{position:relative;overflow:hidden;display:inline-flex;align-items:center}
.btn-book::before,.btn-ghost::before{
    content:'';position:absolute;inset:0;
    background:rgba(201,168,124,.09);
    transform:scaleX(0);transform-origin:left;
    transition:transform .5s var(--ease);
    pointer-events:none;
}
.btn-book:hover::before,.btn-ghost:hover::before{transform:scaleX(1)}

/* ── Scroll cue: pulso vertical ─────────────────────────────────── */
.scroll-cue::after{
    animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{
    0%,100%{opacity:.3;transform:scaleY(0.4);transform-origin:top}
    50%    {opacity:1;transform:scaleY(1);transform-origin:top}
}

/* ── Mobile improvements ─────────────────────────────────────────── */
@media(max-width:880px){
    .beats-list{
        overflow-x:auto;flex-wrap:nowrap;
        padding-bottom:1rem;
        -webkit-overflow-scrolling:touch;
        scrollbar-width:none;
    }
    .beats-list::-webkit-scrollbar{display:none}
    .beat{flex-shrink:0;min-width:11rem}
    .header-actions{gap:.8rem}
    .header-actions .btn-ghost{font-size:.7rem;padding:.55rem 1rem}
    .lang-switch{font-size:.68rem}
}
@media(max-width:560px){
    h1{font-size:clamp(2.1rem,9vw,3rem)!important}
    h2{font-size:clamp(1.6rem,6.5vw,2.4rem)!important}
    .book-page{padding:7rem 1.2rem 4rem}
    .book-form{padding:1.2rem;gap:1.1rem}
    .book-form label{width:100%}
    .book-form input{min-width:100%}
    .checkout{gap:1.2rem}
    .slot-grid{grid-template-columns:repeat(2,1fr)}
    .footer-top{gap:1.2rem}
    .preloader__word{font-size:clamp(2.4rem,10vw,4rem)}
    .page-hero{min-height:340px}
    .footer-cols{grid-template-columns:repeat(2,1fr)}
    .suites-grid{grid-template-columns:1fr}
}
