:root{
  --bg:#0a0a0a;--bg2:#0f0f0f;--card:#141414;--border:#232323;--border-g:rgba(255,122,0,.35);
  --text:#f5f5f5;--muted:#9ca3af;--white:#fff;
  --green:#ff7a00;--green-d:#ea580c;--green-btn:#f97316;--radius:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;line-height:1.6}
a{color:var(--green);text-decoration:none}
img{max-width:100%;display:block}

/* ANNOUNCEMENT BAR */
.topbar{background:#000;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;gap:14px;padding:.45rem 1rem;font-size:.85rem}
.topbar .tb-label{color:var(--muted)}
.topbar .tb-price{color:var(--green);font-weight:800}
.topbar a{background:var(--green-btn);color:#fff;font-weight:700;font-size:.78rem;padding:.25rem .9rem;border-radius:99px}

/* HEADER */
header{position:sticky;top:0;z-index:50;background:rgba(8,8,8,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav-wrap{max-width:1180px;margin:auto;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;flex-wrap:wrap;gap:.6rem}
.logo{font-weight:800;font-size:1.2rem;color:var(--white)}
.logo span{color:var(--green)}
nav{display:flex;flex-wrap:wrap;gap:.15rem}
nav a{color:var(--text);font-size:.84rem;padding:.45rem .65rem;border-radius:8px}
nav a:hover,nav a.active{color:var(--green);background:#161616}
.head-cta{display:flex;align-items:center;gap:.9rem}
.head-phone{color:var(--text);font-weight:600;font-size:.9rem}
.btn{display:inline-block;background:var(--green-btn);color:#fff;font-weight:700;padding:.8rem 1.7rem;border-radius:99px;font-size:.95rem;margin:.25rem;transition:transform .15s,box-shadow .15s}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(249,115,22,.35)}
.btn.alt{background:rgba(255,122,0,.12);color:var(--green);border:1.5px solid var(--green-d)}
.btn.sm{padding:.5rem 1.2rem;font-size:.82rem;margin:0}

/* HERO */
.hero{background:radial-gradient(ellipse 80% 60% at 70% 20%,rgba(255,122,0,.08) 0%,transparent 60%),var(--bg)}
.hero-grid{max-width:1180px;margin:auto;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:4.5rem 1rem 3.5rem}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;padding-top:2.5rem}}
.eyebrow{color:var(--green);font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:.78rem;margin-bottom:1rem}
.hero h1{font-size:clamp(2.2rem,5.2vw,3.6rem);font-weight:800;line-height:1.08;color:var(--white);margin-bottom:1.1rem}
.hero h1 span{color:var(--green)}
.hero .lead{color:var(--muted);font-size:1.06rem;max-width:540px;margin-bottom:1rem}
.hero .lead strong{color:var(--white)}
.stars{color:#fbbf24;font-size:.95rem;margin-bottom:1.3rem}
.stars span{color:var(--text)}
.hero-meta{color:var(--muted);font-size:.88rem;margin-top:.8rem}
.hero-meta a{color:var(--text);font-weight:600}
.hero-visual{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--border-g);box-shadow:0 0 70px rgba(255,122,0,.15)}
.hero-visual img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}

/* TRUST BAR */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg2)}
.trust-grid{max-width:1180px;margin:auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.trust-item{padding:1rem .8rem;text-align:center;border-right:1px solid var(--border);font-size:.85rem;font-weight:600;color:var(--white)}
.trust-item:last-child{border-right:none}
.trust-item .tick{color:var(--green);margin-right:.3rem}
@media(max-width:768px){.trust-item{border-right:none;border-bottom:1px solid var(--border)}.trust-item:last-child{border-bottom:none}}

/* SECTIONS */
section{max-width:1180px;margin:auto;padding:3.5rem 1rem}
section.full{max-width:none;background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
section.full>.inner{max-width:1180px;margin:auto;padding:3.5rem 1rem}
h2{font-size:clamp(1.5rem,3.6vw,2.3rem);font-weight:800;color:var(--white);margin-bottom:.7rem;text-align:center}
.sec-sub{color:var(--muted);text-align:center;max-width:620px;margin:0 auto 2.2rem}
h3{font-size:1.1rem;margin-bottom:.5rem;color:var(--white)}

/* RATES TABLE */
.rates{max-width:940px;margin:auto;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.rates-head{display:grid;grid-template-columns:1.4fr 1fr 1fr;padding:.9rem 1.6rem;border-bottom:1px solid var(--border);color:var(--muted);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase}
.rate-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;align-items:center;padding:1.05rem 1.6rem;border-bottom:1px solid var(--border);color:inherit;transition:background .15s}
.rate-row:last-child{border-bottom:none}
.rate-row:hover{background:rgba(255,122,0,.05)}
.rate-row.hl{background:rgba(255,122,0,.06)}
.rate-dur{font-weight:700;color:var(--white);display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.badge{background:rgba(255,122,0,.15);color:var(--green);font-size:.62rem;font-weight:800;letter-spacing:.08em;padding:.22rem .6rem;border-radius:99px;border:1px solid var(--border-g)}
.rate-price{font-size:1.45rem;font-weight:800;color:var(--white);text-align:center}
.rate-row.hl .rate-price{color:var(--green)}
.rate-hr{color:var(--muted);font-size:.85rem;text-align:right}
.rates-note{text-align:center;color:var(--muted);font-size:.85rem;margin-top:1.1rem}
@media(max-width:640px){.rates-head{display:none}.rate-row{grid-template-columns:1fr auto;gap:.2rem}.rate-hr{display:none}}

/* BOOKING EMBED */
.fh-embed-wrap{max-width:900px;margin:auto;background:#fff;padding:.5rem;border-radius:1.25rem;overflow:hidden;min-height:400px;box-shadow:0 0 60px rgba(255,122,0,.12)}
.fh-embed-wrap iframe{width:100%;border:0;display:block}
.book-alt{text-align:center;color:var(--muted);font-size:.9rem;margin-top:1rem}

/* FEATURE LISTS (included / requirements) */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.feat{background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:1.4rem 1.3rem;display:flex;gap:.9rem;align-items:flex-start;transition:border-color .2s,transform .2s}
.feat:hover{border-color:var(--border-g);transform:translateY(-2px)}
.feat .ic{flex:none;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;background:rgba(255,122,0,.15);color:var(--green)}
.feat.req .ic{background:rgba(251,191,36,.12);color:#fbbf24}
.feat p{color:var(--muted);font-size:.85rem}

/* CARDS / GALLERY */
.grid{display:grid;gap:16px}
.grid.c3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid.c2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.4rem;transition:border-color .2s,transform .2s}
.card:hover{border-color:var(--border-g);transform:translateY(-2px)}
.card img{border-radius:10px;margin-bottom:1rem;aspect-ratio:1/1;object-fit:cover;width:100%}
.card h3{color:var(--green)}
.card p{color:var(--muted);font-size:.9rem}
.card.photo{padding:0;overflow:hidden}
.card.photo img{margin:0;border-radius:0;aspect-ratio:4/3}

/* SEO TEXT */
.seo-text{max-width:840px;margin:auto}
.seo-text p{color:var(--muted);margin-bottom:1rem;font-size:.97rem}
.seo-text strong{color:var(--white)}

/* FAQ */
.faq-list{max-width:840px;margin:auto}
.faq-list details{background:var(--card);border:1.5px solid var(--border);border-radius:12px;margin-bottom:.6rem;padding:1rem 1.2rem;transition:border-color .2s}
.faq-list details:hover,.faq-list details[open]{border-color:var(--border-g)}
.faq-list summary{cursor:pointer;font-weight:700;font-size:.95rem;color:var(--white)}
.faq-list details p{color:var(--muted);margin-top:.6rem;font-size:.9rem}

/* CTA BAND */
.cta-band{background:linear-gradient(120deg,rgba(255,122,0,.12),rgba(255,122,0,.03)),var(--bg2);text-align:center;padding:3.5rem 1rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cta-band h2{margin-bottom:.6rem}
.cta-band p{color:var(--muted);max-width:640px;margin:0 auto 1.4rem}
.cta-band .note{font-size:.85rem;margin-top:.8rem;color:var(--muted)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;max-width:940px;margin:auto}
.contact-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.7rem 1.4rem;text-align:center}
.contact-card .ic{font-size:1.8rem;margin-bottom:.6rem}
.contact-card h3{color:var(--white)}
.contact-card p{color:var(--muted);font-size:.9rem}
.hours-note{text-align:center;color:var(--muted);font-size:.9rem;margin-top:1.4rem}

/* FOOTER */
footer{background:#060606;border-top:1px solid var(--border);padding:2.6rem 1rem;text-align:center}
footer .social{display:flex;gap:.8rem;justify-content:center;margin-bottom:1.2rem;flex-wrap:wrap}
footer .social a{color:var(--muted);font-size:.85rem;border:1px solid var(--border);padding:.4rem 1rem;border-radius:99px}
footer .social a:hover{color:var(--green);border-color:var(--border-g)}
footer nav{justify-content:center;margin-bottom:1rem}
footer p{color:#6b7280;font-size:.82rem}

/* FLOATING WHATSAPP */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:99;width:58px;height:58px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.45);font-size:1.7rem;transition:transform .15s}
.wa-float:hover{transform:scale(1.07)}

.center{text-align:center}
.muted{color:var(--muted)}

/* ANIMATIONS (reference architecture) */
.fade-in{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.fade-in.visible{opacity:1;transform:none}
@keyframes pulse-ring{0%,100%{box-shadow:0 0 0 0 rgba(249,115,22,.45)}60%{box-shadow:0 0 0 12px rgba(249,115,22,0)}}
.pulse{animation:pulse-ring 2.2s infinite}
.faq-list summary{display:flex;justify-content:space-between;align-items:center;gap:1rem;list-style:none}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:'+';color:var(--green);font-size:1.4rem;line-height:1;flex-shrink:0}
.faq-list details[open] summary::after{content:'−'}
