/* ============================================
   AVALON ESCAPES — DESIGN TOKENS
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&display=swap');

:root{
  --navy: #0f2649;
  --navy-deep: #0a1c38;
  --blue: #265196;
  --green: #213a3e;
  --ivory: #faf8f3;
  --white: #ffffff;
  --line: rgba(255,255,255,0.18);
  --line-dark: rgba(15,38,73,0.12);
  --ink: #1c2a3a;

  --display: 'Cormorant Garamond', Georgia, serif; /* stands in for Amore Christmas */
  --body: 'Montserrat', sans-serif;

  --maxw: 1200px;
  --section-pad: clamp(48px, 7vw, 96px);
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior: smooth; }
body{
  font-family: var(--body);
  color: var(--ink);
  background: var(--ivory);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a{ color:inherit; text-decoration:none; }
button{ font-family: inherit; border:none; background:none; cursor:pointer; }
img{ max-width:100%; display:block; }
:focus-visible{ outline: 2px solid var(--blue); outline-offset: 3px; }

.eyebrow{
  font-family: var(--body);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--blue);
}
.eyebrow.on-dark{ color: #9fb8e0; }

h1,h2,h3{ font-family: var(--display); font-weight: 500; line-height: 1.08; }

.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family: var(--body);
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 16px 30px;
  border-radius: 2px;
  transition: all .25s ease;
  white-space: nowrap;
}
.btn-filled{ background: var(--white); color: var(--navy); }
.btn-filled:hover{ background: var(--blue); color: var(--white); }
.btn-ghost{ border: 1px solid var(--line); color: var(--white); }
.btn-ghost:hover{ background: rgba(255,255,255,0.1); }
.btn-dark{ background: var(--navy); color: var(--white); }
.btn-dark:hover{ background: var(--blue); }
.btn-outline-dark{ border: 1px solid var(--line-dark); color: var(--navy); }
.btn-outline-dark:hover{ background: var(--navy); color: var(--white); border-color: var(--navy); }

/* ============================================
   NAV
   ============================================ */
.nav{
  position: fixed; top:0; left:0; right:0; z-index: 100;
  display:flex; flex-direction:column;
  transition: background .3s ease, box-shadow .3s ease;
}
.nav.scrolled{ background: rgba(15,38,73,0.96); box-shadow: 0 2px 24px rgba(0,0,0,0.15); backdrop-filter: blur(6px); }
.nav-inner{
  max-width: var(--maxw); width:100%; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding: 22px 28px;
}
.nav-mark{ display:flex; align-items:center; gap:10px; color:var(--white); cursor:pointer; }
.nav-butterfly{ width:26px; height:26px; object-fit:contain; }
.nav-word{ font-family: var(--display); font-size: 22px; letter-spacing: 0.04em; transition: opacity .2s ease; }
.nav-mark:hover .nav-word{ opacity: 0.75; }
.nav-links{ display:flex; gap:36px; }
.nav-links a{
  color: var(--white); font-size: 12.5px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
  position:relative; padding-bottom:4px;
}
.nav-links a::after{
  content:''; position:absolute; left:0; right:100%; bottom:0; height:1px; background:var(--white);
  transition: right .25s ease;
}
.nav-links a:hover::after{ right:0; }
.nav-toggle{ display:none; flex-direction:column; gap:5px; width:26px; }
.nav-toggle span{ width:100%; height:1.5px; background:var(--white); transition: all .25s ease; }
.nav-mobile{ display:none; flex-direction:column; background:var(--navy-deep); padding: 0 28px; overflow:hidden; max-height:0; transition: max-height .3s ease; }
.nav-mobile a{ color:var(--white); padding:16px 0; border-bottom:1px solid var(--line); font-size:13px; letter-spacing:0.08em; text-transform:uppercase; font-weight:600; }
.nav-mobile.open{ max-height: 320px; }

@media (max-width: 860px){
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .nav-mobile{ display:flex; }
}

/* ============================================
   HERO + SIGNATURE COMPASS
   ============================================ */
.hero{
  position:relative;
  min-height: 100vh;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(165deg, var(--navy-deep) 0%, var(--navy) 45%, var(--green) 100%);
  overflow:hidden;
  color: var(--white);
}
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg-layer{
  position:absolute; inset:0;
  overflow:hidden;
  opacity:0;
  transition: opacity 1.5s ease-in-out;
}
.hero-bg-layer.active{ opacity:1; }
.hero-bg-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
}
.hero-bg::after{
  content:''; position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, rgba(8,20,40,0.12) 0%, rgba(10,24,46,0.02) 35%, rgba(10,24,46,0.1) 75%, rgba(8,20,40,0.3) 100%);
}
@media (prefers-reduced-motion: reduce){
  .hero-bg-layer{ transition:none; }
  .hero-bg-layer:first-child{ opacity:1; }
  .hero-bg-video{ display:none; }
}
.hero-waves{
  position:absolute; bottom:0; left:0; width:100%; height:38%;
  opacity:0.5;
}
.hero-waves svg{ width:100%; height:100%; }

.hero-content{
  position:relative; z-index:2; text-align:center; max-width:780px; padding: 0 24px;
}
.hero-mark{
  width:54px; height:54px; margin:0 auto 28px; object-fit:contain; display:block;
  opacity:0; animation: fadeUp .9s ease forwards; animation-delay: .1s;
}
.hero-title{
  font-size: clamp(48px, 9vw, 96px);
  letter-spacing: 0.01em;
  text-shadow: 0 2px 8px rgba(0,0,0,0.4), 0 8px 40px rgba(0,0,0,0.45);
  opacity:0; animation: fadeUp .9s ease forwards; animation-delay: .3s;
}
.hero-sub{
  font-family: var(--body); font-weight:300; font-size: clamp(15px,2vw,18px);
  letter-spacing:0.03em; line-height:1.7; color: #ffffff; margin: 22px auto 40px; max-width:520px;
  text-shadow: 0 1px 4px rgba(0,0,0,0.5), 0 4px 20px rgba(0,0,0,0.5);
  opacity:0; animation: fadeUp .9s ease forwards; animation-delay: .5s;
}
.hero-ctas{ display:flex; gap:18px; justify-content:center; flex-wrap:wrap;
  opacity:0; animation: fadeUp .9s ease forwards; animation-delay: .7s;
}
@keyframes fadeUp{ from{ opacity:0; transform: translateY(16px); } to{ opacity:1; transform:translateY(0); } }

.scroll-cue{
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px; color: rgba(255,255,255,0.65);
}
.scroll-cue .line{ width:1px; height:34px; background: rgba(255,255,255,0.4); position:relative; overflow:hidden; }
.scroll-cue .line::after{ content:''; position:absolute; top:0; left:0; width:100%; height:40%; background:var(--white); animation: drip 2s ease-in-out infinite; }
@keyframes drip{ 0%{ top:-40%; } 100%{ top:100%; } }
.scroll-cue span{ font-size:10px; letter-spacing:0.2em; text-transform:uppercase; }

@media (max-width: 600px){
  .hero-ctas{ flex-direction:column; width:100%; }
  .hero-ctas .btn{ justify-content:center; width:100%; }
}

/* hero background now uses real photography (see hero-bg-layer), gradient scenes removed */

/* ============================================
   SECTION SCAFFOLDING
   ============================================ */
.section{ padding: var(--section-pad) 28px; }
.section-inner{ max-width: var(--maxw); margin: 0 auto; }
.section-dark{ background: var(--navy); color: var(--white); }
.section-green{ background: var(--green); color: var(--white); }
.section-ivory{ background: var(--ivory); color: var(--ink); }
.section-white{ background: var(--white); color: var(--ink); }

.reveal{ opacity:0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ============================================
   THE AVALON APPROACH — editorial accordion
   ============================================ */
.approach-section{ position:relative; }
.approach-editorial{ display:grid; grid-template-columns: 0.95fr 1.05fr; gap:70px; align-items:center; }
.approach-photo{ aspect-ratio: 4/5; overflow:hidden; border-radius:2px; }
.approach-photo img{ width:100%; height:100%; object-fit:cover; transition: opacity .25s ease; }
.approach-content .eyebrow{ display:block; margin-bottom:16px; }
.approach-content h2{ font-size: clamp(32px, 4.2vw, 48px); color:var(--navy); margin-bottom:40px; }

.approach-accordion{ display:flex; flex-direction:column; }
.approach-item{ border-top:1px solid var(--line-dark); }
.approach-item:last-child{ border-bottom:1px solid var(--line-dark); }
.approach-item-head{
  width:100%; display:flex; align-items:center; gap:20px;
  padding:24px 0; text-align:left; cursor:pointer;
}
.approach-item-num{
  font-family: var(--display); font-size:18px; color: rgba(38,81,150,0.45);
  flex:none; width:28px; transition: color .3s ease;
}
.approach-item.open .approach-item-num{ color: var(--blue); }
.approach-item-title{
  flex:1; font-family: var(--display); font-size: clamp(18px,2.2vw,21px);
  color:var(--navy); font-weight:500; transition: color .3s ease;
}
.approach-item-icon{
  flex:none; width:26px; height:26px; border-radius:50%; border:1px solid var(--line-dark);
  display:flex; align-items:center; justify-content:center;
  font-size:15px; color:var(--blue); font-weight:300;
  transition: transform .3s ease, background .3s ease, color .3s ease;
}
.approach-item.open .approach-item-icon{ transform: rotate(45deg); background:var(--blue); color:var(--white); border-color:var(--blue); }
.approach-item-body{
  max-height:0; overflow:hidden; transition: max-height .35s ease;
}
.approach-item.open .approach-item-body{ max-height:200px; }
.approach-item-body p{
  padding: 0 0 26px 48px; font-size:14.5px; line-height:1.8; color:#5a6580; font-weight:300; max-width:440px;
}
@media (max-width: 900px){
  .approach-editorial{ grid-template-columns:1fr; gap:36px; }
  .approach-photo{ aspect-ratio: 16/10; }
}

/* ============================================
   TRIPS RAIL (horizontal scroll)
   ============================================ */
.trips-rail-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:40px; flex-wrap:wrap; }
.trips-rail-head h2{ font-size: clamp(28px,4vw,40px); margin-top:10px; color:var(--navy); }
.rail-nav{ display:flex; gap:10px; }
.rail-btn{
  width:42px; height:42px; border-radius:50%; border:1px solid var(--line-dark);
  display:flex; align-items:center; justify-content:center; transition: all .2s ease; color:var(--navy);
}
.rail-btn:hover{ background:var(--navy); color:var(--white); border-color:var(--navy); }

.trips-rail{
  display:flex; gap:24px; overflow-x:auto; padding-bottom:18px; scroll-snap-type:x mandatory;
  scrollbar-width:none;
}
.trips-rail::-webkit-scrollbar{ display:none; }
.trip-card{
  flex: 0 0 320px; scroll-snap-align:start;
  background:var(--white); border:1px solid var(--line-dark);
  display:flex; flex-direction:column; cursor:pointer;
  transition: transform .3s ease, box-shadow .3s ease;
}
.trip-card:hover{ transform: translateY(-6px); box-shadow: 0 22px 40px rgba(15,38,73,0.12); }
.trip-card-img{
  height:230px; position:relative; overflow:hidden;
  display:flex; align-items:flex-end; padding:18px;
  background-size: cover; background-position: center;
}
.trip-card-img::after{ content:''; position:absolute; inset:0; background: linear-gradient(180deg, transparent 40%, rgba(10,20,40,0.55) 100%); }
.trip-card-tag{
  position:relative; z-index:1; color:var(--white); font-size:11px; letter-spacing:0.12em; text-transform:uppercase;
  font-weight:600; border:1px solid rgba(255,255,255,0.5); padding:6px 12px; border-radius:20px;
}
.trip-card-body{ padding:22px 22px 26px; flex:1; display:flex; flex-direction:column; }
.trip-card-dest{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--blue); font-weight:600; margin-bottom:8px; }
.trip-card-name{ font-family:var(--display); font-size:24px; color:var(--navy); margin-bottom:10px; }
.trip-card-vibe{ font-size:13.5px; color:#5a6580; line-height:1.6; font-weight:300; flex:1; }
.trip-card-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:18px; padding-top:16px; border-top:1px solid var(--line-dark); }
.trip-card-dur{ font-size:12px; color:#7a8399; }
.trip-card-cta{ font-size:11.5px; letter-spacing:0.08em; text-transform:uppercase; font-weight:700; color:var(--navy); display:flex; align-items:center; gap:6px; }
.trip-card-cta svg{ width:12px; height:12px; transition: transform .2s ease; }
.trip-card:hover .trip-card-cta svg{ transform: translateX(4px); }

/* ============================================
   WHY AVALON — photo cards
   ============================================ */
.why-section{ overflow:hidden; }
.why-head{ text-align:center; max-width:620px; margin:0 auto 40px; }
.why-head .eyebrow{ display:block; margin-bottom:14px; }
.why-head h2{ font-size: clamp(30px,4vw,42px); margin-bottom:20px; color:var(--navy); }
.why-head p{ font-size:15px; line-height:1.8; color:#46506b; font-weight:300; }

.why-grid-photo{ display:grid; grid-template-columns: repeat(4, 1fr); gap:18px; }
.why-card{
  position:relative; aspect-ratio: 3/4.2; border-radius:2px; overflow:hidden;
  background-size:cover; background-position:center;
  display:flex; align-items:flex-end;
}
.why-card-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(10,28,56,0.05) 0%, rgba(10,28,56,0.55) 55%, rgba(8,20,40,0.92) 100%);
  transition: background .4s ease;
}
.why-card:hover .why-card-overlay{
  background: linear-gradient(180deg, rgba(10,28,56,0.3) 0%, rgba(10,28,56,0.75) 45%, rgba(8,20,40,0.95) 100%);
}
.why-card-content{
  position:relative; z-index:1; padding:26px 22px; color:var(--white);
}
.why-card-content h3{
  font-family: var(--display); font-size:21px; font-weight:500; margin-bottom:10px;
}
.why-card-content p{
  font-size:13px; line-height:1.65; color:#d7dfee; font-weight:300;
  max-height:0; opacity:0; overflow:hidden;
  transition: max-height .4s ease, opacity .35s ease;
}
.why-card:hover .why-card-content p{ max-height:140px; opacity:1; }

@media (max-width: 900px){
  .why-grid-photo{ grid-template-columns: repeat(2, 1fr); }
  .why-card-content p{ max-height:140px; opacity:1; }
}

/* ============================================
   HOW IT WORKS — centered interactive route map
   ============================================ */
/* ============================================
   HOW IT WORKS — THE CHART TO AVALON
   ============================================ */
.how-it-works-section{
  position:relative;
  background:#ffffff;
  padding:clamp(56px,7vw,96px) clamp(16px,3vw,40px) clamp(56px,7vw,96px) !important;
  overflow:hidden;
}
.hiw-header{
  text-align:center; margin-bottom:clamp(24px,3vw,40px);
  background:var(--white);
  padding:clamp(32px,4vw,52px) 24px;
  margin-left:calc(-1 * clamp(16px,3vw,40px));
  margin-right:calc(-1 * clamp(16px,3vw,40px));
  margin-top:calc(-1 * clamp(56px,7vw,96px));
  margin-bottom:clamp(32px,4vw,52px);
}
.hiw-header h2{ font-size:clamp(26px,3.5vw,42px); color:var(--navy); margin-top:10px; }
.hiw-header .eyebrow{ color:var(--blue); }
.hiw-map-wrap{ max-width:1020px; margin:0 auto; }
.hiw-map-svg{ width:100%; height:auto; display:block; }

/* chart ink styles */
.hiw-g{ stroke:rgba(100,72,30,0.22); stroke-width:0.6; fill:none; }
.hiw-depth{ fill:none; stroke:rgba(100,72,30,0.15); stroke-width:0.7; }
.hiw-landmass{ fill:rgba(120,90,40,0.18); stroke:rgba(80,56,20,0.35); stroke-width:0.8; }
.hiw-sounding{
  font-family:'Montserrat',sans-serif; font-size:6.5px; font-style:italic;
  fill:rgba(80,56,20,0.3); text-anchor:middle;
}
.hiw-map-label{
  font-family:'Montserrat',sans-serif; font-size:7px; font-weight:600;
  letter-spacing:0.1em; fill:rgba(80,56,20,0.35);
}
.hiw-ocean-label{
  font-family:'Cormorant Garamond',serif; font-size:14px; font-style:italic;
  fill:rgba(80,56,20,0.2); letter-spacing:0.2em; text-anchor:middle;
}
.hiw-compass-text{
  font-family:'Cormorant Garamond',serif; font-weight:600;
  letter-spacing:0.1em; text-anchor:middle;
}
/* route — dark sepia ink dashes */
.hiw-route{
  fill:none; stroke:rgba(60,40,10,0.55); stroke-width:1.4;
  stroke-linecap:round; stroke-dasharray:6 9;
}
/* waypoints — sepia style */
.hiw-wp-pulse{
  fill:none; stroke:rgba(60,40,10,0.3); stroke-width:0.8;
  opacity:0; transform-origin:center; transform-box:fill-box;
}
.hiw-wp.hit .hiw-wp-pulse{ animation:hiwPulse 2.2s ease-out forwards; }
@keyframes hiwPulse{ 0%{opacity:0.7;transform:scale(0.5);} 100%{opacity:0;transform:scale(3.5);} }
.hiw-wp-ring{ fill:none; stroke:rgba(80,56,20,0.3); stroke-width:1.2; transition:stroke .5s ease; }
.hiw-wp-dot{ fill:#e8dbb8; stroke:rgba(80,56,20,0.5); stroke-width:1.5; transition:fill .5s ease,stroke .5s ease; }
.hiw-wp.hit .hiw-wp-ring{ stroke:rgba(60,40,10,0.8); }
.hiw-wp.hit .hiw-wp-dot{ fill:rgba(60,40,10,0.85); stroke:rgba(60,40,10,0.9); }
.hiw-wp-lbl{
  font-family:'Cormorant Garamond',serif; font-size:11px; font-style:italic;
  fill:rgba(80,56,20,0.4); text-anchor:middle; transition:fill .5s ease;
}
.hiw-wp.hit .hiw-wp-lbl{ fill:rgba(60,40,10,0.75); }
/* red X */
.hiw-x-line{ stroke:#8b1a1a; stroke-width:3.2; stroke-linecap:round; opacity:0; transition:opacity .7s ease; }
.hiw-x-line.hit{ opacity:1; }
.hiw-x-ring{ fill:none; stroke:rgba(139,26,26,0.3); stroke-width:1.2; opacity:0; transition:opacity .7s ease .1s; }
.hiw-x-ring.hit{ opacity:1; }
.hiw-x-pulse{ fill:none; stroke:rgba(139,26,26,0.35); stroke-width:1; opacity:0; transform-origin:center; transform-box:fill-box; }
.hiw-x-pulse.hit{ animation:hiwXPulse 2.8s ease-out .1s forwards; }
@keyframes hiwXPulse{ 0%{opacity:0.7;transform:scale(0.4);} 100%{opacity:0;transform:scale(3.2);} }
.hiw-avalon-name{
  font-family:'Cormorant Garamond',serif; font-size:26px; font-style:italic;
  fill:#3a2a10; text-anchor:middle; letter-spacing:0.1em;
  opacity:0; transition:opacity .9s ease .3s;
}
.hiw-avalon-name.hit{ opacity:1; }
.hiw-avalon-sub{
  font-family:'Montserrat',sans-serif; font-size:9px; font-weight:600;
  letter-spacing:0.18em; fill:rgba(80,56,20,0.55); text-anchor:middle;
  opacity:0; transition:opacity .9s ease .55s;
}
.hiw-avalon-sub.hit{ opacity:1; }
/* foreignObject fade */
.hiw-fo{ opacity:0; transition:opacity .7s ease; overflow:visible; }
.hiw-fo.hit{ opacity:1; }
/* cards — parchment style */
.hiw-card{
  background:rgba(245,238,210,0.97);
  border:1px solid rgba(80,56,20,0.22);
  border-radius:1px; padding:14px 17px;
  box-shadow:0 4px 18px rgba(60,40,10,0.18);
  box-sizing:border-box; width:100%;
}
.hiw-card-place{
  font-family:'Cormorant Garamond',serif; font-size:32px; font-style:italic; font-weight:400;
  color:rgba(100,72,30,0.45); display:block; margin-bottom:2px; line-height:1;
}
.hiw-card h4{
  font-family:'Cormorant Garamond',serif; font-size:17px; font-weight:600;
  color:#3a2a10; line-height:1.2; margin-bottom:6px;
}
.hiw-card p{
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:300;
  line-height:1.65; color:#5a4828; margin:0;
}
.hiw-def{
  background:rgba(245,235,205,0.97);
  border:1px solid rgba(139,26,26,0.25);
  border-radius:1px; padding:16px 18px;
  box-shadow:0 6px 24px rgba(60,40,10,0.2);
  box-sizing:border-box; width:100%;
}
.hiw-def-title{
  font-family:'Cormorant Garamond',serif; font-size:16px; font-style:italic; font-weight:600;
  color:#8b1a1a; display:block; margin-bottom:7px;
}
.hiw-def p{
  font-family:'Montserrat',sans-serif; font-size:11px; font-weight:300;
  line-height:1.72; color:#5a4828; margin:0;
}
@media(prefers-reduced-motion:reduce){
  .hiw-wp-pulse,.hiw-x-pulse{ animation:none !important; }
  .hiw-fo,.hiw-x-line,.hiw-x-ring,.hiw-avalon-name,.hiw-avalon-sub{ transition:none; opacity:1; }
  .hiw-wp-dot{ fill:rgba(60,40,10,0.85); }
}

/* ============================================
   NEWSLETTER BAND
   ============================================ */
.newsletter{ text-align:center; padding-top: clamp(60px,8vw,100px) !important; }
.newsletter h2{ font-size: clamp(26px,3.6vw,36px); margin: 14px 0 14px; }
.newsletter p{ font-size:14.5px; color:#aebbd6; font-weight:300; max-width:440px; margin:0 auto 32px; line-height:1.7; }
.newsletter-form{ display:flex; max-width:440px; margin:0 auto; border-bottom:1px solid var(--line); }
.newsletter-form input{
  flex:1; background:none; border:none; color:var(--white); font-family:var(--body); font-size:14px;
  padding:14px 4px; font-weight:300;
}
.newsletter-form input::placeholder{ color:#7c8aac; }
.newsletter-form button{ color:var(--white); font-size:12px; letter-spacing:0.1em; text-transform:uppercase; font-weight:600; padding:14px 6px; }

/* ============================================
   FINAL CTA — real video background
   ============================================ */
.final-cta{
  position:relative;
  background: linear-gradient(135deg, var(--green) 0%, var(--navy) 100%);
  text-align:center; color:var(--white);
  overflow:hidden;
}
.final-cta h2{ position:relative; z-index:2; font-size: clamp(32px,5vw,56px); margin-bottom:32px; text-shadow: 0 2px 8px rgba(0,0,0,0.4), 0 8px 36px rgba(0,0,0,0.45); }
.final-cta .section-inner{ position:relative; z-index:2; }
.cta-bg{ position:absolute; inset:0; overflow:hidden; z-index:0; }
.cta-bg-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
}
.cta-bg-grad{
  position:absolute; inset:0;
  background: linear-gradient(165deg, rgba(15,30,30,0.78), rgba(15,38,73,0.82) 60%, rgba(10,28,56,0.85));
}

/* ============================================
   PAGE HEADER (sub-pages)
   ============================================ */
.page-head{
  padding: calc(var(--section-pad) + 60px) 28px 60px;
  background: linear-gradient(165deg, var(--navy-deep), var(--navy));
  color:var(--white); text-align:center;
}
.page-head .eyebrow{ display:block; margin-bottom:16px; text-shadow: 0 1px 8px rgba(0,0,0,0.5); }
.page-head h1{ font-size: clamp(38px,6vw,64px); text-shadow: 0 2px 8px rgba(0,0,0,0.4), 0 8px 36px rgba(0,0,0,0.45); }
.page-head p{ font-size:15px; color:#ffffff; font-weight:300; max-width:520px; margin:18px auto 0; line-height:1.8; text-shadow: 0 1px 6px rgba(0,0,0,0.5); }

/* ============================================
   OUR TRIPS PAGE
   ============================================ */
.filters{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:46px; }
.filter-pill{
  font-size:12px; letter-spacing:0.04em; padding:10px 18px; border-radius:20px;
  border:1px solid var(--line-dark); color:#56607a; font-weight:500; transition: all .2s ease;
}
.filter-pill:hover{ border-color:var(--navy); color:var(--navy); }
.filter-pill.active{ background:var(--navy); color:var(--white); border-color:var(--navy); }

.trips-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:28px; }
.trips-grid .trip-card{ flex: none; }
@media (max-width: 980px){ .trips-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){ .trips-grid{ grid-template-columns: 1fr; } }

/* ============================================
   TRIP DETAIL
   ============================================ */
.trip-hero{
  position:relative; min-height:52vh; display:flex; align-items:flex-end;
  background: linear-gradient(165deg, var(--navy-deep), var(--blue) 70%, var(--green));
  color:var(--white); padding: 100px 28px 48px;
}
.trip-hero-inner{ max-width:var(--maxw); margin:0 auto; width:100%; }
.trip-hero .eyebrow{ display:block; margin-bottom:14px; }
.trip-hero h1{ font-size: clamp(36px,6vw,64px); margin-bottom:18px; }
.trip-hero-meta{ display:flex; gap:28px; flex-wrap:wrap; margin-top:24px; }
.trip-hero-meta div{ font-size:12px; color:#cdd6ea; }
.trip-hero-meta strong{ display:block; font-size:14px; color:var(--white); font-weight:600; margin-bottom:4px; }

.quickfacts{ background:var(--white); border-bottom:1px solid var(--line-dark); }
.quickfacts-grid{ display:grid; grid-template-columns: repeat(5,1fr); }
.qf{ padding:30px 20px; text-align:center; border-right:1px solid var(--line-dark); }
.qf:last-child{ border-right:none; }
.qf-label{ font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:#9aa3b8; margin-bottom:8px; }
.qf-value{ font-size:14.5px; font-weight:600; color:var(--navy); }
@media (max-width: 760px){ .quickfacts-grid{ grid-template-columns: repeat(2,1fr); } .qf{ border-bottom:1px solid var(--line-dark); } }

.gallery{ display:grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: auto auto; gap:14px; }
.gallery-tile{ border-radius:2px; min-height:180px; position:relative; overflow:hidden; }
.gallery-tile:nth-child(1){ grid-row: span 2; min-height:380px; }
@media (max-width: 760px){ .gallery{ grid-template-columns:1fr 1fr; } .gallery-tile:nth-child(1){ grid-column:span 2; min-height:240px; } }

.two-col{ display:grid; grid-template-columns: 1.2fr 0.8fr; gap:70px; }
@media (max-width: 900px){ .two-col{ grid-template-columns:1fr; gap:50px; } }
.detail-block h2{ font-size: clamp(26px,3.4vw,34px); color:var(--navy); margin-bottom:20px; }
.detail-block p{ font-size:15px; line-height:1.85; color:#46506b; font-weight:300; margin-bottom:16px; }

.highlight-list{ display:grid; grid-template-columns: 1fr 1fr; gap:16px; margin-top:8px; }
.highlight-item{ display:flex; gap:12px; align-items:flex-start; font-size:14px; color:#3a4459; font-weight:400; }
.highlight-item svg{ width:18px; height:18px; flex:none; color:var(--blue); margin-top:2px; }
@media (max-width: 560px){ .highlight-list{ grid-template-columns:1fr; } }

.itinerary-day{ border-left:2px solid var(--line-dark); padding:0 0 28px 26px; position:relative; }
.itinerary-day::before{ content:''; position:absolute; left:-5px; top:4px; width:8px; height:8px; border-radius:50%; background:var(--blue); }
.itinerary-day:last-child{ padding-bottom:0; }
.itinerary-day .day-label{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--blue); font-weight:700; margin-bottom:6px; }
.itinerary-day h4{ font-family:var(--display); font-size:19px; color:var(--navy); margin-bottom:8px; font-weight:600;}
.itinerary-day p{ font-size:14px; line-height:1.7; color:#56607a; font-weight:300; }

.sidebar-card{ background:var(--ivory); border:1px solid var(--line-dark); padding:34px; position:sticky; top:110px; }
.sidebar-card h3{ font-family:var(--display); font-size:22px; color:var(--navy); margin-bottom:10px; }
.sidebar-card p{ font-size:13.5px; color:#5a6580; font-weight:300; line-height:1.7; margin-bottom:24px; }
.sidebar-card .btn{ width:100%; justify-content:center; margin-bottom:12px; }
.sidebar-contact{ margin-top:24px; padding-top:24px; border-top:1px solid var(--line-dark); font-size:13px; color:#5a6580; }
.sidebar-contact a{ color:var(--navy); font-weight:600; }

.inex-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; }
.inex-grid h4{ font-size:13px; letter-spacing:0.08em; text-transform:uppercase; color:var(--navy); margin-bottom:16px; font-weight:700; }
.inex-grid ul{ list-style:none; display:flex; flex-direction:column; gap:12px; }
.inex-grid li{ font-size:14px; color:#46506b; font-weight:300; padding-left:22px; position:relative; }
.inex-grid li::before{ content:'—'; position:absolute; left:0; color:#9aa3b8; }
@media (max-width: 640px){ .inex-grid{ grid-template-columns:1fr; gap:30px; } }

.faq-item{ border-bottom:1px solid var(--line-dark); }
.faq-q{ width:100%; text-align:left; padding:22px 0; display:flex; justify-content:space-between; align-items:center; font-size:15px; font-weight:500; color:var(--navy); }
.faq-q svg{ width:14px; height:14px; transition: transform .25s ease; flex:none; color:var(--blue); }
.faq-item.open .faq-q svg{ transform: rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition: max-height .3s ease; }
.faq-item.open .faq-a{ max-height:200px; }
.faq-a p{ padding-bottom:22px; font-size:14px; line-height:1.75; color:#56607a; font-weight:300; }

.sustain-band{ background: var(--green); color:var(--white); }
.sustain-grid{ display:grid; grid-template-columns: 0.9fr 1.1fr; gap:60px; align-items:start; }
.sustain-grid .eyebrow{ display:block; margin-bottom:16px; }
.sustain-grid h2{ font-size: clamp(28px,3.8vw,40px); margin-bottom:20px; }
.sustain-grid > div:first-child p{ font-size:15px; line-height:1.85; color:#c3d6d6; font-weight:300; }
.commit-list{ display:flex; flex-direction:column; gap:0; }
.commit-item{ display:flex; gap:18px; padding:22px 0; border-bottom:1px solid rgba(255,255,255,0.15); }
.commit-item:last-child{ border-bottom:none; }
.commit-num{ font-family:var(--display); font-size:26px; color:#9fc4c4; flex:none; width:36px; }
.commit-item h3{ font-family:var(--body); font-weight:600; font-size:14.5px; margin-bottom:6px; }
.commit-item p{ font-size:13.5px; line-height:1.7; color:#c3d6d6; font-weight:300; }
@media (max-width: 860px){ .sustain-grid{ grid-template-columns:1fr; gap:36px; } }

/* ============================================
   ABOUT PAGE
   ============================================ */
.about-hero{ display:grid; grid-template-columns: 1fr 1fr; gap:60px; align-items:center; }
/* ============================================
   ABOUT
   ============================================ */
.about-hero-video{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  color:var(--white);
}
.about-video-bg{
  position:absolute; inset:0; z-index:0;
}
.about-video-bg video{
  /* vertical video — fill height, center horizontally on the balloon */
  height:100%;
  width:auto;
  min-width:100%;
  object-fit:cover;
  object-position:30% 80%;
  display:block;
  position:absolute;
  top:0; left:50%;
  transform:translateX(-50%);
}
.about-video-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg,
    rgba(8,20,40,0.25) 0%,
    rgba(10,24,46,0.1) 40%,
    rgba(10,24,46,0.55) 85%,
    rgba(8,20,40,0.75) 100%);
}
.about-hero-content{
  position:relative; z-index:2;
  text-align:center;
  max-width:760px;
  padding:0 24px;
  margin-top:40vh;
}
.about-hero-content h1{
  font-size:clamp(32px,5vw,64px);
  line-height:1.08;
  letter-spacing:0.01em;
  text-shadow:0 2px 8px rgba(0,0,0,0.5), 0 8px 40px rgba(0,0,0,0.45);
  margin:20px 0 24px;
}
.about-hero-content p{
  font-family:var(--body);
  font-weight:300;
  font-size:clamp(14px,1.6vw,17px);
  line-height:1.75;
  color:rgba(255,255,255,0.88);
  text-shadow:0 1px 4px rgba(0,0,0,0.5);
  max-width:500px;
  margin:0 auto;
}
.about-portrait{
  aspect-ratio: 4/5; border-radius:2px; position:relative; overflow:hidden;
  background: linear-gradient(160deg, var(--blue), var(--navy));
}
.about-hero h1{ font-size: clamp(32px,5vw,52px); color:var(--navy); margin:16px 0 22px; }
.about-hero p{ font-size:15.5px; line-height:1.85; color:#46506b; font-weight:300; margin-bottom:16px; }
@media (max-width: 860px){ .about-hero{ grid-template-columns:1fr; gap:36px; } }

.philosophy-panels{
  display:flex;
  flex-direction:column;
}
.phil-panel{
  position:relative;
  height:100vh;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  overflow:hidden;
}
.phil-panel-bg{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1.08);
  transition:transform 0.1s linear;
  will-change:transform;
}
.phil-panel-overlay{
  position:absolute; inset:0;
  background: linear-gradient(
    to top,
    rgba(8,20,40,0.85) 0%,
    rgba(8,20,40,0.4) 40%,
    rgba(8,20,40,0.1) 100%
  );
}
.phil-panel-content{
  position:relative; z-index:2;
  padding: clamp(40px,6vw,80px) clamp(32px,6vw,100px);
  max-width:820px;
}
.phil-panel-headline{
  font-family: var(--display);
  font-size: clamp(52px,9vw,120px);
  font-weight:400;
  line-height:1.0;
  letter-spacing:-0.02em;
  color:var(--white);
  margin:16px 0 24px;
  text-shadow:0 2px 20px rgba(0,0,0,0.3);
  opacity:0;
  transform:translateY(30px);
  transition:opacity .9s ease, transform .9s cubic-bezier(.22,1,.36,1);
}
.phil-panel.in-view .phil-panel-headline{
  opacity:1;
  transform:translateY(0);
}
.phil-panel-sub{
  font-family:var(--body);
  font-size:clamp(14px,1.4vw,16px);
  font-weight:300;
  line-height:1.8;
  color:rgba(255,255,255,0.7);
  max-width:480px;
  margin:0;
  opacity:0;
  transform:translateY(16px);
  transition:opacity .8s ease .2s, transform .8s cubic-bezier(.22,1,.36,1) .2s;
}
.phil-panel.in-view .phil-panel-sub{
  opacity:1;
  transform:translateY(0);
}
@media(max-width:680px){
  .phil-panel{ height:80vh; }
  .phil-panel-headline{ font-size:clamp(40px,12vw,64px); }
}
@media(prefers-reduced-motion:reduce){
  .phil-panel-bg{ transform:none !important; }
  .phil-panel-headline,.phil-panel-sub{ opacity:1; transform:none; transition:none; }
}
.philosophy .eyebrow{ display:block; margin-bottom:16px; }
.philosophy h2{ font-size: clamp(26px,3.6vw,38px); margin-bottom:24px; }
.philosophy p{ font-size:16px; line-height:1.9; color:#aebbd6; font-weight:300; }

.trust-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap:30px; text-align:center; }
.trust-item svg{ width:38px; height:38px; color:var(--blue); margin:0 auto 16px; }
.trust-item h3{ font-family:var(--body); font-size:14.5px; font-weight:600; color:var(--navy); margin-bottom:8px; }
.trust-item p{ font-size:13px; color:#5a6580; font-weight:300; line-height:1.6; }
@media (max-width: 860px){ .trust-grid{ grid-template-columns: repeat(2,1fr); gap:40px 24px; } }

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-grid{ display:grid; grid-template-columns: 0.9fr 1.4fr; gap:70px; }
@media (max-width: 900px){ .contact-grid{ grid-template-columns:1fr; gap:46px; } }
.contact-info h1{ font-size: clamp(30px,4.6vw,46px); color:var(--navy); margin-bottom:18px; }
.contact-info p{ font-size:15px; line-height:1.85; color:#46506b; font-weight:300; margin-bottom:32px; }
.contact-channel{ display:flex; gap:16px; align-items:flex-start; margin-bottom:24px; }
.contact-channel svg{ width:24px; height:24px; color:var(--blue); flex:none; margin-top:2px; }
.contact-channel strong{ display:block; font-size:13.5px; color:var(--navy); margin-bottom:3px; }
.contact-channel a, .contact-channel span{ font-size:13.5px; color:#5a6580; }

.form-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:22px; }
.form-field{ display:flex; flex-direction:column; gap:8px; }
.form-field.full{ grid-column: 1 / -1; }
.form-field label{ font-size:11.5px; letter-spacing:0.06em; text-transform:uppercase; color:#7a8399; font-weight:600; }
.form-field input, .form-field select, .form-field textarea{
  font-family: var(--body); font-size:14.5px; padding:13px 4px; border:none; border-bottom:1px solid var(--line-dark);
  background:transparent; color:var(--ink); font-weight:400;
}
.form-field textarea{ resize:vertical; min-height:90px; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{ border-color:var(--blue); }
.form-consent{ display:flex; gap:12px; align-items:flex-start; font-size:12.5px; color:#5a6580; font-weight:300; line-height:1.6; }
.form-consent input{ margin-top:3px; }
.form-submit{ margin-top:10px; }

@media (max-width: 560px){ .form-grid{ grid-template-columns:1fr; } }

/* utility */
.mt-60{ margin-top:60px; }
.mt-80{ margin-top:80px; }
.center{ text-align:center; }

/* ============================================
   BOOKING WIDGET — FULL FUNNEL
   ============================================ */
.bw-hidden{ display:none !important; }
.bw-step{ animation:bwIn .3s ease; }
@keyframes bwIn{ from{opacity:0;transform:translateY(8px);} to{opacity:1;transform:translateY(0);} }

/* Progress bar */
.bw-progress-bar{
  display:flex; align-items:center;
  margin-bottom:20px; padding-bottom:20px;
  border-bottom:1px solid var(--line-dark);
}
.bw-prog-step{
  display:flex; flex-direction:column; align-items:center; gap:4px;
  flex:0 0 auto;
}
.bw-prog-dot{
  width:26px; height:26px; border-radius:50%;
  border:1.5px solid var(--line-dark);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; color:#9aa3b8;
  transition:all .3s ease;
}
.bw-prog-lbl{
  font-size:9px; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; color:#9aa3b8;
  transition:color .3s ease;
}
.bw-prog-step.active .bw-prog-dot{ background:var(--navy); border-color:var(--navy); color:var(--white); }
.bw-prog-step.active .bw-prog-lbl{ color:var(--navy); }
.bw-prog-step.done .bw-prog-dot{ background:var(--blue); border-color:var(--blue); color:var(--white); }
.bw-prog-line{ flex:1; height:1px; background:var(--line-dark); margin:0 8px; margin-bottom:14px; }

/* Back link */
.bw-back{
  font-size:12px; font-weight:600; letter-spacing:0.05em;
  color:var(--blue); cursor:pointer; margin-bottom:16px;
  display:inline-flex; align-items:center; gap:4px;
}
.bw-back:hover{ text-decoration:underline; }

.bw-label{
  font-size:10px; font-weight:700; letter-spacing:0.12em;
  text-transform:uppercase; color:#9aa3b8; margin-bottom:10px;
}

/* Step 1 layout: nights left, calendar right */
.bw-step1-layout{
  display:grid;
  grid-template-columns:100px 1fr;
  gap:16px;
  align-items:start;
}
.bw-nights-col{ display:flex; flex-direction:column; }
.bw-nights-selector{
  display:flex; flex-direction:column; align-items:center;
  gap:6px; padding:0;
}
.bw-ns-arrow{
  width:28px; height:28px; border-radius:50%;
  border:1px solid var(--line-dark);
  background:transparent; cursor:pointer;
  font-size:16px; font-weight:300; color:var(--navy);
  display:flex; align-items:center; justify-content:center;
  transition:all .2s ease; line-height:1;
}
.bw-ns-arrow:hover{ background:var(--navy); color:var(--white); border-color:var(--navy); }
.bw-ns-center{ text-align:center; }
.bw-ns-number{
  font-family:var(--display); font-size:80px; font-weight:300;
  color:var(--navy); line-height:1; display:block;
  letter-spacing:-0.03em; min-width:60px; text-align:center;
}
.bw-ns-unit{
  font-size:9px; font-weight:700; letter-spacing:0.12em;
  text-transform:uppercase; color:#9aa3b8; display:block;
}
.bw-ns-desc{
  font-size:10px; font-weight:300; color:#9aa3b8;
  font-style:italic; line-height:1.4; margin-top:8px;
  text-align:center;
}

/* Calendar */
.bw-cal-col{}
.bw-cal-nav{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:8px;
}
.bw-cal-month{ font-family:var(--display); font-size:16px; font-weight:500; color:var(--navy); }
.bw-cal-arrow{
  background:none; border:none; cursor:pointer;
  font-size:13px; color:var(--navy); padding:2px 4px;
  transition:color .2s ease;
}
.bw-cal-arrow:hover{ color:var(--blue); }
.bw-cal-grid{
  display:grid; grid-template-columns:repeat(7,1fr);
  gap:2px;
}
.bw-cal-day-hdr{
  text-align:center; font-size:9px; font-weight:700;
  letter-spacing:0.06em; color:#c0c6d4; padding:5px 0;
}
.bw-cal-cell{
  text-align:center; border-radius:2px; cursor:pointer;
  transition:all .15s ease; padding:5px 2px;
}
.bw-cal-empty{ cursor:default; }
.bw-cal-past{ opacity:0.3; cursor:default; }
.bw-cell-day{ font-size:12px; font-weight:500; color:var(--navy); line-height:1.3; }
.bw-cell-price{ font-size:8.5px; color:#7a8399; line-height:1.2; }
.bw-cal-low{ background:rgba(33,58,62,0.05); }
.bw-cal-high{ background:rgba(38,81,150,0.07); }
.bw-cal-low:not(.bw-cal-past):hover{ background:rgba(33,58,62,0.16); }
.bw-cal-high:not(.bw-cal-past):hover{ background:rgba(38,81,150,0.18); }
.bw-cal-selected{ background:var(--navy) !important; }
.bw-cal-selected .bw-cell-day{ color:var(--white) !important; }
.bw-cal-selected .bw-cell-price{ color:rgba(255,255,255,0.6) !important; }
.bw-cal-legend{
  display:flex; align-items:center; gap:8px; margin-top:6px;
  font-size:9px; color:#9aa3b8;
}
.bw-leg{ display:inline-block; width:10px; height:10px; border-radius:2px; }
.bw-leg-low{ background:rgba(33,58,62,0.15); }
.bw-leg-high{ background:rgba(38,81,150,0.2); }

/* Room cards */
.bw-rooms{ display:flex; flex-direction:column; gap:10px; }
.bw-room-card{
  display:flex; justify-content:space-between; align-items:center;
  border:1px solid var(--line-dark); border-radius:2px;
  padding:14px 16px; cursor:pointer;
  transition:all .2s ease;
}
.bw-room-card:hover{ border-color:var(--blue); }
.bw-room-card.selected{ border-color:var(--navy); background:rgba(15,38,73,0.03); }
.bw-room-info{ display:flex; flex-direction:column; gap:3px; }
.bw-room-info strong{ font-size:13px; font-weight:600; color:var(--navy); }
.bw-room-info span{ font-size:11px; color:#7a8399; max-width:160px; line-height:1.3; }
.bw-room-price{ display:flex; flex-direction:column; align-items:flex-end; gap:2px; }
.bw-room-price strong{ font-family:var(--display); font-size:18px; color:var(--navy); }
.bw-room-price span{ font-size:9px; color:#9aa3b8; text-transform:uppercase; letter-spacing:0.08em; }
.bw-room-extra{ font-size:10px; color:var(--blue); }
.bw-room-included{ font-size:10px; color:#2e7d32; }

/* Summary */
.bw-sum-header{
  font-family:var(--display); font-size:18px; font-weight:500;
  color:var(--navy); margin-bottom:14px;
}
.bw-sum-row{
  display:flex; justify-content:space-between; align-items:center;
  padding:7px 0; border-bottom:1px solid var(--line-dark);
  font-size:12px;
}
.bw-sum-row span{ color:#7a8399; }
.bw-sum-row strong{ color:var(--navy); font-weight:600; }
.bw-season-high{ color:var(--blue) !important; }
.bw-season-low{ color:#2e7d32 !important; }
.bw-sum-total{
  margin-top:16px; padding:16px;
  background:rgba(15,38,73,0.04); border-radius:2px;
  text-align:center;
}
.bw-sum-total span{ font-size:10px; color:#9aa3b8; display:block; }
.bw-sum-total strong{
  font-family:var(--display); font-size:32px;
  color:var(--navy); display:block; margin:4px 0 2px;
}
.bw-sum-note{ font-size:10px; color:#9aa3b8; font-style:italic; margin-top:8px; line-height:1.5; }

/* Request form — redesigned */
.bw-form-title{
  font-family:var(--display); font-size:20px; font-weight:500;
  color:var(--navy); margin:0 0 6px;
}
.bw-form-sub{
  font-size:11.5px; color:#7a8399; line-height:1.6;
  margin:0 0 20px;
}
.bw-form-field{
  display:flex; flex-direction:column; gap:5px; margin-bottom:12px;
}
.bw-form-field label{
  font-size:10px; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; color:#9aa3b8;
}
.bw-request-form input{
  border:1px solid var(--line-dark); border-radius:2px;
  padding:11px 13px; font-family:var(--body); font-size:13px;
  color:var(--ink); background:var(--white); outline:none;
  transition:border-color .2s ease; width:100%; box-sizing:border-box;
}
.bw-request-form input:focus{ border-color:var(--blue); }
.bw-submit-btn{
  width:100%; background:var(--navy); color:var(--white);
  font-family:var(--body); font-size:12px; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase;
  padding:15px; border-radius:2px; cursor:pointer;
  transition:background .25s ease; margin-top:4px;
}
.bw-submit-btn:hover{ background:var(--blue); }
.bw-form-legal{
  font-size:10px; color:#9aa3b8; margin-top:10px;
  text-align:center; line-height:1.5;
}
.bw-form-legal a{ color:#9aa3b8; text-decoration:underline; }

/* Success state */
.bw-sent-state{
  text-align:center; padding:10px 0;
}
.bw-sent-icon{
  width:48px; height:48px; border-radius:50%;
  background:rgba(46,125,50,0.1); border:1.5px solid rgba(46,125,50,0.3);
  display:flex; align-items:center; justify-content:center;
  font-size:20px; color:#2e7d32; margin:0 auto 16px;
}
.bw-sent-title{
  font-family:var(--display); font-size:22px; font-weight:500;
  color:var(--navy); margin:0 0 10px;
}
.bw-sent-msg{
  font-size:12px; color:#7a8399; line-height:1.65;
  margin:0 0 20px;
}
.bw-sent-details{
  text-align:left; border:1px solid var(--line-dark);
  border-radius:2px; margin-bottom:16px; overflow:hidden;
}
.bw-sent-row{
  display:flex; justify-content:space-between;
  padding:8px 12px; border-bottom:1px solid var(--line-dark);
  font-size:12px;
}
.bw-sent-row:last-child{ border-bottom:none; }
.bw-sent-row span{ color:#9aa3b8; }
.bw-sent-row strong{ color:var(--navy); font-weight:600; }
.bw-sent-wa{
  font-size:11px; color:#9aa3b8; font-style:italic;
}
.bw-dots::after{
  content:'';
  animation:bwDots 1.5s infinite;
}
@keyframes bwDots{
  0%{ content:''; }
  33%{ content:'.'; }
  66%{ content:'..'; }
  100%{ content:'...'; }
}

.bw-sent{
  font-size:13px; color:#2e7d32; font-weight:500; padding:12px 0;
  text-align:center;
}
.bw-divider{ height:1px; background:var(--line-dark); margin:18px 0; }

/* ============================================
   BROCHURE FORM IN SIDEBAR
   ============================================ */
.sidebar-brochure{
  margin-top:24px;
  padding-top:24px;
  border-top:1px solid var(--line-dark);
}
.sidebar-brochure-label{
  font-size:12px;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#7a8399;
  margin-bottom:12px;
}
.brochure-form{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.brochure-form input{
  border:1px solid var(--line-dark);
  border-radius:2px;
  padding:12px 14px;
  font-family:var(--body);
  font-size:13px;
  color:var(--ink);
  background:var(--white);
  outline:none;
  transition:border-color .2s ease;
}
.brochure-form input:focus{ border-color:var(--blue); }
.brochure-form button{
  background:var(--navy);
  color:var(--white);
  font-family:var(--body);
  font-size:12px;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:13px 20px;
  border-radius:2px;
  cursor:pointer;
  transition:background .25s ease;
}
.brochure-form button:hover{ background:var(--blue); }
.brochure-sent{
  font-size:13px;
  color:#2e7d32;
  font-weight:500;
  padding:12px 0;
}

/* ============================================
   ROOM MODAL
   ============================================ */
.bw-modal-overlay{
  position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,0.7);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  animation:bwIn .2s ease;
}
.bw-modal{
  background:var(--white); border-radius:4px;
  max-width:560px; width:100%;
  max-height:90vh; overflow-y:auto;
  position:relative;
}
.bw-modal-close{
  position:absolute; top:12px; right:14px;
  background:none; border:none; font-size:18px;
  cursor:pointer; color:#7a8399; z-index:2;
  width:32px; height:32px; display:flex;
  align-items:center; justify-content:center;
  border-radius:50%; transition:background .2s ease;
}
.bw-modal-close:hover{ background:rgba(0,0,0,0.06); }
.bw-modal-gallery{
  position:relative; overflow:hidden;
}
.bw-modal-img{
  width:100%; height:260px; object-fit:cover; display:block;
}
.bw-modal-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(0,0,0,0.4); color:var(--white);
  border:none; cursor:pointer; padding:8px 12px;
  font-size:16px; border-radius:2px;
  transition:background .2s ease;
}
.bw-modal-arrow:hover{ background:rgba(0,0,0,0.7); }
.bw-modal-prev{ left:10px; }
.bw-modal-next{ right:10px; }
.bw-modal-thumbs{
  display:flex; gap:6px; padding:10px 14px;
  overflow-x:auto;
}
.bw-modal-thumb{
  width:64px; height:48px; object-fit:cover;
  border-radius:2px; cursor:pointer; flex-shrink:0;
  opacity:0.55; transition:opacity .2s ease;
  border:2px solid transparent;
}
.bw-modal-thumb.active{ opacity:1; border-color:var(--navy); }
.bw-modal-body{ padding:16px 18px 20px; }
.bw-modal-title{
  font-family:var(--display); font-size:20px;
  color:var(--navy); display:block; margin-bottom:12px;
}
.bw-modal-amenities{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:1fr 1fr; gap:6px;
}
.bw-modal-amenities li{
  font-size:12px; color:#5a6580;
  padding-left:16px; position:relative;
}
.bw-modal-amenities li::before{
  content:'✓'; position:absolute; left:0;
  color:var(--blue); font-weight:700;
}

/* View photos button */
.bw-view-photos{
  font-size:10px; font-weight:700; letter-spacing:0.08em;
  color:var(--blue); cursor:pointer; text-transform:uppercase;
}
/* Room photo button */
.bw-room-photo-btn{
  font-size:10px; font-weight:600; letter-spacing:0.06em;
  color:var(--blue); background:none; border:none;
  cursor:pointer; padding:0; margin-top:5px;
  text-decoration:underline;
}

/* Add-on cards — redesigned */
.bw-addon-card{
  display:flex; align-items:stretch;
  border:1px solid var(--line-dark); border-radius:2px;
  overflow:hidden; margin-bottom:8px;
  background:var(--white);
}
.bw-ao-img{
  width:80px; flex-shrink:0;
  background-size:cover; background-position:center;
}
.bw-ao-content{
  padding:12px 14px; flex:1;
}
.bw-ao-top{
  display:flex; justify-content:space-between;
  align-items:flex-start; gap:8px; margin-bottom:5px;
}
.bw-ao-top strong{
  font-size:13px; font-weight:600; color:var(--navy); line-height:1.2;
}
.bw-ao-price{ text-align:right; flex-shrink:0; }
.bw-ao-amount{
  font-family:var(--display); font-size:18px;
  color:var(--navy); display:block; line-height:1;
}
.bw-ao-unit{
  font-size:9px; color:#9aa3b8; text-transform:uppercase;
  letter-spacing:0.08em; display:block; margin-top:2px;
}
.bw-ao-content p{
  font-size:11px; color:#7a8399; line-height:1.45; margin:0;
}

/* Room card redesign */
.bw-room-card{
  border:1px solid var(--line-dark); border-radius:2px;
  overflow:hidden; margin-bottom:4px;
  transition:border-color .2s ease;
  background:var(--white);
  display:flex; flex-direction:column;
}
.bw-room-card:hover{ border-color:var(--blue); }
.bw-room-card.selected{ border-color:var(--navy); }
.bw-room-thumb-wrap{
  position:relative; cursor:pointer; overflow:hidden;
  height:52px;
}
.bw-room-thumb{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .3s ease;
}
.bw-room-thumb-wrap:hover .bw-room-thumb{ transform:scale(1.04); }
.bw-room-thumb-btn{
  position:absolute; bottom:8px; right:8px;
  background:rgba(0,0,0,0.55); color:var(--white);
  font-size:10px; font-weight:600; letter-spacing:0.06em;
  padding:4px 10px; border-radius:2px;
  pointer-events:none;
}
.bw-room-body{
  display:flex; justify-content:space-between;
  align-items:center; padding:6px 10px; cursor:pointer;
}
.bw-room-info{ flex:1; }
.bw-room-info strong{ font-size:11px; font-weight:600; color:var(--navy); display:block; margin-bottom:1px; }
.bw-room-info span{ font-size:10px; color:#7a8399; line-height:1.2; }
.bw-room-price{ text-align:right; flex-shrink:0; margin-left:12px; }
.bw-room-price strong{ font-family:var(--display); font-size:15px; color:var(--navy); display:block; }
.bw-room-price span{ font-size:9px; color:#9aa3b8; text-transform:uppercase; letter-spacing:0.06em; }
.bw-room-extra{ font-size:10px; color:var(--blue); display:block; }
.bw-room-included{ font-size:10px; color:#2e7d32; display:block; }

/* Insurance list */
.bw-ins-list{
  list-style:none; padding:0; margin:6px 0 0;
}
.bw-ins-list li{
  font-size:11px; color:#5a6580; padding-left:16px;
  position:relative; margin-bottom:3px;
}
.bw-ins-list li::before{
  content:'✓'; position:absolute; left:0;
  color:#2e7d32; font-weight:700; font-size:10px;
}

/* Hotel card in room step */
.bw-hotel-card{
  display:flex; align-items:center; gap:12px;
  border:1px solid var(--line-dark); border-radius:2px;
  overflow:hidden; margin-bottom:12px; cursor:pointer;
  transition:border-color .2s ease;
}
.bw-hotel-card:hover{ border-color:var(--blue); }
.bw-hotel-card img{
  width:72px; height:72px; object-fit:cover; flex-shrink:0;
}
.bw-hotel-info{
  padding:8px 10px 8px 0; flex:1;
}
.bw-hotel-info strong{
  font-family:var(--display); font-size:14px; color:var(--navy);
  display:block; margin-bottom:1px;
}
.bw-hotel-info span{
  font-size:10px; color:#c9a84c; letter-spacing:0.05em;
  display:block; margin-bottom:4px;
}
.bw-hotel-info p{
  font-size:10px; color:#7a8399; line-height:1.4; margin:0;
}
/* Insurance badge */
.bw-insurance-badge{
  display:flex; gap:12px; align-items:flex-start;
  background:rgba(46,125,50,0.06); border:1px solid rgba(46,125,50,0.2);
  border-radius:2px; padding:12px 14px;
}
.bw-ins-icon{
  color:#2e7d32; font-size:8px; margin-top:4px; flex-shrink:0;
}
.bw-insurance-badge strong{
  font-size:12px; font-weight:700; color:#2e7d32;
  display:block; margin-bottom:4px;
}
.bw-insurance-badge p{
  font-size:11px; color:#5a6580; line-height:1.5; margin:0;
}

/* Add-on cards */
.bw-addon-card{
  display:flex; align-items:flex-start; gap:12px;
  border:1px solid var(--line-dark); border-radius:2px;
  padding:12px 14px; cursor:pointer;
  transition:all .2s ease; margin-bottom:8px;
}
.bw-addon-card:hover{ border-color:var(--blue); }
.bw-addon-card.selected{ border-color:var(--navy); background:rgba(15,38,73,0.04); }
.bw-addon-check{
  width:20px; height:20px; border-radius:50%;
  border:1.5px solid var(--line-dark);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; color:var(--white); flex-shrink:0; margin-top:1px;
  transition:all .2s ease;
}
.bw-addon-card.selected .bw-addon-check{
  background:var(--navy); border-color:var(--navy);
}
.bw-addon-info{ flex:1; }
.bw-addon-info strong{ font-size:12.5px; font-weight:600; color:var(--navy); display:block; margin-bottom:3px; }
.bw-addon-info span{ font-size:10.5px; color:#7a8399; line-height:1.4; }
.bw-addon-price{
  font-family:var(--display); font-size:16px; font-weight:500;
  color:var(--navy); text-align:right; flex-shrink:0;
  display:flex; flex-direction:column; align-items:flex-end;
}
.bw-addon-price span{ font-size:9px; color:#9aa3b8; text-transform:uppercase; letter-spacing:0.08em; margin-top:2px; }

/* Full-width calendar layout */
.pm-cal-full{ width:100%; }
.bw-cal-footer{
  display:flex; justify-content:space-between; align-items:center;
  margin-top:10px;
}
.bw-cal-nights-display{
  font-family:var(--display); font-size:15px; font-style:italic;
  color:var(--navy);
}

/* Range selection styles */
.bw-cal-ci{
  background:var(--navy) !important;
  border-radius:2px 0 0 2px;
}
.bw-cal-ci .bw-cell-day{ color:var(--white) !important; }
.bw-cal-co{
  background:var(--navy) !important;
  border-radius:0 2px 2px 0;
}
.bw-cal-co .bw-cell-day{ color:var(--white) !important; }
.bw-cal-inrange{
  background:rgba(38,81,150,0.12) !important;
  border-radius:0;
}
.bw-cal-inrange .bw-cell-day{ color:var(--navy) !important; }
.bw-cal-inhover{
  background:rgba(38,81,150,0.07) !important;
  border-radius:0;
}

/* Nights selector — clean inline */
.bw-nights-clean{
  display:flex; align-items:center; justify-content:center;
  gap:14px; margin-bottom:10px;
}
.bw-nc-btn{
  width:28px; height:28px; border-radius:50%;
  border:1px solid var(--line-dark);
  background:transparent; cursor:pointer;
  font-size:16px; color:var(--navy); line-height:1;
  display:flex; align-items:center; justify-content:center;
  transition:all .2s ease;
}
.bw-nc-btn:hover{ background:var(--navy); color:var(--white); border-color:var(--navy); }
.bw-nc-mid{ text-align:center; }

/* Premium summary card */
.bw-sum-premium{
  background:var(--navy); border-radius:3px;
  padding:28px 28px; color:var(--white);
  margin-bottom:4px; min-height:220px;
}
.bw-sum-exp-title{
  font-family:var(--display); font-size:22px; font-weight:400;
  color:var(--white); margin-bottom:4px; line-height:1.15;
}
.bw-sum-dest{
  font-size:10px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase;
  color:rgba(255,255,255,0.45); margin-bottom:18px;
}
.bw-sum-dates{
  display:flex; align-items:flex-start; gap:12px;
  margin-bottom:18px;
}
.bw-sum-date-col{ flex:1; }
.bw-sum-date-col span{
  font-size:9px; font-weight:700; letter-spacing:0.12em;
  text-transform:uppercase; color:rgba(255,255,255,0.4);
  display:block; margin-bottom:4px;
}
.bw-sum-date-col strong{
  font-family:var(--display); font-size:15px; font-weight:400;
  color:var(--white); display:block; line-height:1.2;
}
.bw-sum-date-sep{
  color:rgba(255,255,255,0.2); font-size:18px; margin-top:18px;
}
.bw-sum-tags{
  display:flex; flex-wrap:wrap; gap:6px; margin-bottom:14px;
}
.bw-sum-tag{
  font-size:10px; font-weight:600; letter-spacing:0.08em;
  text-transform:uppercase;
  background:rgba(255,255,255,0.1);
  color:rgba(255,255,255,0.7);
  padding:4px 10px; border-radius:20px;
}
.bw-sum-tag-high{ background:rgba(201,168,76,0.2); color:#c9a84c; }
.bw-sum-tag-low{ background:rgba(33,58,62,0.4); color:rgba(255,255,255,0.6); }
.bw-sum-addons-line{
  font-size:11px; color:rgba(255,255,255,0.4);
  margin-bottom:18px; line-height:1.5;
}
.bw-sum-price-row{
  border-top:1px solid rgba(255,255,255,0.12);
  padding-top:16px; margin-top:4px;
}
.bw-sum-price-row > span:first-child{
  font-size:10px; color:rgba(255,255,255,0.4);
  text-transform:uppercase; letter-spacing:0.1em;
  display:block; margin-bottom:6px;
}
.bw-sum-price-row strong{
  font-family:var(--display); font-size:42px; font-weight:400;
  color:var(--white); display:block; line-height:1; margin-bottom:8px;
}
.bw-sum-pp{
  font-size:11px; color:rgba(255,255,255,0.4);
  text-transform:uppercase; letter-spacing:0.1em;
}
.bw-sum-premium .bw-sum-note{
  font-size:10px; color:rgba(255,255,255,0.3);
  font-style:italic; margin-top:10px; line-height:1.5;
}

.pm-inline-form{ margin-top:4px; }
.pm-form-title{
  font-family:var(--display); font-size:22px; font-weight:500;
  color:var(--navy); margin:0 0 6px;
}
.pm-form-sub{
  font-size:12px; color:#7a8399; line-height:1.65; margin:0 0 18px;
}

/* ============================================
   SIDEBAR CONTACT FORM
   ============================================ */
.sidebar-eyebrow{
  font-size:10px; font-weight:700; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--blue); margin-bottom:8px;
}
.sidebar-cta-title{
  font-family:var(--display); font-size:22px; font-weight:500;
  color:var(--navy); line-height:1.15; margin-bottom:8px;
}
.sidebar-cta-sub{
  font-size:12px; color:#7a8399; line-height:1.65;
  margin-bottom:20px;
}
.sf-field{
  display:flex; flex-direction:column; gap:4px; margin-bottom:12px;
}
.sf-field label{
  font-size:10px; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; color:#9aa3b8;
}
.sf-optional{ font-weight:400; text-transform:none; letter-spacing:0; }
.sf-field input, .sf-field textarea{
  border:1px solid var(--line-dark); border-radius:2px;
  padding:10px 13px; font-family:var(--body); font-size:13px;
  color:var(--ink); background:var(--white); outline:none;
  transition:border-color .2s ease; width:100%; box-sizing:border-box;
  resize:none;
}
.sf-field input:focus, .sf-field textarea:focus{ border-color:var(--blue); }
.sf-submit{
  width:100%; background:var(--navy); color:var(--white);
  font-family:var(--body); font-size:12px; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase;
  padding:14px; border-radius:2px; cursor:pointer;
  transition:background .25s ease; margin-top:4px;
  border:none;
}
.sf-submit:hover{ background:var(--blue); }
.sf-legal{
  font-size:10px; color:#9aa3b8; margin-top:10px;
  text-align:center; line-height:1.5;
}
.sf-legal a{ color:#9aa3b8; text-decoration:underline; }
.sidebar-divider{ height:1px; background:var(--line-dark); margin:20px 0; }
.sidebar-trip-from{
  font-family:var(--body); font-size:13px; color:#7a8399;
  margin-bottom:18px;
}
.sidebar-trip-from strong{
  font-family:var(--display); font-size:28px; color:var(--navy);
  font-weight:400;
}
.sidebar-trip-from span{ font-size:11px; }
.sidebar-prices-btn{
  display:block; width:100%; text-align:center;
  background:var(--navy); color:var(--white) !important;
  font-family:var(--body); font-size:12px; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase;
  padding:15px; border-radius:2px; margin-bottom:10px;
  transition:background .25s ease;
}
.sidebar-prices-btn:hover{ background:var(--blue); }
.sidebar-plan-btn{
  display:block; width:100%; text-align:center;
  background:transparent; color:var(--navy);
  border:1px solid var(--line-dark);
  font-family:var(--body); font-size:12px; font-weight:600;
  letter-spacing:0.08em; text-transform:uppercase;
  padding:14px; border-radius:2px; margin-bottom:18px;
  cursor:pointer; transition:all .25s ease;
}
.sidebar-plan-btn:hover{ border-color:var(--navy); background:rgba(15,38,73,0.04); }
/* Plan modal */
.plan-modal-overlay{
  position:fixed; inset:0; z-index:9000;
  background:rgba(0,0,0,0.6);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
}
.plan-modal{
  background:var(--white); border-radius:3px;
  max-width:480px; width:100%;
  max-height:90vh; overflow-y:auto;
  position:relative; padding:36px;
}

/* Sent state */
.sf-sent{
  text-align:center; padding:10px 0;
}
.sf-sent-icon{
  width:44px; height:44px; border-radius:50%;
  background:rgba(46,125,50,0.1); border:1.5px solid rgba(46,125,50,0.3);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; color:#2e7d32; margin:0 auto 14px;
}
.sf-sent h4{
  font-family:var(--display); font-size:20px; font-weight:500;
  color:var(--navy); margin:0 0 8px;
}
.sf-sent p{
  font-size:12px; color:#7a8399; line-height:1.65; margin:0 0 8px;
}
.sf-sent-wa{ font-style:italic; }

/* Pricing modal */
.pricing-modal-overlay{
  position:fixed; inset:0; z-index:9000;
  background:rgba(0,0,0,0.6);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
}
.pricing-modal{
  background:var(--white); border-radius:3px;
  max-width:860px; width:100%;
  max-height:92vh; overflow-y:auto;
  position:relative; padding:36px 40px;
}
.pricing-modal-close{
  position:absolute; top:14px; right:16px;
  background:none; border:none; font-size:18px;
  cursor:pointer; color:#9aa3b8;
  width:32px; height:32px; display:flex;
  align-items:center; justify-content:center;
  border-radius:50%; transition:background .2s ease;
}
.pricing-modal-close:hover{ background:rgba(0,0,0,0.06); }
.pm-title{
  font-family:var(--display); font-size:26px; font-weight:500;
  color:var(--navy); margin:0 0 6px;
}
.pm-sub{
  font-size:13px; color:#7a8399; margin:0 0 24px;
}
.pm-two-col{
  display:grid; grid-template-columns:160px 1fr; gap:36px;
  align-items:start;
}
.pm-hidden{ display:none !important; }
.pm-step{ animation:bwIn .3s ease; }
.pm-cta-note{
  font-size:12px; color:#7a8399; font-style:italic;
  margin:0 0 14px; line-height:1.5;
}

/* Add-on selectable */
.bw-addon-card{
  display:flex; align-items:stretch;
  border:1px solid var(--line-dark); border-radius:2px;
  overflow:hidden; margin-bottom:8px;
  background:var(--white); cursor:pointer;
  transition:border-color .2s ease;
}
.bw-addon-card:hover{ border-color:var(--blue); }
.bw-addon-card.selected{ border-color:var(--navy); background:rgba(15,38,73,0.03); }
.bw-ao-check{
  width:20px; height:20px; border-radius:50%;
  border:1.5px solid var(--line-dark);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; color:var(--white); flex-shrink:0;
  transition:all .2s ease; margin-right:8px; margin-top:2px;
}
.bw-addon-card.selected .bw-ao-check{
  background:var(--navy); border-color:var(--navy);
}
.bw-ao-img{
  width:72px; flex-shrink:0;
  background-size:cover; background-position:center;
}
.bw-ao-content{ padding:10px 12px; flex:1; }
.bw-ao-top{
  display:flex; align-items:center; gap:6px; margin-bottom:4px;
}
.bw-ao-top strong{ font-size:12.5px; font-weight:600; color:var(--navy); flex:1; }
.bw-ao-price{ text-align:right; flex-shrink:0; }
.bw-ao-amount{
  font-family:var(--display); font-size:16px;
  color:var(--navy); display:block; line-height:1;
}
.bw-ao-unit{
  font-size:9px; color:#9aa3b8; text-transform:uppercase;
  letter-spacing:0.08em; display:block; margin-top:1px;
}
.bw-ao-content p{ font-size:10.5px; color:#7a8399; line-height:1.4; margin:0; }

/* Request overlay — centered fullscreen */
.pm-request-overlay{
  position:fixed; inset:0; z-index:10000;
  background:rgba(8,20,40,0.75);
  backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  animation:bwIn .25s ease;
}
.pm-request-box{
  background:var(--white); border-radius:3px;
  max-width:460px; width:100%;
  padding:40px 44px;
  position:relative;
  box-shadow:0 24px 80px rgba(0,0,0,0.3);
}
.pm-req-close{
  position:absolute; top:14px; right:16px;
  background:none; border:none; font-size:18px;
  cursor:pointer; color:#9aa3b8;
  width:32px; height:32px; display:flex;
  align-items:center; justify-content:center;
  border-radius:50%; transition:background .2s ease;
}
.pm-req-close:hover{ background:rgba(0,0,0,0.06); }
.pm-req-eyebrow{
  font-size:10px; font-weight:700; letter-spacing:0.16em;
  text-transform:uppercase; color:var(--blue); margin-bottom:10px;
}
.pm-req-title{
  font-family:var(--display); font-size:28px; font-weight:500;
  color:var(--navy); line-height:1.1; margin-bottom:10px;
}
.pm-req-sub{
  font-size:13px; color:#7a8399; line-height:1.65;
  margin-bottom:24px;
}

/* ============================================
   TRIP DETAIL — EDITORIAL SECTIONS
   ============================================ */

/* Shared */
.td-section-inner{
  max-width:1100px; margin:0 auto;
  padding:clamp(60px,8vw,100px) clamp(24px,5vw,80px);
}
.td-section-head{ margin-bottom:clamp(36px,4vw,56px); }
.td-section-head h2{
  font-size:clamp(28px,4vw,48px);
  color:var(--navy); margin-top:12px;
}

/* OVERVIEW — split image + text */
.td-overview{ background:var(--ivory); overflow:hidden; }
.td-overview-inner{
  max-width:1100px; margin:0 auto;
  padding:clamp(60px,8vw,100px) clamp(24px,5vw,80px);
  display:grid; grid-template-columns:1fr 1fr; gap:60px;
  align-items:center;
}
.td-overview-title{
  font-size:clamp(28px,4vw,46px);
  color:var(--navy); margin:14px 0 24px; line-height:1.1;
}
.td-overview-body{
  font-size:clamp(15px,1.5vw,17px);
  line-height:1.85; color:#4a5568; font-weight:300;
}
.td-overview-slider{
  height:clamp(340px,45vw,560px);
  border-radius:2px;
  box-shadow:0 20px 60px rgba(15,38,73,0.18);
  position:relative; overflow:hidden;
}
.td-slide{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.2s ease;
}
.td-slide.active{ opacity:1; }
.td-slider-dots{
  position:absolute; bottom:16px; left:50%;
  transform:translateX(-50%);
  display:flex; gap:8px; z-index:2;
}
.td-slider-dot{
  width:7px; height:7px; border-radius:50%;
  background:rgba(255,255,255,0.45); border:none; cursor:pointer;
  transition:background .3s ease, transform .3s ease;
  padding:0;
}
.td-slider-dot.active{ background:var(--white); transform:scale(1.25); }
@media(max-width:760px){
  .td-overview-inner{ grid-template-columns:1fr; gap:32px; }
  .td-overview-img{ height:260px; }
}

/* HIGHLIGHTS — numbered cards */
.td-highlights{ background:var(--white); }
.td-hl-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
}
.td-hl-card{
  border-radius:2px; position:relative;
  overflow:hidden; height:220px;
  background-size:cover; background-position:center;
  transition:transform .4s ease, box-shadow .4s ease;
  cursor:default;
}
.td-hl-card:hover{
  transform:scale(1.02);
  box-shadow:0 16px 48px rgba(15,38,73,0.2);
}
.td-hl-overlay{
  position:absolute; inset:0;
  background:linear-gradient(160deg, rgba(8,20,40,0.3) 0%, rgba(8,20,40,0.72) 100%);
}
.td-hl-content{
  position:absolute; inset:0;
  padding:24px; display:flex;
  flex-direction:column; justify-content:flex-end;
}
.td-hl-num{
  font-family:var(--display); font-size:40px; font-weight:400;
  color:rgba(255,255,255,0.25); line-height:1;
  margin-bottom:8px; letter-spacing:-0.02em;
}
.td-hl-card p{
  font-size:13.5px; line-height:1.55; color:rgba(255,255,255,0.9);
  margin:0; font-weight:400;
  text-shadow:0 1px 4px rgba(0,0,0,0.4);
}

/* ITINERARY — timeline */
.td-itinerary{ background:var(--ivory); }
.td-timeline{ max-width:680px; }
.td-tl-item{
  display:grid; grid-template-columns:32px 1fr;
  gap:24px; margin-bottom:0;
}
.td-tl-left{
  display:flex; flex-direction:column; align-items:center;
}
.td-tl-dot{
  width:12px; height:12px; border-radius:50%;
  background:var(--white); border:2px solid var(--blue);
  flex-shrink:0; margin-top:5px;
  transition:background .3s ease;
}
.td-tl-item.in .td-tl-dot{ background:var(--blue); }
.td-tl-line{
  width:1px; flex:1; background:rgba(38,81,150,0.2);
  margin:6px 0; min-height:40px;
}
.td-tl-body{ padding-bottom:40px; }
.td-tl-day{
  font-size:10px; font-weight:700; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--blue); display:block;
  margin-bottom:6px;
}
.td-tl-body h4{
  font-family:var(--display); font-size:20px; font-weight:500;
  color:var(--navy); margin:0 0 8px;
}
.td-tl-body p{
  font-size:14px; line-height:1.75; color:#5a6580; margin:0;
}

/* ITINERARY — interactive accordion */
.td-itin-list{
  border-top:1px solid var(--line-dark);
}
.td-itin-row{
  border-bottom:1px solid var(--line-dark);
  overflow:hidden;
}
.td-itin-header{
  display:flex; align-items:center; gap:24px;
  padding:22px 0; cursor:pointer;
  transition:opacity .2s ease;
}
.td-itin-header:hover{ opacity:0.7; }
.td-itin-n{
  font-family:var(--display); font-size:32px; font-weight:300;
  color:rgba(38,81,150,0.2); line-height:1; flex-shrink:0;
  width:48px; transition:color .3s ease;
}
.td-itin-row.open .td-itin-n{ color:var(--blue); }
.td-itin-hcol{ flex:1; }
.td-itin-label{
  font-size:10px; font-weight:700; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--blue); display:block; margin-bottom:4px;
}
.td-itin-header h4{
  font-family:var(--display); font-size:clamp(18px,2.2vw,24px);
  font-weight:400; color:var(--navy); margin:0; line-height:1.2;
  transition:color .3s ease;
}
.td-itin-row.open .td-itin-header h4{ color:var(--blue); }
.td-itin-plus{
  font-size:24px; font-weight:300; color:#9aa3b8;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1), color .3s ease;
  flex-shrink:0; width:28px; text-align:center;
}
.td-itin-row.open .td-itin-plus{
  transform:rotate(45deg);
  color:var(--blue);
}
.td-itin-body{
  max-height:0; overflow:hidden;
  transition:max-height .5s cubic-bezier(.4,0,.2,1), padding .4s ease;
  padding:0 0 0 72px;
}
.td-itin-row.open .td-itin-body{
  max-height:300px;
  padding:0 0 24px 72px;
}
.td-itin-body p{
  font-size:15px; line-height:1.8; color:#5a6580; margin:0;
  border-left:2px solid rgba(38,81,150,0.15); padding-left:20px;
}

/* INCLUDES/EXCLUDES */
.td-includes{ background:var(--white); }
.td-inex-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:40px;
}
@media(max-width:640px){ .td-inex-grid{ grid-template-columns:1fr; } }
.td-inex-label{
  font-size:10px; font-weight:700; letter-spacing:0.14em;
  text-transform:uppercase; padding:8px 0;
  border-bottom:2px solid; margin-bottom:16px;
}
.td-inex-yes{ color:#2e7d32; border-color:#2e7d32; }
.td-inex-no{ color:#c0392b; border-color:#c0392b; }
.td-inex-item{
  display:flex; align-items:flex-start; gap:10px;
  font-size:13.5px; line-height:1.55; color:#4a5568;
  padding:10px 0; border-bottom:1px solid var(--line-dark);
}
.td-inex-item svg{ width:16px; height:16px; flex-shrink:0; margin-top:2px; }
.td-inex-item-yes svg{ color:#2e7d32; }
.td-inex-item-no svg{ color:#c0392b; }

/* WHO FOR — dark pullquote */
.td-whoffor{
  background:var(--navy);
  padding:0;
}
.td-whoffor .td-section-inner{
  padding:clamp(56px,7vw,90px) clamp(24px,5vw,80px);
}
.td-whoffor-quote{
  font-family:var(--display); font-size:clamp(20px,3vw,32px);
  font-weight:400; font-style:italic;
  color:rgba(255,255,255,0.85); line-height:1.5;
  margin:20px 0 0; max-width:800px;
  border-left:2px solid rgba(255,255,255,0.2);
  padding-left:28px;
}

/* FAQ */
.td-faq{ background:var(--ivory); }

/* ============================================
   FUVAHMULAH DIVE MAP
   ============================================ */
.td-divemap{ background:var(--navy); }
.td-divemap .td-section-inner{ padding:clamp(60px,8vw,100px) clamp(24px,5vw,80px); }
.td-divemap .td-section-head h2{ color:var(--white); }
.td-divemap .eyebrow{ color:rgba(201,168,76,0.9); }
.td-map-sub{
  font-size:14px; color:rgba(255,255,255,0.5);
  line-height:1.65; margin-top:10px; max-width:600px;
}
.td-map-wrap{
  display:grid; grid-template-columns:280px 1fr;
  gap:32px; align-items:stretch; margin-top:40px;
}
@media(max-width:760px){
  .td-map-wrap{ grid-template-columns:1fr; }
}

/* Info panel */
.td-map-info{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:2px; padding:24px;
  display:flex; align-items:center; justify-content:center;
  min-height:280px;
}
.td-map-hint{
  font-size:13px; color:rgba(255,255,255,0.25);
  font-style:italic; text-align:center;
}
.td-map-card{ width:100%; }
.td-map-card-head{
  display:flex; justify-content:space-between;
  align-items:flex-start; margin-bottom:6px;
}
.td-map-card h4{
  font-family:var(--display); font-size:22px;
  font-weight:400; color:var(--white); margin:0;
}
.td-map-card-depth{
  font-size:11px; font-weight:700;
  color:rgba(201,168,76,0.9); letter-spacing:0.08em;
  text-transform:uppercase; flex-shrink:0; margin-top:4px;
}
.td-map-card-level{
  font-size:10px; color:rgba(255,255,255,0.35);
  text-transform:uppercase; letter-spacing:0.1em;
  margin:0 0 14px;
}
.td-map-card-text{
  font-size:13px; line-height:1.7;
  color:rgba(255,255,255,0.65); margin:0 0 16px;
}
.td-map-card-species{
  display:flex; flex-wrap:wrap; gap:6px;
}
.td-site-species{
  font-size:10px; font-weight:600;
  background:rgba(255,255,255,0.07);
  color:rgba(255,255,255,0.6);
  padding:3px 10px; border-radius:20px;
  letter-spacing:0.05em;
}

/* SVG map */
.td-map-svg{
  width:100%; height:auto; display:block;
  border-radius:2px; border:1px solid rgba(255,255,255,0.06);
}
.td-island{
  fill:rgba(34,90,34,0.5);
  stroke:rgba(255,255,255,0.2); stroke-width:1.2;
}
.td-island-label{
  font-family:Montserrat,sans-serif; font-size:11px;
  font-weight:700; letter-spacing:0.18em;
  fill:rgba(255,255,255,0.5); text-anchor:middle;
}
.td-island-sublabel{
  font-family:Montserrat,sans-serif; font-size:7px;
  letter-spacing:0.1em; fill:rgba(255,255,255,0.25);
  text-anchor:middle;
}

/* Dive site markers */
.td-dive-site{ cursor:pointer; }
.td-site-ring{
  fill:none; stroke:rgba(201,168,76,0.4); stroke-width:1.2;
  transition:all .3s ease;
}
.td-dive-site:hover .td-site-ring,
.td-dive-site.active .td-site-ring{
  stroke:rgba(201,168,76,0.9); stroke-width:1.8;
  r:20;
}
.td-site-dot{
  fill:rgba(201,168,76,0.85);
  transition:fill .3s ease, r .3s ease;
}
.td-site-dot.td-deep{ fill:rgba(38,81,150,0.9); }
.td-dive-site:hover .td-site-dot,
.td-dive-site.active .td-site-dot{ fill:#c9a84c; r:8; }
.td-dive-site:hover .td-site-dot.td-deep,
.td-dive-site.active .td-site-dot.td-deep{ fill:var(--blue); }
.td-site-lbl{
  font-family:Montserrat,sans-serif; font-size:8px;
  font-weight:600; letter-spacing:0.08em;
  fill:rgba(255,255,255,0.5); text-anchor:middle;
  transition:fill .3s ease;
  pointer-events:none;
}
.td-dive-site:hover .td-site-lbl,
.td-dive-site.active .td-site-lbl{
  fill:rgba(255,255,255,0.9);
}

#tdGoogleMap{
  width:100%; height:520px;
  border:none; display:block;
  filter:saturate(1.15) contrast(1.05) brightness(0.95);
}
.leaflet-tooltip{
  background:rgba(15,38,73,0.92) !important;
  border:1px solid rgba(255,255,255,0.15) !important;
  color:rgba(255,255,255,0.9) !important;
  font-family:Montserrat,sans-serif !important;
  font-size:11px !important;
  font-weight:600 !important;
  letter-spacing:0.04em !important;
  padding:5px 10px !important;
  border-radius:2px !important;
  box-shadow:0 4px 16px rgba(0,0,0,0.3) !important;
}
.leaflet-tooltip-top:before{
  border-top-color:rgba(15,38,73,0.92) !important;
}

.td-map-card-box{
  border-top:1px solid rgba(255,255,255,0.07);
  background:rgba(0,0,0,0.2);
  animation:bwIn .3s ease;
}
.td-map-card{ padding:16px 20px; }
.td-map-card-head{
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:8px;
}
.td-map-card h4{
  font-family:var(--display); font-size:20px;
  font-weight:400; color:var(--white); margin:0 0 2px;
}
.td-map-card-depth{
  font-size:11px; font-weight:700;
  color:rgba(201,168,76,0.9); letter-spacing:0.08em;
  text-transform:uppercase; flex-shrink:0; margin-top:3px;
  background:rgba(201,168,76,0.12); padding:3px 10px; border-radius:20px;
}
.td-map-card-level{
  font-size:10px; color:rgba(255,255,255,0.3);
  text-transform:uppercase; letter-spacing:0.08em; margin:0;
}
.td-map-card-text{
  font-size:13px; line-height:1.65;
  color:rgba(255,255,255,0.6); margin:0 0 12px;
}
.td-map-card-species{
  display:flex; flex-wrap:wrap; gap:6px;
}
.td-animal-tag{
  display:flex; align-items:center; gap:5px;
  background:rgba(255,255,255,0.07); border-radius:20px;
  padding:4px 10px; font-size:11px;
  color:rgba(255,255,255,0.65);
}
.td-animal-icon{ font-size:13px; }

/* ============================================
   DIVE SITES SECTION
   ============================================ */
.td-divemap .td-map-fullwrap{
  margin-top:36px; border-radius:3px;
  overflow:hidden; border:1px solid rgba(255,255,255,0.08);
}
.td-dive-sites-section{ background:var(--ivory); }
.td-dive-sites-section .td-section-head h2{ color:var(--navy); }

.td-ds-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(340px,1fr));
  gap:1px;
  background:rgba(15,38,73,0.1);
  border:1px solid rgba(15,38,73,0.1);
  border-radius:2px;
  overflow:hidden;
}
.td-ds-card{
  background:var(--white);
  display:flex; flex-direction:column;
  transition:box-shadow .3s ease, transform .3s ease;
  cursor:default; overflow:hidden;
}
.td-ds-card:hover{
  box-shadow:0 12px 40px rgba(15,38,73,0.12);
  transform:translateY(-2px);
}
.td-ds-photo{
  height:180px; width:100%;
  background-size:cover; background-position:center;
  position:relative; overflow:hidden; flex-shrink:0;
  transition:transform .5s ease;
}
.td-ds-card:hover .td-ds-photo{ transform:scale(1.04); }
.td-ds-photo-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(8,20,45,0.1) 0%, rgba(8,20,45,0.5) 100%);
}
.td-ds-card > .td-ds-num{
  display:none;
}
.td-ds-body{
  padding:20px 22px 22px;
  flex:1;
}
.td-ds-num{
  font-family:var(--display); font-size:36px; font-weight:300;
  color:rgba(15,38,73,0.1); line-height:1; flex-shrink:0;
  min-width:38px; letter-spacing:-0.03em;
  transition:color .3s ease; display:inline-block;
}
.td-ds-card:hover .td-ds-num{ color:rgba(38,81,150,0.2); }
.td-ds-body{ flex:1; min-width:0; }
.td-ds-head{
  display:flex; justify-content:space-between;
  align-items:center; gap:10px; margin-bottom:4px;
}
.td-ds-head h4{
  font-family:var(--display); font-size:19px; font-weight:500;
  color:var(--navy); margin:0; line-height:1.2;
}
.td-ds-meta{ display:flex; gap:6px; align-items:center; flex-shrink:0; }
.td-ds-badge{
  font-size:8px; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; padding:3px 8px; border-radius:20px;
  background:rgba(38,81,150,0.08); color:var(--blue);
}
.td-ds-badge.td-ds-deep{
  background:rgba(91,155,213,0.12); color:#4080c0;
}
.td-ds-depth{
  font-size:10px; font-weight:600; color:#9aa3b8;
  letter-spacing:0.04em;
}
.td-ds-nick{
  font-size:10px; color:#9aa3b8; letter-spacing:0.06em;
  text-transform:uppercase; margin:0 0 10px;
}
.td-ds-desc{
  font-size:13px; line-height:1.7; color:#5a6580;
  margin:0 0 12px;
}
.td-ds-animals{
  display:flex; flex-wrap:wrap; gap:5px;
}
.td-ds-animal{
  font-size:10.5px; color:#7a8399;
  background:rgba(15,38,73,0.04);
  border:1px solid rgba(15,38,73,0.08);
  padding:3px 9px; border-radius:20px;
  transition:all .2s ease;
}
.td-ds-card:hover .td-ds-animal{
  background:rgba(38,81,150,0.06);
  border-color:rgba(38,81,150,0.12);
  color:var(--blue);
}

/* Map only - no list */
#tdGoogleMap{
  width:100%; height:480px;
  border:none; display:block;
}

/* Animal tooltip */
/* Animal tag with inline tooltip */
.animal-tooltip{
  background:#fff;
  border-radius:3px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.2), 0 2px 12px rgba(0,0,0,0.08);
  border:1px solid rgba(15,38,73,0.07);
}
.at-img{
  width:100%; height:130px;
  background-size:cover; background-position:center;
}
.at-body{ padding:12px 14px; }
.at-latin{
  font-size:9px; color:#9aa3b8; letter-spacing:0.1em;
  font-style:italic; display:block; margin-bottom:3px;
}
.at-body strong{
  font-family:var(--display); font-size:16px; font-weight:500;
  color:var(--navy); display:block; margin-bottom:6px;
}
.at-body p{
  font-size:11px; line-height:1.6; color:#5a6580; margin:0;
}

.td-ds-animal{
  display:inline-flex; align-items:center; gap:7px;
  font-size:10.5px; color:#7a8399;
  border:1px solid rgba(15,38,73,0.1);
  padding:4px 12px 4px 8px; border-radius:20px;
  cursor:pointer; transition:all .2s ease;
}
.td-ds-animal:hover{
  border-color:var(--navy);
  color:var(--navy);
  background:rgba(15,38,73,0.04);
}
.td-ds-card:hover .td-ds-animal{ border-color:rgba(38,81,150,0.12); }
.td-animal-svg{
  display:flex; align-items:center;
  width:22px; height:16px; flex-shrink:0;
  color:var(--blue); opacity:0.7;
  transition:opacity .2s ease;
}
.td-ds-animal:hover .td-animal-svg{ opacity:1; color:var(--navy); }
.td-animal-svg svg{ width:100%; height:100%; }

/* ============================================
   EXPERIENCE SECTION
   ============================================ */
.td-experience-section{
  background:var(--navy);
  padding:0;
}
.td-experience-section .td-section-inner{
  padding:clamp(60px,8vw,100px) clamp(24px,5vw,80px);
}
.td-experience-section .eyebrow{ color:rgba(201,168,76,0.8); }
.td-experience-section h2{ color:var(--white); max-width:560px; }

.td-exp-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  margin-top:48px;
  border-top:1px solid rgba(255,255,255,0.08);
}
@media(max-width:640px){ .td-exp-grid{ grid-template-columns:1fr; } }
.td-exp-card{
  padding:36px 32px;
  border-bottom:1px solid rgba(255,255,255,0.06);
  border-right:1px solid rgba(255,255,255,0.06);
  transition:background .3s ease;
}
.td-exp-card:hover{ background:rgba(255,255,255,0.03); }
.td-exp-num{
  font-family:var(--display); font-size:13px;
  color:rgba(201,168,76,0.7); letter-spacing:0.12em;
  text-transform:uppercase; margin-bottom:14px;
}
.td-exp-card h3{
  font-family:var(--display); font-size:24px;
  font-weight:400; color:var(--white);
  margin:0 0 14px; line-height:1.2;
}
.td-exp-card p{
  font-size:14px; line-height:1.75;
  color:rgba(255,255,255,0.5); margin:0;
}

/* ============================================
   TRIP OVERVIEW — editorial 50/50
   ============================================ */
.td-overview{ background:var(--ivory); }
.td-ov-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:0;
}
@media(max-width:768px){ .td-ov-grid{ grid-template-columns:1fr; } }

.td-ov-text{
  padding:clamp(60px,8vw,100px) clamp(32px,5vw,72px);
  display:flex; flex-direction:column; justify-content:center;
}
.td-ov-text .eyebrow{ color:var(--blue); margin-bottom:16px; }
.td-ov-text h2{
  font-size:clamp(32px,4vw,52px);
  color:var(--navy); margin:0 0 20px;
}
.td-ov-lead{
  font-size:16px; line-height:1.8;
  color:#5a6580; margin:0 0 40px; max-width:480px;
}
.td-ov-facts{
  display:grid; grid-template-columns:1fr 1fr;
  gap:24px 32px; border-top:1px solid rgba(15,38,73,0.1);
  padding-top:32px;
}
.td-ov-fact{ display:flex; flex-direction:column; gap:4px; }
.td-ov-fact-val{
  font-family:var(--display); font-size:28px;
  font-weight:400; color:var(--navy); line-height:1;
}
.td-ov-fact-label{
  font-size:10px; text-transform:uppercase;
  letter-spacing:0.1em; color:#9aa3b8;
}
.td-ov-photo{
  background-size:cover; background-position:center;
  min-height:260px;
}

/* ============================================
   WEEK / ITINERARY
   ============================================ */
.td-week-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  margin-top:48px;
  border:1px solid rgba(15,38,73,0.1);
  border-radius:2px;
  overflow:hidden;
}
@media(max-width:640px){ .td-week-grid{ grid-template-columns:1fr; } }

.td-week-item{
  padding:36px 32px;
  border-right:1px solid rgba(15,38,73,0.08);
  border-bottom:1px solid rgba(15,38,73,0.08);
  background:#fff;
  transition:background .25s ease;
}
.td-week-item:hover{ background:var(--ivory); }
.td-week-day{
  font-size:10px; font-weight:700; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--blue);
  display:block; margin-bottom:10px;
}
.td-week-item h4{
  font-family:var(--display); font-size:20px;
  font-weight:500; color:var(--navy);
  margin:0 0 10px;
}
.td-week-item p{
  font-size:14px; line-height:1.75;
  color:#5a6580; margin:0;
}

/* Fix animal tooltip text size */
.animal-tooltip strong{
  font-family:'Cormorant Garamond', Georgia, serif;
  font-size:17px; font-weight:500;
  color:#0f2649; display:block; margin-bottom:6px;
}
.animal-tooltip .at-latin{
  font-size:10px; color:#9aa3b8;
  letter-spacing:0.1em; display:block;
  margin-bottom:4px; font-style:italic;
}
.animal-tooltip p{
  font-size:12px; line-height:1.65;
  color:#5a6580; margin:0;
}

/* Fix experience section text */
.td-exp-card p{
  font-size:14px; line-height:1.75;
  color:rgba(255,255,255,0.6); margin:0;
}
.td-exp-card h3{
  font-size:22px; margin:0 0 12px;
}

/* General readability fixes */
.td-map-sub{
  font-size:15px; color:#7a8399;
  line-height:1.7; margin-top:10px;
}

/* ============================================
   THE DIVE + THE ISLAND — split sections
   ============================================ */
.td-split-section{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:560px;
}
.td-split-section.td-split-reverse{ direction:rtl; }
.td-split-section.td-split-reverse > *{ direction:ltr; }
@media(max-width:768px){
  .td-split-section, .td-split-section.td-split-reverse{ grid-template-columns:1fr; direction:ltr; }
}
.td-split-photo{
  background-size:cover; background-position:center;
  min-height:400px;
}
.td-split-content{
  padding:clamp(52px,7vw,88px) clamp(32px,5vw,72px);
  background:var(--ivory);
  display:flex; flex-direction:column; justify-content:center;
}
.td-split-section:nth-child(even) .td-split-content{ background:#fff; }
.td-split-content .eyebrow{ color:var(--blue); margin-bottom:14px; }
.td-split-content h2{
  font-size:clamp(28px,3.5vw,44px);
  color:var(--navy); margin:0 0 18px; line-height:1.15;
}
.td-split-content p{
  font-size:15px; line-height:1.8; color:#5a6580; margin:0 0 14px;
}
.td-split-facts{
  display:flex; gap:32px; margin-top:32px;
  padding-top:28px; border-top:1px solid rgba(15,38,73,0.1);
}
.td-split-facts div{ display:flex; flex-direction:column; gap:3px; }
.td-split-facts strong{
  font-family:var(--display); font-size:22px;
  font-weight:500; color:var(--navy); line-height:1;
}
.td-split-facts span{
  font-size:10px; text-transform:uppercase;
  letter-spacing:0.09em; color:#9aa3b8;
}

/* Dive site number badge on photo */
.td-ds-num-badge{
  position:absolute; top:12px; left:14px;
  font-family:var(--display); font-size:22px;
  font-weight:300; color:rgba(255,255,255,0.7);
  line-height:1;
}
.td-ds-photo{ position:relative; }

/* Hidden sites */
.td-ds-hidden{ display:none !important; }

/* Expand button */
.td-ds-expand-wrap{
  text-align:center; padding:40px 0 0;
}
.td-ds-expand-btn{
  font-family:var(--body); font-size:12px;
  font-weight:600; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--navy);
  background:transparent; border:1px solid rgba(15,38,73,0.2);
  padding:14px 32px; border-radius:2px; cursor:pointer;
  transition:all .25s ease;
}
.td-ds-expand-btn:hover{
  background:var(--navy); color:#fff;
  border-color:var(--navy);
}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{ background:var(--navy-deep); color:#aebbd6; padding: 70px 28px 0; }
.footer-inner{ max-width:var(--maxw); margin:0 auto; display:flex; justify-content:space-between; gap:50px; flex-wrap:wrap; padding-bottom:50px; border-bottom:1px solid var(--line); }
.footer-mark{ display:flex; gap:14px; align-items:flex-start; max-width:280px; }
.footer-butterfly{ width:30px; height:30px; object-fit:contain; flex:none; margin-top:2px; }
.footer-word{ font-family: var(--display); font-size:20px; color:var(--white); margin-bottom:6px; }
.footer-tag{ font-size:13px; font-weight:300; }
.footer-cols{ display:flex; gap:60px; flex-wrap:wrap; }
.footer-cols > div{ display:flex; flex-direction:column; gap:12px; }
.footer-head{ font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:#7c8aac; margin-bottom:6px; font-weight:700; }
.footer-cols a{ font-size:13.5px; font-weight:300; transition: color .2s ease; }
.footer-cols a:hover{ color:var(--white); }
.footer-bottom{ max-width:var(--maxw); margin:0 auto; padding:26px 0; font-size:11.5px; color:#5e6c8c; }

/* ============================================
   LEGAL PAGES
   ============================================ */
.legal-page{ padding-bottom: 100px; }
.legal-inner{ max-width: 760px; margin: 0 auto; }
.legal-inner .eyebrow{ display:block; margin-bottom:14px; }
.legal-inner h1{ font-size: clamp(32px,4.6vw,46px); color:var(--navy); margin-bottom:10px; }
.legal-updated{ font-size:13px; color:#9aa3b8; font-weight:300; margin-bottom:48px; }
.legal-body h3{
  font-family: var(--display); font-size:21px; color:var(--navy); font-weight:600;
  margin: 38px 0 14px;
}
.legal-body p{ font-size:15px; line-height:1.85; color:#46506b; font-weight:300; margin-bottom:16px; }
.legal-body ul{ margin: 8px 0 16px; padding-left:22px; }
.legal-body li{ font-size:15px; line-height:1.85; color:#46506b; font-weight:300; margin-bottom:8px; }
.legal-body a{ color:var(--blue); font-weight:600; }
.legal-body strong{ color:var(--navy); font-weight:600; }
/* ============================================
   FUVAHMULAH DIVE MAP — REAL IMAGE VERSION
   ============================================ */
.td-divemap{ background:var(--navy); }
.td-divemap .td-section-inner{ padding:clamp(60px,8vw,100px) clamp(24px,5vw,80px); }
.td-divemap .td-section-head h2{ color:var(--white); }
.td-divemap .eyebrow{ color:rgba(201,168,76,0.9); }
.td-map-sub{
  font-size:14px; color:rgba(255,255,255,0.5);
  line-height:1.65; margin-top:10px; max-width:640px;
}
.td-map-wrap{
  display:grid; grid-template-columns:220px 1fr;
  gap:0; margin-top:40px; border:1px solid rgba(255,255,255,0.08);
  border-radius:3px; overflow:hidden;
}
@media(max-width:800px){ .td-map-wrap{ grid-template-columns:1fr; } }

/* List panel */
.td-site-list{
  background:rgba(0,0,0,0.25);
  border-right:1px solid rgba(255,255,255,0.07);
  overflow-y:auto; max-height:560px;
}
.td-site-list-item{
  display:flex; align-items:center; gap:12px;
  padding:11px 16px; cursor:pointer;
  border-bottom:1px solid rgba(255,255,255,0.05);
  transition:background .2s ease;
}
.td-site-list-item:hover{ background:rgba(255,255,255,0.05); }
.td-site-list-item.active{ background:rgba(201,168,76,0.12); border-left:2px solid #c9a84c; padding-left:14px; }
.td-list-num{
  font-family:var(--display); font-size:18px; font-weight:300;
  color:rgba(201,168,76,0.6); min-width:24px; line-height:1;
}
.td-site-list-item.active .td-list-num{ color:#c9a84c; }
.td-site-list-item.td-list-deep .td-list-num{ color:rgba(100,140,220,0.7); }
.td-site-list-item.td-list-deep.active .td-list-num{ color:#6496dc; }
.td-list-info{ display:flex; flex-direction:column; gap:2px; }
.td-list-name{
  font-size:11.5px; font-weight:600; color:rgba(255,255,255,0.75);
  line-height:1.2;
}
.td-site-list-item.active .td-list-name{ color:var(--white); }
.td-list-sub{
  font-size:9.5px; color:rgba(255,255,255,0.3); letter-spacing:0.04em;
}

/* Right panel */
.td-map-right{
  display:flex; flex-direction:column;
  background:rgba(0,0,0,0.1);
}
.td-map-container{
  flex:1; position:relative; overflow:hidden;
  min-height:380px;
}
.td-map-img{
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  display:block;
}
.td-map-overlay{
  position:absolute; inset:0;
  width:100%; height:100%;
}

/* Dots */
.td-map-dot{ cursor:pointer; }
.td-dot-pulse{
  fill:none; stroke:rgba(201,168,76,0); stroke-width:2;
  transition:all .3s ease;
}
.td-map-dot:hover .td-dot-pulse,
.td-map-dot.active .td-dot-pulse{
  stroke:rgba(201,168,76,0.5); stroke-width:2;
  animation:dotPulse 1.5s ease-in-out infinite;
}
@keyframes dotPulse{
  0%,100%{ r:12; opacity:0.8; }
  50%{ r:20; opacity:0; }
}
.td-dot-shallow{
  fill:rgba(201,168,76,0.85); stroke:rgba(255,255,255,0.4); stroke-width:1.2;
  transition:r .3s ease;
}
.td-dot-deep{
  fill:rgba(80,130,220,0.85); stroke:rgba(255,255,255,0.4); stroke-width:1.2;
  transition:r .3s ease;
}
.td-map-dot:hover .td-dot-shallow,
.td-map-dot.active .td-dot-shallow{ fill:#c9a84c; r:10; }
.td-map-dot:hover .td-dot-deep,
.td-map-dot.active .td-dot-deep{ fill:#80a8f0; r:10; }
.td-dot-num{
  font-family:Montserrat,sans-serif; font-size:8px; font-weight:700;
  fill:rgba(15,38,73,0.9); text-anchor:middle; pointer-events:none;
}

/* Info card */
.td-map-card-box{
  padding:18px 20px;
  border-top:1px solid rgba(255,255,255,0.07);
  min-height:130px; background:rgba(0,0,0,0.2);
}
.td-map-hint{
  font-size:12px; color:rgba(255,255,255,0.2);
  font-style:italic; margin:0;
  padding-top:12px;
}
.td-map-card{ width:100%; }
.td-map-card-head{
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:4px;
}
.td-map-card h4{
  font-family:var(--display); font-size:18px;
  font-weight:400; color:var(--white); margin:0;
}
.td-map-card-depth{
  font-size:10px; font-weight:700;
  color:rgba(201,168,76,0.9); letter-spacing:0.08em;
  text-transform:uppercase; margin-top:3px; flex-shrink:0;
}
.td-map-card-level{
  font-size:10px; color:rgba(255,255,255,0.3);
  text-transform:uppercase; letter-spacing:0.08em; margin:0 0 8px;
}
.td-map-card-text{
  font-size:12.5px; line-height:1.65;
  color:rgba(255,255,255,0.6); margin:0 0 10px;
}
.td-map-card-species{
  display:flex; flex-wrap:wrap; gap:5px;
}
.td-site-species{
  font-size:9.5px; font-weight:600;
  background:rgba(255,255,255,0.07);
  color:rgba(255,255,255,0.55);
  padding:2px 9px; border-radius:20px; letter-spacing:0.04em;
}


/* HERO VIDEO */
.trip-hero{ position:relative; overflow:hidden; }
.trip-hero-bg-video{ position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0; }
.trip-hero-overlay{ position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(6,14,32,0.55) 0%,rgba(6,14,32,0.1) 50%,transparent 100%); }
.trip-hero-inner{ position:relative;z-index:2; }

/* SPLIT VIDEO */
.td-split-video{ position:relative;min-height:560px;overflow:hidden;flex:1; }
.td-split-video video{ position:absolute;inset:0;width:100%;height:100%;object-fit:cover; }

/* MINI MAP */
.td-split-map-live{ min-height:560px;flex:1;position:relative; }
.td-split-map-live .leaflet-container{ height:100%!important;min-height:560px; }
.td-split-map-live .leaflet-control-zoom-in,
.td-split-map-live .leaflet-control-zoom-out{ background:#c9a84c!important;color:#0f2649!important;border:none!important;font-weight:900!important; }

/* HOTEL SECTION */
.td-hotel-section{ background:var(--ivory);padding:80px 28px; }
.td-hotel-grid{ display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:var(--maxw);margin:0 auto; }
@media(max-width:900px){ .td-hotel-grid{ grid-template-columns:1fr; } }
.td-hotel-text .eyebrow{ display:block;margin-bottom:12px; }
.td-hotel-text h2{ font-size:clamp(28px,3vw,38px);color:var(--navy);margin-bottom:16px; }
.td-hotel-text p{ font-size:15px;line-height:1.7;color:#56607a;margin-bottom:20px; }
.td-hotel-features{ padding:0 0 0 18px;margin:0; }
.td-hotel-features li{ font-size:14px;color:#46506b;line-height:2.1; }
.td-hotel-photos{ display:grid;grid-template-columns:1fr 1fr;gap:8px; }
.td-hotel-img-main{ grid-column:1/-1;width:100%;height:220px;object-fit:cover;border-radius:2px; }
.td-hotel-img-sec{ width:100%;height:140px;object-fit:cover;border-radius:2px; }

/* DIVE SITES — 4 cols, centered */
.td-ds-grid{ max-width:var(--maxw);margin:0 auto;grid-template-columns:repeat(4,1fr)!important; }
@media(max-width:900px){ .td-ds-grid{ grid-template-columns:repeat(2,1fr)!important; } }
@media(max-width:500px){ .td-ds-grid{ grid-template-columns:1fr!important; } }
.td-ds-expand-wrap{ margin-top:36px;text-align:center; }
.td-ds-expand-btn{ background:none;border:1px solid var(--line-dark);color:var(--navy);padding:14px 40px;font-family:var(--body);font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:all 0.2s; }
.td-ds-expand-btn:hover{ background:var(--navy);color:#fff;border-color:var(--navy); }

/* STICKY CALENDAR */
.td-cal-sidebar{ position:fixed;top:80px;right:0;width:300px;z-index:500; }
.td-cal-widget{ background:#fff;border:1px solid var(--line-dark);border-right:none;border-radius:4px 0 0 4px;padding:20px;box-shadow:-4px 0 20px rgba(6,14,32,0.12);max-height:calc(100vh - 100px);overflow-y:auto; }
.td-cal-teaser{ margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--line-dark); }
.td-cal-teaser-val{ display:block;font-family:var(--display);font-size:22px;color:var(--navy);font-weight:600; }
.td-cal-teaser-label{ display:block;font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:#9aa3b8;margin-top:2px;margin-bottom:8px; }
.td-cal-teaser-hint{ font-size:12px;color:#9aa3b8;line-height:1.5;margin:0; }
.td-bw-tabs{ display:flex;border-bottom:1px solid var(--line-dark);margin-bottom:16px; }
.td-bw-tab{ flex:1;background:none;border:none;padding:8px 4px;font-family:var(--body);font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#9aa3b8;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all 0.2s; }
.td-bw-tab.active{ color:var(--navy);border-bottom-color:var(--navy); }
.td-bw-hidden{ display:none; }
.td-bw-nights{ display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px; }
.td-bw-nights-label{ font-size:11px;color:#7a8399;margin:0 0 10px; }
.td-bw-cal-nav{ display:flex;align-items:center;justify-content:space-between;margin-bottom:8px; }
.td-bw-cal-nav button{ background:none;border:1px solid var(--line-dark);padding:4px 10px;cursor:pointer;border-radius:2px;font-size:13px;color:var(--navy); }
.td-bw-cal-nav span{ font-weight:700;font-size:13px;color:var(--navy); }
.td-bw-cal{ display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:14px; }
.td-bw-next{ width:100%;padding:11px;font-size:12px; }
.td-bw-back{ background:none;border:none;color:var(--blue);font-size:11px;cursor:pointer;padding:0 0 12px;display:block; }
.td-bw-submit{ width:100%;padding:12px;font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;font-family:var(--body);background:var(--gold);color:var(--navy);border:none;cursor:pointer;border-radius:2px;margin-top:6px; }
.td-bw-submit:hover{ background:#d4b05a; }
.pm-input{ width:100%;border:1px solid var(--line-dark);padding:10px 12px;font-size:13px;margin-bottom:10px;border-radius:2px;font-family:var(--body);box-sizing:border-box; }

/* FLOATING BAR */
.td-float-bar{ position:fixed;bottom:0;left:0;right:0;z-index:800;background:var(--navy);border-top:1px solid rgba(255,255,255,0.1);padding:12px 28px;display:flex;align-items:center;justify-content:center;gap:12px; }
.td-float-bar-btn{ padding:10px 24px;font-size:12px;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;font-family:var(--body);border-radius:2px;cursor:pointer;text-decoration:none;border:none;transition:all 0.2s; }
.td-float-primary{ background:var(--gold);color:var(--navy); }
.td-float-wa{ background:#25D366;color:#fff!important;display:flex;align-items:center;gap:8px; }

/* PLAN MODAL */
.pm-overlay{ position:fixed;inset:0;background:rgba(6,14,32,0.82);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px; }
.pm-wrap{ background:#fff;border-radius:4px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;padding:40px;position:relative; }
.pm-close{ position:absolute;top:16px;right:16px;background:none;border:none;font-size:18px;cursor:pointer;color:#7a8399; }
.pm-wrap h3{ font-family:var(--display);font-size:26px;color:var(--navy);margin-bottom:16px; }

/* QUICKFACTS INSIDE HERO */
.td-hero-quickfacts{
  background:rgba(6,14,32,0.72);
  backdrop-filter:blur(8px);
  border-top:1px solid rgba(255,255,255,0.1);
  position:relative; z-index:2;
}
.td-hero-quickfacts .quickfacts-grid{
  display:flex; flex-wrap:wrap;
}
.td-hero-quickfacts .qf{
  flex:1; min-width:120px;
  padding:18px 24px;
  border-right:1px solid rgba(255,255,255,0.1);
}
.td-hero-quickfacts .qf:last-child{ border-right:none; }
.td-hero-quickfacts .qf-label{
  font-size:9px; letter-spacing:0.12em; text-transform:uppercase;
  color:rgba(255,255,255,0.45); margin-bottom:5px;
}
.td-hero-quickfacts .qf-value{
  font-size:13px; font-weight:600; color:#fff;
}

/* Override old quickfacts styles when inside hero */
.td-hero-quickfacts .section-inner{ max-width:none; padding:0; }

/* REQUEST MODAL - full screen */
.td-request-modal{
  position:fixed; inset:0; background:rgba(6,14,32,0.88);
  z-index:9000; display:flex; align-items:center; justify-content:center; padding:24px;
}
.td-request-modal-inner{
  background:#fff; border-radius:4px; max-width:900px; width:100%;
  max-height:90vh; overflow-y:auto; padding:48px; position:relative;
}
.td-request-close{
  position:absolute; top:20px; right:20px; background:none; border:none;
  font-size:20px; cursor:pointer; color:#7a8399; line-height:1;
}
.td-request-close:hover{ color:var(--navy); }
.td-request-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start;
}
@media(max-width:700px){ .td-request-grid{ grid-template-columns:1fr; } }
.td-request-left .eyebrow{ display:block; margin-bottom:16px; }
.td-request-right .eyebrow{ display:block; margin-bottom:8px; }
.td-request-right h3{
  font-family:var(--display); font-size:28px; color:var(--navy); margin-bottom:12px;
}
.td-request-submit{
  width:100%; padding:16px; font-size:13px; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; font-family:var(--body); background:var(--navy);
  color:#fff; border:none; cursor:pointer; border-radius:2px; margin-top:4px;
  transition:background 0.2s;
}
.td-request-submit:hover{ background:var(--blue); }

/* CALENDAR SIDEBAR SIMPLIFIED */
.td-cal-eyebrow{ font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:12px;display:block; }
.td-cal-continue{ width:100%;padding:13px;font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;font-family:var(--body);background:var(--navy);color:#fff;border:none;cursor:pointer;border-radius:2px;margin-top:12px;transition:background 0.2s; }
.td-cal-continue:hover{ background:var(--blue); }

/* REQUEST MODAL STEPS */
.td-modal-steps{ }
.td-modal-step h3{ font-family:var(--display);font-size:28px;color:var(--navy);margin:8px 0 20px; }
.td-request-next{ width:100%;padding:15px;font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;font-family:var(--body);background:var(--navy);color:#fff;border:none;cursor:pointer;border-radius:2px;margin-top:20px;transition:background 0.2s; }
.td-request-next:hover{ background:var(--blue); }
.td-request-back{ background:none;border:none;color:var(--blue);font-size:12px;cursor:pointer;padding:10px 0 0;display:block;font-family:var(--body); }

/* MODAL FINAL STEP GRID */
.td-modal-final-grid{ display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start; }
@media(max-width:700px){ .td-modal-final-grid{ grid-template-columns:1fr; } }
.td-modal-summary .eyebrow,.td-modal-form .eyebrow{ display:block;margin-bottom:8px; }
.td-modal-form h3{ font-family:var(--display);font-size:26px;color:var(--navy);margin:8px 0 12px; }

/* Calendar subtitle */
.td-cal-subtitle{ font-size:12px;color:#9aa3b8;margin:0 0 14px;line-height:1.5; }

/* Price badge after room selected */
.td-modal-price-badge{
  background:var(--ivory); border:1px solid var(--line-dark);
  border-radius:2px; padding:12px 16px; margin:12px 0;
  font-family:var(--display); font-size:20px; color:var(--navy);
  font-weight:600; text-align:center;
}

/* ROOM CARDS */
.bw-room-card{ border:1.5px solid var(--line-dark);border-radius:3px;overflow:hidden;cursor:pointer;transition:border-color 0.2s;margin-bottom:10px; }
.bw-room-card.selected{ border-color:var(--navy);box-shadow:0 0 0 1px var(--navy); }
.bw-room-photo{ height:200px;background-size:cover;background-position:center;background-color:#1a3a5c; }
.bw-room-body{ padding:14px 16px; }
.bw-room-top{ display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px; }
.bw-room-name{ font-size:15px;font-weight:600;color:var(--navy); }
.bw-room-price{ font-family:var(--display);font-size:18px;color:var(--navy);font-weight:600; }
.bw-room-unit{ font-size:11px;font-weight:400;color:#9aa3b8; }
.bw-room-sub{ font-size:12px;color:#7a8399;line-height:1.5; }
.bw-room-check{ font-size:11px;color:#2a7a4a;font-weight:700;margin-top:6px; }

/* SUMMARY LINES */
.td-summary-line{ display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line-dark);font-size:13px; }
.td-summary-line span{ color:#7a8399; }
.td-summary-line strong{ color:var(--navy); }
.td-summary-total{ display:flex;justify-content:space-between;padding:14px 0 0;font-size:14px;font-weight:700; }
.td-summary-total span{ color:var(--navy); }
.td-summary-total strong{ font-family:var(--display);font-size:20px;color:var(--navy); }


/* ROOM CARDS IN MODAL - horizontal grid */
#tdModalRooms{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media(max-width:700px){ #tdModalRooms{ grid-template-columns:1fr; } }
#tdModalRooms .bw-room-card{ margin-bottom:0; }
#tdModalRooms .bw-room-photo{ height:180px; }

/* ADDON GRID */
.bw-addon-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media(max-width:700px){ .bw-addon-grid{ grid-template-columns:1fr 1fr; } }
.bw-addon-card{ border:1.5px solid var(--line-dark);border-radius:3px;overflow:hidden;cursor:pointer;transition:border-color 0.2s; }
.bw-addon-card.selected{ border-color:var(--navy);box-shadow:0 0 0 1px var(--navy); }
.bw-ao-img{ height:120px;background-size:cover;background-position:center;background-color:#e8e4dc; }
.bw-ao-body{ padding:12px 14px; }
.bw-ao-top{ display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px; }
.bw-ao-top strong{ font-size:14px;font-weight:600;color:var(--navy); }
.bw-ao-price{ font-size:13px;color:var(--blue);font-weight:600; }
.bw-ao-sub{ font-size:12px;color:#7a8399;line-height:1.4; }
.bw-ao-check{ font-size:11px;color:#2a7a4a;font-weight:700;margin-top:6px; }

/* ROOM CARD CLEAN LAYOUT */
.bw-room-card .bw-room-body{ padding:16px; }
.bw-room-card .bw-room-top{ display:flex; justify-content:space-between; align-items:center; gap:8px; margin-bottom:6px; }
.bw-room-card .bw-room-name{ font-size:15px; font-weight:700; color:var(--navy); white-space:nowrap; }
.bw-room-card .bw-room-price{ font-family:var(--display); font-size:18px; color:var(--navy); font-weight:600; white-space:nowrap; }
.bw-room-card .bw-room-unit{ font-size:10px; font-weight:400; color:#9aa3b8; display:block; text-align:right; }
.bw-room-card .bw-room-sub{ font-size:12px; color:#7a8399; line-height:1.5; margin:0; }
.bw-room-card .bw-room-check{ font-size:11px; color:#2a7a4a; font-weight:700; margin-top:8px; letter-spacing:0.04em; }

/* ROOM IMAGE TAG */
.bw-room-img{ width:100%; height:200px; object-fit:cover; display:block; background:#1a3a5c; }

/* ROOM CARDS — clean layout fix */
#tdModalRooms .bw-room-card{ display:flex; flex-direction:column; }
#tdModalRooms .bw-room-img{ width:100%; height:180px; object-fit:cover; display:block; flex-shrink:0; }
#tdModalRooms .bw-room-body{ padding:16px; flex:1; display:flex; flex-direction:column; gap:6px; }
#tdModalRooms .bw-room-top{ display:flex; flex-direction:column; gap:2px; }
#tdModalRooms .bw-room-name{ font-family:var(--display); font-size:18px; color:var(--navy); font-weight:600; }
#tdModalRooms .bw-room-price{ font-size:15px; color:var(--blue); font-weight:700; }
#tdModalRooms .bw-room-unit{ font-size:10px; color:#9aa3b8; font-weight:400; }
#tdModalRooms .bw-room-sub{ font-size:12px; color:#7a8399; line-height:1.5; }
#tdModalRooms .bw-room-check{ font-size:11px; color:#2a7a4a; font-weight:700; letter-spacing:0.04em; margin-top:auto; padding-top:8px; }

/* PEOPLE SELECTOR */
.td-cal-people-row{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; padding-bottom:14px; border-bottom:1px solid var(--line-dark); }
.td-cal-people-label{ font-size:11px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--navy); }
.td-cal-people-ctrl{ display:flex; align-items:center; gap:12px; }
.td-cal-people-ctrl button{ width:28px; height:28px; border:1px solid var(--line-dark); background:none; border-radius:50%; cursor:pointer; font-size:16px; color:var(--navy); display:flex; align-items:center; justify-content:center; line-height:1; transition:all 0.15s; }
.td-cal-people-ctrl button:hover{ background:var(--navy); color:#fff; border-color:var(--navy); }
.td-cal-people-ctrl span{ font-family:var(--display); font-size:20px; color:var(--navy); font-weight:600; min-width:20px; text-align:center; }

/* STEP C — shark photo background */
.td-modal-step-final{
  min-height:100vh;
  background:#fff;
  padding:80px 60px 60px;
}
.td-modal-step-final .td-modal-final-grid{ max-width:900px; margin:0 auto; }
@media(max-width:700px){ .td-modal-step-final{ padding:60px 24px 40px; } }

/* TRIP BANNER - small photo at top of summary step */
.td-modal-trip-banner{
  position:relative; height:160px; border-radius:4px; overflow:hidden; margin-bottom:36px;
}
.td-modal-trip-img{
  width:100%; height:100%; object-fit:cover; object-position:center 40%;
  display:block;
}
.td-modal-trip-banner-text{
  position:absolute; bottom:0; left:0; right:0;
  padding:16px 20px;
  background:linear-gradient(transparent, rgba(6,14,32,0.75));
}
.td-modal-trip-banner-text span{
  color:#fff; font-family:var(--display); font-size:18px; font-weight:400;
}

/* SUMMARY ITEMS - premium style */
.td-modal-sum-title{ font-family:var(--display); font-size:32px; color:var(--navy); margin:6px 0 24px; }
.td-sum-item{ display:flex; flex-direction:column; gap:2px; padding:14px 0; border-bottom:1px solid var(--line-dark); }
.td-sum-k{ font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:#9aa3b8; }
.td-sum-v{ font-size:15px; color:var(--navy); font-weight:500; }
.td-sum-total{ display:flex; flex-direction:column; gap:4px; padding:20px 0 0; }
.td-sum-total span:first-child{ font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:#9aa3b8; }
.td-sum-total strong{ font-family:var(--display); font-size:32px; color:var(--navy); font-weight:600; }
.td-sum-pp{ font-size:12px; color:#9aa3b8; }

/* Form side title */
.td-modal-form .eyebrow{ display:block; margin-bottom:6px; color:#9aa3b8; }
.td-modal-form h3{ font-family:var(--display); font-size:28px; color:var(--navy); margin:4px 0 8px; }
.td-modal-form > p{ font-size:13px; color:#7a8399; margin-bottom:20px; line-height:1.6; }

/* MODAL TOPBAR */
.td-modal-topbar{
  padding:16px 24px; border-bottom:1px solid var(--line-dark);
  position:sticky; top:0; background:#fff; z-index:10;
}
.td-modal-back-site{
  background:none; border:none; cursor:pointer; font-family:var(--body);
  font-size:12px; font-weight:600; letter-spacing:0.06em; text-transform:uppercase;
  color:#9aa3b8; display:flex; align-items:center; gap:8px;
  transition:color 0.2s;
}
.td-modal-back-site:hover{ color:var(--navy); }

/* EXTRAS SECTION — photo hover cards */
.td-extras-section{ background:var(--ivory); padding:80px 28px; }
.td-extras-section .td-section-head{ max-width:var(--maxw); margin:0 auto 48px; }
.td-extras-section .eyebrow{ color:var(--blue); }
.td-extras-section h2{ color:var(--navy); }
.td-extras-section p{ color:#56607a; }
.td-extras-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:3px;
  max-width:var(--maxw); margin:0 auto;
}
@media(max-width:900px){ .td-extras-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:500px){ .td-extras-grid{ grid-template-columns:1fr; } }
.td-extra-card{
  position:relative; height:320px; overflow:hidden; cursor:pointer;
  background-size:cover; background-position:center;
}
.td-extra-card::before{
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(6,14,32,0.85) 0%, rgba(6,14,32,0.2) 60%, transparent 100%);
  z-index:1; transition:opacity 0.4s ease;
}
.td-extra-card:hover::before{
  background:rgba(6,14,32,0.82);
}
.td-extra-label{
  position:absolute; bottom:24px; left:24px; z-index:2;
  font-family:var(--display); font-size:22px; color:#fff; font-weight:400;
  transition:transform 0.4s ease, opacity 0.3s ease;
}
.td-extra-overlay{
  position:absolute; inset:0; z-index:3;
  display:flex; flex-direction:column; justify-content:center;
  padding:32px; opacity:0; transform:translateY(10px);
  transition:opacity 0.35s ease, transform 0.35s ease;
}
.td-extra-overlay h4{
  font-family:var(--display); font-size:24px; color:#fff;
  margin-bottom:12px; font-weight:400;
}
.td-extra-overlay p{
  font-size:14px; color:rgba(255,255,255,0.8); line-height:1.7; margin:0;
}
.td-extra-card:hover .td-extra-label{ opacity:0; transform:translateY(-8px); }
.td-extra-card:hover .td-extra-overlay{ opacity:1; transform:translateY(0); }

/* ===== TRIP PAGE — MORE BREATHING ROOM ===== */
.td-split-section{ min-height:600px; }
.td-split-content{ padding:80px 64px; }

.td-dive-sites-section .td-section-inner{ padding-top:80px; padding-bottom:60px; }
.td-extras-section{ padding:60px 28px; }
.td-hotel-section{ padding:100px 28px; }
.td-logistics{ padding:60px 28px; }

/* More space around section heads */
.td-section-head{ margin-bottom:56px; }
.td-section-head h2{ margin-bottom:12px; }

/* Space between quickfacts and first content */
.td-hero-quickfacts + *,
.quickfacts + *{ margin-top:0; }

/* Overview section more air */
.td-overview{ padding:100px 28px; }
.td-ov-grid{ gap:80px; }

/* Who is this for */
.td-whoffor{ padding:100px 28px; }

/* FAQ */
.td-faq .td-section-inner{ padding-top:100px; padding-bottom:100px; }

/* Final CTA */
.section.final-cta{ padding:100px 28px; }

/* global section spacing removed — trip detail only */

/* ===== TRIP DETAIL — SPACE BETWEEN SPLIT SECTIONS ===== */
.td-split-section + .td-split-section{ margin-top:80px; }
.td-split-section + .td-hotel-section{ margin-top:80px; }
.td-hotel-section + .td-extras-section{ margin-top:0; }
.td-extras-section + .td-dive-sites-section{ margin-top:80px; }
.td-dive-sites-section + .td-whoffor{ margin-top:80px; }
.td-whoffor + .td-faq{ margin-top:0; }

/* ── LANG SWITCHER ────────────────────────────── */
.lang-switcher{ display:flex;align-items:center;gap:3px;margin-left:20px; }
.lang-btn{ background:none;border:none;color:rgba(255,255,255,0.4);font-family:Montserrat,sans-serif;font-size:10px;font-weight:600;letter-spacing:.1em;cursor:pointer;padding:3px 2px;transition:color .2s;text-transform:uppercase; }
.lang-btn:hover,.lang-btn.active{ color:rgba(255,255,255,0.9); }
.lang-sep{ color:rgba(255,255,255,0.2);font-size:9px;line-height:1; }
.nav.scrolled .lang-btn{ color:rgba(15,38,73,0.35); }
.nav.scrolled .lang-btn:hover,.nav.scrolled .lang-btn.active{ color:var(--navy); }
.nav.scrolled .lang-sep{ color:rgba(15,38,73,0.2); }
@media(max-width:900px){ .lang-switcher{ display:none; } }

