:root{
  --ocean:#2563a8;--ocean-deep:#173a63;--turq:#2bb3c0;--gold:#e0a93f;--sand:#f3ead7;
  --bg:#fbfdff;--fg:#16314f;--muted:#5a6b80;--card:#ffffff;--border:#dde6ef;--radius:18px;
  --display:'Playfair Display',serif;--body:'Outfit',sans-serif;
  --shadow-card:0 16px 40px -16px rgba(23,58,99,.28);
  --shadow-lux:0 24px 60px -20px rgba(23,58,99,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.6}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--display);margin:0;line-height:1.15}
a{text-decoration:none;color:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 22px}
.container.narrow{max-width:820px}
.eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;margin:0 0 12px}
.eyebrow.gold{color:var(--gold)}.eyebrow.turq{color:var(--turq)}
.section{padding:90px 0}
.section-alt{background:rgba(43,179,192,.06)}
.section-ocean{background:linear-gradient(135deg,var(--ocean-deep),var(--ocean) 55%,var(--turq));color:#fff}
.heading{max-width:640px;margin:0 auto 50px;text-align:center}
.heading h2{font-size:clamp(1.9rem,4vw,3rem);color:var(--ocean-deep)}
.heading-sub{color:var(--muted);margin-top:14px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:14px 28px;font-weight:600;font-family:var(--body);cursor:pointer;border:0;transition:.25s}
.btn-gold{background:var(--gold);color:var(--ocean-deep);box-shadow:var(--shadow-card)}
.btn-gold:hover{filter:brightness(1.06);box-shadow:var(--shadow-lux)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.glass{background:rgba(255,255,255,.12);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.22)}

/* HEADER */
.site-header{position:fixed;inset:0 0 auto 0;z-index:40;transition:.3s}
.site-header.scrolled{background:rgba(255,255,255,.85);backdrop-filter:blur(14px);box-shadow:var(--shadow-card)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;max-width:1200px;margin:0 auto}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:46px;width:46px;border-radius:50%;object-fit:cover}
.brand-name{font-family:var(--display);font-weight:700;font-size:1.25rem;color:#fff}
.scrolled .brand-name{color:var(--ocean-deep)}
.brand-name span{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:rgba(255,255,255,.92);font-weight:500;font-size:.95rem;transition:.2s}
.scrolled .nav-links a{color:var(--fg)}
.nav-links a:hover{color:var(--gold)}
.nav-cta{color:var(--ocean-deep)!important;padding:10px 22px}
.nav-toggle{display:none;background:none;border:0;font-size:1.7rem;color:#fff;cursor:pointer}
.scrolled .nav-toggle{color:var(--ocean-deep)}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:ken 18s ease-out infinite alternate}
@keyframes ken{from{transform:scale(1)}to{transform:scale(1.12)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(23,58,99,.7),rgba(23,58,99,.45),rgba(23,58,99,.85))}
.hero-content{position:relative;z-index:2;color:#fff;max-width:860px;padding:0 22px;animation:fade .9s ease both}
.hero-content h1{font-size:clamp(2.4rem,6vw,4.6rem);font-weight:800}
.hero-sub{font-size:clamp(1rem,2vw,1.2rem);color:rgba(255,255,255,.88);margin:22px auto 0;max-width:620px}
.hero-cta{margin-top:34px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
@keyframes fade{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{background:var(--card);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-card);transition:.4s}
.card:hover{box-shadow:var(--shadow-lux);transform:translateY(-4px)}
.slider{position:relative;height:300px;overflow:hidden}
.slide{position:absolute;inset:0;height:100%;width:100%;object-fit:cover;opacity:0;transition:opacity .7s,transform .7s}
.slide.active{opacity:1}
.card:hover .slide.active{transform:scale(1.08)}
.slide-fade{position:absolute;inset:0;background:linear-gradient(to top,rgba(23,58,99,.8),transparent 55%)}
.tag{position:absolute;top:14px;left:14px;z-index:3;font-size:.72rem;font-weight:600;color:#fff;background:rgba(255,255,255,.18);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.25);padding:5px 12px;border-radius:999px}
.snav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;height:36px;width:36px;border-radius:50%;border:0;background:rgba(255,255,255,.18);backdrop-filter:blur(10px);color:#fff;font-size:1.3rem;cursor:pointer;opacity:0;transition:.25s}
.card:hover .snav{opacity:1}
.snav.prev{left:12px}.snav.next{right:12px}
.dots{position:absolute;bottom:16px;left:0;right:0;z-index:3;display:flex;gap:7px;justify-content:center}
.dot{height:6px;width:8px;border:0;border-radius:999px;background:rgba(255,255,255,.6);cursor:pointer;transition:.3s;padding:0}
.dot.active{width:24px;background:var(--gold)}
.card-title{position:absolute;bottom:30px;left:20px;z-index:3;color:#fff;font-size:1.9rem;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.card-body{padding:24px}
.card-body p{color:var(--muted);min-height:78px;margin:0 0 18px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.about-media{position:relative}
.about-media img{border-radius:24px;box-shadow:var(--shadow-lux);aspect-ratio:4/3;object-fit:cover;width:100%}
.about-badge{position:absolute;bottom:-22px;right:18px;background:rgba(23,58,99,.85);backdrop-filter:blur(10px);color:#fff;border-radius:18px;padding:16px 20px;text-align:center}
.about-badge strong{font-family:var(--display);font-size:1.8rem;color:var(--gold);display:block}
.about-badge span{font-size:.72rem}
.about-grid h2{font-size:clamp(1.8rem,3.5vw,2.7rem);color:var(--ocean-deep);margin-top:6px}
.ticks{list-style:none;padding:0;margin:26px 0}
.ticks li{position:relative;padding-left:34px;margin:12px 0;color:var(--fg)}
.ticks li:before{content:"✓";position:absolute;left:0;top:0;height:22px;width:22px;border-radius:50%;background:rgba(43,179,192,.18);color:var(--turq);display:flex;align-items:center;justify-content:center;font-size:.8rem}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.why-card{border-radius:18px;padding:28px;transition:.3s}
.why-card:hover{transform:translateY(-5px)}
.why-ico{font-size:2rem;margin-bottom:14px}
.why-card h3{font-size:1.25rem}
.why-card p{color:rgba(255,255,255,.8);font-size:.92rem;margin:8px 0 0}

/* ACTIVITIES */
.act-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}
.act{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;background:var(--card);border:1px solid var(--border);border-radius:18px;padding:26px 12px;box-shadow:var(--shadow-card);transition:.3s}
.act:hover{transform:translateY(-5px);border-color:rgba(43,179,192,.5)}
.act span{font-size:2.2rem}
.act strong{color:var(--ocean-deep)}

/* TESTIMONIALS */
.reviews{position:relative;min-height:270px}
.review{position:absolute;inset:0;background:var(--card);border-radius:24px;padding:40px;box-shadow:var(--shadow-lux);text-align:center;opacity:0;transition:opacity .7s;pointer-events:none}
.review.active{opacity:1;pointer-events:auto}
.stars{color:var(--gold);font-size:1.3rem;letter-spacing:3px;margin-bottom:14px}
.review blockquote{font-family:var(--display);font-style:italic;font-size:1.25rem;margin:0;color:var(--fg)}
.review figcaption{margin-top:22px}
.review figcaption strong{color:var(--ocean-deep);display:block}
.review figcaption span{color:var(--muted);font-size:.9rem}
.rdots{display:flex;gap:9px;justify-content:center;margin-top:26px}
.rdot{height:8px;width:8px;border:0;border-radius:999px;background:rgba(90,107,128,.4);cursor:pointer;transition:.3s}
.rdot.active{width:30px;background:var(--gold)}

/* FOOTER */
.footer{background:linear-gradient(135deg,var(--ocean-deep),var(--ocean) 55%,var(--turq));color:#fff}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:38px;padding:64px 22px 40px}
.footer h3{font-size:1.1rem;margin-bottom:16px}
.footer-text{color:rgba(255,255,255,.78);font-size:.92rem;margin-top:14px}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin:9px 0;color:rgba(255,255,255,.78);font-size:.92rem}
.footer-links a:hover{color:var(--gold)}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{height:40px;width:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;transition:.25s}
.socials a:hover{background:rgba(255,255,255,.25)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);text-align:center;padding:20px;font-size:.8rem;color:rgba(255,255,255,.6)}

/* WHATSAPP FLOAT */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:50;display:flex;align-items:center;gap:8px;background:#25D366;color:#fff;padding:15px 18px;border-radius:999px;box-shadow:var(--shadow-lux);font-weight:600;transition:.25s}
.wa-float:hover{transform:scale(1.05)}
.wa-icon{font-size:1.4rem;animation:floaty 3s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* RESPONSIVE */
@media(max-width:1024px){.cards,.why-grid{grid-template-columns:repeat(2,1fr)}.act-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){
  .nav-toggle{display:block}
  .nav-links{position:absolute;top:100%;left:14px;right:14px;flex-direction:column;align-items:stretch;gap:6px;background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-radius:18px;padding:14px;box-shadow:var(--shadow-card);display:none}
  .nav-links.open{display:flex}
  .nav-links a{color:var(--fg);padding:10px 14px;border-radius:10px}
  .nav-cta{text-align:center}
  .cards,.why-grid,.about-grid,.footer-grid{grid-template-columns:1fr}
  .act-grid{grid-template-columns:repeat(2,1fr)}
  .section{padding:64px 0}
  .about-media{margin-bottom:30px}
  .wa-label{display:none}
}
