/* ============================================================
   SkyVillage Cabanas — site.css
   Estilo: refúgio premium · natureza · verde-floresta + dourado champagne
   ============================================================ */
:root{
  --green:#1b4a33; --green-d:#10311f; --green-l:#2c6b48; --green-900:#0e2117;
  --green-soft:#eef3ee;
  --gold:#b8924e; --gold-d:#9a7838; --gold-l:#cdaa66; --champagne:#ddd3a0; --gold-soft:#f7f1e3;
  --paper:#ffffff; --paper-2:#f7f6f1; --paper-3:#e9e7df; --paper-4:#dcd9cf;
  --txt:#1d2620; --txt-2:#54605a; --txt-3:#8a948d;
  --line:#e7e8e1; --radius:10px; --maxw:1200px;
  --shadow:0 18px 50px rgba(16,49,31,.10); --shadow-sm:0 4px 16px rgba(16,49,31,.07);
  --ff-display:'Cormorant Garamond',Georgia,serif;
  --ff-ui:'DM Sans',sans-serif; --ff-body:'DM Sans',sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff-body);color:var(--txt);background:var(--paper);line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--ff-display);font-weight:700;line-height:1.1;letter-spacing:-.005em;color:var(--txt)}
a{color:var(--green);text-decoration:none;transition:.2s}
a:hover{color:var(--green-d)}
img{max-width:100%;height:auto}
.container{max-width:var(--maxw)}

/* Botões */
.sv-btn-primary{background:var(--green);color:#fff;border:0;font-family:var(--ff-ui);font-weight:700;letter-spacing:.03em;padding:.72rem 1.6rem;border-radius:100px;text-transform:uppercase;font-size:.8rem;transition:.22s;box-shadow:0 8px 22px rgba(27,74,51,.22)}
.sv-btn-primary:hover{background:var(--green-d);color:#fff;transform:translateY(-2px);box-shadow:0 14px 30px rgba(27,74,51,.30)}
.sv-btn-outline{background:transparent;color:var(--green-d);border:1.5px solid var(--green);font-family:var(--ff-ui);font-weight:700;padding:.64rem 1.5rem;border-radius:100px;text-transform:uppercase;font-size:.8rem}
.sv-btn-outline:hover{background:var(--green);color:#fff}
.sv-btn-ghost{background:#fff;color:var(--txt);border:1.5px solid var(--paper-3);font-family:var(--ff-ui);font-weight:700;border-radius:100px;padding:.64rem 1.5rem;text-transform:uppercase;font-size:.8rem}
.sv-btn-ghost:hover{background:var(--paper-2);border-color:var(--gold);color:var(--gold-d)}
.sv-btn-gold{background:var(--gold);color:#fff;border:0;font-family:var(--ff-ui);font-weight:700;letter-spacing:.03em;padding:.72rem 1.6rem;border-radius:100px;text-transform:uppercase;font-size:.8rem;box-shadow:0 8px 22px rgba(184,146,78,.25)}
.sv-btn-gold:hover{background:var(--gold-d);color:#fff;transform:translateY(-2px)}
.sv-btn-whats{background:#25d366;color:#fff;font-family:var(--ff-ui);font-weight:700;border-radius:100px;text-transform:uppercase;font-size:.8rem;padding:.64rem 1.5rem}
.sv-btn-whats:hover{background:#1da851;color:#fff}
.sv-btn-airbnb{background:#ff5a5f;color:#fff;font-family:var(--ff-ui);font-weight:700;border-radius:100px;text-transform:uppercase;font-size:.8rem;padding:.64rem 1.5rem;display:inline-flex;align-items:center;gap:.45rem}
.sv-btn-airbnb:hover{background:#e0484d;color:#fff}

/* Topbar */
.sv-topbar{background:var(--green-900);color:rgba(255,255,255,.82);font-size:.82rem;padding:.5rem 0}
.sv-topbar-info span{margin-right:1.4rem}
.sv-topbar-social a{color:var(--champagne);margin-left:1rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;font-weight:600;font-family:var(--ff-ui)}
.sv-topbar-social a:hover{color:#fff}

/* Header / Nav */
.sv-header{background:#fff;position:sticky;top:0;z-index:1030;box-shadow:0 2px 20px rgba(16,49,31,.07);border-bottom:1px solid var(--line)}
.sv-header .navbar{padding:.4rem 0}
.sv-header .navbar-brand{padding:0;margin:0}
.sv-header .navbar-brand img{height:46px!important;width:auto!important;max-height:46px;display:block}
@media(max-width:991px){.sv-header .navbar-brand img{height:40px!important;max-height:40px}}
.sv-header .nav-link{color:var(--txt);font-family:var(--ff-ui);font-weight:600;font-size:.86rem;text-transform:uppercase;letter-spacing:.04em;padding:.5rem .9rem!important;position:relative}
.sv-header .nav-link:hover,.sv-header .nav-link.active{color:var(--green)}
.sv-header .nav-link.active::after{content:"";position:absolute;left:.9rem;right:.9rem;bottom:-2px;height:2px;background:var(--gold)}
.sv-header .dropdown-menu{border:0;border-top:3px solid var(--gold);border-radius:0 0 8px 8px;box-shadow:var(--shadow);margin-top:.3rem}
.sv-header .dropdown-item{font-family:var(--ff-ui);font-weight:500;padding:.55rem 1.1rem;color:var(--txt)}
.sv-header .dropdown-item:hover{background:var(--green-soft);color:var(--green)}

/* Hero */
.sv-hero{position:relative;background:linear-gradient(140deg,#13301f 0%,#1b4a33 60%,#225c3f 100%);color:#fff;overflow:hidden;min-height:600px;display:flex;align-items:center}
.sv-hero::after{content:"";position:absolute;top:-25%;right:-8%;width:55%;height:150%;background:radial-gradient(circle,rgba(184,146,78,.22),transparent 62%);pointer-events:none}
.sv-hero-inner{position:relative;z-index:2;padding:5.5rem 0}
.sv-hero .eyebrow{display:inline-block;background:rgba(221,211,160,.14);border:1px solid rgba(221,211,160,.4);color:var(--champagne);font-family:var(--ff-ui);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;padding:.42rem 1.1rem;border-radius:100px;margin-bottom:1.5rem}
.sv-hero h1{color:#fff;font-size:clamp(2.6rem,6vw,4.6rem);font-weight:600;margin-bottom:1.1rem;line-height:1.02}
.sv-hero h1 .hl{color:var(--champagne);font-style:italic}
.sv-hero p.lead{color:rgba(255,255,255,.86);font-size:1.18rem;max-width:560px;margin-bottom:2.2rem;font-family:var(--ff-body)}
.sv-hero-slide{background-size:cover;background-position:center}
.sv-hero-slide::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(14,33,23,.86) 25%,rgba(14,33,23,.62) 65%,rgba(14,33,23,.40))}

/* Section utils */
.sv-section{padding:5.5rem 0}
.sv-section.alt{background:var(--paper-2)}
.sv-section.dark{background:var(--green-900);color:#fff}
.sv-section.dark h2,.sv-section.dark h3{color:#fff}
.sv-section.dark .sv-lead{color:rgba(255,255,255,.78)}
.sv-section.dark .sv-eyebrow{color:var(--champagne)}
.sv-eyebrow{display:block;color:var(--gold-d);font-family:var(--ff-ui);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;margin-bottom:.7rem}
.sv-title{font-size:clamp(2rem,4vw,3rem);margin-bottom:1rem;color:var(--txt);font-weight:600}
.sv-title .hl{color:var(--gold-d);font-style:italic}
.sv-section.dark .sv-title .hl{color:var(--champagne)}
.sv-lead{color:var(--txt-2);font-size:1.08rem;max-width:660px}
.sv-divider{width:60px;height:3px;background:var(--gold);border:0;opacity:1;margin:1.1rem 0 1.6rem}

/* Cards de cabana */
.sv-prod-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:100%;transition:.28s;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.sv-prod-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:transparent}
.sv-prod-thumb{aspect-ratio:4/3;background:var(--green-soft);overflow:hidden;position:relative}
.sv-prod-thumb img{width:100%;height:100%;object-fit:cover;transition:.5s}
.sv-prod-card:hover .sv-prod-thumb img{transform:scale(1.07)}
.sv-prod-thumb .sv-noimg{display:flex;align-items:center;justify-content:center;height:100%;color:var(--txt-3);font-family:var(--ff-ui);font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.1em}
.sv-prod-cat{position:absolute;top:.8rem;left:.8rem;background:rgba(14,33,23,.86);color:var(--champagne);font-family:var(--ff-ui);font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:.3rem .8rem;border-radius:100px}
.sv-prod-cap{position:absolute;bottom:.8rem;right:.8rem;background:rgba(255,255,255,.92);color:var(--green-d);font-family:var(--ff-ui);font-size:.68rem;font-weight:700;padding:.28rem .7rem;border-radius:100px}
.sv-prod-body{padding:1.3rem 1.4rem 1.5rem;flex:1;display:flex;flex-direction:column}
.sv-prod-body h3{font-size:1.4rem;margin-bottom:.4rem;color:var(--txt);font-weight:600}
.sv-prod-body p{color:var(--txt-2);font-size:.92rem;margin-bottom:1.1rem;flex:1}
.sv-prod-foot{display:flex;gap:.5rem}
.sv-prod-foot .btn{flex:1;font-size:.74rem;padding:.55rem}

/* Diferenciais */
.sv-feat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.7rem;height:100%;transition:.25s;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.sv-feat::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:.3s}
.sv-feat:hover::before{transform:scaleX(1)}
.sv-feat:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.sv-feat .sv-feat-ic{width:56px;height:56px;border-radius:50%;background:var(--green-soft);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.1rem}
.sv-feat h3{color:var(--txt);font-size:1.3rem;margin-bottom:.4rem;font-weight:600}
.sv-feat p{color:var(--txt-2);font-size:.92rem;margin:0;font-family:var(--ff-body)}

/* Stats */
.sv-stat{text-align:center;padding:1rem}
.sv-stat .num{font-family:var(--ff-display);font-weight:700;font-size:clamp(2.4rem,4vw,3.4rem);color:var(--champagne);line-height:1}
.sv-stat .lbl{text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:rgba(255,255,255,.7);margin-top:.5rem;font-weight:600;font-family:var(--ff-ui)}

/* CTA */
.sv-cta{background:linear-gradient(100deg,var(--green-d),var(--green));color:#fff;padding:3.6rem 0;position:relative;overflow:hidden}
.sv-cta::after{content:"";position:absolute;top:-40%;right:-5%;width:40%;height:180%;background:radial-gradient(circle,rgba(184,146,78,.22),transparent 60%)}
.sv-cta h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.7rem);font-weight:600}
.sv-cta p{color:rgba(255,255,255,.9);margin:0}
.sv-cta .sv-btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.45)}
.sv-cta .sv-btn-ghost:hover{background:#fff;color:var(--green-d);border-color:#fff}

/* Depoimentos */
.sv-depo{background:#fff;border:1px solid var(--line);border-top:3px solid var(--gold);border-radius:var(--radius);padding:1.9rem;height:100%;box-shadow:var(--shadow-sm)}
.sv-depo p{font-family:var(--ff-display);font-size:1.25rem;font-style:italic;color:var(--txt);line-height:1.45}
.sv-depo .autor{font-family:var(--ff-ui);font-weight:700;color:var(--txt);margin-top:1rem}
.sv-depo .cargo{color:var(--txt-2);font-size:.85rem}

/* Breadcrumb */
.sv-breadcrumb-wrap{background:var(--paper-2);border-bottom:1px solid var(--line)}
.sv-breadcrumb ol{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:0;padding:.8rem 0;font-size:.85rem;color:var(--txt-2)}
.sv-breadcrumb li::after{content:"›";margin-left:.5rem;color:var(--txt-3)}
.sv-breadcrumb li:last-child::after{content:""}
.sv-breadcrumb a{color:var(--green)}
.sv-breadcrumb a:hover{color:var(--gold-d)}

/* Pagehead */
.sv-pagehead{background:linear-gradient(140deg,#13301f,#1b4a33);color:#fff;padding:3.8rem 0;position:relative;overflow:hidden}
.sv-pagehead::after{content:"";position:absolute;top:-40%;right:-5%;width:40%;height:180%;background:radial-gradient(circle,rgba(184,146,78,.2),transparent 60%)}
.sv-pagehead h1{color:#fff;position:relative;z-index:2;font-weight:600;font-size:clamp(2.2rem,4.5vw,3.4rem)}
.sv-pagehead p{color:rgba(255,255,255,.82);position:relative;z-index:2;max-width:660px}
.sv-pagehead .sv-eyebrow{position:relative;z-index:2;color:var(--champagne)}

/* Cabana detalhe */
.sv-gallery-main{aspect-ratio:4/3;background:var(--green-soft);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.sv-gallery-main img{width:100%;height:100%;object-fit:cover}
.sv-gallery-thumbs{display:flex;gap:.6rem;margin-top:.7rem;flex-wrap:wrap}
.sv-gallery-thumbs img{width:76px;height:76px;object-fit:cover;border-radius:6px;border:2px solid var(--line);cursor:pointer}
.sv-gallery-thumbs img.active,.sv-gallery-thumbs img:hover{border-color:var(--gold)}
.sv-spec-table{width:100%;border-collapse:collapse}
.sv-spec-table th,.sv-spec-table td{padding:.75rem 1rem;border-bottom:1px solid var(--line);text-align:left;font-size:.92rem;color:var(--txt)}
.sv-spec-table th{background:var(--paper-2);font-family:var(--ff-ui);font-weight:700;width:42%}
.sv-tabs .nav-link{color:var(--txt-2);font-family:var(--ff-ui);font-weight:700;text-transform:uppercase;font-size:.82rem;border:0;border-bottom:2px solid transparent;background:transparent}
.sv-tabs .nav-link.active{color:var(--green);background:transparent;border-bottom-color:var(--gold)}
.sv-amenities{display:flex;flex-wrap:wrap;gap:.55rem;margin:.8rem 0 .2rem}
.sv-amenity{display:inline-flex;align-items:center;gap:.5rem;background:var(--green-soft);color:var(--green-d);border-radius:100px;padding:.4rem 1rem;font-size:.88rem;font-weight:600;font-family:var(--ff-ui)}
.sv-article{font-family:var(--ff-body);color:var(--txt);font-size:1rem;line-height:1.8}

/* Forms */
.sv-form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.3rem}
.sv-form label{font-family:var(--ff-ui);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--txt-2);margin-bottom:.35rem}
.sv-form .form-control,.sv-form .form-select{border-radius:8px;border:1px solid var(--paper-3);padding:.72rem .9rem;background:#fff;color:var(--txt);font-family:var(--ff-body)}
.sv-form .form-control:focus,.sv-form .form-select:focus{border-color:var(--green);box-shadow:0 0 0 .2rem rgba(27,74,51,.12)}

/* Blog */
.sv-post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:100%;box-shadow:var(--shadow-sm);transition:.25s;display:flex;flex-direction:column}
.sv-post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.sv-post-thumb{aspect-ratio:16/10;background:var(--green-soft);overflow:hidden}
.sv-post-thumb img{width:100%;height:100%;object-fit:cover}
.sv-post-body{padding:1.3rem 1.4rem 1.5rem;flex:1;display:flex;flex-direction:column}
.sv-post-body .data{color:var(--gold-d);font-family:var(--ff-ui);font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.sv-post-body h3{font-size:1.3rem;margin:.4rem 0 .5rem;font-weight:600}

/* Footer */
.sv-footer{background:var(--green-900);color:rgba(255,255,255,.74);padding:4rem 0 1.5rem}
.sv-footer h5{color:#fff;font-family:var(--ff-ui);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.86rem;margin-bottom:1rem}
.sv-footer ul{list-style:none;padding:0;margin:0}
.sv-footer ul li{margin-bottom:.5rem}
.sv-footer a{color:rgba(255,255,255,.74)}
.sv-footer a:hover{color:var(--champagne)}
.sv-footer-desc{color:rgba(255,255,255,.7);font-size:.92rem}
.sv-footer-logo{background:rgba(255,255,255,.04);border-radius:50%;padding:.2rem}
.sv-footer-social a{display:inline-block;margin-right:1rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;font-weight:600;font-family:var(--ff-ui)}
.sv-footer-contato li{font-size:.9rem}
.sv-footer hr{border-color:rgba(255,255,255,.12);margin:2rem 0 1.2rem}
.sv-footer-bottom{font-size:.84rem;color:rgba(255,255,255,.6)}
.sv-footer-bottom a{color:rgba(255,255,255,.7)}
.sv-footer-credito{text-align:center;font-size:.8rem;color:rgba(255,255,255,.45);padding-top:.9rem}
.sv-footer-credito strong{color:var(--gold-l)}

/* WhatsApp flutuante */
.sv-whats-float{position:fixed;right:20px;bottom:20px;width:58px;height:58px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(37,211,102,.4);z-index:1500;transition:.2s}
.sv-whats-float:hover{transform:scale(1.08)}

/* Cookie LGPD */
.sv-cookie{position:fixed;left:18px;right:18px;bottom:18px;max-width:760px;margin:0 auto;background:var(--green-900);color:rgba(255,255,255,.9);border:1px solid rgba(221,211,160,.25);border-radius:12px;padding:1rem 1.2rem;display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;justify-content:space-between;z-index:1600;box-shadow:var(--shadow)}
.sv-cookie span{font-size:.86rem;flex:1;min-width:220px}
.sv-cookie a{color:var(--champagne);text-decoration:underline}
.sv-cookie-btns{display:flex;gap:.5rem}

/* Scroll reveal */
.sv-reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.sv-reveal.show{opacity:1;transform:none}

@media (max-width:768px){
  .sv-section{padding:3.5rem 0}
  .sv-hero{min-height:480px}
  .sv-hero-inner{padding:3.5rem 0}
}

/* ── Avaliações / estrelas / badges (área do cliente + site) ── */
.sv-badge{display:inline-block;border-radius:100px;padding:.2rem .8rem;font-size:.74rem;font-weight:700;font-family:var(--ff-ui);letter-spacing:.02em}
.sv-stars-show{color:var(--gold);letter-spacing:1px;font-size:1.05rem;line-height:1}
.sv-aval-resumo{display:flex;align-items:center;gap:.5rem;color:var(--txt-2);font-size:.95rem}
.sv-aval-resumo strong{color:var(--txt);font-size:1.15rem}
.sv-review{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.4rem;height:100%;display:flex;flex-direction:column;gap:.5rem;box-shadow:0 4px 18px rgba(16,49,31,.05)}
.sv-review-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.sv-review-head strong{font-family:var(--ff-h);font-size:1.05rem;color:var(--txt)}
.sv-review-text{margin:0;color:var(--txt-2);line-height:1.6}
.sv-review-fotos{display:flex;gap:.5rem;flex-wrap:wrap}
.sv-review-fotos img{width:74px;height:74px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.sv-stars-input{display:inline-flex;flex-direction:row-reverse;justify-content:flex-end}
.sv-stars-input input{position:absolute;opacity:0;width:0;height:0}
.sv-stars-input label{font-size:2.1rem;color:#d9d2c0;cursor:pointer;padding:0 .08rem;transition:color .15s;line-height:1}
.sv-stars-input label:hover,
.sv-stars-input label:hover ~ label,
.sv-stars-input input:checked ~ label{color:var(--gold)}

/* ── Lightbox de fotos das avaliações ──────────────────── */
.svrl{position:fixed;inset:0;background:rgba(14,16,22,.94);z-index:3000;display:none;align-items:center;justify-content:center}
.svrl.open{display:flex;animation:svrlFade .25s ease}
@keyframes svrlFade{from{opacity:0}to{opacity:1}}
.svrl-stage{max-width:95vw;max-height:90vh;display:flex;align-items:center;justify-content:center;padding:1rem}
.svrl-stage img{max-width:100%;max-height:88vh;object-fit:contain;border-radius:8px;box-shadow:0 24px 60px rgba(0,0,0,.5);background:#111}
.svrl-close,.svrl-prev,.svrl-next{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.18s;line-height:1}
.svrl-close:hover,.svrl-prev:hover,.svrl-next:hover{background:var(--gold);border-color:var(--gold)}
.svrl-close{top:20px;right:24px;width:46px;height:46px;font-size:1.8rem}
.svrl-prev,.svrl-next{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:2.2rem}
.svrl-prev:hover,.svrl-next:hover{transform:translateY(-50%) scale(1.08)}
.svrl-prev{left:24px}.svrl-next{right:24px}
.svrl-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.8);font-size:.85rem;font-weight:600;background:rgba(0,0,0,.4);padding:.4rem 1rem;border-radius:100px}
@media(max-width:768px){.svrl-prev,.svrl-next{width:42px;height:42px;font-size:1.7rem}.svrl-prev{left:8px}.svrl-next{right:8px}.svrl-close{width:38px;height:38px;font-size:1.4rem}}

/* Edição de fotos da avaliação (área do cliente) */
.sv-edit-fotos{display:flex;flex-wrap:wrap;gap:.7rem;margin:.5rem 0}
.sv-edit-foto{display:flex;flex-direction:column;align-items:center;gap:.3rem;cursor:pointer}
.sv-edit-foto img{width:90px;height:90px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.sv-edit-foto .rm-chk{font-size:.78rem;color:var(--txt-2);display:flex;align-items:center;gap:.25rem}
