/* Start custom CSS *//* ============================================================
   Tioman Fun Dive — "Bioluminescent Abyss" 
   Dark immersive premium · Syne + Plus Jakarta Sans
   TDB Tioman Dive Buddy 2025
   ============================================================ */

/* === GAP FIX (Elementor HTML Widget) === */
.tdb-fundive-page {
  margin-top: -40px;
}

/* Immediate wrapper — .elementor-widget-container */
.elementor-widget-container:has(> .tdb-fundive-page) {
  padding: 0 !important;
  margin: 0 !important;
}

/* Widget level */
.elementor-widget:has(.tdb-fundive-page) {
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Widget wrap */
.elementor-widget-wrap:has(.tdb-fundive-page) {
  padding: 0 !important;
  margin: 0 !important;
}

/* Column populated */
.elementor-element-populated:has(.tdb-fundive-page) {
  padding: 0 !important;
  margin: 0 !important;
}

/* Column */
.elementor-column:has(.tdb-fundive-page) {
  padding: 0 !important;
  width: 100% !important;
}

/* Container / Row */
.elementor-container:has(.tdb-fundive-page) {
  padding: 0 !important;
  margin: 0 auto !important;
  max-width: 100% !important;
}
.elementor-row:has(.tdb-fundive-page) {
  padding: 0 !important;
  margin: 0 !important;
}

/* Section */
.elementor-section:has(.tdb-fundive-page) {
  padding: 0 !important;
  margin: 0 !important;
}

/* Elementor top-level content area */
.elementor:has(.tdb-fundive-page) > .elementor-section-wrap > .elementor-section {
  padding: 0 !important;
  margin: 0 !important;
}

/* Mobile 33px side padding */
@media only screen and (max-width: 767px) {
  .content_wrapper .section_wrapper:has(.tdb-fundive-page),
  .container:has(.tdb-fundive-page) {
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

/* === RESET & TOKENS === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Abyss palette */
  --abyss:#070B14;
  --abyss-mid:#0D1321;
  --abyss-light:#131A2E;
  --surface:#1A2342;
  --surface-light:#222D4A;
  /* Bioluminescent accents */
  --cyan:#00E5FF;
  --cyan-dim:rgba(0,229,255,.15);
  --cyan-glow:rgba(0,229,255,.4);
  --teal:#00B4D8;
  --teal-deep:#006D77;
  /* Warm accents */
  --amber:#FFB703;
  --amber-dk:#E5A300;
  --coral:#FF6B6B;
  --coral-dk:#E55555;
  /* Neutrals */
  --white:#FFFFFF;
  --snow:#F0F4F8;
  --mist:#94A3B8;
  --slate:#64748B;
  --text:#E2E8F0;
  --text-dim:#8892A4;
  /* Typography */
  --font-display:'Syne',sans-serif;
  --font-body:'Plus Jakarta Sans','Segoe UI',sans-serif;
  /* Spacing */
  --sp-xs:.5rem;--sp-sm:1rem;--sp-md:1.5rem;--sp-lg:2.5rem;--sp-xl:4rem;
  /* Shapes */
  --radius:8px;--radius-lg:16px;--radius-xl:24px;
  /* Shadows */
  --glow-sm:0 0 20px rgba(0,229,255,.12);
  --glow-md:0 0 40px rgba(0,229,255,.15);
  --glow-lg:0 4px 60px rgba(0,229,255,.2);
  --shadow-card:0 4px 24px rgba(0,0,0,.4);
  --shadow-hover:0 8px 40px rgba(0,229,255,.15);
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text);background:var(--abyss);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--cyan);text-decoration:none;transition:color .25s,filter .25s}
a:hover{color:var(--white);filter:drop-shadow(0 0 6px var(--cyan-glow))}
.tdb-container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--sp-md)}

/* === BUBBLES === */
.tdb-bubbles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.tdb-bubble{position:absolute;border-radius:50%;opacity:0;animation:bubbleFloat linear infinite}
@keyframes bubbleFloat{
  0%{transform:translateY(0) scale(.3);opacity:0}
  8%{opacity:1}
  50%{opacity:.6}
  100%{transform:translateY(-120vh) scale(1);opacity:0}
}
.tdb-bubble--1{width:10px;height:10px;left:6%;bottom:-14px;background:var(--cyan-dim);box-shadow:0 0 8px var(--cyan-dim);animation-duration:11s;animation-delay:0s}
.tdb-bubble--2{width:18px;height:18px;left:18%;bottom:-24px;background:rgba(0,180,216,.1);box-shadow:0 0 12px rgba(0,180,216,.15);animation-duration:14s;animation-delay:2s}
.tdb-bubble--3{width:7px;height:7px;left:32%;bottom:-10px;background:var(--cyan-dim);box-shadow:0 0 6px var(--cyan-dim);animation-duration:9s;animation-delay:1s}
.tdb-bubble--4{width:14px;height:14px;left:48%;bottom:-20px;background:rgba(0,229,255,.08);box-shadow:0 0 10px rgba(0,229,255,.1);animation-duration:15s;animation-delay:4s}
.tdb-bubble--5{width:9px;height:9px;left:60%;bottom:-14px;background:var(--cyan-dim);box-shadow:0 0 8px var(--cyan-dim);animation-duration:10s;animation-delay:3s}
.tdb-bubble--6{width:22px;height:22px;left:75%;bottom:-30px;background:rgba(0,180,216,.06);box-shadow:0 0 14px rgba(0,180,216,.1);animation-duration:17s;animation-delay:5s}
.tdb-bubble--7{width:5px;height:5px;left:12%;bottom:-8px;background:rgba(0,229,255,.25);box-shadow:0 0 6px rgba(0,229,255,.2);animation-duration:8s;animation-delay:6s}
.tdb-bubble--8{width:12px;height:12px;left:55%;bottom:-18px;background:rgba(0,180,216,.08);box-shadow:0 0 10px rgba(0,180,216,.12);animation-duration:12s;animation-delay:1.5s}
.tdb-bubble--9{width:16px;height:16px;left:88%;bottom:-22px;background:var(--cyan-dim);box-shadow:0 0 12px var(--cyan-dim);animation-duration:14s;animation-delay:7s}
.tdb-bubble--10{width:8px;height:8px;left:42%;bottom:-12px;background:rgba(0,229,255,.12);box-shadow:0 0 8px rgba(0,229,255,.1);animation-duration:10s;animation-delay:2.5s}
.tdb-bubble--11{width:4px;height:4px;left:95%;bottom:-6px;background:rgba(0,229,255,.3);box-shadow:0 0 6px rgba(0,229,255,.25);animation-duration:7s;animation-delay:8s}
.tdb-bubble--12{width:20px;height:20px;left:3%;bottom:-28px;background:rgba(0,180,216,.06);box-shadow:0 0 14px rgba(0,180,216,.08);animation-duration:16s;animation-delay:0.5s}

.tdb-deco-circle{position:absolute;border-radius:50%;pointer-events:none;z-index:0}

/* === FISH === */
.tdb-fish-wrap{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.tdb-fish{position:absolute;opacity:.15;animation-timing-function:linear;animation-iteration-count:infinite;filter:drop-shadow(0 0 4px var(--cyan-dim))}
.tdb-fish--r{animation-name:fishSwimR}
.tdb-fish--l{animation-name:fishSwimL}
@keyframes fishSwimR{
  0%{transform:translateX(-80px) translateY(0)}
  25%{transform:translateX(25vw) translateY(-12px)}
  50%{transform:translateX(50vw) translateY(8px)}
  75%{transform:translateX(75vw) translateY(-6px)}
  100%{transform:translateX(110vw) translateY(0)}
}
@keyframes fishSwimL{
  0%{transform:translateX(110vw) scaleX(-1) translateY(0)}
  25%{transform:translateX(75vw) scaleX(-1) translateY(10px)}
  50%{transform:translateX(50vw) scaleX(-1) translateY(-8px)}
  75%{transform:translateX(25vw) scaleX(-1) translateY(5px)}
  100%{transform:translateX(-80px) scaleX(-1) translateY(0)}
}
.tdb-fish--1{top:30%;animation-duration:18s;animation-delay:0s;opacity:.12}
.tdb-fish--2{top:55%;animation-duration:22s;animation-delay:4s;opacity:.08}
.tdb-fish--3{top:70%;animation-duration:15s;animation-delay:8s;opacity:.14}
.tdb-fish--4{top:20%;animation-duration:25s;animation-delay:2s;opacity:.06}
.tdb-fish-school{position:absolute;opacity:.08;animation:schoolDrift 20s linear infinite}
@keyframes schoolDrift{
  0%{transform:translateX(-120px) translateY(0)}
  50%{transform:translateX(55vw) translateY(-15px)}
  100%{transform:translateX(115vw) translateY(5px)}
}

/* === DIVER === */
.tdb-diver{position:absolute;bottom:15%;right:8%;opacity:.06;animation:diverFloat 6s ease-in-out infinite;z-index:0;filter:drop-shadow(0 0 12px var(--cyan-dim))}
@keyframes diverFloat{
  0%,100%{transform:translateY(0) rotate(-2deg)}
  50%{transform:translateY(-18px) rotate(2deg)}
}

/* === LIGHT RAYS === */
.tdb-lightrays{position:absolute;top:0;left:0;right:0;height:100%;overflow:hidden;pointer-events:none;z-index:0}
.tdb-lightray{position:absolute;top:-20%;width:60px;height:140%;background:linear-gradient(180deg,rgba(0,229,255,.04) 0%,transparent 100%);transform-origin:top center;animation:rayPulse 8s ease-in-out infinite}
.tdb-lightray:nth-child(1){left:10%;transform:rotate(12deg);animation-delay:0s;width:40px}
.tdb-lightray:nth-child(2){left:30%;transform:rotate(-8deg);animation-delay:2s;width:70px;opacity:.7}
.tdb-lightray:nth-child(3){left:55%;transform:rotate(5deg);animation-delay:4s;width:50px}
.tdb-lightray:nth-child(4){left:78%;transform:rotate(-15deg);animation-delay:1s;width:80px;opacity:.5}
.tdb-lightray:nth-child(5){left:92%;transform:rotate(10deg);animation-delay:3s;width:35px}
@keyframes rayPulse{0%,100%{opacity:.3}50%{opacity:.8}}

/* === JELLYFISH === */
.tdb-jellyfish{position:absolute;opacity:.1;animation:jellyDrift linear infinite;filter:drop-shadow(0 0 8px var(--cyan-dim))}
@keyframes jellyDrift{
  0%{transform:translateY(110%) translateX(0) scale(.8);opacity:0}
  10%{opacity:.1}
  50%{transform:translateY(40%) translateX(20px) scale(1)}
  90%{opacity:.06}
  100%{transform:translateY(-20%) translateX(-10px) scale(.9);opacity:0}
}

/* === TURTLE === */
.tdb-turtle{position:absolute;opacity:.08;animation:turtleGlide 28s linear infinite;filter:drop-shadow(0 0 6px var(--cyan-dim))}
@keyframes turtleGlide{
  0%{transform:translateX(-100px) translateY(0) rotate(-3deg)}
  25%{transform:translateX(25vw) translateY(-20px) rotate(2deg)}
  50%{transform:translateX(50vw) translateY(10px) rotate(-2deg)}
  75%{transform:translateX(75vw) translateY(-10px) rotate(3deg)}
  100%{transform:translateX(110vw) translateY(0) rotate(-3deg)}
}

/* === SEAWEED === */
.tdb-seaweed{position:absolute;bottom:0;opacity:.08;transform-origin:bottom center;animation:seaweedSway 4s ease-in-out infinite;filter:drop-shadow(0 0 4px var(--cyan-dim))}
@keyframes seaweedSway{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}
.tdb-seaweed--1{left:5%;animation-delay:0s}
.tdb-seaweed--2{left:15%;animation-delay:.5s;opacity:.05}
.tdb-seaweed--3{right:10%;animation-delay:1s}
.tdb-seaweed--4{right:20%;animation-delay:1.5s;opacity:.06}

/* === WAVE DIVIDERS === */
.tdb-wave{display:block;width:100%;height:auto;margin-top:-1px}
.tdb-wave-flip{transform:scaleY(-1);margin-bottom:-1px;margin-top:0}

/* ============================================================
   HERO
   ============================================================ */
.tdb-hero{
  position:relative;
  background:
    radial-gradient(ellipse 80% 50% at 30% 80%, rgba(0,109,119,.25) 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 70% 20%, rgba(0,229,255,.08) 0%, transparent 60%),
    linear-gradient(170deg, var(--abyss) 0%, var(--abyss-mid) 40%, #0A1628 70%, var(--surface) 100%);
  color:var(--white);
  padding:calc(var(--sp-xl) + 2rem) 0 calc(var(--sp-xl) + 3rem);
  text-align:center;overflow:hidden;
}
.tdb-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle 400px at 50% 100%, rgba(0,229,255,.06) 0%, transparent 100%),
    radial-gradient(circle 200px at 80% 30%, rgba(255,183,3,.03) 0%, transparent 100%);
  pointer-events:none;
}
/* Animated scan line */
.tdb-hero::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--cyan-dim), transparent);
  animation:heroScan 4s ease-in-out infinite;pointer-events:none;z-index:1;
}
@keyframes heroScan{
  0%{top:0;opacity:0}
  50%{opacity:.6}
  100%{top:100%;opacity:0}
}

.tdb-hero .tdb-container{position:relative;z-index:2}
.tdb-hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,229,255,.08);
  border:1px solid rgba(0,229,255,.2);
  padding:8px 20px;border-radius:50px;
  font-size:.82rem;font-weight:600;letter-spacing:.06em;
  margin-bottom:var(--sp-md);
  backdrop-filter:blur(8px);color:var(--cyan);
  text-transform:uppercase;
  box-shadow:var(--glow-sm);
  animation:badgePulse 3s ease-in-out infinite alternate;
}
@keyframes badgePulse{
  0%{box-shadow:0 0 15px rgba(0,229,255,.08)}
  100%{box-shadow:0 0 25px rgba(0,229,255,.18)}
}

.tdb-hero h1{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,5.5vw,4rem);
  font-weight:800;line-height:1.1;
  margin-bottom:var(--sp-sm);color:var(--white);
  letter-spacing:-.02em;
  text-shadow:0 0 60px rgba(0,229,255,.15);
}
.tdb-hero__sub{
  font-size:clamp(1rem,2vw,1.15rem);
  color:var(--mist);max-width:680px;
  margin:0 auto var(--sp-lg);line-height:1.7;
  font-weight:400;
}
.tdb-hero__sub strong{color:var(--amber);font-weight:700}

.tdb-hero__cta{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg, var(--amber), var(--amber-dk));
  color:var(--abyss);font-family:var(--font-display);font-weight:700;
  padding:16px 36px;border-radius:50px;font-size:1rem;
  letter-spacing:.02em;
  box-shadow:0 4px 20px rgba(255,183,3,.3);
  transition:all .3s cubic-bezier(.23,1,.32,1);
  text-transform:uppercase;
}
.tdb-hero__cta:hover{
  color:var(--abyss);filter:none;
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 8px 32px rgba(255,183,3,.45);
}

/* ============================================================
   HIGHLIGHTS
   ============================================================ */
.tdb-highlights-section{
  position:relative;overflow:hidden;
  background:var(--abyss);
  padding-top:var(--sp-sm);
}
.tdb-highlights{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:12px;margin:calc(-2.5rem) auto var(--sp-lg);
  position:relative;z-index:2;
}
.tdb-highlight-card{
  background:var(--abyss-light);
  border:1px solid rgba(0,229,255,.08);
  border-radius:var(--radius-lg);padding:var(--sp-md);
  text-align:center;
  transition:all .35s cubic-bezier(.23,1,.32,1);
  position:relative;overflow:hidden;
}
.tdb-highlight-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--cyan), transparent);
  opacity:0;transition:opacity .35s;
}
.tdb-highlight-card:hover{
  border-color:rgba(0,229,255,.2);
  transform:translateY(-4px);
  box-shadow:var(--glow-md);
}
.tdb-highlight-card:hover::before{opacity:1}
.tdb-highlight-card__icon{font-size:2rem;margin-bottom:var(--sp-xs);filter:drop-shadow(0 0 8px var(--cyan-dim))}
.tdb-highlight-card__title{font-family:var(--font-display);font-weight:700;font-size:.9rem;color:var(--white);margin-bottom:4px}
.tdb-highlight-card__text{font-size:.78rem;color:var(--text-dim)}

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.tdb-section-heading{text-align:center;margin-bottom:var(--sp-lg)}
.tdb-section-heading h2{
  font-family:var(--font-display);font-size:clamp(1.6rem,3.5vw,2.4rem);
  font-weight:800;color:var(--white);margin-bottom:var(--sp-xs);
  letter-spacing:-.01em;
  position:relative;display:inline-block;
}
.tdb-section-heading h2::after{
  content:'';display:block;width:60px;height:3px;margin:12px auto 0;
  background:linear-gradient(90deg, var(--cyan), var(--teal));
  border-radius:2px;
  box-shadow:0 0 12px var(--cyan-dim);
}
.tdb-section-heading p{color:var(--text-dim);max-width:640px;margin:0 auto;font-size:1rem}

/* ============================================================
   PRICING
   ============================================================ */
.tdb-pricing-section{
  padding:var(--sp-xl) 0;position:relative;overflow:hidden;
  background:var(--abyss);
}
.tdb-pricing-section>.tdb-deco-circle:nth-child(1){width:300px;height:300px;top:-80px;right:-100px;background:radial-gradient(circle,rgba(0,229,255,.06) 0%,transparent 70%)}
.tdb-pricing-section>.tdb-deco-circle:nth-child(2){width:200px;height:200px;bottom:40px;left:-60px;background:radial-gradient(circle,rgba(0,180,216,.04) 0%,transparent 70%)}

.tdb-resort-tabs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:var(--sp-lg);position:relative;z-index:1}
.tdb-resort-tab{
  padding:10px 22px;border-radius:50px;
  border:1px solid rgba(0,229,255,.15);
  background:var(--abyss-light);color:var(--mist);
  font-family:var(--font-body);font-weight:600;font-size:.85rem;
  cursor:pointer;transition:all .25s;letter-spacing:.02em;
}
.tdb-resort-tab:hover{border-color:rgba(0,229,255,.35);color:var(--cyan)}
.tdb-resort-tab.active{
  border-color:var(--cyan);background:rgba(0,229,255,.1);
  color:var(--cyan);box-shadow:var(--glow-sm);
}

.tdb-pricing-wrap{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  border-radius:var(--radius-lg);
  border:1px solid rgba(0,229,255,.1);
  background:var(--abyss-mid);position:relative;z-index:1;
  box-shadow:var(--shadow-card);
}
.tdb-pricing-table{width:100%;min-width:820px;border-collapse:collapse}
.tdb-pricing-table thead th{
  background:var(--surface);color:var(--mist);
  padding:16px 16px;font-size:.85rem;font-weight:600;
  text-align:center;white-space:nowrap;
  border-bottom:1px solid rgba(0,229,255,.1);
  font-family:var(--font-display);letter-spacing:.02em;
}
.tdb-pricing-table thead th:first-child{text-align:left;border-radius:var(--radius-lg) 0 0 0}
.tdb-pricing-table thead th:last-child{border-radius:0 var(--radius-lg) 0 0}
.tdb-pricing-table thead th small{display:block;font-weight:400;opacity:.7;font-size:.75rem;margin-top:2px;font-family:var(--font-body)}
.tdb-pricing-table thead th.popular-col{
  background:linear-gradient(180deg, rgba(255,183,3,.15), rgba(255,183,3,.05));
  color:var(--amber);
}
.tdb-popular-badge{
  display:inline-block;background:var(--amber);color:var(--abyss);
  font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  padding:3px 10px;border-radius:50px;margin-top:4px;
  font-family:var(--font-display);
}

.tdb-pricing-table tbody td{
  padding:12px 16px;text-align:center;
  border-bottom:1px solid rgba(255,255,255,.04);
  font-size:.9rem;color:var(--text);
  transition:background .2s;
}
.tdb-pricing-table tbody td:first-child{text-align:left;font-weight:600;white-space:nowrap;color:var(--mist)}
.tdb-pricing-table tbody td.popular-col{
  background:rgba(255,183,3,.04);font-weight:700;color:var(--amber);
}
.tdb-pricing-table tbody tr:hover td{background:rgba(0,229,255,.03)}
.tdb-pricing-table tbody tr:hover td.popular-col{background:rgba(255,183,3,.08)}

.tdb-resort-header td{
  background:var(--surface)!important;font-weight:700!important;font-size:.9rem!important;
  color:var(--cyan)!important;padding:10px 16px!important;text-align:left!important;
  letter-spacing:.04em;border-bottom:1px solid rgba(0,229,255,.15)!important;
  font-family:var(--font-display)!important;
}
.tdb-cta-row td{padding:14px 16px;background:var(--abyss-light)!important;border-bottom:1px solid rgba(0,229,255,.06)}

.tdb-book-btn{display:inline-block;padding:8px 20px;border-radius:50px;font-weight:700;font-size:.8rem;transition:all .25s;font-family:var(--font-display);letter-spacing:.03em}
.tdb-book-btn--primary{
  background:transparent;color:var(--cyan);
  border:1px solid rgba(0,229,255,.3);
}
.tdb-book-btn--primary:hover{
  background:rgba(0,229,255,.1);color:var(--white);
  box-shadow:var(--glow-sm);border-color:var(--cyan);
}
.tdb-book-btn--popular{
  background:linear-gradient(135deg,var(--amber),var(--amber-dk));
  color:var(--abyss);padding:10px 24px;font-size:.85rem;
  box-shadow:0 2px 12px rgba(255,183,3,.25);border:none;
}
.tdb-book-btn--popular:hover{
  color:var(--abyss);transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(255,183,3,.4);
}

/* ============================================================
   INCLUDED / EXCLUDED
   ============================================================ */
.tdb-inclusions{
  padding:var(--sp-xl) 0;
  background:linear-gradient(180deg, var(--abyss-mid), var(--abyss-light));
  position:relative;overflow:hidden;
}
.tdb-inclusions>.tdb-deco-circle{width:250px;height:250px;top:30px;left:-80px;background:radial-gradient(circle,rgba(0,229,255,.04) 0%,transparent 70%)}
.tdb-incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-md);position:relative;z-index:1}
.tdb-incl-card{
  background:var(--abyss-mid);
  border:1px solid rgba(0,229,255,.08);
  border-radius:var(--radius-lg);
  padding:var(--sp-md) var(--sp-md) var(--sp-sm);
  box-shadow:var(--shadow-card);
}
.tdb-incl-card h3{
  font-family:var(--font-display);font-size:1.2rem;font-weight:700;
  color:var(--white);margin-bottom:var(--sp-sm);
  display:flex;align-items:center;gap:10px;
}
.tdb-incl-list{list-style:none;padding:0}
.tdb-incl-list li{
  position:relative;padding:10px 0 10px 28px;font-size:.88rem;
  border-bottom:1px solid rgba(255,255,255,.04);line-height:1.6;color:var(--text-dim);
}
.tdb-incl-list li:last-child{border-bottom:none}
.tdb-incl-list li::before{position:absolute;left:0;top:10px;font-size:1rem}
.tdb-incl-list--included li::before{content:'✓';color:var(--cyan);font-weight:700;text-shadow:0 0 8px var(--cyan-dim)}
.tdb-incl-list--excluded li::before{content:'✕';color:var(--coral);font-weight:700;text-shadow:0 0 8px rgba(255,107,107,.2)}
.tdb-incl-list li strong{color:var(--white)}

/* ============================================================
   ITINERARY
   ============================================================ */
.tdb-itinerary{padding:var(--sp-xl) 0;position:relative;overflow:hidden;background:var(--abyss)}
.tdb-itinerary-wrap{
  overflow-x:auto;border-radius:var(--radius-lg);
  border:1px solid rgba(0,229,255,.08);
  background:var(--abyss-mid);position:relative;z-index:1;
  box-shadow:var(--shadow-card);
}
.tdb-itinerary-table{width:100%;min-width:700px;border-collapse:collapse}
.tdb-itinerary-table thead th{
  background:var(--surface);color:var(--mist);
  padding:12px 14px;font-size:.82rem;font-weight:600;text-align:center;
  border-bottom:1px solid rgba(0,229,255,.1);
  font-family:var(--font-display);
}
.tdb-itinerary-table thead th:first-child,.tdb-itinerary-table thead th:nth-child(2){text-align:left}
.tdb-itinerary-table thead th small{display:block;font-weight:400;opacity:.7;font-size:.72rem;font-family:var(--font-body)}
.tdb-itinerary-table td{padding:10px 14px;text-align:center;border-bottom:1px solid rgba(255,255,255,.04);font-size:.85rem;color:var(--text)}
.tdb-itinerary-table td:first-child{font-weight:700;text-align:left;color:var(--white)}
.tdb-itinerary-table td:nth-child(2){text-align:left;color:var(--text-dim);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}
.itinerary-note{background:rgba(0,229,255,.03);font-style:italic;color:var(--text-dim);font-size:.82rem}
.itinerary-checkout{color:var(--coral);font-weight:700}

.tdb-dive-count{
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(0,229,255,.12);color:var(--cyan);
  width:30px;height:30px;border-radius:50%;
  font-weight:700;font-size:.85rem;
  border:1px solid rgba(0,229,255,.2);
  box-shadow:0 0 10px rgba(0,229,255,.1);
}
.tdb-session-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-md);margin-top:var(--sp-md)}
.tdb-session-card{
  background:var(--abyss-mid);border-radius:var(--radius-lg);
  padding:var(--sp-md);box-shadow:var(--shadow-card);
  border-left:3px solid var(--cyan);
  border:1px solid rgba(0,229,255,.08);
  border-left:3px solid var(--cyan);
}
.tdb-session-card h4{font-family:var(--font-display);font-size:1rem;color:var(--white);margin-bottom:6px}
.tdb-session-card p{font-size:.85rem;color:var(--text-dim);margin-bottom:2px}
.tdb-session-card strong{color:var(--cyan)}

/* ============================================================
   DIVE SCHEDULE
   ============================================================ */
.tdb-schedule{
  padding:var(--sp-xl) 0;
  background:linear-gradient(180deg, var(--abyss-light), var(--abyss-mid));
  position:relative;overflow:hidden;
}
.tdb-schedule>.tdb-deco-circle{width:280px;height:280px;bottom:-60px;right:-80px;background:radial-gradient(circle,rgba(0,229,255,.05) 0%,transparent 70%)}
.tdb-schedule-wrap{
  overflow-x:auto;border-radius:var(--radius-lg);
  border:1px solid rgba(0,229,255,.08);
  background:var(--abyss-mid);position:relative;z-index:1;
  box-shadow:var(--shadow-card);
}
.tdb-schedule-table{width:100%;min-width:600px;border-collapse:collapse}
.tdb-schedule-table thead th{
  background:var(--surface);color:var(--mist);
  padding:12px 16px;font-size:.85rem;font-weight:600;text-align:left;
  border-bottom:1px solid rgba(0,229,255,.1);
  font-family:var(--font-display);
}
.tdb-schedule-table tbody td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.04);font-size:.88rem;color:var(--text)}
.tdb-schedule-table tbody td:first-child{font-weight:700;color:var(--white)}
.tdb-schedule-table tbody tr:nth-child(even){background:rgba(0,229,255,.02)}
.tdb-schedule-table tbody tr:hover{background:rgba(0,229,255,.04)}

.tdb-remote-tag{
  display:inline-block;background:rgba(255,183,3,.12);
  color:var(--amber);font-size:.68rem;font-weight:700;
  padding:2px 8px;border-radius:50px;margin-left:6px;vertical-align:middle;
  border:1px solid rgba(255,183,3,.2);
}
.tdb-schedule-note{text-align:center;margin-top:var(--sp-sm);font-size:.82rem;color:var(--text-dim);font-style:italic;position:relative;z-index:1}

/* Dive map */
.tdb-divemap{
  margin-top:var(--sp-lg);background:var(--abyss-mid);
  border-radius:var(--radius-lg);border:1px solid rgba(0,229,255,.08);
  box-shadow:var(--shadow-card);overflow:hidden;position:relative;z-index:1;
}
.tdb-divemap__title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--white);padding:var(--sp-md) var(--sp-md) 0;margin-bottom:4px}
.tdb-divemap__desc{padding:0 var(--sp-md);font-size:.85rem;color:var(--text-dim);line-height:1.6;margin-bottom:var(--sp-sm)}
.tdb-divemap__img-wrap{padding:0 var(--sp-md) var(--sp-md)}
.tdb-divemap__img-wrap img{width:100%;height:auto;border-radius:var(--radius);border:1px solid rgba(0,229,255,.08)}

/* ============================================================
   BOOKING INFO
   ============================================================ */
.tdb-booking-info{padding:var(--sp-xl) 0;background:var(--abyss)}
.tdb-info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--sp-md)}
.tdb-info-card{
  background:var(--abyss-mid);border-radius:var(--radius-lg);
  padding:var(--sp-md);box-shadow:var(--shadow-card);
  border:1px solid rgba(0,229,255,.06);
  border-top:3px solid var(--cyan);
  position:relative;overflow:hidden;
}
.tdb-info-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:60px;
  background:linear-gradient(180deg, rgba(0,229,255,.04), transparent);
  pointer-events:none;
}
.tdb-info-card h3{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--white);margin-bottom:var(--sp-sm);display:flex;align-items:center;gap:8px;position:relative}
.tdb-info-card p,.tdb-info-card li{font-size:.88rem;color:var(--text-dim);line-height:1.7}
.tdb-info-card ul{list-style:none;padding:0}
.tdb-info-card li{padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.tdb-info-card li:last-child{border-bottom:none}
.tdb-info-card strong{color:var(--white)}

/* ============================================================
   FAQ
   ============================================================ */
.tdb-faq{
  padding:var(--sp-xl) 0;
  background:linear-gradient(180deg, var(--abyss-mid), var(--abyss));
  position:relative;overflow:hidden;
}
.tdb-faq>.tdb-deco-circle:nth-child(1){width:220px;height:220px;top:-40px;left:-60px;background:radial-gradient(circle,rgba(0,229,255,.04) 0%,transparent 70%)}
.tdb-faq>.tdb-deco-circle:nth-child(2){width:180px;height:180px;bottom:20px;right:-40px;background:radial-gradient(circle,rgba(0,180,216,.04) 0%,transparent 70%)}
.tdb-faq-list{max-width:800px;margin:0 auto;position:relative;z-index:1}
.tdb-faq-item{
  background:var(--abyss-light);
  border:1px solid rgba(0,229,255,.06);
  border-radius:var(--radius-lg);margin-bottom:10px;
  overflow:hidden;transition:all .25s;
}
.tdb-faq-item:hover{border-color:rgba(0,229,255,.15)}
.tdb-faq-item[open]{border-color:rgba(0,229,255,.2);box-shadow:var(--glow-sm)}
.tdb-faq-item summary{
  padding:var(--sp-md);font-family:var(--font-display);
  font-weight:600;font-size:.95rem;color:var(--white);
  cursor:pointer;list-style:none;display:flex;
  justify-content:space-between;align-items:center;
  transition:all .25s;
}
.tdb-faq-item summary:hover{background:rgba(0,229,255,.03)}
.tdb-faq-item summary::after{
  content:'+';font-size:1.4rem;font-weight:300;
  color:var(--cyan);transition:transform .25s;
  flex-shrink:0;margin-left:var(--sp-sm);
}
.tdb-faq-item[open] summary::after{content:'\2212'}
.tdb-faq-item[open] summary{color:var(--cyan)}
.tdb-faq-item summary::-webkit-details-marker{display:none}
.tdb-faq-answer{padding:0 var(--sp-md) var(--sp-md);color:var(--text-dim);font-size:.9rem;line-height:1.8}

/* ============================================================
   BOTTOM CTA
   ============================================================ */
.tdb-bottom-cta{
  background:
    radial-gradient(ellipse 60% 50% at 50% 100%, rgba(0,229,255,.08) 0%, transparent 70%),
    linear-gradient(160deg, var(--abyss-mid), var(--surface));
  color:var(--white);padding:var(--sp-xl) 0;
  text-align:center;position:relative;overflow:hidden;
  border-top:1px solid rgba(0,229,255,.08);
}
.tdb-bottom-cta .tdb-container{position:relative;z-index:1}
.tdb-bottom-cta h2{
  font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:800;margin-bottom:var(--sp-xs);color:var(--white);
  letter-spacing:-.01em;
}
.tdb-bottom-cta p{color:var(--text-dim);margin-bottom:var(--sp-md);font-size:1rem}
.tdb-bottom-cta .tdb-hero__cta{font-size:1.05rem;padding:16px 40px}

/* ============================================================
   STICKY MOBILE BAR — REMOVED
   ============================================================ */
.tdb-sticky-bar{display:none!important}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:768px){
  .tdb-incl-grid,.tdb-session-grid{grid-template-columns:1fr}
  .tdb-highlights{grid-template-columns:repeat(2,1fr)}
  .tdb-diver{display:none}
  .tdb-fish-wrap{display:none}
}
@media(max-width:480px){
  .tdb-highlights{grid-template-columns:1fr 1fr;gap:8px}
  .tdb-highlight-card{padding:var(--sp-sm)}
  .tdb-resort-tabs{gap:6px}
  .tdb-resort-tab{padding:8px 14px;font-size:.78rem}
}/* End custom CSS */