/* ===================================================================
   PIGEON ISLAND TOURS — Design Tokens
   Color: deep reef navy / lagoon teal / Pigeon Island turquoise /
          sunset amber / bone sand
   Type:  Fraunces (display) + Inter (body / UI)
=================================================================== */
:root{
  --navy:        #04222F;
  --navy-soft:   #0A2E3D;
  --teal:        #0E5C73;
  --turquoise:   #1FB6C9;
  --turquoise-l: #6FE0E8;
  --amber:       #F2A33D;
  --amber-deep:  #D87F1E;
  --sand:        #FBF7EE;
  --sand-dim:    #F1EADA;
  --foam:        #E8FBFA;
  --ink:         #0B2B36;
  --ink-soft:    #4D6772;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  --container: 1240px;
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 10px;

  --ease: cubic-bezier(.22,.85,.32,1);
  --shadow-soft: 0 30px 60px -25px rgba(4,34,47,0.35);
  --shadow-card: 0 18px 40px -18px rgba(4,34,47,0.28);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important;}
}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--sand);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
button{font-family:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;}

:focus-visible{
  outline:3px solid var(--amber);
  outline-offset:3px;
  border-radius:4px;
}

.grain{
  position:fixed; inset:0; pointer-events:none; z-index:9999;
  opacity:0.025; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===================================================================
   TIDE LINE — signature scroll device
=================================================================== */
.tideline{
  position:fixed; left:18px; top:90px; bottom:18px; width:40px;
  z-index:40; display:none;
  pointer-events:none;
}
@media (min-width:1100px){ .tideline{display:block;} }
.tideline__svg{ width:40px; height:100%; }
.tideline__path{
  fill:none; stroke:rgba(31,182,201,0.35); stroke-width:1.6;
  vector-effect:non-scaling-stroke;
}
.tideline__marks{ position:absolute; top:0; left:30px; height:100%; }
.tideline__mark{
  position:absolute; left:0;
  font-family:var(--font-body); font-size:10px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--ink-soft); opacity:0.45;
  white-space:nowrap; transform:rotate(90deg) translateX(-50%);
  transform-origin:left center;
  transition:opacity .3s var(--ease), color .3s var(--ease);
}
.tideline__mark.is-active{ opacity:1; color:var(--teal); font-weight:600; }

/* ===================================================================
   UTILITIES
=================================================================== */
.eyebrow{
  font-family:var(--font-body); font-size:12.5px; letter-spacing:0.22em;
  text-transform:uppercase; font-weight:700; color:var(--teal);
  margin:0 0 14px;
}
.eyebrow--light{ color:var(--turquoise-l); }
.h2{
  font-family:var(--font-display); font-weight:600; font-size:clamp(2rem,4vw,3rem);
  line-height:1.08; color:var(--navy); margin:0 0 18px; letter-spacing:-0.01em;
}
.h2--light{ color:var(--sand); }
.section-head{
  max-width:720px; margin:0 auto 56px; padding:0 24px; text-align:center;
}
.section-head__sub{ font-size:1.05rem; color:var(--ink-soft); margin:0; }
.section-head__sub--light{ color:rgba(232,251,250,0.78); }

.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-weight:600; font-size:0.95rem;
  padding:15px 30px; border-radius:100px; border:none;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease);
  white-space:nowrap;
}
.btn--accent{
  background:linear-gradient(135deg,var(--amber),var(--amber-deep));
  color:var(--navy); box-shadow:0 14px 30px -10px rgba(242,163,61,0.55);
}
.btn--accent:hover{ transform:translateY(-3px); box-shadow:0 20px 36px -10px rgba(242,163,61,0.65); }
.btn--outline-light{
  background:transparent; color:var(--sand); border:1.5px solid rgba(251,247,238,0.55);
}
.btn--outline-light:hover{ background:rgba(251,247,238,0.12); transform:translateY(-3px); }
.btn--ghost-light{ background:rgba(251,247,238,0.12); color:var(--sand); border:1px solid rgba(251,247,238,0.25); padding:11px 22px; font-size:0.88rem;}
.btn--ghost-light:hover{ background:rgba(251,247,238,0.22); }
.icon-wa{ width:18px; height:18px; fill:currentColor; flex-shrink:0; }
.icon-wa--lg{ width:26px; height:26px; }

/* reveal-on-load / scroll animation */
.reveal{
  opacity:0; transform:translateY(26px);
  animation:revealUp 1s var(--ease) forwards;
  animation-delay:calc(var(--delay,0) * 120ms + 120ms);
}
.reveal[data-delay="1"]{ --delay:1; }
.reveal[data-delay="2"]{ --delay:2; }
.reveal[data-delay="3"]{ --delay:3; }
.reveal[data-delay="4"]{ --delay:4; }
@keyframes revealUp{ to{ opacity:1; transform:translateY(0); } }

.fade-in-scroll{
  opacity:0; transform:translateY(34px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.fade-in-scroll.is-visible{ opacity:1; transform:translateY(0); }

/* ===================================================================
   NAVIGATION
=================================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  padding:6px 0;
}
.nav__inner{
  max-width:var(--container); margin:0 auto; padding:14px 24px;
  display:flex; align-items:center; gap:28px;
}
.nav__brand{ flex-shrink:0; display:flex; align-items:center; }
.nav__logo{ height:46px; width:auto; transition:height .35s var(--ease); filter:drop-shadow(0 2px 6px rgba(0,0,0,0.25)); }
.nav__links{
  display:none; gap:30px; flex:1; font-weight:600; font-size:0.93rem;
}
.nav__links a{
  color:var(--sand); opacity:0.85; position:relative; padding:4px 0;
  transition:opacity .25s;
}
.nav__links a::after{
  content:''; position:absolute; left:0; right:0; bottom:-2px; height:2px;
  background:var(--amber); transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav__links a:hover{ opacity:1; }
.nav__links a:hover::after{ transform:scaleX(1); }
@media (min-width:980px){ .nav__links{ display:flex; } }

.nav__cta{ display:none; margin-left:auto; }
@media (min-width:980px){ .nav__cta{ display:inline-flex; } }

.nav__burger{
  margin-left:auto; background:none; border:none; width:40px; height:34px;
  display:flex; flex-direction:column; justify-content:center; gap:6px; padding:0;
}
@media (min-width:980px){ .nav__burger{ display:none; } }
.nav__burger span{
  display:block; height:2.4px; width:100%; background:var(--sand); border-radius:2px;
  transition:transform .3s var(--ease), opacity .3s var(--ease);
}
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

.nav.is-scrolled{
  background:rgba(4,34,47,0.86); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 10px 30px -16px rgba(0,0,0,0.4);
}
.nav.is-scrolled .nav__logo{ height:38px; }

.nav__mobile{
  max-height:0; overflow:hidden; background:rgba(4,34,47,0.97);
  backdrop-filter:blur(14px);
  transition:max-height .4s var(--ease);
  display:flex; flex-direction:column; gap:2px; padding:0 24px;
}
.nav__mobile.is-open{ max-height:480px; padding:10px 24px 26px; }
.nav__mobile a{
  color:var(--sand); padding:13px 4px; font-weight:600; font-size:1rem;
  border-bottom:1px solid rgba(251,247,238,0.08);
}
.nav__mobile .btn{ margin-top:16px; justify-content:center; }

/* ===================================================================
   HERO
=================================================================== */
.hero{
  position:relative; min-height:100vh; overflow:hidden;
  display:flex; align-items:center;
  background:linear-gradient(180deg,#06303F 0%, #0A4258 45%, #0E5C73 100%);
}
.hero__sky{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 22% 8%, rgba(255,214,150,0.35), transparent 60%),
    linear-gradient(180deg,#F2C879 0%, #E8965B 18%, #B95F6E 32%, #5B5B8C 48%, #1B4F66 62%, #0A3140 100%);
  opacity:0.9;
}
.hero__sun{
  position:absolute; top:9%; left:20%; width:140px; height:140px; border-radius:50%;
  background:radial-gradient(circle, #FFE9B8 0%, #FFD27A 45%, rgba(255,210,122,0) 75%);
  filter:blur(2px);
  animation:sunPulse 6s ease-in-out infinite;
}
@keyframes sunPulse{ 0%,100%{ opacity:0.9; } 50%{ opacity:1; transform:scale(1.04); } }

.hero__island{
  position:absolute; left:0; right:0; bottom:14%; width:100%; height:42%;
  z-index:2;
}
.island__far{ fill:#264B5E; opacity:0.55; }
.island__near{ fill:#16323F; opacity:0.9; }
.island__near--rock{ fill:#16323F; opacity:0.9; }
.island__palms path{ fill:#0E2530; opacity:0.95; }

.hero__waves{ position:absolute; left:0; right:0; bottom:0; height:46%; z-index:3; }
.wave{ position:absolute; left:0; bottom:0; width:100%; height:100%; }
.wave path{ }
.wave--back path{ fill:#0E5C73; opacity:0.55; }
.wave--mid path{ fill:#0A4A5E; opacity:0.75; }
.wave--front path{ fill:#072F3C; opacity:0.95; }
.wave--back{ animation:waveDrift 13s ease-in-out infinite; }
.wave--mid{ animation:waveDrift 9s ease-in-out infinite reverse; }
.wave--front{ animation:waveDrift 7s ease-in-out infinite; }
@keyframes waveDrift{
  0%,100%{ transform:translateX(0) translateY(0); }
  50%{ transform:translateX(-2.5%) translateY(4px); }
}

.hero__caustics{
  position:absolute; left:0; right:0; bottom:0; height:30%; z-index:4;
  background:
    repeating-linear-gradient(115deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 26px),
    repeating-linear-gradient(65deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 30px);
  mix-blend-mode:soft-light;
  animation:causticsShift 11s linear infinite;
  opacity:0.7;
}
@keyframes causticsShift{
  0%{ background-position:0 0, 0 0; }
  100%{ background-position:120px 60px, -100px 80px; }
}

.hero__content{
  position:relative; z-index:5; max-width:var(--container); margin:0 auto;
  padding:160px 24px 140px; width:100%;
}
.hero__headline{
  font-family:var(--font-display); font-weight:600; color:var(--sand);
  font-size:clamp(2.4rem,6.4vw,4.6rem); line-height:1.04; letter-spacing:-0.01em;
  margin:0 0 22px; max-width:840px;
  text-shadow:0 10px 40px rgba(0,0,0,0.25);
}
.hero__headline em{ font-style:italic; color:var(--amber); font-weight:500; }
.hero__sub{
  color:rgba(251,247,238,0.88); font-size:clamp(1rem,1.6vw,1.2rem); line-height:1.6;
  max-width:560px; margin:0 0 38px;
}
.hero__actions{ display:flex; flex-wrap:wrap; gap:16px; margin-bottom:34px; }
.hero__badges{
  display:flex; flex-wrap:wrap; gap:10px; align-items:center;
  font-size:0.82rem; letter-spacing:0.05em; color:rgba(251,247,238,0.7); font-weight:600;
}
.hero__badges .dot{ color:var(--amber); opacity:0.7; }

.hero__scroll{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%); z-index:6;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  color:rgba(251,247,238,0.75); font-size:0.72rem; letter-spacing:0.18em; text-transform:uppercase;
}
.hero__scroll-line{ width:1px; height:38px; background:rgba(251,247,238,0.5); position:relative; overflow:hidden; }
.hero__scroll-line::after{
  content:''; position:absolute; top:0; left:0; width:100%; height:40%; background:var(--amber);
  animation:scrollDrip 2.2s ease-in-out infinite;
}
@keyframes scrollDrip{ 0%{ top:-40%; } 100%{ top:100%; } }

/* ===================================================================
   ABOUT
=================================================================== */
.about{ padding:120px 24px; background:var(--sand); }
.about__inner{
  max-width:var(--container); margin:0 auto; display:grid;
  grid-template-columns:1fr; gap:60px; align-items:center;
}
@media (min-width:960px){ .about__inner{ grid-template-columns:0.85fr 1.15fr; gap:80px; } }

.about__art{ position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-soft); }
.about__svg{ width:100%; display:block; background:linear-gradient(160deg,var(--foam),#fff); }
.about__diver{ animation:diverDrift 7s ease-in-out infinite; }
@keyframes diverDrift{ 0%,100%{ transform:translateY(0) rotate(0deg); } 50%{ transform:translateY(-10px) rotate(-1deg); } }
.about__bubbles circle{ animation:bubbleUp 4s ease-in infinite; }
.about__bubbles circle:nth-child(2){ animation-delay:1s; }
.about__bubbles circle:nth-child(3){ animation-delay:2s; }
@keyframes bubbleUp{ 0%{ opacity:0; transform:translateY(0); } 20%{ opacity:0.8; } 100%{ opacity:0; transform:translateY(-60px); } }
.about__stamp{
  position:absolute; top:24px; right:24px; background:rgba(4,34,47,0.85); color:var(--sand);
  font-size:0.75rem; letter-spacing:0.12em; text-transform:uppercase; font-weight:700;
  padding:8px 16px; border-radius:100px; backdrop-filter:blur(6px);
}

.about__lede{ font-size:1.18rem; line-height:1.65; color:var(--ink); margin:0 0 16px; font-weight:500; }
.about__copy p{ color:var(--ink-soft); line-height:1.75; font-size:1.02rem; }
.about__points{ margin-top:34px; display:grid; gap:22px; }
.about__points li{ display:flex; gap:18px; align-items:flex-start; }
.about__points-mark{
  font-family:var(--font-display); font-size:0.95rem; font-weight:600; color:var(--turquoise);
  border:1.5px solid var(--turquoise); border-radius:50%; width:38px; height:38px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.about__points strong{ display:block; font-size:1.02rem; color:var(--navy); margin-bottom:3px; }
.about__points p{ margin:0; font-size:0.94rem; }

/* ===================================================================
   TOURS
=================================================================== */
.tours{ padding:120px 0 110px; background:var(--sand); }
.tour-tabs{
  display:flex; justify-content:center; gap:10px; margin-bottom:48px; padding:0 24px;
  flex-wrap:wrap;
}
.tour-tab{
  background:transparent; border:1.5px solid rgba(11,43,54,0.18); color:var(--ink-soft);
  padding:12px 26px; border-radius:100px; font-weight:600; font-size:0.92rem;
  transition:all .3s var(--ease);
}
.tour-tab.is-active{
  background:var(--navy); color:var(--sand); border-color:var(--navy);
  box-shadow:0 10px 24px -10px rgba(4,34,47,0.4);
}
.tour-panel{ display:none; }
.tour-panel.is-active{ display:block; }

.card-grid{
  max-width:var(--container); margin:0 auto; padding:0 24px;
  display:grid; grid-template-columns:1fr; gap:28px;
}
@media (min-width:640px){ .card-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1080px){ .card-grid{ grid-template-columns:repeat(3,1fr); } }

.tour-card{
  background:#fff; border-radius:var(--radius-md); overflow:hidden;
  box-shadow:var(--shadow-card); transition:transform .4s var(--ease), box-shadow .4s var(--ease);
  display:flex; flex-direction:column;
}
.tour-card:hover{ transform:translateY(-8px); box-shadow:0 28px 50px -20px rgba(4,34,47,0.35); }
.tour-card__media{
  height:200px; position:relative; overflow:hidden;
  transition:transform .6s var(--ease);
}
.tour-card:hover .tour-card__media{ transform:scale(1.04); }
.tour-card__media::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(4,34,47,0) 50%, rgba(4,34,47,0.35) 100%);
}
.tour-card__tag{
  position:absolute; top:14px; left:14px; z-index:2;
  background:var(--amber); color:var(--navy); font-size:0.72rem; font-weight:700;
  padding:6px 14px; border-radius:100px; letter-spacing:0.04em;
}
.tour-card__tag--seasonal{ background:var(--turquoise); color:#fff; }

/* gradient "photography" placeholders, each evoking its scene */
.tour-card__media--reef{ background:linear-gradient(135deg,#1FB6C9 0%,#0E5C73 55%,#073B4A 100%); }
.tour-card__media--scuba{ background:linear-gradient(135deg,#0A4A5E 0%,#073B4A 60%,#041F28 100%); }
.tour-card__media--angel{ background:linear-gradient(135deg,#3FCDD6 0%,#1A8C9C 60%,#0A4A5E 100%); }
.tour-card__media--navy{ background:linear-gradient(135deg,#2E7D8F 0%,#10495B 60%,#062430 100%); }
.tour-card__media--whale{ background:linear-gradient(135deg,#16475A 0%,#0A2E3D 70%,#041820 100%); }
.tour-card__media--lagoon{ background:linear-gradient(135deg,#5BC8A6 0%,#1F8C8C 55%,#0E5C73 100%); }
.tour-card__media--fishing{ background:linear-gradient(135deg,#E8965B 0%,#B95F6E 55%,#0E5C73 100%); }
.tour-card__media--cooking{ background:linear-gradient(135deg,#F2A33D 0%,#D87F1E 55%,#8C4E18 100%); }
.tour-card__media--rice{ background:linear-gradient(135deg,#F2C879 0%,#E8965B 55%,#A85440 100%); }
.tour-card__media--seafood{ background:linear-gradient(135deg,#E8965B 0%,#0E5C73 70%,#073B4A 100%); }
.tour-card__media--city{ background:linear-gradient(135deg,#6F7FA3 0%,#3D5066 55%,#1A2A38 100%); }
.tour-card__media--croc{ background:linear-gradient(135deg,#6B8E5A 0%,#3E5C38 55%,#1E2E1A 100%); }
.tour-card__media--village{ background:linear-gradient(135deg,#D9A857 0%,#A8723D 55%,#5C3A1E 100%); }

.tour-card__body{ padding:24px 24px 22px; display:flex; flex-direction:column; gap:10px; flex:1; }
.tour-card__body h3{ font-family:var(--font-display); font-size:1.18rem; color:var(--navy); margin:0; line-height:1.3; }
.tour-card__body p{ font-size:0.92rem; color:var(--ink-soft); line-height:1.55; margin:0; flex:1; }
.tour-card__foot{ display:flex; align-items:center; justify-content:space-between; margin-top:8px; }
.tour-card__meta{ font-size:0.8rem; color:var(--teal); font-weight:600; }
.tour-card__btn{
  background:var(--foam); color:var(--teal); font-weight:700; font-size:0.82rem;
  padding:9px 18px; border-radius:100px; transition:all .3s var(--ease);
}
.tour-card__btn:hover{ background:var(--turquoise); color:#fff; }

/* ===================================================================
   SAFARI
=================================================================== */
.safari{ position:relative; padding:120px 24px; overflow:hidden; }
.safari__bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 80% 20%, rgba(242,163,61,0.18), transparent 60%),
    linear-gradient(160deg, #04222F 0%, #0A2E3D 55%, #0E5C73 100%);
}
.safari .section-head{ position:relative; z-index:1; }
.safari-grid{
  position:relative; z-index:1; max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns:1fr; gap:20px;
}
@media (min-width:640px){ .safari-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .safari-grid{ grid-template-columns:repeat(3,1fr); } }
.safari-card{
  background:rgba(251,247,238,0.06); border:1px solid rgba(251,247,238,0.12);
  border-radius:var(--radius-md); padding:30px 26px; backdrop-filter:blur(6px);
  transition:transform .4s var(--ease), background .4s var(--ease), border-color .4s var(--ease);
}
.safari-card:hover{
  transform:translateY(-6px); background:rgba(251,247,238,0.1); border-color:rgba(242,163,61,0.4);
}
.safari-card h3{ font-family:var(--font-display); color:var(--sand); font-size:1.12rem; margin:0 0 10px; }
.safari-card p{ color:rgba(232,251,250,0.72); font-size:0.92rem; line-height:1.6; margin:0; }

/* ===================================================================
   WHY US
=================================================================== */
.why{ padding:120px 24px; background:var(--sand); }
.why-grid{
  max-width:var(--container); margin:0 auto; display:grid; grid-template-columns:1fr; gap:24px;
}
@media (min-width:640px){ .why-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1080px){ .why-grid{ grid-template-columns:repeat(4,1fr); } }
.why-card{
  background:#fff; border-radius:var(--radius-md); padding:34px 26px;
  box-shadow:var(--shadow-card); transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.why-card:hover{ transform:translateY(-6px); box-shadow:0 24px 44px -18px rgba(4,34,47,0.3); }
.why-icon{ width:42px; height:42px; color:var(--turquoise); margin-bottom:18px; }
.why-card h3{ font-family:var(--font-display); font-size:1.05rem; color:var(--navy); margin:0 0 8px; }
.why-card p{ font-size:0.9rem; color:var(--ink-soft); line-height:1.55; margin:0; }

/* ===================================================================
   REVIEWS
=================================================================== */
.reviews{ padding:120px 24px; background:linear-gradient(180deg,var(--sand),var(--foam)); }
.reviews__slider{ max-width:880px; margin:0 auto; position:relative; overflow:hidden; }
.reviews__track{ display:flex; transition:transform .6s var(--ease); }
.review-card{
  flex:0 0 100%; background:#fff; border-radius:var(--radius-lg);
  padding:46px 40px; text-align:center; box-shadow:var(--shadow-soft);
  margin:0 6px;
}
.review-card__stars{ color:var(--amber); font-size:1.3rem; letter-spacing:3px; margin-bottom:18px; }
.review-card p{ font-family:var(--font-display); font-style:italic; font-size:1.25rem; line-height:1.55; color:var(--navy); margin:0 0 26px; }
.review-card__who{ display:flex; align-items:center; justify-content:center; gap:12px; }
.review-card__avatar{
  width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--turquoise),var(--teal));
  color:#fff; font-weight:700; font-size:0.85rem; display:flex; align-items:center; justify-content:center;
}
.review-card__who strong{ display:block; font-size:0.92rem; color:var(--navy); }
.review-card__who small{ color:var(--ink-soft); font-size:0.8rem; }
.reviews__dots{ display:flex; justify-content:center; gap:9px; margin-top:30px; }
.reviews__dots button{
  width:9px; height:9px; border-radius:50%; border:none; background:rgba(14,92,115,0.25);
  transition:background .3s, transform .3s;
}
.reviews__dots button.is-active{ background:var(--teal); transform:scale(1.3); }

/* ===================================================================
   GALLERY
=================================================================== */
.gallery{ padding:120px 24px 130px; background:var(--sand); }
.masonry{
  max-width:var(--container); margin:0 auto; display:grid;
  grid-template-columns:repeat(2,1fr); gap:16px;
}
@media (min-width:760px){ .masonry{ grid-template-columns:repeat(4,1fr); } }
.masonry__item{
  margin:0; border-radius:var(--radius-md); overflow:hidden; position:relative;
  cursor:pointer; min-height:200px; display:flex; align-items:flex-end;
  transition:transform .4s var(--ease);
}
.masonry__item:hover{ transform:scale(0.97); }
.masonry__item::after{
  content:''; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%, rgba(4,34,47,0.65) 100%);
}
.masonry__label{
  position:relative; z-index:1; color:#fff; font-weight:700; font-size:0.92rem;
  padding:18px; letter-spacing:0.02em;
}
.masonry__item:nth-child(odd){ grid-row:span 2; }
@media (max-width:759px){ .masonry__item:nth-child(odd){ grid-row:auto; min-height:240px;} .masonry__item:nth-child(even){ min-height:160px; } }

.m-coral{ background:linear-gradient(155deg,#FF8C61,#1FB6C9 60%,#0E5C73); }
.m-fish{ background:linear-gradient(155deg,#F2A33D,#1FB6C9 65%,#073B4A); }
.m-turtle{ background:linear-gradient(155deg,#6FE0E8,#0E5C73 70%,#04222F); }
.m-beach{ background:linear-gradient(155deg,#FBF7EE,#F2C879 50%,#1FB6C9); }
.m-island{ background:linear-gradient(155deg,#1FB6C9,#0A4258 60%,#04222F); }
.m-whale{ background:linear-gradient(155deg,#16475A,#04222F 70%,#000); }
.m-safari{ background:linear-gradient(155deg,#D9A857,#6B8E5A 60%,#2E3E1E); }
.m-village{ background:linear-gradient(155deg,#E8965B,#A8723D 60%,#5C3A1E); }

.lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(4,34,47,0.94);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .35s var(--ease);
  padding:40px 24px;
}
.lightbox.is-open{ opacity:1; visibility:visible; }
.lightbox__frame{
  width:min(640px,90vw); height:min(420px,55vh); border-radius:var(--radius-md);
  background:linear-gradient(155deg,#1FB6C9,#04222F);
}
.lightbox__caption{ color:var(--sand); margin-top:20px; font-size:0.95rem; }
.lightbox__close{
  position:absolute; top:26px; right:30px; background:none; border:none; color:var(--sand);
  font-size:2.2rem; line-height:1; cursor:pointer;
}

/* ===================================================================
   CONTACT
=================================================================== */
.contact{ position:relative; padding:120px 24px 110px; overflow:hidden; }
.contact__bg{
  position:absolute; inset:0; z-index:0;
  background:linear-gradient(170deg,#04222F 0%, #0A2E3D 50%, #0E5C73 100%);
}
.contact .section-head{ position:relative; z-index:1; }
.contact__grid{
  position:relative; z-index:1; max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns:1fr; gap:40px;
}
@media (min-width:960px){ .contact__grid{ grid-template-columns:1fr 1fr; gap:60px; } }

.contact__info{ display:flex; flex-direction:column; gap:18px; }
.contact__whatsapp{
  display:flex; align-items:center; gap:16px; background:linear-gradient(135deg,#25D366,#1FAA52);
  color:#fff; padding:20px 24px; border-radius:var(--radius-md); transition:transform .3s var(--ease);
}
.contact__whatsapp:hover{ transform:translateY(-4px); }
.contact__whatsapp strong{ display:block; font-size:1rem; }
.contact__whatsapp span{ font-size:0.86rem; opacity:0.9; }
.contact__row{
  display:flex; align-items:center; gap:16px; color:var(--sand);
  background:rgba(251,247,238,0.06); border:1px solid rgba(251,247,238,0.12);
  padding:18px 22px; border-radius:var(--radius-md);
}
.contact__icon{ width:22px; height:22px; color:var(--turquoise-l); flex-shrink:0; }
.contact__row strong{ display:block; font-size:0.92rem; }
.contact__row span{ font-size:0.86rem; color:rgba(232,251,250,0.72); }
.contact__map{
  border-radius:var(--radius-md); overflow:hidden; margin-top:8px; height:260px;
  border:1px solid rgba(251,247,238,0.12);
}
.contact__map iframe{ width:100%; height:100%; border:0; filter:grayscale(0.1) contrast(1.05); }

.contact__form{
  background:var(--sand); border-radius:var(--radius-lg); padding:38px 32px;
  box-shadow:var(--shadow-soft);
}
.contact__form h3{ font-family:var(--font-display); color:var(--navy); font-size:1.4rem; margin:0 0 22px; }
.contact__field{ margin-bottom:18px; }
.contact__field-row{ display:grid; grid-template-columns:1fr; gap:18px; margin-bottom:0;}
@media (min-width:520px){ .contact__field-row{ grid-template-columns:1fr 1fr; } }
.contact__field-row .contact__field{ margin-bottom:18px; }
.contact__field label{ display:block; font-size:0.82rem; font-weight:600; color:var(--teal); margin-bottom:7px; }
.contact__field input, .contact__field select, .contact__field textarea{
  width:100%; padding:13px 16px; border-radius:var(--radius-sm); border:1.5px solid rgba(11,43,54,0.15);
  background:#fff; font-size:0.95rem; color:var(--ink); transition:border-color .25s;
  resize:vertical;
}
.contact__field input:focus, .contact__field select:focus, .contact__field textarea:focus{
  border-color:var(--turquoise); outline:none;
}
.contact__submit{ width:100%; justify-content:center; margin-top:6px; }
.contact__success{
  display:none; margin:14px 0 0; color:var(--teal); font-weight:600; font-size:0.9rem; text-align:center;
}
.contact__success.is-shown{ display:block; }

/* ===================================================================
   FOOTER
=================================================================== */
.footer{ background:#031A24; padding:80px 24px 0; }
.footer__inner{
  max-width:var(--container); margin:0 auto; display:grid; grid-template-columns:1fr; gap:40px;
  padding-bottom:50px; border-bottom:1px solid rgba(251,247,238,0.08);
}
@media (min-width:760px){ .footer__inner{ grid-template-columns:1.4fr 1fr 1fr 1fr; } }
.footer__logo{ height:54px; width:auto; margin-bottom:16px; filter:brightness(1.15); }
.footer__brand p{ color:rgba(232,251,250,0.65); font-size:0.9rem; line-height:1.6; margin:0 0 18px; }
.footer__social{ display:flex; gap:12px; }
.footer__social a{
  width:38px; height:38px; border-radius:50%; background:rgba(251,247,238,0.08);
  display:flex; align-items:center; justify-content:center; transition:background .3s;
}
.footer__social a:hover{ background:var(--turquoise); }
.footer__social svg{ width:17px; height:17px; fill:var(--sand); stroke:var(--sand); }
.footer__col h4{ color:var(--sand); font-size:0.85rem; letter-spacing:0.1em; text-transform:uppercase; margin:0 0 18px; }
.footer__col a{ display:block; color:rgba(232,251,250,0.62); font-size:0.92rem; padding:6px 0; transition:color .25s; }
.footer__col a:hover{ color:var(--turquoise-l); }
.footer__bottom{ max-width:var(--container); margin:0 auto; padding:26px 0; text-align:center; }
.footer__bottom p{ color:rgba(232,251,250,0.45); font-size:0.82rem; margin:0; }

/* ===================================================================
   FLOATING WHATSAPP FAB
=================================================================== */
.fab-wa{
  position:fixed; bottom:24px; right:24px; z-index:90;
  width:58px; height:58px; border-radius:50%;
  background:linear-gradient(135deg,#25D366,#1FAA52);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 14px 30px -8px rgba(37,211,102,0.55);
  animation:fabPulse 2.6s ease-in-out infinite;
}
@media (max-width:600px){
  .fab-wa{ width:50px; height:50px; bottom:16px; right:16px; }
  .fab-wa svg{ width:24px; height:24px; }
}
.fab-wa svg{ width:28px; height:28px; fill:#fff; }
@keyframes fabPulse{
  0%,100%{ box-shadow:0 14px 30px -8px rgba(37,211,102,0.55); }
  50%{ box-shadow:0 14px 30px -8px rgba(37,211,102,0.85), 0 0 0 8px rgba(37,211,102,0.12); }
}
