/* ============================================================
   Caribbean Watersports — stylesheet
   Tropical / premium, conversion-focused
   ============================================================ */

:root{
  --ocean-900:#063540;
  --ocean-800:#0a4f5c;
  --ocean-700:#0d6c7a;
  --teal-500:#13a3b0;
  --aqua-400:#2bd0c4;
  --aqua-200:#9af0e6;
  --sand-100:#fdf8f0;
  --sand-200:#f7eedd;
  --coral-500:#ff6b5e;
  --coral-600:#f5503f;
  --sun-400:#ffb43d;
  --sun-500:#ff9e2c;
  --ink-900:#0c2025;
  --ink-700:#33474d;
  --ink-500:#5e7177;
  --white:#ffffff;
  --shadow-md:0 12px 30px -12px rgba(6,53,64,.35);
  --shadow-lg:0 30px 70px -25px rgba(6,53,64,.5);
  --radius:18px;
  --radius-lg:26px;
  --max:1200px;
  --ease:cubic-bezier(.16,.84,.44,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Outfit',system-ui,sans-serif;
  color:var(--ink-700);
  background:var(--sand-100);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{color:var(--ink-900);line-height:1.1;font-weight:700}
section{position:relative}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  font-weight:600;font-size:1rem;border:none;cursor:pointer;
  padding:.85em 1.5em;border-radius:999px;transition:transform .2s var(--ease),box-shadow .2s,background .2s;
  white-space:nowrap;font-family:inherit;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn--primary{background:linear-gradient(135deg,var(--coral-500),var(--coral-600));color:#fff;box-shadow:0 10px 24px -8px rgba(245,80,63,.6)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 32px -8px rgba(245,80,63,.7)}
.btn--sun{background:linear-gradient(135deg,var(--sun-400),var(--sun-500));color:#3a2200;box-shadow:0 10px 24px -8px rgba(255,158,44,.6)}
.btn--sun:hover{transform:translateY(-2px)}
.btn--ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn--ghost:hover{background:rgba(255,255,255,.26)}
.nav .btn--ghost{color:var(--ocean-800);border-color:var(--ocean-700)}
.btn--sm{padding:.55em 1.1em;font-size:.9rem}
.btn--lg{padding:1em 1.8em;font-size:1.08rem}
.btn--block{width:100%}

/* ---------- announce bar ---------- */
.announce{background:linear-gradient(90deg,var(--ocean-900),var(--ocean-700));color:#eafdfb;font-size:.86rem}
.announce__inner{max-width:var(--max);margin:0 auto;padding:.55rem 1.25rem;display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;justify-content:center}
.announce__badge{color:var(--sun-400);font-weight:600}
.announce__sep{opacity:.4}
.announce__call{margin-left:auto;font-weight:600;color:#fff}
@media(max-width:680px){.announce__call{margin-left:0}.announce__sep{display:none}}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:60;background:rgba(253,248,240,.82);backdrop-filter:blur(14px);border-bottom:1px solid rgba(6,53,64,.08);transition:box-shadow .3s}
.nav.is-scrolled{box-shadow:var(--shadow-md)}
.nav__inner{max-width:var(--max);margin:0 auto;padding:.7rem 1.25rem;display:flex;align-items:center;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.5rem;font-weight:800;font-size:1.2rem;color:var(--ocean-800)}
.brand__mark{font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}
.brand__txt{line-height:1;letter-spacing:-.5px}
.brand__txt span{color:var(--teal-500)}
.brand--light{color:#fff}.brand--light .brand__txt span{color:var(--aqua-400)}
.nav__links{display:flex;gap:1.5rem;margin-left:1rem;font-weight:500}
.nav__links a{color:var(--ink-700);position:relative;transition:color .2s}
.nav__links a:hover{color:var(--coral-600)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--coral-500);transition:width .25s}
.nav__links a:hover::after{width:100%}
.nav__cta{margin-left:auto;display:flex;gap:.6rem}
.nav__burger{display:none;background:none;border:none;font-size:1.6rem;color:var(--ocean-800);cursor:pointer}
@media(max-width:1200px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);flex-direction:column;background:var(--ocean-800);padding:5rem 2rem;gap:1.4rem;transform:translateX(100%);transition:transform .35s var(--ease);box-shadow:var(--shadow-lg)}
  .nav__links.is-open{transform:translateX(0)}
  .nav__links a{color:#fff;font-size:1.2rem}
  .nav__burger{display:block;order:3}
  .nav__cta{margin-left:auto}
  .nav__cta .btn--ghost{display:none}
}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;padding:3rem 1.25rem 5rem}
.hero__bg{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1505228395891-9a51e7e86bf6?w=1800&q=80') center/cover no-repeat;transform:scale(1.05);animation:slowzoom 20s ease-in-out infinite alternate}
@keyframes slowzoom{to{transform:scale(1.14)}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(6,53,64,.86) 0%,rgba(10,79,92,.62) 45%,rgba(19,163,176,.28) 100%)}
.hero__inner{position:relative;max-width:var(--max);margin:0 auto;width:100%;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.hero__eyebrow{color:var(--aqua-200);font-weight:600;letter-spacing:2px;text-transform:uppercase;font-size:.8rem;margin-bottom:1rem}
.hero__title{color:#fff;font-size:clamp(2.6rem,6vw,4.6rem);font-weight:800;letter-spacing:-1.5px;text-shadow:0 4px 30px rgba(0,0,0,.3)}
.hero__title span{background:linear-gradient(120deg,var(--sun-400),var(--coral-500));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__sub{color:#eafdfb;font-size:1.18rem;max-width:32rem;margin:1.4rem 0 2rem;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.hero__trust{display:flex;gap:2rem;flex-wrap:wrap}
.hero__trust-item{color:#fff}
.hero__trust-item strong{display:block;font-size:1.9rem;font-weight:800;color:var(--aqua-400);line-height:1}
.hero__trust-item span{font-size:.85rem;opacity:.85}
.hero__scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);color:#fff;font-size:.85rem;opacity:.8;animation:bob 2s ease-in-out infinite}
@keyframes bob{50%{transform:translate(-50%,8px)}}
@media(max-width:920px){.hero__inner{grid-template-columns:1fr;gap:2rem}.hero__scroll{display:none}}

/* hero quote card */
.quotecard{background:rgba(255,255,255,.97);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.6rem;backdrop-filter:blur(6px)}
.quotecard__head h3{font-size:1.4rem}
.quotecard__head p{font-size:.92rem;color:var(--ink-500);margin:.25rem 0 1rem}
.quoteform label{display:block;font-size:.78rem;font-weight:600;color:var(--ink-700);margin-bottom:.7rem}
.quoteform__row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.quoteform__fine{font-size:.74rem;color:var(--ink-500);text-align:center;margin-top:.7rem}
input,select,textarea{
  width:100%;font-family:inherit;font-size:.95rem;color:var(--ink-900);
  padding:.7em .85em;border:1.5px solid #dfe7e8;border-radius:12px;background:#fff;
  margin-top:.28rem;transition:border .2s,box-shadow .2s;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal-500);box-shadow:0 0 0 3px rgba(19,163,176,.15)}
textarea{resize:vertical}

/* ---------- logos / trust strip ---------- */
.logos{background:var(--ocean-900);color:#cdeef0}
.logos__inner{max-width:var(--max);margin:0 auto;padding:1rem 1.25rem;display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;font-size:.9rem;font-weight:500}

/* ---------- sections ---------- */
.section{padding:5.5rem 1.25rem;max-width:var(--max);margin:0 auto}
.section__head{text-align:center;max-width:42rem;margin:0 auto 3rem}
.kicker{color:var(--coral-500);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:.8rem;margin-bottom:.7rem}
.kicker--light{color:var(--aqua-400)}
.section__head h2{font-size:clamp(1.9rem,4vw,2.9rem);letter-spacing:-1px}
.section__lead{margin-top:1rem;font-size:1.1rem;color:var(--ink-500)}

/* ---------- activity cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
@media(max-width:1000px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cards{grid-template-columns:1fr}}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card__media{height:170px;background:var(--img) center/cover no-repeat;position:relative}
.card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,53,64,.35),transparent 60%)}
.card__tag{position:absolute;top:.8rem;left:.8rem;z-index:2;background:rgba(255,255,255,.92);color:var(--ocean-800);font-size:.72rem;font-weight:700;padding:.3em .8em;border-radius:999px;letter-spacing:.3px}
.card__body{padding:1.2rem;display:flex;flex-direction:column;flex:1}
.card__body h3{font-size:1.25rem;margin-bottom:.4rem}
.card__body p{font-size:.92rem;color:var(--ink-500);flex:1}
.card__foot{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;gap:.5rem}
.price{font-weight:800;color:var(--ocean-800);font-size:1.05rem}
.price small{font-weight:500;color:var(--ink-500);font-size:.72rem}
.card__btn{font-weight:700;color:var(--coral-600);font-size:.92rem;white-space:nowrap}
.card__btn:hover{color:var(--coral-500)}

/* ---------- builder ---------- */
.builder{max-width:none;background:linear-gradient(135deg,var(--ocean-900),var(--ocean-700));color:#fff;padding:0}
.builder__inner{max-width:var(--max);margin:0 auto;padding:5rem 1.25rem;display:grid;grid-template-columns:1fr 1.05fr;gap:3.5rem;align-items:center}
.builder__copy h2{color:#fff;font-size:clamp(1.9rem,4vw,2.8rem)}
.builder__copy p{color:#d6f3f4;margin:1rem 0;font-size:1.08rem}
.builder__list{list-style:none;display:grid;gap:.6rem}
.builder__list li{color:#eafdfb}
@media(max-width:920px){.builder__inner{grid-template-columns:1fr;gap:2rem}}

.wizard{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.8rem;color:var(--ink-700)}
.wizard__bar{height:7px;background:#e7eef0;border-radius:999px;overflow:hidden;margin-bottom:1.6rem}
.wizard__fill{height:100%;width:25%;background:linear-gradient(90deg,var(--teal-500),var(--aqua-400));border-radius:999px;transition:width .4s var(--ease)}
.wizard__step{display:none;animation:fade .35s var(--ease)}
.wizard__step.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.wizard__step h3{font-size:1.35rem;margin-bottom:1.1rem;color:var(--ink-900)}
.wizard__step label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.9rem}
.wizard__inline{margin-top:1rem}
.chiprow{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:.4rem}
.chip{font-family:inherit;font-size:.92rem;font-weight:600;padding:.6em 1em;border-radius:999px;border:1.5px solid #d8e3e5;background:#f7fbfb;color:var(--ink-700);cursor:pointer;transition:all .18s}
.chip:hover{border-color:var(--teal-500);color:var(--ocean-800)}
.chip.is-selected{background:var(--ocean-800);color:#fff;border-color:var(--ocean-800)}
.check{display:flex !important;align-items:center;gap:.5rem;font-weight:500 !important;color:var(--ink-700)}
.check input{width:auto;margin:0}
.wizard__nav{display:flex;align-items:center;gap:1rem;margin-top:1.6rem}
.wizard__count{margin:0 auto;font-size:.82rem;color:var(--ink-500);font-weight:600}

/* ---------- why / stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-bottom:3.5rem}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{text-align:center;background:#fff;border-radius:var(--radius);padding:1.6rem 1rem;box-shadow:var(--shadow-md)}
.stat__num{display:block;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:var(--teal-500);line-height:1}
.stat__label{font-size:.86rem;color:var(--ink-500);margin-top:.4rem;display:block}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
@media(max-width:900px){.why__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.why__grid{grid-template-columns:1fr}}
.why__item{padding:1.4rem}
.why__item span{font-size:2rem}
.why__item h4{margin:.6rem 0 .4rem;font-size:1.15rem}
.why__item p{font-size:.92rem;color:var(--ink-500)}

/* ---------- feature ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--sand-200)}
.feature__media{min-height:460px;background:url('https://images.unsplash.com/photo-1502209524164-acea936639a2?w=1200&q=80') center/cover no-repeat}
.feature__copy{padding:clamp(2.5rem,6vw,5rem)}
.feature__copy h2{font-size:clamp(1.9rem,4vw,2.8rem);letter-spacing:-1px}
.feature__copy p{margin:1rem 0;font-size:1.08rem;color:var(--ink-700)}
.feature__list{list-style:none;display:grid;gap:.7rem;margin:1.4rem 0 2rem}
.feature__list li{font-weight:500}
@media(max-width:860px){.feature{grid-template-columns:1fr}.feature__media{min-height:300px}}

/* ---------- reviews ---------- */
.reviews{}
.reviewgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media(max-width:860px){.reviewgrid{grid-template-columns:1fr}}
.review{background:#fff;border-radius:var(--radius);padding:1.7rem;box-shadow:var(--shadow-md);position:relative}
.review__stars{color:var(--sun-400);font-size:1.1rem;letter-spacing:2px;margin-bottom:.7rem}
.review p{font-size:1rem;color:var(--ink-700)}
.review footer{margin-top:1rem;font-weight:700;color:var(--ocean-800);font-size:.9rem}
.reviews__cta{text-align:center;margin-top:2.6rem}
.reviews__cta span{display:block;margin-top:.9rem;color:var(--ink-500);font-size:.9rem}

/* ---------- groups ---------- */
.groups{max-width:none;background:linear-gradient(135deg,var(--teal-500),var(--ocean-800));padding:0}
.groups__inner{max-width:var(--max);margin:0 auto;padding:5rem 1.25rem;display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.groups__copy h2{color:#fff;font-size:clamp(1.9rem,4vw,2.7rem)}
.groups__copy p{color:#e7fbfb;margin:1rem 0 1.6rem;font-size:1.08rem}
.groups__badges{display:flex;flex-wrap:wrap;gap:.7rem}
.groups__badges span{background:rgba(255,255,255,.16);color:#fff;padding:.5em 1em;border-radius:999px;font-size:.88rem;font-weight:600}
@media(max-width:880px){.groups__inner{grid-template-columns:1fr;gap:2rem}}

/* card form (groups, contact) */
.card-form{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.8rem}
.card-form h3{font-size:1.4rem;margin-bottom:1rem}
.card-form label{display:block;font-size:.8rem;font-weight:600;color:var(--ink-700);margin-bottom:.9rem}
.card-form__row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
@media(max-width:480px){.card-form__row{grid-template-columns:1fr}}

/* ---------- magnet ---------- */
.magnet{background:linear-gradient(135deg,var(--sun-400),var(--coral-500));padding:3.5rem 1.25rem}
.magnet__inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.magnet__copy h2{color:#3a2200;font-size:clamp(1.5rem,3.5vw,2.1rem)}
.magnet__copy p{color:#5a3a00;max-width:32rem;margin-top:.5rem}
.magnet__form{display:flex;gap:.7rem;flex:1;min-width:280px}
.magnet__form input{margin:0;flex:1}
@media(max-width:560px){.magnet__form{flex-direction:column}}

/* ---------- faq ---------- */
.faq__list{max-width:46rem;margin:0 auto;display:grid;gap:.8rem}
.faq__item{background:#fff;border-radius:14px;box-shadow:var(--shadow-md);padding:1.1rem 1.4rem;cursor:pointer}
.faq__item summary{font-weight:700;color:var(--ink-900);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq__item summary::after{content:"+";font-size:1.5rem;color:var(--teal-500);transition:transform .2s}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{margin-top:.8rem;color:var(--ink-500)}

/* ---------- final cta ---------- */
.finalcta{}
.finalcta__inner{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;background:linear-gradient(135deg,var(--ocean-900),var(--ocean-700));border-radius:var(--radius-lg);padding:clamp(2rem,5vw,4rem);color:#fff}
.finalcta__copy h2{color:#fff;font-size:clamp(1.8rem,4vw,2.7rem)}
.finalcta__copy p{color:#d6f3f4;margin:1rem 0 1.6rem;font-size:1.08rem}
.finalcta__contact{list-style:none;display:grid;gap:.7rem;font-size:1.05rem}
.finalcta__contact a{font-weight:700;color:var(--aqua-200)}
@media(max-width:860px){.finalcta__inner{grid-template-columns:1fr;gap:2rem}}

/* ---------- footer ---------- */
.footer{background:var(--ocean-900);color:#bfe3e6;padding:3.5rem 1.25rem 1.5rem}
.footer__inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:2.5rem}
@media(max-width:860px){.footer__inner{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer__inner{grid-template-columns:1fr}}
.footer__brand p{margin-top:.8rem;font-size:.92rem;max-width:24rem}
.footer__tag{font-family:'Caveat',cursive;font-size:1.5rem;color:var(--sun-400) !important;margin-top:1rem !important}
.footer__col h5{color:#fff;margin-bottom:1rem;font-size:1rem;letter-spacing:.5px}
.footer__col a{display:block;margin-bottom:.5rem;font-size:.92rem;transition:color .2s}
.footer__col a:hover{color:var(--aqua-400)}
.footer__col p{font-size:.92rem;margin-bottom:.5rem}
.footer__bar{max-width:var(--max);margin:2.5rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.82rem;opacity:.8}

/* ---------- floaters ---------- */
.floaters{position:fixed;right:1.1rem;bottom:1.1rem;z-index:50;display:flex;flex-direction:column;gap:.7rem}
.floater{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:1.5rem;box-shadow:var(--shadow-lg);transition:transform .2s}
.floater:hover{transform:scale(1.1)}
.floater--call{background:linear-gradient(135deg,var(--coral-500),var(--coral-600))}
.floater--text{background:linear-gradient(135deg,var(--teal-500),var(--aqua-400))}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:1.25rem}
.modal.is-open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(6,53,64,.6);backdrop-filter:blur(4px);animation:fade .3s}
.modal__card{position:relative;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:430px;width:100%;padding:2.2rem 1.8rem 1.8rem;text-align:center;animation:pop .35s var(--ease)}
@keyframes pop{from{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:none}}
.modal__art{font-size:3rem}
.modal__card h3{font-size:1.55rem;margin:.6rem 0}
.modal__card p{color:var(--ink-500);margin-bottom:1.2rem}
.modal__form{display:grid;gap:.7rem}
.modal__x{position:absolute;top:.7rem;right:1rem;background:none;border:none;font-size:1.8rem;color:var(--ink-500);cursor:pointer;line-height:1}
.modal__decline{display:block;margin:1rem auto 0;background:none;border:none;color:var(--ink-500);font-size:.85rem;text-decoration:underline;cursor:pointer;font-family:inherit}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:1.5rem;transform:translate(-50%,150%);background:var(--ocean-800);color:#fff;padding:1rem 1.5rem;border-radius:14px;box-shadow:var(--shadow-lg);z-index:120;font-weight:600;max-width:90vw;text-align:center;transition:transform .45s var(--ease)}
.toast.is-visible{transform:translate(-50%,0)}
.toast strong{color:var(--aqua-400)}

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

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
}
