/* Start custom CSS *//* ============================================================
   TDB SNORKELING — "Tropical Splash / Sun & Sea" Theme
   Typography: Fredoka (playful rounded) + Plus Jakarta Sans (clean modern)
   Palette: Ocean Teal #0E4D64 + Sunshine #F5A623 + Mint #4ECDC4 + Cream #FFFDF7
   ============================================================ */

.sn-page{
  --sn-ocean:#0E4D64;
  --sn-deep:#0A3A4D;
  --sn-ink:#073040;
  --sn-steel:#3D7A8E;

  --sn-sun:#F5A623;
  --sn-sun-light:#FFCA6B;
  --sn-amber:#E8941A;

  --sn-mint:#4ECDC4;
  --sn-mint-light:#7EDDD6;
  --sn-sea:#2BAA9F;

  --sn-cream:#FFFDF7;
  --sn-sand:#FFF8EC;
  --sn-white:#FFFFFF;
  --sn-light:#F0E6D6;
  --sn-text:#3A3632;
  --sn-muted:#7B756C;

  --font-head:'Fredoka',sans-serif;
  --font-body:'Plus Jakarta Sans',sans-serif;

  --sp-xs:8px;--sp-sm:16px;--sp-md:24px;--sp-lg:40px;--sp-xl:64px;--sp-2xl:96px;
  --radius:14px;

  font-family:var(--font-body);font-weight:400;color:var(--sn-text);line-height:1.75;
  margin:0;padding:0;
}
.sn-page *,.sn-page *::before,.sn-page *::after{box-sizing:border-box}
.sn-page h1,.sn-page h2,.sn-page h3{font-family:var(--font-head);margin:0;line-height:1.15}
.sn-page p{margin:0}
.sn-page img{max-width:100%;display:block}
.sn-page a{text-decoration:none;color:inherit}
.sn-wrap{max-width:1100px;margin:0 auto;padding:0 clamp(20px,4vw,40px)}

/* --- HERO --- */
.sn-hero{
  position:relative;min-height:92vh;display:flex;align-items:center;
  overflow:hidden;
  background:linear-gradient(165deg,#0A3A4D 0%,#0E4D64 30%,#147A6E 60%,#1A8F6C 100%);
  width:100vw;left:50%;margin-left:-50vw;
  margin-top:-40px;padding-top:40px;
}
.sn-hero__bg{position:absolute;inset:0;z-index:0}
.sn-hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.sn-hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(14,77,100,.3) 0%,rgba(10,58,77,.55) 35%,rgba(7,48,64,.88) 68%,rgba(7,48,64,.97) 100%),
    radial-gradient(ellipse at 30% 20%,rgba(78,205,196,.1) 0%,transparent 50%),
    radial-gradient(ellipse at 80% 70%,rgba(245,166,35,.05) 0%,transparent 50%);
}
.sn-hero__wave{
  position:absolute;bottom:-2px;left:0;width:100%;height:auto;z-index:5;
}

/* Decorations */
.sn-deco{position:absolute;pointer-events:none;z-index:2}
.sn-deco--fish1{width:30px;top:25%;color:rgba(245,166,35,.06);animation:snSwimR 26s linear infinite}
.sn-deco--fish2{width:22px;top:60%;color:rgba(78,205,196,.05);animation:snSwimL 32s linear infinite;animation-delay:4s}
.sn-deco--turtle{width:48px;top:38%;color:rgba(255,255,255,.03);animation:snSwimR 40s linear infinite;animation-delay:8s}
.sn-deco--jelly{width:28px;right:8%;top:18%;color:rgba(245,166,35,.04);animation:snJellyFloat 16s ease-in-out infinite}
@keyframes snSwimR{0%{left:-5%}100%{left:105%}}
@keyframes snSwimL{0%{left:105%;transform:scaleX(-1)}100%{left:-5%;transform:scaleX(-1)}}
@keyframes snJellyFloat{0%,100%{transform:translateY(0) rotate(-2deg)}25%{transform:translateY(-18px) rotate(2deg)}50%{transform:translateY(-6px) rotate(-1deg)}75%{transform:translateY(-22px) rotate(3deg)}}
@keyframes snMantaGlide{0%,100%{transform:translateX(0) translateY(0)}25%{transform:translateX(25px) translateY(-12px)}50%{transform:translateX(45px) translateY(6px)}75%{transform:translateX(18px) translateY(-8px)}}
@keyframes snSeaweedSway{0%,100%{transform:rotate(0)}25%{transform:rotate(4deg)}75%{transform:rotate(-3deg)}}
@keyframes snSeahorseBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* Bubbles */
.sn-bubbles{position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden}
.sn-bubbles i{
  position:absolute;bottom:-10px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.07),rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.04);
  animation:snBub linear infinite;
}
.sn-bubbles i:nth-child(1){width:5px;height:5px;left:7%;animation-duration:14s}
.sn-bubbles i:nth-child(2){width:14px;height:14px;left:16%;animation-duration:20s;animation-delay:2s;
  background:radial-gradient(circle at 35% 35%,rgba(245,166,35,.06),transparent);border-color:rgba(245,166,35,.04)}
.sn-bubbles i:nth-child(3){width:4px;height:4px;left:26%;animation-duration:11s;animation-delay:5s}
.sn-bubbles i:nth-child(4){width:18px;height:18px;left:35%;animation-duration:25s;animation-delay:1s}
.sn-bubbles i:nth-child(5){width:8px;height:8px;left:44%;animation-duration:15s;animation-delay:7s}
.sn-bubbles i:nth-child(6){width:3px;height:3px;left:53%;animation-duration:10s;animation-delay:3s}
.sn-bubbles i:nth-child(7){width:22px;height:22px;left:62%;animation-duration:27s;animation-delay:5s;
  background:radial-gradient(circle at 35% 35%,rgba(78,205,196,.05),transparent);border-color:rgba(78,205,196,.03)}
.sn-bubbles i:nth-child(8){width:6px;height:6px;left:71%;animation-duration:13s;animation-delay:2s}
.sn-bubbles i:nth-child(9){width:11px;height:11px;left:80%;animation-duration:18s;animation-delay:0s}
.sn-bubbles i:nth-child(10){width:9px;height:9px;left:21%;animation-duration:17s;animation-delay:8s}
.sn-bubbles i:nth-child(11){width:15px;height:15px;left:47%;animation-duration:23s;animation-delay:2.5s;
  background:radial-gradient(circle at 35% 35%,rgba(245,166,35,.05),transparent);border-color:rgba(245,166,35,.03)}
.sn-bubbles i:nth-child(12){width:4px;height:4px;left:67%;animation-duration:9s;animation-delay:6s}
.sn-bubbles i:nth-child(13){width:17px;height:17px;left:10%;animation-duration:24s;animation-delay:1.5s}
.sn-bubbles i:nth-child(14){width:6px;height:6px;left:37%;animation-duration:12s;animation-delay:5.5s}
.sn-bubbles i:nth-child(15){width:24px;height:24px;left:55%;animation-duration:29s;animation-delay:.5s;
  background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.04),transparent)}
.sn-bubbles i:nth-child(16){width:5px;height:5px;left:85%;animation-duration:13s;animation-delay:4s}
.sn-bubbles i:nth-child(17){width:10px;height:10px;left:31%;animation-duration:18s;animation-delay:7s}
.sn-bubbles i:nth-child(18){width:3px;height:3px;left:73%;animation-duration:8s;animation-delay:3.5s}
.sn-bubbles i:nth-child(19){width:16px;height:16px;left:4%;animation-duration:22s;animation-delay:6s;
  background:radial-gradient(circle at 35% 35%,rgba(78,205,196,.04),transparent);border-color:rgba(78,205,196,.02)}
.sn-bubbles i:nth-child(20){width:7px;height:7px;left:91%;animation-duration:15s;animation-delay:1s}
@keyframes snBub{
  0%{transform:translateY(0) scale(0);opacity:0}
  10%{opacity:.5;transform:translateY(-8vh) scale(1)}
  50%{opacity:.18;transform:translateY(-50vh) scale(.9)}
  100%{transform:translateY(-110vh) scale(.3);opacity:0}
}

@media(max-width:768px){.sn-deco,.sn-bubbles,.sn-scu{display:none}}

/* Hero content */
.sn-hero__content{position:relative;z-index:10;padding-top:clamp(100px,16vh,180px);padding-bottom:clamp(120px,18vh,180px)}

.sn-hero__badge{
  display:inline-block;font-family:var(--font-body);font-size:.75rem;font-weight:600;
  color:var(--sn-sun);padding:8px 20px;
  border:1px solid rgba(245,166,35,.2);background:rgba(245,166,35,.08);
  border-radius:30px;margin-bottom:var(--sp-lg);
}

.sn-hero h1{
  font-size:clamp(2.8rem,7.5vw,5.2rem);font-weight:600;
  color:var(--sn-white);margin-bottom:var(--sp-md);
}
.sn-hero h1 span{color:var(--sn-sun-light)}

.sn-hero__sub{
  font-size:clamp(.95rem,1.3vw,1.05rem);color:rgba(255,255,255,.88);
  max-width:520px;margin-bottom:var(--sp-lg);line-height:1.8;
}

/* Hero buttons */
.sn-hero__actions,.sn-hero__actions2{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}

.sn-btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-body);font-size:.85rem;font-weight:700;
  padding:14px 28px;border:none;cursor:pointer;border-radius:30px;
  transition:all .35s cubic-bezier(.23,1,.32,1);
}
.sn-btn--sun{background:var(--sn-sun);color:var(--sn-white)}
.sn-btn--sun:hover{background:var(--sn-sun-light);transform:translateY(-3px);box-shadow:0 14px 44px rgba(245,166,35,.35)}
.sn-btn--mint{background:var(--sn-mint);color:var(--sn-white)}
.sn-btn--mint:hover{background:var(--sn-mint-light);transform:translateY(-3px);box-shadow:0 14px 44px rgba(78,205,196,.3)}
.sn-btn--glass{background:rgba(255,255,255,.18);color:#FFFFFF;border:2px solid #FFCA6B;backdrop-filter:blur(8px);font-weight:700}
.sn-btn--glass:hover{border-color:var(--sn-sun);color:#FFFFFF;background:rgba(245,166,35,.3);transform:translateY(-3px)}
.sn-btn--glass-w{background:rgba(255,255,255,.08);color:var(--sn-white);border:2px solid rgba(255,255,255,.45)}
.sn-btn--glass-w:hover{border-color:var(--sn-mint);color:var(--sn-mint);background:rgba(78,205,196,.1);transform:translateY(-3px)}

/* Hero stats bar */
.sn-hero__bar{
  display:flex;flex-wrap:wrap;gap:0;max-width:560px;margin-top:var(--sp-lg);
  background:rgba(255,255,255,.05);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);overflow:hidden;
}
.sn-hero__stat{
  flex:1;min-width:110px;padding:14px 16px;text-align:center;
  border-right:1px solid rgba(255,255,255,.05);
}
.sn-hero__stat:last-child{border-right:none}
.sn-hero__stat strong{display:block;font-family:var(--font-head);font-size:.92rem;color:var(--sn-sun-light)}
.sn-hero__stat span{font-size:.65rem;color:rgba(255,255,255,.65);letter-spacing:.08em;text-transform:uppercase}

/* --- SECTIONS --- */
.sn-section{
  padding:var(--sp-2xl) 0;position:relative;overflow:hidden;
  width:100vw;left:50%;margin-left:-50vw;
}
.sn-section--white{background:var(--sn-white)}
.sn-section--cream{background:var(--sn-cream)}
.sn-section--ocean{background:var(--sn-ocean)}

.sn-sh{margin-bottom:var(--sp-xl)}
.sn-sh h2{font-size:clamp(1.8rem,4.5vw,2.8rem);font-weight:600;color:var(--sn-ocean)}
.sn-sh--light h2{color:var(--sn-white)}
.sn-sh__sub{font-size:.95rem;color:var(--sn-text);max-width:520px;margin-top:var(--sp-sm);line-height:1.75;opacity:.65}

.sn-label{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-body);font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--sn-mint);
  margin-bottom:var(--sp-sm);
}
.sn-label::before{content:'';width:20px;height:3px;background:var(--sn-mint);border-radius:2px}
.sn-label--sun{color:var(--sn-sun)}.sn-label--sun::before{background:var(--sn-sun)}

/* Scuba elements */
.sn-scu{position:absolute;pointer-events:none;z-index:0}
.sn-scu--fish-r1{width:22px;top:30%;color:rgba(78,205,196,.04);animation:snSwimR 28s linear infinite;animation-delay:3s}
.sn-scu--seahorse{width:20px;right:4%;top:50%;color:rgba(245,166,35,.03);animation:snSeahorseBob 10s ease-in-out infinite}
.sn-scu--manta1{width:55px;left:4%;top:8%;color:rgba(245,166,35,.03);animation:snMantaGlide 22s ease-in-out infinite}
.sn-scu--school1{width:56px;right:6%;top:60%;color:rgba(78,205,196,.03);animation:snSwimL 34s linear infinite;animation-delay:4s}
.sn-scu--turtle2{width:40px;right:5%;top:20%;color:rgba(255,255,255,.03);animation:snSwimR 36s linear infinite;animation-delay:6s}
.sn-scu--coral1{width:30px;right:3%;bottom:6%;color:rgba(78,205,196,.04);animation:snSeaweedSway 12s ease-in-out infinite}
.sn-scu--fish-l1{width:20px;top:45%;color:rgba(245,166,35,.04);animation:snSwimL 26s linear infinite;animation-delay:5s}
.sn-scu--diver{width:44px;left:7%;top:30%;color:rgba(255,255,255,.03);animation:snSwimR 32s linear infinite;animation-delay:8s}

/* --- ABOUT --- */
.sn-about__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(30px,5vw,60px);align-items:start}
.sn-about__text p{font-size:.95rem;color:var(--sn-text);margin-bottom:var(--sp-sm);line-height:1.8}
.sn-about__text strong{color:var(--sn-ocean);font-weight:700}

.sn-about__highlights{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sn-highlight{
  padding:20px;background:var(--sn-white);border:1px solid var(--sn-light);
  border-radius:var(--radius);text-align:center;
  transition:all .35s ease;
}
.sn-highlight:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,.06);border-color:var(--sn-mint)}
.sn-highlight span{font-size:1.8rem;display:block;margin-bottom:6px}
.sn-highlight strong{font-family:var(--font-head);font-size:.88rem;color:var(--sn-ocean);display:block;margin-bottom:4px}
.sn-highlight p{font-size:.78rem;color:var(--sn-text);line-height:1.5;opacity:.7}

/* --- PRICING TABLE --- */
.sn-ptable{
  background:var(--sn-cream);border:1px solid var(--sn-light);
  border-radius:var(--radius);overflow:hidden;
}
.sn-ptable__head{
  display:grid;grid-template-columns:1fr repeat(3,.8fr);
  background:var(--sn-ocean);color:var(--sn-white);
}
.sn-ptable__head > *{padding:14px 16px;font-size:.75rem;font-weight:700;text-align:center;letter-spacing:.06em}
.sn-ptable__label{text-align:left}
.sn-ptable__col{font-family:var(--font-head);font-size:.88rem}

.sn-ptable__group{border-bottom:1px solid var(--sn-light)}
.sn-ptable__group:last-child{border-bottom:none}
.sn-ptable__gname{
  padding:12px 16px;font-family:var(--font-head);font-size:.88rem;font-weight:500;
  color:var(--sn-ocean);background:rgba(14,77,100,.03);
}
.sn-ptable__row{
  display:grid;grid-template-columns:1fr repeat(3,.8fr);
  border-top:1px solid rgba(0,0,0,.04);
}
.sn-ptable__row span{padding:12px 16px;font-size:.85rem;color:var(--sn-text)}
.sn-ptable__row strong{
  padding:12px 16px;text-align:center;font-size:.88rem;font-weight:700;
  color:var(--sn-ocean);font-family:var(--font-head);
}
.sn-ptable__row:hover{background:rgba(78,205,196,.04)}

.sn-price-note{
  margin-top:var(--sp-md);font-size:.9rem;color:var(--sn-text);
  padding:14px 20px;background:rgba(245,166,35,.06);border:1px solid rgba(245,166,35,.12);
  border-radius:var(--radius);
}
.sn-price-note a{color:var(--sn-sun);font-weight:700;text-decoration:underline;text-underline-offset:3px}
.sn-price-extra{margin-top:var(--sp-sm);font-size:.88rem;color:var(--sn-text);opacity:.75;
  padding:14px 20px;background:rgba(78,205,196,.06);border:1px solid rgba(78,205,196,.12);
  border-radius:var(--radius);
}

/* --- WHAT'S INCLUDED --- */
.sn-inc__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sn-inc-card{
  padding:28px 22px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  transition:all .35s ease;
}
.sn-inc-card:hover{border-color:rgba(245,166,35,.2);transform:translateY(-4px)}
.sn-inc-card--pop{
  border-color:rgba(245,166,35,.25);background:rgba(245,166,35,.06);
  transform:scale(1.02);
}
.sn-inc-card--pop:hover{transform:scale(1.02) translateY(-4px)}
.sn-inc-card__tag{
  display:inline-block;font-family:var(--font-head);font-size:.78rem;font-weight:600;
  color:var(--sn-sun);padding:4px 14px;
  background:rgba(245,166,35,.1);border-radius:20px;margin-bottom:var(--sp-sm);
}
.sn-inc-card h3{font-size:1.1rem;font-weight:600;color:var(--sn-white);margin-bottom:var(--sp-md)}
.sn-inc-card__list{display:flex;flex-direction:column;gap:8px}
.sn-inc-card__list div{font-size:.85rem;color:rgba(255,255,255,.75);line-height:1.5}

.sn-inc-note{
  text-align:center;margin-top:var(--sp-xl);font-size:.85rem;color:rgba(255,255,255,.55);
}

/* --- WHY --- */
.sn-why__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.sn-why__card{
  padding:28px 24px;background:var(--sn-white);border:1px solid var(--sn-light);
  border-radius:var(--radius);transition:all .35s ease;
}
.sn-why__card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.06);border-color:var(--sn-mint)}
.sn-why__card h3{font-size:1.05rem;font-weight:600;color:var(--sn-ocean);margin-bottom:8px}
.sn-why__card p{font-size:.88rem;color:var(--sn-text);line-height:1.7;opacity:.7}

/* --- INFO --- */
.sn-info__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.sn-info-card{
  padding:22px 20px;background:var(--sn-cream);border:1px solid var(--sn-light);
  border-radius:var(--radius);transition:all .3s ease;
}
.sn-info-card:hover{border-color:var(--sn-sun)}
.sn-info-card strong{font-family:var(--font-head);font-size:.92rem;color:var(--sn-ocean);display:block;margin-bottom:6px}
.sn-info-card p{font-size:.85rem;color:var(--sn-text);line-height:1.65;opacity:.7}

/* --- CTA --- */
.sn-cta{
  background:linear-gradient(160deg,var(--sn-deep),#0A5E44);
  text-align:center;position:relative;overflow:hidden;
  padding:var(--sp-2xl) 0 0 !important;
}
.sn-cta h2{font-size:clamp(2rem,5vw,3rem);font-weight:600;color:var(--sn-white);margin-bottom:var(--sp-sm)}
.sn-cta p{font-size:1rem;color:rgba(255,255,255,.65);max-width:480px;margin:0 auto var(--sp-lg);line-height:1.8}
.sn-cta__btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.sn-cta__fade{height:120px;background:linear-gradient(to bottom,transparent,#ffffff);margin-top:var(--sp-2xl)}

/* --- RESPONSIVE --- */
@media(max-width:1024px){
  .sn-about__grid{grid-template-columns:1fr}
  .sn-inc__grid{grid-template-columns:1fr}
  .sn-inc-card--pop{transform:none}
}
@media(max-width:768px){
  .sn-hero{min-height:auto;padding-top:60px}
  .sn-hero__bar{flex-direction:column}
  .sn-hero__stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.04)}
  .sn-hero__stat:last-child{border-bottom:none}
  .sn-section{padding:var(--sp-xl) 0}
  .sn-about__highlights{grid-template-columns:1fr}
  .sn-why__grid{grid-template-columns:1fr}
  .sn-info__grid{grid-template-columns:1fr}
  .sn-hero__actions,.sn-hero__actions2,.sn-cta__btns{flex-direction:column;align-items:flex-start}
  .sn-ptable__head,.sn-ptable__row{grid-template-columns:1.2fr repeat(3,.6fr)}
  .sn-ptable__row span,.sn-ptable__row strong{padding:10px 10px;font-size:.78rem}
  .sn-ptable__head > *{padding:10px 10px;font-size:.7rem}
  .sn-ptable__col{font-size:.78rem}
  .sn-ptable__gname{font-size:.82rem;padding:10px 10px}
}/* End custom CSS */