/* ═══════════════════════════════════════════════════
   RECONECTA RESIDENCIAL — style.css
   Paleta: quente, acolhedora, clara
════════════════════════════════════════════════════ */
:root {
  --laranja:   #D4622A;
  --laranja-c: #E8794A;
  --creme:     #FDF6EE;
  --areia:     #F5EDE0;
  --areia-e:   #EAD9C4;
  --castanho:  #5C3D2E;
  --cast-c:    #7A5240;
  --texto:     #2C1810;
  --texto-s:   #6B4C3B;
  --texto-l:   #9C7A6A;
  --branco:    #FFFFFF;
  --bd:        rgba(92,61,46,0.12);
  --verde:     #4A7C59;
  --radius:    12px;
  --shadow:    0 4px 24px rgba(92,61,46,0.10);
  --shadow-h:  0 12px 40px rgba(92,61,46,0.16);
}

/* ── RESET ── */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Outfit',sans-serif;background:var(--creme);color:var(--texto);overflow-x:hidden}

/* ── SPLASH ── */
#splash{position:fixed;inset:0;background:var(--castanho);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .7s,visibility .7s}
#splash.hide{opacity:0;visibility:hidden;pointer-events:none}
.splash-inner{text-align:center;animation:splashIn .8s ease both}
.splash-logo{width:110px;height:110px;border-radius:50%;background:var(--creme);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 0 0 10px rgba(253,246,238,.12),0 0 0 22px rgba(253,246,238,.05)}
.splash-logo img{width:82px;height:82px;object-fit:contain;border-radius:50%}
.splash-name{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,5vw,2rem);color:var(--creme);font-weight:400;letter-spacing:.04em}
.splash-name em{color:var(--laranja-c);font-style:italic}
.splash-sub{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(253,246,238,.4);margin-top:8px}
.splash-bar{width:90px;height:2px;background:rgba(253,246,238,.15);margin:20px auto 0;overflow:hidden}
.splash-progress{height:100%;background:var(--laranja-c);animation:progress 2.2s ease forwards}

/* ── NAV ── */
nav{position:fixed;top:0;width:100%;z-index:200;background:rgba(253,246,238,.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;padding:0 4vw;height:62px;transition:box-shadow .3s}
nav.scrolled{box-shadow:0 4px 24px rgba(92,61,46,.10)}
.nav-logo{display:flex;align-items:center;gap:9px}
.nav-logo img{height:38px;width:38px;object-fit:contain;border-radius:50%}
.nav-brand{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--castanho);font-weight:600;line-height:1.2}
.nav-brand span{display:block;font-size:.54rem;font-family:'Outfit',sans-serif;letter-spacing:.15em;text-transform:uppercase;color:var(--texto-l);font-weight:400}
.nav-links{display:flex;gap:22px;list-style:none;align-items:center}
.nav-links a{text-decoration:none;color:var(--texto-s);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:1px;background:var(--laranja);transform:scaleX(0);transition:transform .25s}
.nav-links a:hover{color:var(--laranja)}.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{background:var(--laranja);color:var(--branco);padding:9px 22px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;font-family:'Outfit',sans-serif;transition:background .2s;border:none;cursor:pointer;border-radius:6px}
.nav-cta:hover{background:var(--laranja-c)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--castanho);transition:all .3s}
.mob-menu{display:none;position:fixed;top:62px;left:0;right:0;background:var(--creme);border-bottom:1px solid var(--bd);z-index:199;padding:20px 5vw 28px;flex-direction:column;box-shadow:0 8px 30px rgba(92,61,46,.10)}
.mob-menu.open{display:flex}
.mob-menu a{text-decoration:none;color:var(--texto);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;padding:13px 0;border-bottom:1px solid var(--bd);display:block}
.mob-cta{background:var(--laranja);color:var(--branco);text-align:center;margin-top:14px;padding:13px;border:none;border-radius:6px;cursor:pointer;font-family:'Outfit',sans-serif;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;width:100%;display:block}

/* ── HERO ── */
.hero{min-height:100svh;position:relative;overflow:hidden;display:flex;align-items:center;background:var(--castanho);padding-top:62px}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;background-size:cover;background-position:center;transition:opacity 1.5s ease}
.hero-slide.active{opacity:1}
.hero-slide-1{background-image:url('fotos/piscina1.jpg')}
.hero-slide-2{background-image:url('fotos/estabelecimento.jpg')}
.hero-slide-3{background-image:url('fotos/piscina2.jpg')}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(44,24,16,.88) 0%,rgba(44,24,16,.48) 60%,rgba(44,24,16,.18) 100%)}
.hero-body{position:relative;padding:0 6vw;max-width:720px;animation:fadeUp 1s ease 2.3s both}
.hero-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(232,121,74,.5);color:var(--laranja-c);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;padding:6px 16px;margin-bottom:22px;font-weight:500;border-radius:20px}
.hero-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--laranja-c);animation:blink 2s infinite}
.hero-h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,9vw,5.5rem);font-weight:300;line-height:.95;color:var(--creme);margin-bottom:20px}
.hero-h1 em{font-style:italic;color:var(--laranja-c)}
.hero-p{font-size:clamp(.85rem,2vw,.98rem);line-height:1.85;color:rgba(253,246,238,.65);max-width:440px;font-weight:300;margin-bottom:36px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-p{background:var(--laranja);color:var(--branco);padding:14px 30px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;font-family:'Outfit',sans-serif;transition:all .25s;display:inline-block;border:none;cursor:pointer;border-radius:8px}
.btn-p:hover{background:var(--laranja-c);transform:translateY(-2px)}
.btn-g{border:1px solid rgba(253,246,238,.45);color:rgba(253,246,238,.9);padding:14px 30px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:400;text-decoration:none;font-family:'Outfit',sans-serif;transition:all .25s;display:inline-block;border-radius:8px}
.btn-g:hover{border-color:var(--creme);color:var(--creme)}
.hero-dots{position:absolute;bottom:28px;left:6vw;display:flex;gap:8px}
.dot{width:20px;height:2px;background:rgba(253,246,238,.3);cursor:pointer;transition:all .3s;border-radius:2px}
.dot.active{background:var(--laranja-c);width:40px}
.hero-scroll{position:absolute;bottom:28px;right:5vw;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(253,246,238,.3);font-size:.57rem;letter-spacing:.2em;text-transform:uppercase;writing-mode:vertical-rl}
.scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,rgba(253,246,238,.4),transparent);animation:pulse 2.2s ease-in-out infinite}

/* ── STATS BAR ── */
.bar{background:var(--castanho);display:grid;grid-template-columns:repeat(4,1fr)}
.bar-item{padding:26px 18px;border-right:1px solid rgba(253,246,238,.08);color:var(--creme);text-align:center}
.bar-item:last-child{border:none}
.bar-n{font-family:'Cormorant Garamond',serif;font-size:2.1rem;font-weight:600;color:var(--laranja-c);line-height:1;margin-bottom:4px}
.bar-l{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(253,246,238,.5)}

/* ── SECÇÕES ── */
.s{padding:72px 5vw}
.tag{font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--laranja);font-weight:600;margin-bottom:12px;display:block}
.h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,5vw,2.9rem);font-weight:400;line-height:1.1;color:var(--texto)}
.h2 em{color:var(--castanho);font-style:italic}
.desc{font-size:.86rem;line-height:1.9;color:var(--texto-s);margin-top:16px;font-weight:300}
.sh{max-width:560px;margin-bottom:44px}

/* ── SOBRE ── */
.sobre{background:var(--creme)}
.sobre-g{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.img-stack{position:relative}
.img-main{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;border-radius:var(--radius)}
.img-acc{position:absolute;bottom:-20px;right:-20px;width:52%;aspect-ratio:3/4;object-fit:cover;border:4px solid var(--creme);border-radius:var(--radius)}
.sobre-list{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:10px}
.sobre-list li{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;line-height:1.6;color:var(--texto)}
.sobre-list li::before{content:'';display:block;flex-shrink:0;width:14px;height:1px;background:var(--laranja);margin-top:10px}

/* ── SERVIÇOS ── */
.servicos{background:var(--areia)}
.srv-g{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:3px}
.srv{background:var(--creme);padding:36px 28px;position:relative;overflow:hidden;transition:background .4s,transform .3s;cursor:default;border-radius:0}
.srv::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--laranja);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.srv:hover{background:var(--castanho);transform:translateY(-3px)}.srv:hover .srv-t{color:var(--creme)}.srv:hover .srv-d{color:rgba(253,246,238,.55)}.srv:hover::before{transform:scaleX(1)}
.srv-n{font-size:1.7rem;font-weight:300;font-family:'Cormorant Garamond',serif;color:var(--laranja);margin-bottom:16px;opacity:.5}
.srv-t{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:600;margin-bottom:10px;transition:color .4s;color:var(--texto)}
.srv-d{font-size:.78rem;line-height:1.8;color:var(--texto-s);transition:color .4s}

/* ── QUARTOS ── */
.quartos{background:var(--creme)}
.q-g{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.q-card{background:var(--branco);overflow:hidden;transition:box-shadow .3s,transform .3s;border:1px solid var(--bd);border-radius:var(--radius);box-shadow:var(--shadow)}
.q-card:hover{box-shadow:var(--shadow-h);transform:translateY(-4px)}
.q-card.esgotado{opacity:.55}
.q-img{position:relative;overflow:hidden;aspect-ratio:4/3}
.q-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.q-card:hover .q-img img{transform:scale(1.05)}
.q-badge{position:absolute;top:10px;left:10px;color:var(--branco);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;font-weight:600;border-radius:20px}
.q-badge.disp{background:var(--verde)}.q-badge.last{background:#C4860B}.q-badge.esg{background:#C0392B}
.q-body{padding:20px 22px 22px}
.q-name{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:600;margin-bottom:10px;color:var(--texto)}
.q-p{font-size:.78rem;line-height:1.7;color:var(--texto-s);margin-bottom:12px}
.q-info{margin-bottom:14px;padding:8px 12px;font-size:.71rem;line-height:1.7;border-left:3px solid;border-radius:0 6px 6px 0}
.q-info.no-pool{background:#FFF8F4;border-color:var(--laranja);color:var(--castanho)}
.q-info.pool{background:#F4FBF6;border-color:var(--verde);color:#2C5C3A}
.q-btn{display:block;width:100%;text-align:center;background:var(--laranja);color:var(--branco);padding:11px 18px;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;font-family:'Outfit',sans-serif;transition:background .2s;cursor:pointer;border:none;border-radius:8px}
.q-btn:hover{background:var(--laranja-c)}.q-btn.off{background:var(--texto-l);cursor:not-allowed;pointer-events:none}

/* ── GALERIA COM TABS ── */
.galeria{background:var(--areia);padding-bottom:0}
.gal-tabs{display:flex;flex-wrap:nowrap;border-bottom:2px solid var(--bd);margin-bottom:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.gal-tabs::-webkit-scrollbar{display:none}
.gal-tab{background:none;border:none;padding:13px 20px;font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--texto-l);cursor:pointer;transition:all .2s;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap}
.gal-tab:hover{color:var(--laranja)}.gal-tab.active{color:var(--laranja);border-bottom-color:var(--laranja)}
.gal-panel{display:none;animation:fadeIn .35s ease}.gal-panel.active{display:block}
.gal-g{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.gal-item{overflow:hidden;position:relative;aspect-ratio:1;cursor:pointer}
.gal-item.wide{grid-column:1/3;aspect-ratio:16/9}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.gal-item:hover img{transform:scale(1.06)}
.gal-overlay{position:absolute;inset:0;background:rgba(44,24,16,0);display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start;padding:10px;transition:background .3s}
.gal-item:hover .gal-overlay{background:rgba(44,24,16,.18)}
.gal-zoom{width:32px;height:32px;background:rgba(253,246,238,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;flex-shrink:0}
.gal-item:hover .gal-zoom{opacity:1}
.gal-zoom svg{width:15px;fill:var(--castanho)}
.gal-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(44,24,16,.65),transparent);color:var(--creme);padding:18px 12px 10px;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;opacity:0;transition:opacity .3s}
.gal-item:hover .gal-label{opacity:1}

/* ── LIGHTBOX ── */
#lightbox{display:none;position:fixed;inset:0;background:rgba(20,8,4,.92);z-index:900;align-items:center;justify-content:center;padding:20px}
#lightbox.open{display:flex}
#lightbox img{max-width:92vw;max-height:88svh;object-fit:contain;border-radius:8px;box-shadow:0 20px 80px rgba(0,0,0,.5);animation:lbIn .3s ease}
.lb-close{position:absolute;top:16px;right:20px;background:none;border:none;color:rgba(253,246,238,.7);font-size:2rem;cursor:pointer;line-height:1;transition:color .2s}
.lb-close:hover{color:var(--creme)}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(253,246,238,.12);border:none;color:var(--creme);font-size:1.8rem;cursor:pointer;padding:12px 16px;transition:background .2s;border-radius:4px}
.lb-prev{left:12px}.lb-next{right:12px}
.lb-prev:hover,.lb-next:hover{background:rgba(253,246,238,.22)}
.lb-caption{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);color:rgba(253,246,238,.6);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap}

/* ── PISCINA ── */
.piscina{background:var(--castanho);color:var(--creme);display:grid;grid-template-columns:1fr 1fr;min-height:460px}
.pis-img{position:relative;overflow:hidden}
.pis-img img{width:100%;height:100%;object-fit:cover;display:block;opacity:.65;transition:opacity .4s}
.piscina:hover .pis-img img{opacity:.78}
.pis-body{padding:56px 50px;display:flex;flex-direction:column;justify-content:center}
.pis-body .tag{color:var(--laranja-c)}.pis-body .h2{color:var(--creme)}.pis-body .h2 em{color:var(--laranja-c)}.pis-body .desc{color:rgba(253,246,238,.6)}
.pis-feats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:22px 0}
.pis-f{border-left:2px solid var(--laranja);padding:10px 14px;font-size:.76rem;color:rgba(253,246,238,.65);line-height:1.5;border-radius:0 4px 4px 0}
.pis-f strong{display:block;color:var(--creme);font-size:.78rem;margin-bottom:2px;font-weight:500}

/* ── RESTAURANTE ── */
.rb{background:var(--creme)}
.rb-g{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.rb-imgs{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.ri{overflow:hidden;aspect-ratio:1;border-radius:8px}.ri:first-child{grid-column:1/-1;aspect-ratio:16/9}
.ri img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.ri:hover img{transform:scale(1.04)}
.menu-toggle-btn{display:flex;align-items:center;gap:8px;margin-top:22px;background:none;border:1px solid var(--bd);padding:11px 18px;font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:var(--castanho);cursor:pointer;transition:all .2s;border-radius:6px;width:100%}
.menu-toggle-btn:hover{border-color:var(--laranja);color:var(--laranja)}
.menu-toggle-btn .chevron{width:14px;fill:currentColor;transition:transform .3s;margin-left:auto}
.menu-toggle-btn.open .chevron{transform:rotate(180deg)}
.menu-s{overflow:hidden;max-height:0;transition:max-height .45s ease,opacity .35s ease;opacity:0}
.menu-s.open{max-height:400px;opacity:1}
.menu-inner{border-top:1px solid var(--bd);padding-top:20px;margin-top:20px}
.menu-lb{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--texto-l);margin-bottom:14px}
.menu-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(92,61,46,.06);font-size:.83rem;color:var(--texto)}
.menu-row:last-child{border:none}
.menu-b{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--texto-s)}

/* ── LOCALIZAÇÃO ── */
.loc{background:var(--areia-e)}
.loc-g{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.loc-list{border:1px solid var(--bd);margin-top:28px;border-radius:var(--radius);overflow:hidden;background:var(--creme)}
.loc-i{display:flex;align-items:flex-start;gap:16px;padding:16px 20px;border-bottom:1px solid var(--bd)}
.loc-i:last-child{border:none}
.loc-dot{width:7px;height:7px;border-radius:50%;background:var(--laranja);flex-shrink:0;margin-top:6px}
.loc-lb{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--texto-l);margin-bottom:3px}
.loc-v{font-size:.84rem;color:var(--texto);line-height:1.6}
.loc-v a{color:var(--laranja);text-decoration:none;font-weight:500}
.loc-v a:hover{color:var(--laranja-c)}
.map-f{width:100%;aspect-ratio:4/3;border:none;border-radius:var(--radius)}
.btn-maps{display:inline-flex;align-items:center;gap:8px;margin-top:12px;background:var(--laranja);color:var(--branco);padding:11px 22px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;text-decoration:none;font-family:'Outfit',sans-serif;transition:background .2s;border-radius:6px;border:none;cursor:pointer}
.btn-maps:hover{background:var(--laranja-c)}
.btn-maps svg{width:14px;fill:var(--branco)}

/* ── MODAL RESERVA ── */
.modal-res-overlay{display:none;position:fixed;inset:0;background:rgba(44,24,16,.6);z-index:800;align-items:center;justify-content:center;padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.modal-res-overlay.open{display:flex}
.modal-res{background:var(--creme);width:100%;max-width:600px;border-radius:var(--radius);overflow:hidden;max-height:90svh;overflow-y:auto;animation:modalIn .35s ease;box-shadow:0 30px 80px rgba(44,24,16,.3)}
.modal-res-head{background:var(--castanho);padding:20px 26px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1}
.modal-res-head h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--creme)}
.modal-res-head p{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(253,246,238,.4);margin-top:3px}
.modal-close-btn{background:none;border:none;font-size:1.8rem;color:rgba(253,246,238,.5);cursor:pointer;line-height:1;padding:0 4px;flex-shrink:0}
.modal-close-btn:hover{color:var(--creme)}
.modal-res-body{padding:24px}
.form-hint-modal{font-size:.72rem;color:var(--texto-l);margin-bottom:18px;display:block;line-height:1.5;padding:10px 14px;background:rgba(92,61,46,.06);border-radius:6px}
.form-hint-modal.selected{background:rgba(74,124,89,.1);color:#3A6B4A;border-left:3px solid var(--verde)}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.fi{display:flex;flex-direction:column;gap:6px}
.fi.full{grid-column:1/-1}
.fi label{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--texto-s);font-weight:600}
.fi input,.fi select,.fi textarea{width:100%;padding:11px 13px;border:1px solid var(--bd);background:var(--branco);font-family:'Outfit',sans-serif;font-size:.85rem;color:var(--texto);outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none;border-radius:8px}
.fi input:focus,.fi select:focus,.fi textarea:focus{border-color:var(--laranja)}
.fi textarea{resize:vertical;min-height:80px}
.f-sub{margin-top:18px;width:100%;background:var(--laranja);color:var(--branco);border:none;padding:14px;font-family:'Outfit',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:background .2s;border-radius:8px}
.f-sub:hover{background:var(--laranja-c)}.f-sub:disabled{background:var(--texto-l);cursor:not-allowed}
.f-note{font-size:.67rem;color:var(--texto-l);margin-top:10px;text-align:center;line-height:1.6}
.f-err{display:none;background:#FFF4F0;border:1px solid var(--laranja);padding:10px 14px;margin-top:10px;font-size:.78rem;color:var(--laranja);border-radius:6px}
.f-ok{display:none;text-align:center;padding:32px 16px}
.f-ok .ck{width:48px;height:48px;border-radius:50%;background:rgba(74,124,89,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--verde);font-size:1.4rem}
.countdown-box{margin:16px 0;padding:14px 16px;background:rgba(212,98,42,.06);border:1px solid rgba(212,98,42,.2);border-radius:8px}
.countdown-label{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--texto-l);margin-bottom:6px;font-weight:600}
#countdown{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:600;color:var(--laranja);line-height:1;text-align:center}
.cond-box{padding:12px 14px;background:#F4FBF6;border-left:3px solid var(--verde);text-align:left;font-size:.76rem;line-height:1.7;color:var(--castanho);margin-bottom:12px;border-radius:0 6px 6px 0}
.pay-box{padding:12px 14px;background:#FFF8F4;border-left:3px solid var(--laranja);font-size:.76rem;line-height:1.75;color:var(--castanho);border-radius:0 6px 6px 0}
.pay-box a{color:var(--laranja);font-weight:600;text-decoration:none}

/* ── WA BANNER ── */
.wa{background:#25D366;color:var(--branco);display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 5vw;text-decoration:none;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;font-family:'Outfit',sans-serif;transition:background .2s}
.wa:hover{background:#1fb558}.wa svg{width:18px;fill:var(--branco)}

/* ── FOOTER ── */
footer{background:var(--castanho);color:rgba(253,246,238,.4);padding:36px 5vw;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px}
.f-logo{display:flex;align-items:center;gap:9px}
.f-logo img{height:32px;width:32px;border-radius:50%;opacity:.5}
.f-logo-text{font-family:'Cormorant Garamond',serif;font-size:.95rem;color:rgba(253,246,238,.55)}
.f-logo-text em{color:var(--laranja-c);font-style:italic}
.f-center{text-align:center;font-size:.68rem;letter-spacing:.06em;line-height:1.9}
.f-center a{color:rgba(253,246,238,.45);text-decoration:none;transition:color .2s}.f-center a:hover{color:var(--laranja-c)}
.f-soc{display:flex;gap:8px}
.f-s{width:32px;height:32px;border:1px solid rgba(253,246,238,.15);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:border-color .2s;border-radius:6px}
.f-s:hover{border-color:var(--laranja-c)}.f-s svg{width:14px;fill:rgba(253,246,238,.45);transition:fill .2s}.f-s:hover svg{fill:var(--laranja-c)}

/* ── REVEAL ── */
.rev{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.rev.visible{opacity:1;transform:translateY(0)}
.rev-l{transition-delay:.1s}.rev-r{transition-delay:.2s}

/* ── KEYFRAMES ── */
@keyframes splashIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes progress{from{width:0}to{width:100%}}
@keyframes blink{0%,100%{opacity:.4}50%{opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes lbIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}

/* ── RESPONSIVE TABLET ── */
@media(max-width:900px){
  .nav-links,.nav-cta{display:none}.hamburger{display:flex}
  .bar{grid-template-columns:repeat(2,1fr)}
  .sobre-g,.rb-g,.loc-g,.piscina{grid-template-columns:1fr}
  .piscina{min-height:auto}.pis-img{aspect-ratio:16/9}.pis-body{padding:40px 5vw}.pis-feats{grid-template-columns:1fr 1fr}
  .img-acc{display:none}
  .rb-imgs{grid-template-columns:1fr 1fr}.ri:first-child{grid-column:1/-1}
  footer{grid-template-columns:1fr;text-align:center}.f-soc{justify-content:center}.f-logo{justify-content:center}
}

/* ── RESPONSIVE MOBILE ── */
@media(max-width:600px){
  .bar{grid-template-columns:1fr 1fr}.bar-item{padding:20px 14px}.s{padding:54px 5vw}
  .fg{grid-template-columns:1fr}
  .gal-g{grid-template-columns:1fr 1fr}
  .gal-item.wide{grid-column:1/-1;aspect-ratio:4/3}
  .hero-h1{font-size:2.6rem}.hero-body{padding:0 5vw}.hero-scroll{display:none}
  .q-g{grid-template-columns:1fr}
  .modal-res{border-radius:16px 16px 0 0;align-self:flex-end;max-height:92svh}
  .modal-res-overlay{align-items:flex-end;padding:0}
  .pis-feats{grid-template-columns:1fr}
  .rb-imgs{grid-template-columns:1fr}.ri:first-child{grid-column:auto;aspect-ratio:4/3}
  .loc-g{grid-template-columns:1fr}
  .lb-prev{left:4px}.lb-next{right:4px}
}
