/*
Theme Name: Moondance Stable
Theme URI: https://example.com/
Author: OpenAI
Description: Stable custom theme for Moondance with editable settings, pricing, map, and inquiry form.
Version: 1.1
Text Domain: moondance-stable
*/

:root{
  --bg:#121211;
  --panel:#171715;
  --panel-2:#1d1d1b;
  --soft:#efeee9;
  --text:#f6f3ec;
  --muted:rgba(246,243,236,.68);
  --line:rgba(255,255,255,.10);
  --gold:#c8a453;
  --gold-soft:rgba(200,164,83,.18);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Tenor Sans",sans-serif;
  overflow-x:hidden;
}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}
.container{width:min(1240px,calc(100% - 56px));margin:0 auto}
.eyebrow{margin:0 0 16px;font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted)}
.eyebrow::before{content:"";display:inline-block;width:28px;height:1px;margin-right:12px;vertical-align:middle;background:currentColor;opacity:.7}
.title{margin:0;font-family:"Cormorant Garamond",serif;font-size:clamp(42px,6vw,82px);font-weight:300;line-height:.96;letter-spacing:-.01em}
.title em{font-style:italic}
.rule{width:34px;height:1px;background:currentColor;opacity:.28;margin:24px 0}
.body{margin:0;max-width:900px;color:var(--muted);line-height:1.95;font-size:14px}
.section{padding:110px 0}
.placeholder{
  background:
    linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02)),
    repeating-linear-gradient(45deg, rgba(255,255,255,.03), rgba(255,255,255,.03) 12px, rgba(255,255,255,.015) 12px, rgba(255,255,255,.015) 24px);
  border:1px solid rgba(255,255,255,.08);
  position:relative;overflow:hidden;min-height:240px
}
.placeholder::after{
  content:attr(data-label);
  position:absolute;left:18px;bottom:18px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.46)
}

/* Nav */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:2000;
  padding:8px 0;transition:.3s ease;background:transparent
}
.site-nav.scrolled{
  padding:6px 0;background:rgba(200,164,83,.94);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(94,71,24,.18);box-shadow:0 4px 14px rgba(0,0,0,.10)
}
.nav-inner{
  width:min(1320px,calc(100% - 34px));
  margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:16px
}
.brand{display:flex;align-items:center;justify-content:flex-start;min-width:100px;margin-right:auto;flex:0 0 auto}
.brand img{max-height:34px;width:auto}
.brand-logo{width:150px;height:42px;min-height:auto;margin:0;border:1px dashed rgba(255,255,255,.24);background:transparent}
.nav-links{
  display:flex;align-items:center;gap:14px;flex-wrap:nowrap;justify-content:flex-end;
  margin-left:auto;flex:0 1 auto
}
.nav-links a{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.78);line-height:1;white-space:nowrap}
.site-nav.scrolled .nav-links a,.site-nav.scrolled .brand{color:#17130a}
.site-nav.scrolled .brand-logo{border-color:rgba(23,19,10,.28)}
.nav-links a.nav-book{border:1px solid rgba(255,255,255,.22);padding:6px 10px}
.site-nav.scrolled .nav-links a.nav-book{border-color:rgba(23,19,10,.24);background:rgba(255,255,255,.18)}

/* Hero */
.hero{min-height:100vh;position:relative;display:flex;flex-direction:column;justify-content:center;overflow:hidden;background:#101010}
.hero-media{position:absolute;inset:0}
.hero-video,.hero-image{width:100%;height:100%;object-fit:cover;background:#171717}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(18,18,17,.16), rgba(18,18,17,.24) 42%, rgba(18,18,17,.82))}
.hero-content{position:relative;z-index:2;width:min(1100px,calc(100% - 56px));margin:0 auto;text-align:center;padding-top:110px}
.hero-logo{width:260px;height:88px;min-height:auto;margin:0 auto 24px;border:1px dashed rgba(255,255,255,.24);background:transparent}
.hero-logo img{width:100%;height:100%;object-fit:contain}
.hero-tag{margin:0 0 16px;font-size:11px;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.48)}
.hero-title{margin:0;font-family:"Cormorant Garamond",serif;font-size:clamp(26px,3vw,40px);font-weight:300;line-height:1.04;white-space:nowrap}
.hero-title em{font-style:italic}
.hero-bottom-nav{position:relative;z-index:2;margin-top:auto;display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,.11)}
.hero-nav-item{padding:22px 16px;border-right:1px solid rgba(255,255,255,.11);text-align:center;display:flex;flex-direction:column;gap:8px}
.hero-nav-item:last-child{border-right:0}
.hero-nav-num{font-size:11px;letter-spacing:.28em;color:rgba(255,255,255,.34)}
.hero-nav-label{font-size:12px;letter-spacing:.24em;text-transform:uppercase}
.hero-nav-arrow{color:rgba(255,255,255,.3)}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#111}
.stat{padding:34px 20px;text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat-num{display:block;font-family:"Cormorant Garamond",serif;font-size:38px;margin-bottom:6px}
.stat-lbl{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}

/* Vessel */
.vessel-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.vessel-photo{aspect-ratio:4/3;min-height:460px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.vessel-photo img{width:100%;height:100%;object-fit:cover}
.specs{margin-top:34px;padding-top:28px;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 26px}
.spec-lbl{display:block;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.spec-val{font-family:"Cormorant Garamond",serif;font-size:26px}

/* Onboard */
.spaces{background:var(--soft);color:#171715}
.spaces .body,.spaces .eyebrow{color:rgba(23,23,21,.66)}
.spaces-grid{margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.space-card{position:relative;overflow:hidden;background:#262626;min-height:360px}
.space-card.wide{grid-column:span 2;min-height:430px}
.space-card img,.space-card video{width:100%;height:100%;object-fit:cover}
.space-card .placeholder{height:100%;min-height:inherit;border:0}
.space-overlay{position:absolute;inset:0;padding:24px;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,.16));color:#fff}
.space-num{font-size:11px;letter-spacing:.26em;color:rgba(255,255,255,.42)}
.space-name{margin:8px 0 10px;font-family:"Cormorant Garamond",serif;font-size:36px;font-weight:300}
.space-desc{margin:0;color:rgba(255,255,255,.72);line-height:1.82;font-size:13px}

/* Crew */
.crew-standalone{background:#111110}
.crew{margin-top:34px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.crew-card{border:1px solid rgba(255,255,255,.10);padding:18px;background:rgba(255,255,255,.03)}
.crew-head{width:72px;height:72px;min-height:auto;margin-bottom:14px;border:1px solid rgba(255,255,255,.10)}
.crew-head img{width:100%;height:100%;object-fit:cover}
.crew-role{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.46);margin-bottom:6px}
.crew-name{margin:0 0 10px;font-family:"Cormorant Garamond",serif;font-size:30px;font-weight:300}
.crew-bio{margin:0 0 10px;color:var(--muted);line-height:1.82;font-size:13px}
.crew-points{margin:14px 0 0;padding-left:18px;color:rgba(255,255,255,.72);line-height:1.78;font-size:12px}
.crew-points li{margin:4px 0}

/* Gallery */
.gallery{background:#111}
.gallery-grid{margin-top:36px;column-count:4;column-gap:10px}
.gallery-item{overflow:hidden;display:inline-block;width:100%;margin:0 0 10px;break-inside:avoid;vertical-align:top}
.gallery-item.tall,.gallery-item.wide{grid-row:auto;grid-column:auto}
.gallery-item img,.gallery-item video{width:100%;height:auto;object-fit:cover}
.gallery-item .placeholder{height:240px;border:0}

/* Destinations */
.destinations{background:#141413}
.dest-top{max-width:960px;margin:0 auto 48px;text-align:center}
.dest-top .body{margin-inline:auto}
.dest-layout{display:grid;grid-template-columns:minmax(420px, 520px) minmax(620px, 1fr);gap:56px;align-items:start}
.regions{display:flex;flex-direction:column;gap:0;align-content:start}
.region{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);padding:22px 20px;cursor:pointer;transition:.2s ease;min-height:auto;margin-top:-1px;position:relative}
.region.active{border-color:rgba(200,164,83,.42);background:linear-gradient(90deg, rgba(200,164,83,.10) 0%, rgba(255,255,255,.02) 18%, rgba(255,255,255,.03) 100%);box-shadow:inset 2px 0 0 rgba(200,164,83,.9)}
.region-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}
.region-toggle{font-size:30px;line-height:1;color:rgba(255,255,255,.34);margin-top:4px;flex:0 0 auto}
.region.active .region-toggle{color:rgba(255,255,255,.5)}
.region-num{font-size:11px;letter-spacing:.26em;color:rgba(255,255,255,.36)}
.region-name{font-family:"Cormorant Garamond",serif;font-size:31px;font-weight:300;margin:6px 0}
.islands{display:none;flex-wrap:wrap;gap:8px;margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}
.region.active .islands{display:flex}
.island{border:1px solid rgba(255,255,255,.12);padding:8px 10px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.72);cursor:pointer;background:transparent}
.island.active,.island:hover{border-color:rgba(200,164,83,.52);color:var(--gold);background:rgba(200,164,83,.08)}
.map-wrap{display:flex;flex-direction:column;gap:18px;position:sticky;top:92px}
.map-filter-label{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,255,.42)}
.map-filters{display:flex;flex-wrap:wrap;gap:8px}
.map-filter{appearance:none;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:rgba(255,255,255,.72);padding:10px 16px;font:inherit;font-size:11px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:.2s ease}
.map-filter:hover,.map-filter.active{border-color:rgba(200,164,83,.52);background:rgba(200,164,83,.12);color:var(--gold)}
#map{width:100%;height:700px;border:1px solid rgba(255,255,255,.12);background:#0d1620}
.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#131313;color:#fff}
.leaflet-popup-content b{display:block;margin-bottom:4px}
.leaflet-container{background:#0d1620}
.isl-marker{width:12px;height:12px;border-radius:50%;background:rgba(200,164,83,.52);border:1.5px solid rgba(200,164,83,.88);box-shadow:0 0 0 1px rgba(0,0,0,.18)}
.isl-marker.active{background:rgba(200,164,83,.92);border-color:#f1d58a;width:14px;height:14px;box-shadow:0 0 0 1px rgba(0,0,0,.22), 0 0 12px rgba(200,164,83,.28)}


.island-detail{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}
.island-detail-title{font-family:"Cormorant Garamond",serif;font-size:28px;font-weight:300;margin:0 0 16px}
.island-detail-body{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(160px,240px);gap:22px;align-items:start}
.island-detail-body.no-images{grid-template-columns:1fr}
.island-detail-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:12px}
.island-detail-list li{color:rgba(255,255,255,.88)}
.island-detail-spot-title{font-size:14px;line-height:1.5}
.island-detail-spot-desc{margin-top:4px;font-size:12px;line-height:1.6;color:rgba(255,255,255,.62);list-style:none}
.island-detail-images{display:grid;gap:10px}
.island-detail-images img{width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid rgba(255,255,255,.12)}

/* Dining */
.dining{background:var(--soft);color:#171715}
.dining .body,.dining .eyebrow{color:rgba(23,23,21,.66)}
.dining-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.dining-mosaic{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.dining-mosaic img{width:100%;height:100%;object-fit:cover}
.dining-mosaic .placeholder{border-color:rgba(0,0,0,.08)}
.dining-mosaic .wide{grid-column:1 / -1;min-height:270px}
.dining-mosaic .square{min-height:220px}

/* Booking */
.booking{background:#101010}
.booking-layout{display:grid;grid-template-columns:.76fr 1.24fr;gap:48px;align-items:start}
.b-detail{margin-top:24px}
.b-detail h4{margin:0 0 8px;font-family:"Cormorant Garamond",serif;font-size:22px;font-weight:300}
.b-detail p{margin:0;color:var(--muted);line-height:1.85;font-size:14px}
.booking-shell{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);padding:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.field label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.52)}
.field input,.field textarea,.field select{width:100%;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.035);color:var(--text);padding:12px 13px;font:inherit}
.booking-btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 22px;border:1px solid rgba(255,255,255,.26);text-transform:uppercase;letter-spacing:.24em;font-size:11px;margin-top:6px;background:transparent;color:var(--text);cursor:pointer}
.booking-note{margin-top:14px;color:rgba(255,255,255,.65);font-size:13px;line-height:1.6}
.form-success{display:none;margin-top:14px;padding:12px 14px;border:1px solid rgba(200,164,83,.22);background:rgba(200,164,83,.07);color:var(--text)}
.rates{margin-top:22px;border:1px solid rgba(255,255,255,.10);overflow:auto}
.rates table{width:100%;border-collapse:collapse;min-width:620px}
.rates th,.rates td{padding:11px 12px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;font-size:12px}
.rates th{text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.56);font-weight:400;background:rgba(255,255,255,.04)}
.rates td{color:rgba(255,255,255,.88)}
.rates tr:last-child td{border-bottom:0}
.rates tr.is-booked td{opacity:.65}
.status-badge{display:inline-block;padding:4px 8px;border:1px solid rgba(200,164,83,.3);background:rgba(200,164,83,.08);color:var(--gold);font-size:10px;letter-spacing:.18em;text-transform:uppercase}

/* Footer */
footer{padding:28px 0;border-top:1px solid rgba(255,255,255,.08);background:#0d0d0d}
.footer-inner{display:flex;justify-content:space-between;gap:18px;color:rgba(255,255,255,.42);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.privacy-link{color:rgba(255,255,255,.58);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.22);padding-bottom:2px;cursor:pointer}
.privacy-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(6,6,6,.72);z-index:5000}
.privacy-modal.open{display:flex}
.privacy-card{width:min(860px,94vw);max-height:84vh;overflow:auto;background:#121211;color:var(--text);border:1px solid rgba(200,164,83,.28);box-shadow:0 24px 80px rgba(0,0,0,.42);padding:28px 28px 24px}
.privacy-close{appearance:none;border:0;background:transparent;color:rgba(255,255,255,.68);font-size:30px;line-height:1;cursor:pointer;float:right;margin:-4px 0 12px 12px}
.privacy-title{margin:0 0 8px;font-family:"Cormorant Garamond",serif;font-size:40px;font-weight:300;line-height:1}
.privacy-meta{margin:0 0 22px;color:var(--muted);font-size:13px;letter-spacing:.08em}
.privacy-card h3{margin:18px 0 8px;font-family:"Cormorant Garamond",serif;font-size:24px;font-weight:300}
.privacy-card p{margin:0 0 12px;color:var(--muted);line-height:1.8;font-size:14px;text-transform:none;letter-spacing:normal}
.privacy-card ul{margin:0 0 12px 18px;padding:0;color:var(--muted);line-height:1.8;font-size:14px;text-transform:none;letter-spacing:normal}

/* Responsive */
@media (max-width: 1100px){
  .dest-layout{grid-template-columns:1fr}
  .regions{display:flex;flex-direction:column}
  .map-wrap{position:static}
  .island-detail-body{grid-template-columns:1fr}
  #map{height:560px}
}
@media (max-width: 1100px){
  .site-nav{padding:10px 0}
  .site-nav.scrolled{padding:7px 0}
  .nav-inner{width:min(100%,calc(100% - 28px));gap:14px;align-items:center}
  .brand{min-width:96px}
  .brand img{max-height:34px}
  .brand-logo{width:140px;height:40px}
  .nav-links{gap:14px}
  .nav-links a{font-size:9px;letter-spacing:.18em}
  .nav-links a.nav-book{padding:7px 10px}
}



/* Responsive ribbon */
@media (max-width: 1100px){
  .nav-inner,.container,.hero-content{width:min(100%,calc(100% - 28px))}
  .hero{min-height:88vh}
  .hero-content{padding-top:120px}
  .hero-logo{width:220px;height:72px}
  .hero-tag{font-size:10px;letter-spacing:.22em}
  .hero-title{font-size:clamp(24px,5vw,34px);white-space:nowrap}
  .vessel-grid,.dining-grid,.booking-layout{grid-template-columns:1fr}
  .spaces-grid{grid-template-columns:1fr}
  .space-card.wide{grid-column:span 1}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .crew{grid-template-columns:1fr}
}

@media (max-width: 900px){
  .site-nav{padding:7px 0}
  .site-nav.scrolled{padding:5px 0}
  .nav-inner{
    width:min(100%,calc(100% - 18px));
    display:grid;
    grid-template-columns:auto minmax(0,1fr);
    align-items:center;
    gap:10px;
  }
  .brand{min-width:0;margin-right:0}
  .brand img{max-height:24px}
  .brand-logo{width:100px;height:30px}
  .nav-links{
    width:100%;
    margin-left:0;
    justify-content:flex-end;
    gap:10px;
    overflow-x:auto;
    overflow-y:hidden;
    scrollbar-width:none;
    -ms-overflow-style:none;
    white-space:nowrap;
  }
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{
    flex:0 0 auto;
    font-size:8px;
    letter-spacing:.12em;
  }
  .nav-links a.nav-book{
    padding:5px 8px;
  }
  .hero-content{padding-top:96px}
  .hero-bottom-nav,.stats,.form-row{grid-template-columns:1fr}
  .hero-nav-item,.stat{border-right:0;border-bottom:1px solid var(--line)}
  .hero-nav-item:last-child,.stat:last-child{border-bottom:0}
}

@media (max-width: 640px){
  .site-nav{padding:6px 0}
  .site-nav.scrolled{padding:4px 0}
  .nav-inner{
    width:min(100%,calc(100% - 14px));
    gap:8px;
  }
  .brand img{max-height:22px}
  .brand-logo{width:88px;height:26px}
  .nav-links{gap:8px}
  .nav-links a{font-size:7.5px;letter-spacing:.1em}
  .nav-links a.nav-book{padding:4px 7px}
  .hero-content{padding-top:88px}
  .hero-logo{width:180px;height:60px}
  .hero-tag{font-size:9px;letter-spacing:.18em}
  .hero-title{font-size:clamp(22px,7vw,30px)}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-item.tall,.gallery-item.wide{grid-column:auto;grid-row:auto}
  .dest-layout{grid-template-columns:1fr}
  .regions{display:flex;flex-direction:column}
  .map-wrap{position:static}
  #map{height:460px}
  .footer-inner{flex-direction:column}
}

@media (max-width: 420px){
  .nav-links a{font-size:7px;letter-spacing:.08em}
  .nav-links a.nav-book{padding:4px 6px}
  .hero-content{padding-top:82px}
  .hero-title{font-size:24px}
}


/* Dynamic media items */
.dining-mosaic > div img,
.dining-mosaic > div video{width:100%;height:100%;object-fit:cover}

/* Strong mobile width protections */
.vessel-grid > *,
.dining-grid > *,
.booking-layout > *,
.dest-layout > *,
.crew > *{min-width:0}
.booking-shell,
.rates,
.vessel-photo,
.dining-mosaic,
.gallery-grid,
.map-wrap,
.regions{width:100%;max-width:100%;min-width:0}

@media (max-width: 900px){
  html, body{max-width:100%;overflow-x:hidden}
  .container,.hero-content,.nav-inner{max-width:none}
  .booking-layout,
  .vessel-grid,
  .dining-grid,
  .dest-layout,
  .crew{grid-template-columns:1fr !important}
  .booking-shell,
  .rates,
  .vessel-photo,
  .dining-mosaic,
  .gallery-grid,
  .map-wrap,
  .regions{width:100%;max-width:100%}
  .vessel-photo{min-height:0;aspect-ratio:auto}
  .vessel-photo img,
  .vessel-photo video,
  .vessel-photo .placeholder{width:100%;height:auto;min-height:0}
  .rates{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .rates table{min-width:560px}
  .rates th,.rates td{font-size:11px;padding:10px 8px}
  .booking-shell{padding:18px}
  .field input,.field textarea,.field select{max-width:100%}
  .dining-mosaic .wide{min-height:220px}
  .dining-mosaic .square{min-height:180px}
}
@media (max-width: 640px){
  .container,.hero-content,.nav-inner{width:calc(100% - 24px) !important}
  .rates table{min-width:520px}
}


/* Separate nav and hero logos */
.brand-logo,
.hero-logo{
  border:0 !important;
  background:transparent !important;
}
.brand-logo.placeholder::after,
.hero-logo.placeholder::after{
  opacity:.38;
}
.brand img{
  max-height:28px;
  width:auto;
  object-fit:contain;
}
.hero-logo{
  width:min(420px, 42vw);
  height:auto;
  min-height:120px;
  margin:0 auto 18px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-logo img{
  width:100%;
  height:auto;
  max-height:180px;
  object-fit:contain;
}
.hero-content{
  padding-top:96px;
}
.hero-tag{
  margin:0 0 10px;
}
.hero-bottom-nav{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.hero-bottom-nav::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--hero-panel-bg);
  background-size:cover;
  background-position:center;
  opacity:var(--hero-panel-opacity, 0);
  z-index:-2;
  pointer-events:none;
}
.hero-bottom-nav::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom, rgba(10,10,10,.28), rgba(10,10,10,.55));
  z-index:-1;
  pointer-events:none;
}
.hero-nav-item{
  background:transparent;
  backdrop-filter:none;
}
@media (max-width: 900px){
  .brand img{max-height:20px}
  .hero-logo{
    width:min(340px, 68vw);
    min-height:88px;
    margin-bottom:14px;
  }
  .hero-logo img{
    max-height:132px;
  }
  .hero-content{
    padding-top:84px;
  }
}
@media (max-width: 640px){
  .hero-logo{
    width:min(280px, 72vw);
    min-height:72px;
  }
  .hero-logo img{
    max-height:104px;
  }
}

/* keep placeholders from showing dashed boxes */
.brand-logo.placeholder,
.hero-logo.placeholder{
  min-height:40px;
}


.day-cruise{background:var(--panel)}
.day-cruise-grid{margin-top:34px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.day-cruise-item{overflow:hidden;min-height:280px;border:1px solid rgba(255,255,255,.08)}
.day-cruise-item img,.day-cruise-item video{width:100%;height:100%;object-fit:cover}

.booking-layout{display:grid;grid-template-columns:1.02fr .98fr;gap:48px;align-items:start}
.booking-left,.booking-right{display:flex;flex-direction:column;gap:24px;min-width:0}
.booking-info-card{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);padding:24px}
.booking-info-card h4{margin:0 0 12px;font-family:"Cormorant Garamond",serif;font-size:26px;font-weight:300}
.phone-row{grid-template-columns:170px 1fr 1fr}
.country-code-field select{height:100%}

.rates tr.is-booked td:nth-child(1),
.rates tr.is-booked td:nth-child(2){
  color:#c86a6a;
  text-decoration:line-through;
  text-decoration-thickness:1.5px;
}
.rates tr.is-booked .status-badge{
  color:#e08a8a;
  border-color:rgba(224,138,138,.35);
  background:rgba(224,138,138,.08);
}

@media (max-width: 1100px){
  .day-cruise-grid{grid-template-columns:repeat(2,1fr)}
  .phone-row{grid-template-columns:1fr 1fr}
  .country-code-field{grid-column:1/-1}
}
@media (max-width: 900px){
  .booking-layout{grid-template-columns:1fr !important}
  .phone-row{grid-template-columns:1fr}
  .day-cruise-grid{grid-template-columns:1fr}
  .gallery-grid{column-count:2}
}
@media (max-width: 640px){
  .gallery-grid{column-count:1}
}

/* Fix country code dropdown visibility */
select,
option{
  color:#000 !important;
  background:#fff !important;
}

/* Inquiry toggle */
.inquiry-toggle{
  display:inline-flex;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.03);
}
.toggle-btn{
  appearance:none;
  border:0;
  background:transparent;
  color:rgba(255,255,255,.72);
  padding:12px 18px;
  font:inherit;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  cursor:pointer;
  transition:.2s ease;
}
.toggle-btn + .toggle-btn{
  border-left:1px solid rgba(255,255,255,.14);
}
.toggle-btn.is-active{
  background:rgba(200,164,83,.14);
  color:var(--gold);
}
input[type="date"]{
  color:var(--text);
}
input[type="date"]::-webkit-calendar-picker-indicator{
  filter:invert(1) brightness(0.9);
  cursor:pointer;
}
@media (max-width:640px){
  .inquiry-toggle{
    width:100%;
  }
  .toggle-btn{
    flex:1 1 50%;
    text-align:center;
    padding:11px 10px;
    font-size:10px;
    letter-spacing:.16em;
  }
}

/* Dark form controls */
.field select,
.field input[type="date"],
.field input,
.field textarea{
  background:#141414 !important;
  color:#f3efe6 !important;
  border:1px solid rgba(255,255,255,.12) !important;
}
.field select option{
  background:#141414 !important;
  color:#f3efe6 !important;
}
.field input::placeholder,
.field textarea::placeholder{
  color:rgba(243,239,230,.45) !important;
}
/* Booked rows */
.booked-date{
  color:#d46a6a !important;
  text-decoration:line-through;
  text-decoration-thickness:1px;
}
.status-badge.is-booked{
  color:#d46a6a !important;
  border-color:rgba(212,106,106,.45) !important;
  background:rgba(212,106,106,.08) !important;
}
.rates tr.is-booked td{
  opacity:1 !important;
}

/* Extra select polish for inquiry form */
.country-code-field select,
.field select[name="guests"]{
  appearance:auto;
  background:#141414 !important;
  color:#f3efe6 !important;
}


/* Critical booking mobile fixes */
@media (max-width:1024px){
  .booking-layout{
    display:flex !important;
    flex-direction:column !important;
    gap:28px !important;
  }
  .booking-left{
    order:2 !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }
  .booking-right{
    order:1 !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }
}
.booking-shell,
.booking-shell form,
.booking-shell .field,
.booking-shell .form-row,
.booking-shell .charter-only,
.booking-shell .day-cruise-only{
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
}
.booking-shell input[type="date"],
.booking-shell select,
.booking-shell input,
.booking-shell textarea{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
}
@media (max-width:768px){
  .booking-shell{
    overflow:hidden !important;
    padding:18px !important;
  }
  .booking-shell .form-row{
    grid-template-columns:1fr !important;
  }
  .booking-shell .phone-row{
    grid-template-columns:1fr !important;
  }
  .booking-shell .day-cruise-only{
    display:block;
    width:100% !important;
  }
  .booking-shell .day-cruise-only input[type="date"]{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }
}



/* Final mobile booking layout */
@media (max-width:1024px){
  .booking-layout{
    display:flex !important;
    flex-direction:column !important;
    gap:28px !important;
  }
  .booking-left,
  .booking-right{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }

  /* Keep left column first: Reserve header/text, then table */
  .booking-left{
    display:flex !important;
    flex-direction:column !important;
  }
  .booking-left > :first-child{
    order:1 !important;
  }
  .booking-left .rates{
    order:3 !important;
  }

  /* Right column sits between intro and rates */
  .booking-right{
    order:2 !important;
    display:flex !important;
    flex-direction:column !important;
  }
  .booking-right .booking-shell{
    order:1 !important;
  }
  .booking-right .booking-info-card{
    order:2 !important;
  }
}

/* Day cruise width should match all other inputs */
.booking-shell .day-cruise-only{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
}
.booking-shell .day-cruise-only input[type="date"]{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
  margin:0 !important;
}
@media (max-width:768px){
  .booking-shell .day-cruise-only{
    padding:0 !important;
  }
  .booking-shell .day-cruise-only input[type="date"]{
    padding:12px 13px !important;
  }
}



/* Absolute mobile booking sequence fix */
@media (max-width:1024px){
  .booking-layout{
    display:block !important;
  }
  .booking-layout > *{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }
  .booking-mobile-intro,
  .booking-mobile-form,
  .booking-mobile-rates,
  .booking-mobile-fees{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    display:block !important;
  }
}

/* Day cruise date field should match other fields exactly */
.booking-shell .day-cruise-only,
.booking-shell .day-cruise-only.field{
  display:flex !important;
  flex-direction:column !important;
  gap:7px !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
}
.booking-shell .day-cruise-only input[type="date"]{
  -webkit-appearance:none !important;
  appearance:none !important;
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
  padding:12px 13px !important;
  height:auto !important;
  line-height:1.4 !important;
  font:inherit !important;
  border:1px solid rgba(255,255,255,.12) !important;
  background:#141414 !important;
  color:#f3efe6 !important;
}
.booking-shell .day-cruise-only input[type="date"]::-webkit-date-and-time-value{
  text-align:left !important;
}
.booking-shell .day-cruise-only input[type="date"]::-webkit-calendar-picker-indicator{
  filter:invert(1) !important;
  opacity:.9 !important;
}


/* Rebuilt booking section with season tabs */
.booking-layout{
  display:grid !important;
  grid-template-columns:minmax(0,.52fr) minmax(0,.48fr) !important;
  grid-template-areas:
    "intro form"
    "rates fees" !important;
  gap:32px 48px !important;
  align-items:start !important;
}
.booking-intro{grid-area:intro}
.booking-form-wrap{grid-area:form}
.booking-rates-wrap{grid-area:rates;min-width:0}
.booking-fees-wrap{grid-area:fees}
.season-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}
.season-tab{appearance:none;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);color:rgba(255,255,255,.74);padding:10px 14px;font:inherit;font-size:11px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer}
.season-tab.is-active,.season-tab:hover{border-color:rgba(200,164,83,.55);background:rgba(200,164,83,.12);color:var(--gold)}
.season-table{display:none}
.season-table.is-active{display:block}
.season-title{margin:0 0 10px;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.56)}
.booking-shell .day-cruise-only{display:none !important}
.booking-shell .day-cruise-only input[type="date"]{display:block;width:100%;max-width:100%;min-width:0;box-sizing:border-box;padding:12px 13px;height:auto;line-height:1.4}
@media (max-width:1024px){
  .booking-layout{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "intro"
      "form"
      "rates"
      "fees" !important;
    gap:24px !important;
  }
}
@media (max-width:768px){
  .booking-shell .form-row,
  .booking-shell .phone-row{grid-template-columns:1fr !important}
}

/* Booking form toggle correctness */
.booking-shell .charter-only{display:none}
.booking-shell .charter-only.is-active{display:grid}
.booking-shell .day-cruise-only{display:none !important}
.booking-shell .day-cruise-only.is-active{display:flex !important;flex-direction:column}
.booking-layout{
  row-gap:18px !important;
}
.booking-intro .b-detail{margin-top:18px}
.booking-rates-wrap{margin-top:-4px}
@media (max-width:1024px){
  .booking-layout{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "intro"
      "form"
      "rates"
      "fees" !important;
    gap:18px !important;
  }
  .booking-rates-wrap{margin-top:0}
}


/* Final booking form visibility fix */
#charterFields{
  display:grid;
}
#dayCruiseField{
  display:none !important;
}
#dayCruiseField.is-active{
  display:flex !important;
  flex-direction:column !important;
}
#charterFields.is-active{
  display:grid !important;
}
.booking-shell .charter-only:not(.is-active){
  display:none !important;
}
.booking-shell .day-cruise-only:not(.is-active){
  display:none !important;
}

/* Tightened gap between contact block and pricing table */
.booking-layout{
  row-gap:14px !important;
}
.booking-intro{
  margin-bottom:0 !important;
  padding-bottom:0 !important;
}
.booking-intro .body{
  margin-bottom:14px !important;
}
.booking-intro .b-detail{
  margin-top:14px !important;
  margin-bottom:0 !important;
}
.booking-intro .b-detail p{
  margin-bottom:0 !important;
}
.booking-rates-wrap{
  margin-top:-18px !important;
  padding-top:0 !important;
  align-self:start !important;
}
.booking-rates-wrap.compact-rates .season-title{
  margin-top:0 !important;
}
.booking-rates-wrap .rates{
  margin-top:8px !important;
}
@media (max-width:1024px){
  .booking-layout{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "intro"
      "form"
      "rates"
      "fees" !important;
    gap:16px !important;
  }
  .booking-rates-wrap{
    margin-top:0 !important;
  }
}



/* Hero logo + subtitle tighter and larger */
.hero-content{
  gap:10px !important;
}
.hero-logo{
  width:min(500px, 52vw) !important;
  min-height:132px !important;
  margin:0 auto 8px !important;
}
.hero-logo img{
  max-height:216px !important;
}
.hero-tag{
  margin:0 0 4px !important;
  font-size:15px !important;
  letter-spacing:.34em !important;
}
.hero-title{
  margin:0 !important;
  font-size:clamp(58px, 6vw, 86px) !important;
  line-height:.96 !important;
}
@media (max-width: 900px){
  .hero-content{
    gap:8px !important;
  }
  .hero-logo{
    width:min(380px, 76vw) !important;
    min-height:96px !important;
    margin-bottom:6px !important;
  }
  .hero-logo img{
    max-height:150px !important;
  }
  .hero-tag{
    font-size:13px !important;
    letter-spacing:.28em !important;
    margin-bottom:2px !important;
  }
  .hero-title{
    font-size:clamp(42px, 10vw, 60px) !important;
  }
}


/* ===== FINAL HERO BALANCE (LOGO PRIORITY) ===== */
.hero-content{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px !important;
}

/* Moondance logo = primary */
.hero-logo{
  width:min(560px, 60vw) !important;
  min-height:140px !important;
  margin:0 auto 2px !important;
}
.hero-logo img{
  width:100% !important;
  height:auto !important;
  max-height:240px !important;
  object-fit:contain !important;
}

/* Lagoon line = secondary but close */
.hero-tag{
  font-size:16px !important;
  letter-spacing:.35em !important;
  margin:0 0 6px 0 !important;
  opacity:.9 !important;
}

/* Life On Board = tagline, smaller and slightly separated */
.hero-title{
  font-size:clamp(46px, 5vw, 68px) !important;
  line-height:1.05 !important;
  margin-top:10px !important;
  margin-bottom:0 !important;
  opacity:.9 !important;
}

/* Mobile balance */
@media (max-width: 768px){
  .hero-logo{
    width:min(420px, 80vw) !important;
    min-height:96px !important;
    margin-bottom:2px !important;
  }
  .hero-logo img{
    max-height:180px !important;
  }
  .hero-tag{
    font-size:14px !important;
    letter-spacing:.28em !important;
    margin-bottom:6px !important;
  }
  .hero-title{
    font-size:clamp(34px, 8vw, 48px) !important;
    margin-top:12px !important;
  }
}


/* Vessel specs reordered to 8 items */
.vessel-specs-eight{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:26px 48px;
}
@media (max-width: 1024px){
  .vessel-specs-eight{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:22px 30px;
  }
}
@media (max-width: 640px){
  .vessel-specs-eight{
    grid-template-columns:1fr;
    gap:18px;
  }
}

/* Final hero emphasis */
.hero-content{
  gap:4px !important;
}
.hero-logo{
  width:min(610px, 66vw) !important;
  min-height:148px !important;
  margin:0 auto 0 !important;
  position:relative;
}
.hero-logo img{
  max-height:255px !important;
  filter:
    drop-shadow(0 0 1px rgba(255,255,255,.55))
    drop-shadow(0 0 8px rgba(255,255,255,.18))
    drop-shadow(0 0 16px rgba(255,255,255,.10));
}
.hero-tag{
  font-size:17px !important;
  letter-spacing:.34em !important;
  margin:0 !important;
  opacity:.95 !important;
  transform:translateY(-2px);
}
.hero-title{
  font-size:clamp(42px, 4.7vw, 62px) !important;
  line-height:1.03 !important;
  margin-top:14px !important;
  opacity:.92 !important;
}
@media (max-width: 900px){
  .hero-content{
    gap:4px !important;
  }
  .hero-logo{
    width:min(450px, 84vw) !important;
    min-height:108px !important;
  }
  .hero-logo img{
    max-height:190px !important;
  }
  .hero-tag{
    font-size:14px !important;
    letter-spacing:.28em !important;
    transform:none;
  }
  .hero-title{
    font-size:clamp(34px, 8vw, 50px) !important;
    margin-top:10px !important;
  }
}


/* Vessel facts 8-item layout */
.vessel-facts-eight{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:28px 52px;
}
@media (max-width: 1024px){
  .vessel-facts-eight{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:24px 34px;
  }
}
@media (max-width: 640px){
  .vessel-facts-eight{
    grid-template-columns:1fr;
    gap:18px;
  }
}

/* Home base map marker */
.isl-marker.homebase{
  width:14px;
  height:14px;
  border-radius:999px;
  background:#2fa66a;
  border:2px solid rgba(255,255,255,.78);
  box-shadow:0 0 0 3px rgba(47,166,106,.18), 0 0 12px rgba(47,166,106,.45);
}


/* Force final vessel specs order/layout */
.specs.specs-eight{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0,1fr)) !important;
  gap:28px 52px !important;
}
@media (max-width:1024px){
  .specs.specs-eight{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:22px 30px !important;
  }
}
@media (max-width:640px){
  .specs.specs-eight{
    grid-template-columns:1fr !important;
    gap:18px !important;
  }
}


/* Refined vessel specs layout: 3 + 3 + 2 */
.specs.specs-eight{
  display:grid !important;
  grid-template-columns:repeat(12, minmax(0,1fr)) !important;
  gap:26px 28px !important;
  align-items:start !important;
}
.specs.specs-eight > div{
  grid-column:span 4 !important;
  min-width:0 !important;
}
.specs.specs-eight > div:nth-child(7),
.specs.specs-eight > div:nth-child(8){
  grid-column:span 6 !important;
}
.specs .spec-val{
  display:block !important;
  max-width:none !important;
  overflow-wrap:anywhere !important;
  word-break:normal !important;
}
@media (max-width: 1024px){
  .specs.specs-eight{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:22px 28px !important;
  }
  .specs.specs-eight > div,
  .specs.specs-eight > div:nth-child(7),
  .specs.specs-eight > div:nth-child(8){
    grid-column:auto !important;
  }
}
@media (max-width: 640px){
  .specs.specs-eight{
    grid-template-columns:1fr !important;
    gap:18px !important;
  }
}


/* FINAL ALIGN FIX */
.specs.specs-eight{
  display:grid !important;
  grid-template-columns:repeat(12, minmax(0,1fr)) !important;
  gap:26px 28px !important;
}

/* Row 1 */
.specs.specs-eight > div:nth-child(1){ grid-column:1 / span 4; }
.specs.specs-eight > div:nth-child(2){ grid-column:5 / span 4; }
.specs.specs-eight > div:nth-child(3){ grid-column:9 / span 4; }

/* Row 2 */
.specs.specs-eight > div:nth-child(4){ grid-column:1 / span 4; }
.specs.specs-eight > div:nth-child(5){ grid-column:5 / span 4; }
.specs.specs-eight > div:nth-child(6){ grid-column:9 / span 4; }

/* Row 3 */
.specs.specs-eight > div:nth-child(7){ grid-column:1 / span 6; }
.specs.specs-eight > div:nth-child(8){ grid-column:7 / span 6; }


/* ABSOLUTE VESSEL SPECS COLUMN FIX */
.specs.specs-eight{
  display:grid !important;
  grid-template-columns:repeat(12, minmax(0,1fr)) !important;
  gap:26px 28px !important;
  align-items:start !important;
}

/* hard place every item */
.specs.specs-eight > div:nth-child(1){ grid-column:1 / span 4 !important; grid-row:1 !important; }
.specs.specs-eight > div:nth-child(2){ grid-column:5 / span 4 !important; grid-row:1 !important; }
.specs.specs-eight > div:nth-child(3){ grid-column:9 / span 4 !important; grid-row:1 !important; }

.specs.specs-eight > div:nth-child(4){ grid-column:1 / span 4 !important; grid-row:2 !important; }
.specs.specs-eight > div:nth-child(5){ grid-column:5 / span 4 !important; grid-row:2 !important; }
.specs.specs-eight > div:nth-child(6){ grid-column:9 / span 4 !important; grid-row:2 !important; }

/* last row aligned with first and second columns */
.specs.specs-eight > div:nth-child(7){ grid-column:1 / span 4 !important; grid-row:3 !important; }
.specs.specs-eight > div:nth-child(8){ grid-column:5 / span 4 !important; grid-row:3 !important; }

@media (max-width:1024px){
  .specs.specs-eight{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:22px 28px !important;
  }
  .specs.specs-eight > div{
    grid-column:auto !important;
    grid-row:auto !important;
  }
}

@media (max-width:640px){
  .specs.specs-eight{
    grid-template-columns:1fr !important;
    gap:18px !important;
  }
}

.region.active .island-detail,
.island-detail.active{
  display:block;
}
.island-detail{
  display:none;
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid var(--line);
}
.island-detail-title{
  font-family:"Cormorant Garamond",serif;
  font-size:28px;
  line-height:1.05;
  margin:0 0 14px;
}
.island-detail-list{
  margin:0;
  padding-left:18px;
  color:var(--muted);
  line-height:1.9;
  font-size:13px;
}
.island-detail-list li+li{margin-top:4px}
.island-detail-images{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:18px;
}
.island-detail-images img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
}
@media (max-width:900px){
  .island-detail-images{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:640px){
  .island-detail-images{grid-template-columns:1fr}
}


/* Destinations layout hard fix after markup repair */
.dest-layout{
  display:grid !important;
  grid-template-columns:minmax(420px, 520px) minmax(620px, 1fr) !important;
  gap:56px !important;
  align-items:start !important;
}
.dest-layout > .regions,
.dest-layout > .map-wrap{
  min-width:0 !important;
}
.dest-layout > .map-wrap{
  display:flex !important;
  flex-direction:column !important;
  align-self:start !important;
}
@media (max-width:1100px){
  .dest-layout{
    grid-template-columns:1fr !important;
  }
}


/* Island detail only opens after island selection */
.region .island-detail{
  display:none !important;
}
.region .island-detail.active{
  display:block !important;
}


.planned-trips-block{margin-top:120px;padding-top:56px;border-top:1px solid rgba(255,255,255,.08)}
.planned-trips-title{font-family:Cormorant Garamond,serif;font-size:clamp(36px,4.2vw,62px);line-height:.98;font-weight:400;margin:0}
.trip-notices{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:28px}
.trip-notice{padding:18px 20px;border:1px solid rgba(199,161,92,.28);background:rgba(255,255,255,.025);color:var(--muted);font-size:14px;line-height:1.7}
.planned-trip-card-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:38px}
.planned-trip-card{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.1);padding:20px 18px;text-align:left;color:var(--text);transition:.25s ease;display:flex;flex-direction:column;gap:8px}
.planned-trip-card.active,.planned-trip-card:hover{border-color:rgba(199,161,92,.55);background:rgba(199,161,92,.06)}
.planned-trip-card-title{font-size:18px;letter-spacing:.08em;text-transform:uppercase}
.planned-trip-card-copy{font-size:14px;line-height:1.6;color:var(--muted)}
.planned-trip-viewer{margin-top:28px;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(380px,.95fr);gap:28px;align-items:start}
.planned-trip-copy,.planned-trip-media{background:rgba(255,255,255,.018);border:1px solid rgba(255,255,255,.08);padding:26px}
.planned-trip-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:14px}
.planned-trip-kicker{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.planned-trip-name{font-family:Cormorant Garamond,serif;font-size:44px;line-height:.98;font-weight:400;margin:0}
.trip-variant-toggle{display:inline-flex;border:1px solid rgba(255,255,255,.12);padding:4px;background:#0f1113;gap:4px}
.trip-variant-btn{min-width:96px;padding:12px 16px;border:0;background:transparent;color:var(--muted);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.trip-variant-btn.active{background:rgba(199,161,92,.15);color:var(--text)}
.trip-variant-btn:disabled{opacity:.35;cursor:not-allowed}
.planned-trip-blurb{color:var(--muted);font-size:15px;line-height:1.85;margin:0 0 22px}
.planned-trip-itinerary-list{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.planned-trip-itinerary-item{padding:16px 18px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02)}
.planned-trip-itinerary-route{font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}
.planned-trip-itinerary-note{margin-top:8px;color:var(--muted);line-height:1.65;font-size:14px}
.planned-trip-media-frame{aspect-ratio:16/8;border:1px solid rgba(255,255,255,.08);overflow:hidden;background:rgba(255,255,255,.02);margin-bottom:18px}
.planned-trip-media-frame img,.planned-trip-media-frame video{width:100%;height:100%;object-fit:cover;display:block}
.planned-trip-media-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;font-size:12px}
#planned-trip-map{height:360px;border:1px solid rgba(255,255,255,.08)}
@media (max-width: 1100px){.planned-trip-viewer{grid-template-columns:1fr}.trip-notices{grid-template-columns:1fr}}
@media (max-width: 720px){.planned-trip-header{flex-direction:column}.planned-trip-name{font-size:34px}.trip-variant-toggle{width:100%}.trip-variant-btn{flex:1}#planned-trip-map{height:300px}}

.booking-fees-wrap{display:grid;gap:18px}

.day-trip-planner-block{margin-top:64px;padding-top:48px;border-top:1px solid rgba(255,255,255,.08)}
.day-trip-toggle-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:34px}
.day-trip-toggle{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.1);padding:20px 18px;text-align:left;color:var(--text);transition:.25s ease;display:flex;flex-direction:column;gap:8px}
.day-trip-toggle.active,.day-trip-toggle:hover{border-color:rgba(199,161,92,.55);background:rgba(199,161,92,.06)}
#day-trip-map{height:340px;border:1px solid rgba(255,255,255,.08)}
@media (max-width:720px){#day-trip-map{height:300px}}


.custom-charter-block{margin-top:72px;padding-top:8px;border-top:1px solid rgba(196,155,84,.22)}
.custom-charter-viewer{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);gap:28px;margin-top:28px}
.custom-charter-summary{margin-bottom:22px}
.custom-charter-days{display:grid;gap:14px}
.custom-charter-day-row{display:grid;grid-template-columns:minmax(180px,240px) minmax(0,1fr);gap:16px;align-items:center;padding:16px 18px;border:1px solid rgba(196,155,84,.2);background:rgba(255,255,255,.015)}
.custom-charter-day-meta{display:grid;gap:6px}
.custom-charter-day-num{font-family:'Tenor Sans',sans-serif;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#c49b54}
.custom-charter-day-start{font-size:14px;line-height:1.5;color:rgba(255,255,255,.82)}
.custom-charter-select{width:100%;background:#0e0e10;color:#f6efe3;border:1px solid rgba(196,155,84,.28);padding:14px 16px;font-size:14px}
.custom-charter-return-row{background:rgba(196,155,84,.05)}
.custom-charter-media-frame{min-height:140px;margin-bottom:18px}
.custom-charter-media-frame .planned-trip-media-placeholder{height:140px}
#custom-charter-map{height:420px;border:1px solid rgba(196,155,84,.16)}
.custom-itinerary-form-optin{margin-bottom:6px}
.custom-itinerary-checkbox{display:flex;align-items:flex-start;gap:12px;color:#f6efe3;cursor:pointer}
.custom-itinerary-checkbox input{margin-top:4px}
.field-help{margin-top:8px;font-size:13px;line-height:1.5;color:rgba(255,255,255,.62)}
@media (max-width: 980px){.custom-charter-viewer{grid-template-columns:1fr}.custom-charter-day-row{grid-template-columns:1fr}}


/* Custom charter builder accessibility and visual polish */
.trip-variant-toggle{
  border:1px solid rgba(196,155,84,.28);
  background:rgba(196,155,84,.08);
  border-radius:999px;
  padding:5px;
}
.custom-charter-duration-btn,
.trip-variant-btn{
  appearance:none;
  background:transparent;
  color:rgba(246,239,227,.88);
  border:1px solid rgba(196,155,84,.36);
  border-radius:999px;
  padding:12px 20px;
  min-width:122px;
  font-family:'Tenor Sans',sans-serif;
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  transition:background .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease,transform .2s ease;
}
.custom-charter-duration-btn:hover,
.trip-variant-btn:hover{
  border-color:rgba(196,155,84,.65);
  color:#f8f1e4;
  transform:translateY(-1px);
}
.custom-charter-duration-btn.active,
.trip-variant-btn.active{
  background:linear-gradient(180deg, rgba(196,155,84,.28), rgba(196,155,84,.14));
  border-color:#c49b54;
  color:#fff7ea;
  box-shadow:0 0 0 1px rgba(196,155,84,.18), 0 12px 28px rgba(0,0,0,.22);
}
.custom-charter-region-guide{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 22px;
}
.custom-charter-region-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border:1px solid rgba(196,155,84,.18);
  background:rgba(255,255,255,.02);
  color:rgba(246,239,227,.82);
  font-size:12px;
  line-height:1.45;
}
.custom-charter-region-chip strong{
  color:#f4ead8;
  font-weight:600;
}
.custom-charter-region-key{
  width:10px;
  height:10px;
  border-radius:999px;
  background:#c49b54;
  box-shadow:0 0 0 1px rgba(196,155,84,.18);
}
.custom-charter-region-key.region-saronic{background:#c49b54}
.custom-charter-region-key.region-cyclades{background:#8ec5ff}
.custom-charter-region-key.region-ionian{background:#7fd8a7}
.custom-charter-region-key.region-dodecanese{background:#f3a76f}
.custom-charter-region-key.region-base{background:#ffffff}
.custom-charter-day-help{
  margin-top:7px;
  color:rgba(255,255,255,.6);
  font-size:12px;
  line-height:1.45;
}
.custom-charter-select{
  appearance:none;
  -webkit-appearance:none;
  background-color:#121316;
  color:#f6efe3;
  border:1px solid rgba(196,155,84,.32);
  border-radius:0;
  padding:14px 46px 14px 16px;
  background-image:linear-gradient(45deg, transparent 50%, #c49b54 50%), linear-gradient(135deg, #c49b54 50%, transparent 50%);
  background-position:calc(100% - 20px) calc(50% - 3px), calc(100% - 14px) calc(50% - 3px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
}
.custom-charter-select:focus{
  outline:none;
  border-color:#c49b54;
  box-shadow:0 0 0 1px rgba(196,155,84,.18), 0 0 0 4px rgba(196,155,84,.08);
}
.custom-charter-select option,
.custom-charter-select optgroup{
  background:#101114;
  color:#f6efe3;
}
.custom-charter-select optgroup{
  font-style:normal;
  font-weight:600;
}
@media (max-width: 720px){
  .custom-charter-duration-btn,.trip-variant-btn{min-width:0;flex:1;padding:12px 14px}
  .custom-charter-region-guide{gap:8px}
  .custom-charter-region-chip{width:100%}
}


.custom-charter-day-row{cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}
.custom-charter-day-row.is-pick-target{border-color:rgba(196,155,84,.72);background:rgba(196,155,84,.07);box-shadow:0 0 0 1px rgba(196,155,84,.16) inset}
.custom-charter-select-wrap{min-width:0}
.leaflet-interactive.custom-charter-map-marker{cursor:pointer}


#custom-charter-inline-viewer[hidden],
#planned-trip-viewer[hidden]{display:none !important}
.planned-trip-card-custom{border-style:solid}
.custom-charter-select,
.custom-charter-select:focus,
.custom-charter-select:hover{
  background:#121316 !important;
  background-color:#121316 !important;
  color:#f6efe3 !important;
  border:1px solid rgba(196,155,84,.32) !important;
}
.custom-charter-select option,
.custom-charter-select optgroup{
  background:#101114 !important;
  color:#f6efe3 !important;
}
.custom-charter-select::-ms-expand{display:none}


/* Final custom charter select fixes */
.custom-charter-select,
.custom-charter-select:focus,
.custom-charter-select:hover,
.custom-charter-select:active{
  -webkit-text-fill-color:#f6efe3 !important;
  background:#121316 !important;
  background-color:#121316 !important;
  color:#f6efe3 !important;
}
.custom-charter-select option,
.custom-charter-select optgroup{
  -webkit-text-fill-color:#f6efe3 !important;
  background:#121316 !important;
  color:#f6efe3 !important;
}
.custom-charter-viewer .trip-variant-toggle{
  position:relative;
  z-index:3;
}
.custom-charter-viewer .custom-charter-duration-btn{
  cursor:pointer;
}
#custom-charter-map{
  min-height:420px;
}


.planned-trip-itinerary-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.planned-trip-leg-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:var(--muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.planned-trip-leg-badge.is-easy{border-color:rgba(127,216,167,.45);color:#bff1cf;background:rgba(127,216,167,.12)}
.planned-trip-leg-badge.is-moderate{border-color:rgba(196,155,84,.5);color:#f0d39d;background:rgba(196,155,84,.12)}
.planned-trip-leg-badge.is-long{border-color:rgba(243,167,111,.5);color:#ffd0aa;background:rgba(243,167,111,.12)}

.day-trip-included{margin-top:20px;padding:18px 20px;border:1px solid rgba(215,171,90,.24);background:rgba(215,171,90,.04)}
.day-trip-included-lines{display:grid;gap:10px;margin-top:10px}
.day-trip-included-line{position:relative;padding-left:16px;color:#d7d1c7;line-height:1.6}
.day-trip-included-line:before{content:'•';position:absolute;left:0;top:0;color:#d7ab5a}

.hp-field{position:absolute !important;left:-9999px !important;opacity:0 !important;pointer-events:none !important;height:0 !important;width:0 !important;}
.form-error{display:none;margin-top:14px;padding:12px 14px;border:1px solid rgba(255,255,255,.18);background:rgba(120,20,20,.2);color:#f3d6d6;}
