/* =========================
   White Prestige (Blue Aqua)
   Fast scroll, wow hero, yacht-first
   ========================= */

:root{
  --bg:#F7FBFF;
  --card:#FFFFFF;
  --ink:#071225;
  --muted:rgba(7,18,37,.68);
  --line:rgba(7,18,37,.10);

  --blue:#1D72FF;
  --cyan:#00C2FF;
  --aqua:#00D6C9;

  --shadow: 0 18px 60px rgba(7,18,37,.10);
  --shadow2: 0 10px 30px rgba(7,18,37,.08);

  --r:18px;
  --r2:26px;

  --container: 1180px;

  --ease: cubic-bezier(.2,.8,.2,1);
  --ease2: cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif;
  color:var(--ink);
  background: var(--bg);
  overflow-x:hidden;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

img{max-width:100%; display:block}
a{color:inherit}

.container{
  width: min(var(--container), calc(100% - 40px));
  margin: 0 auto;
}

.skip{
  position:absolute; left:-999px; top:auto;
  width:1px;height:1px; overflow:hidden;
}
.skip:focus{
  left:16px; top:12px;
  width:auto;height:auto;
  padding:10px 12px;
  border-radius: 12px;
  background: #fff;
  box-shadow: var(--shadow2);
  border:1px solid var(--line);
  z-index:999;
}

.muted{color: var(--muted)}
.h2{margin:0; font-size: 28px; letter-spacing: -0.6px}
.h3{margin:0; font-size: 18px; letter-spacing: -0.3px}

.section{
  padding: 70px 0;
  scroll-margin-top: 84px;
}

.section__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.miniNote{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(29,114,255,.06);
  border: 1px solid rgba(29,114,255,.14);
  color: rgba(7,18,37,.78);
  font-size: 12px;
  white-space:nowrap;
}
.miniDot{
  width:8px;height:8px;border-radius:999px;
  background: linear-gradient(135deg, var(--blue), var(--aqua));
}

/* =========================
   Topbar
   ========================= */
.topbar{
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(247,251,255,.82);
  backdrop-filter: saturate(160%) blur(10px);
  border-bottom: 1px solid rgba(7,18,37,.08);
}
.topbar__in{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap: 10px;
  text-decoration:none;
}
.brand__mark{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.9), rgba(255,255,255,.2)),
    linear-gradient(135deg, rgba(29,114,255,.20), rgba(0,214,201,.16));
  border: 1px solid rgba(29,114,255,.16);
  box-shadow: 0 14px 34px rgba(29,114,255,.14);
}
.brand__name{
  font-weight: 860;
  letter-spacing: .2px;
}

.nav{
  display:flex;
  align-items:center;
  gap: 16px;
}
.nav a{
  text-decoration:none;
  color: rgba(7,18,37,.78);
  font-size: 14px;
  padding: 10px 10px;
  border-radius: 12px;
  transition: background .2s var(--ease), transform .2s var(--ease);
}
.nav a:hover{
  background: rgba(29,114,255,.06);
  transform: translateY(-1px);
}
.topbar__cta{
  white-space:nowrap;
}

/* =========================
   Buttons
   ========================= */
.btn{
  height: 46px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(7,18,37,.10);
  background: #fff;
  color: rgba(7,18,37,.90);
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  font-weight: 860;
  letter-spacing: .2px;
  box-shadow: 0 10px 26px rgba(7,18,37,.08);
  transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease);
}
.btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 40px rgba(7,18,37,.10);
}
.btn--primary{
  border-color: rgba(29,114,255,.24);
  background: linear-gradient(135deg, rgba(29,114,255,.92), rgba(0,214,201,.92));
  color: #fff;
  box-shadow: 0 18px 44px rgba(29,114,255,.22);
}
.btn--ghost{
  background: rgba(255,255,255,.74);
}
.btn--soft{
  background: rgba(29,114,255,.07);
  border-color: rgba(29,114,255,.14);
  box-shadow: none;
}
.btn--full{width:100%}

/* =========================
   WhatsApp floating
   ========================= */
.waFloat{
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 80;
  display:flex;
  align-items:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: 999px;
  text-decoration:none;
  background: #fff;
  border: 1px solid rgba(7,18,37,.10);
  box-shadow: var(--shadow);
  transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
.waFloat:hover{ transform: translateY(-2px); box-shadow: 0 22px 70px rgba(7,18,37,.14); }
.waFloat__icon{
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  font-weight: 900;
  font-size: 12px;
  color:#fff;
  background: linear-gradient(135deg, #25D366, #128C7E);
}
.waFloat__text{font-size: 13px; font-weight: 880}

/* =========================
   Hero (wow)
   ========================= */
.hero{
  position: relative;
  padding: 76px 0 54px;
  overflow:hidden;
}
.hero__bg{
  position:absolute;
  inset:-20%;
  pointer-events:none;
}
.blob{
  position:absolute;
  width: 620px;
  height: 620px;
  border-radius: 999px;
  filter: blur(30px);
  opacity: .55;
  transform: translate3d(0,0,0);
}
.blob--a{
  left: -120px;
  top: -120px;
  background: radial-gradient(circle at 30% 30%, rgba(29,114,255,.55), rgba(0,214,201,.20), transparent 65%);
  animation: floatA 10s var(--ease2) infinite alternate;
}
.blob--b{
  right: -160px;
  bottom: -180px;
  background: radial-gradient(circle at 40% 40%, rgba(0,194,255,.42), rgba(29,114,255,.18), transparent 65%);
  animation: floatB 12s var(--ease2) infinite alternate;
}
.grid{
  position:absolute;
  inset:0;
  opacity: .10;
  background:
    linear-gradient(to right, rgba(7,18,37,.22) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(7,18,37,.22) 1px, transparent 1px);
  background-size: 90px 90px;
  mask-image: radial-gradient(closest-side at 40% 30%, rgba(0,0,0,1), rgba(0,0,0,.25) 70%, transparent 85%);
}
@keyframes floatA{ from{ transform: translate3d(0,0,0) } to{ transform: translate3d(40px,22px,0) } }
@keyframes floatB{ from{ transform: translate3d(0,0,0) } to{ transform: translate3d(-38px,-26px,0) } }

.hero__in{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 22px;
  align-items: start;
  position:relative;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(7,18,37,.10);
  box-shadow: 0 10px 30px rgba(7,18,37,.08);
  font-size: 12px;
  color: rgba(7,18,37,.78);
}
.badge__dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--blue), var(--aqua));
  box-shadow: 0 0 0 6px rgba(29,114,255,.10);
}

.hero__title{
  margin: 16px 0 10px;
  font-size: clamp(36px, 4.5vw, 62px);
  line-height: 1.02;
  letter-spacing: -1px;
}
.hero__sub{
  display:block;
  margin-top: 10px;
  font-size: clamp(14px, 1.45vw, 18px);
  line-height: 1.5;
  color: rgba(7,18,37,.72);
  font-weight: 650;
}

.hero__lead{
  margin: 0 0 18px;
  max-width: 70ch;
  color: rgba(7,18,37,.70);
  font-size: 15.8px;
  line-height: 1.75;
}

.hero__actions{display:flex; gap: 12px; flex-wrap:wrap; margin: 18px 0 18px}

.hero__chips{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
}
.chip{
  border-radius: 18px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(7,18,37,.10);
  box-shadow: 0 10px 26px rgba(7,18,37,.08);
  padding: 12px 12px;
}
.chip strong{display:block; font-weight: 920; letter-spacing: -0.2px}
.chip span{display:block; margin-top:4px; color: rgba(7,18,37,.66); font-size: 12px}

.featureCard{
  border-radius: var(--r2);
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(7,18,37,.10);
  box-shadow: 0 28px 90px rgba(7,18,37,.12);
  overflow:hidden;
}
.featureCard__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  padding: 16px 16px 0;
}
.featureCard__from{
  display:block;
  font-size: 12px;
  color: rgba(7,18,37,.62);
}
.featureCard__val{
  display:block;
  font-weight: 920;
  font-size: 20px;
  letter-spacing: -0.3px;
}
.pill{
  align-self:flex-start;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(29,114,255,.08);
  border: 1px solid rgba(29,114,255,.14);
  color: rgba(7,18,37,.76);
  font-size: 12px;
  font-weight: 800;
  white-space:nowrap;
}
.featureCard__media{
  margin-top: 12px;
  aspect-ratio: 16 / 10;
  overflow:hidden;
}
.featureCard__media img{
  width:100%;
  height:100%;
  object-fit: cover;
  transform: scale(1.01);
}
.featureCard__meta{
  padding: 14px 16px 16px;
  display:grid;
  gap: 10px;
}
.metaRow{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(247,251,255,.9);
  border: 1px solid rgba(7,18,37,.08);
}
.metaK{color: rgba(7,18,37,.62); font-size: 12px}
.metaV{font-weight: 850; font-size: 12px}

/* =========================
   Filters
   ========================= */
.filters{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  margin: 12px 0 16px;
}
.fbtn{
  height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(7,18,37,.10);
  background: rgba(255,255,255,.82);
  cursor:pointer;
  font-weight: 860;
  color: rgba(7,18,37,.76);
  transition: transform .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease);
}
.fbtn:hover{ transform: translateY(-1px); }
.fbtn.is-active{
  background: linear-gradient(135deg, rgba(29,114,255,.14), rgba(0,214,201,.10));
  border-color: rgba(29,114,255,.18);
  color: rgba(7,18,37,.88);
}

/* =========================
   Fleet (yacht-first)
   ========================= */
.fleet{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}

.ycard{
  border-radius: var(--r2);
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(7,18,37,.10);
  box-shadow: var(--shadow);
  overflow:hidden;
  transition: transform .22s var(--ease), box-shadow .22s var(--ease);
  will-change: transform;
}
.ycard:hover{
  transform: translateY(-3px);
  box-shadow: 0 28px 90px rgba(7,18,37,.14);
}
.ycard.is-hidden{display:none}

.ycard__media{
  position:relative;
  aspect-ratio: 16 / 10;
  overflow:hidden;
  background: rgba(7,18,37,.06);
}
.ycard__media img{
  width:100%;
  height:100%;
  object-fit: cover;
}
.ycard__tag{
  position:absolute;
  left: 12px;
  bottom: 12px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(7,18,37,.10);
  font-size: 12px;
  font-weight: 860;
  color: rgba(7,18,37,.78);
  box-shadow: 0 10px 26px rgba(7,18,37,.10);
}

.ycard__body{
  padding: 14px 14px 16px;
}
.ycard__titleRow{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
}
.price{
  text-align:right;
  line-height:1.1;
}
.price__k{
  display:block;
  font-size: 11px;
  color: rgba(7,18,37,.60);
  font-weight: 850;
}
.price__v{
  display:block;
  font-size: 22px;
  font-weight: 950;
  letter-spacing: -0.4px;
  color: rgba(7,18,37,.92);
}

.bullets{
  margin: 10px 0 12px;
  padding-left: 18px;
  color: rgba(7,18,37,.72);
  line-height: 1.7;
  font-size: 13px;
}
.bullets--wide{columns: 1}

.ycard__actions{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
}

.details{
  margin-top: 12px;
  border-top: 1px solid rgba(7,18,37,.08);
  padding-top: 10px;
}
.details summary{
  cursor:pointer;
  font-weight: 880;
  color: rgba(7,18,37,.80);
  list-style:none;
}
.details summary::-webkit-details-marker{display:none}
.details__in{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
  padding-top: 10px;
}
.kv{
  border-radius: 16px;
  background: rgba(247,251,255,.9);
  border: 1px solid rgba(7,18,37,.08);
  padding: 10px 12px;
}
.kv span{display:block; font-size: 11px; color: rgba(7,18,37,.62)}
.kv strong{display:block; margin-top: 3px; font-size: 12px}

.ycard--wide{grid-column: 1 / -1}

/* =========================
   Gallery masonry + lightbox
   ========================= */
.masonry{
  display:grid;
  grid-template-columns: repeat(12, minmax(0,1fr));
  gap: 12px;
}
.ph{
  grid-column: span 4;
  border-radius: var(--r2);
  border: 1px solid rgba(7,18,37,.10);
  background: #fff;
  box-shadow: var(--shadow2);
  padding: 0;
  cursor:pointer;
  overflow:hidden;
  transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
.ph:hover{ transform: translateY(-2px); box-shadow: 0 22px 70px rgba(7,18,37,.12); }
.ph img{
  width:100%;
  height: 240px;
  object-fit: cover;
}

.lightbox{
  position: fixed;
  inset: 0;
  z-index: 120;
  display:grid;
  place-items:center;
}
.lightbox[hidden]{display:none}
.lightbox__bg{
  position:absolute;
  inset:0;
  background: rgba(7,18,37,.55);
  border: 0;
  cursor: pointer;
}
.lightbox__img{
  position:relative;
  max-width: min(100% - 28px, 1100px);
  max-height: min(100% - 28px, 760px);
  border-radius: 18px;
  box-shadow: 0 30px 120px rgba(0,0,0,.40);
}

/* =========================
   Booking
   ========================= */
.bookGrid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 14px;
  align-items:start;
}

.formCard, .sideCard{
  border-radius: var(--r2);
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(7,18,37,.10);
  box-shadow: var(--shadow);
  overflow:hidden;
}

.formCard__top{
  padding: 16px 16px 10px;
  border-bottom: 1px solid rgba(7,18,37,.08);
  background: linear-gradient(135deg, rgba(29,114,255,.08), rgba(0,214,201,.05));
}
.formTitle{font-weight: 950; letter-spacing: -0.3px}
.formHint{margin-top: 6px; font-size: 12px; color: rgba(7,18,37,.64)}

.formCard{padding-bottom: 14px}

.fgrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 14px 16px 0;
}
.fgrid--3{grid-template-columns: repeat(3, minmax(0,1fr))}

.field{display:flex; flex-direction:column; gap:8px}
.field__label{font-size: 12px; color: rgba(7,18,37,.72); font-weight: 800}

.field input, .field select{
  height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(7,18,37,.12);
  background: rgba(247,251,255,.9);
  color: rgba(7,18,37,.92);
  padding: 0 12px;
  outline:none;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease);
}
.field input:focus, .field select:focus{
  border-color: rgba(29,114,255,.35);
  box-shadow: 0 0 0 4px rgba(29,114,255,.10);
  transform: translateY(-1px);
}
.field__hint{font-size: 11px; color: rgba(7,18,37,.58)}

.addons{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
  padding: 14px 16px 0;
}
.toggle{
  display:flex;
  gap: 10px;
  align-items:center;
  border-radius: 18px;
  border: 1px solid rgba(7,18,37,.10);
  background: rgba(247,251,255,.9);
  padding: 10px 10px;
  cursor:pointer;
  user-select:none;
}
.toggle input{position:absolute; opacity:0; pointer-events:none}
.toggle__ui{
  width: 44px;
  height: 26px;
  border-radius: 999px;
  background: rgba(7,18,37,.12);
  position:relative;
  flex:0 0 auto;
  transition: background .2s var(--ease);
}
.toggle__ui::after{
  content:"";
  position:absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(7,18,37,.12);
  box-shadow: 0 10px 20px rgba(7,18,37,.12);
  transition: transform .2s var(--ease);
}
.toggle__txt strong{display:block; font-weight: 920; font-size: 12px}
.toggle__txt span{display:block; margin-top:3px; font-size: 11px; color: rgba(7,18,37,.62)}

.toggle input:checked + .toggle__ui{
  background: linear-gradient(135deg, rgba(29,114,255,.90), rgba(0,214,201,.90));
}
.toggle input:checked + .toggle__ui::after{
  transform: translateX(18px);
}

.check{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  margin: 14px 16px 0;
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(7,18,37,.10);
  background: rgba(247,251,255,.9);
  color: rgba(7,18,37,.78);
  font-size: 13px;
}
.check input{margin-top: 3px}

.formActions{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  padding: 14px 16px 0;
}

.err{
  min-height: 18px;
  padding: 10px 16px 0;
  color: rgba(188,40,40,.92);
  font-weight: 700;
  font-size: 12px;
}

.success{
  margin: 12px 16px 0;
  border-radius: 18px;
  border: 1px solid rgba(0,214,201,.22);
  background: linear-gradient(135deg, rgba(0,214,201,.10), rgba(29,114,255,.08));
  padding: 12px 12px;
}
.success__title{font-weight: 950}
.success__text{margin-top: 6px; color: rgba(7,18,37,.72); font-size: 12px; line-height: 1.6}

.sideCard{padding: 16px}
.sideCard__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.sideTitle{font-weight: 950}
.currency{
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(29,114,255,.08);
  border: 1px solid rgba(29,114,255,.14);
  font-weight: 900;
  font-size: 12px;
}
.sideValue{
  font-size: 44px;
  font-weight: 980;
  letter-spacing: -1px;
  margin: 10px 0 6px;
}
.sideMeta{color: rgba(7,18,37,.64); font-size: 12px; line-height: 1.6}

.breakdown{
  display:grid;
  gap: 10px;
  margin-top: 12px;
}
.item{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(247,251,255,.9);
  border: 1px solid rgba(7,18,37,.08);
}
.item span{color: rgba(7,18,37,.72); font-size: 12px}
.item strong{font-size: 12px}

.softNote{
  margin-top: 12px;
  padding: 12px 12px;
  border-radius: 18px;
  background: rgba(7,18,37,.04);
  border: 1px solid rgba(7,18,37,.08);
  display:flex;
  align-items:center;
  gap: 10px;
  color: rgba(7,18,37,.68);
  font-size: 12px;
}

/* =========================
   Footer
   ========================= */
.footer{
  padding: 26px 0 44px;
  border-top: 1px solid rgba(7,18,37,.08);
}
.footer__in{
  display:flex;
  justify-content:space-between;
  gap: 14px;
  align-items:center;
}
.link{
  text-decoration:none;
  color: rgba(7,18,37,.72);
  font-weight: 850;
}
.link:hover{ text-decoration: underline; }

/* =========================
   Reveal animation (fast)
   ========================= */
.reveal{
  opacity:0;
  transform: translateY(10px);
  transition: opacity .7s var(--ease2), transform .7s var(--ease2);
  will-change: opacity, transform;
}
.reveal.is-in{
  opacity:1;
  transform: translateY(0);
}

/* =========================
   Responsive
   ========================= */
@media (max-width: 980px){
  .hero__in{grid-template-columns: 1fr; }
  .hero{padding-top: 54px}
  .hero__chips{grid-template-columns: 1fr; }
  .fleet{grid-template-columns: 1fr}
  .bookGrid{grid-template-columns: 1fr}
  .fgrid--3{grid-template-columns: 1fr}
  .addons{grid-template-columns: 1fr}
  .masonry{grid-template-columns: repeat(6, minmax(0,1fr))}
  .ph{grid-column: span 3}
}

@media (max-width: 520px){
  .container{width: calc(100% - 28px)}
  .nav{display:none}
  .topbar__cta{display:none}
  .ph{grid-column: span 6}
  .ph img{height: 220px}
  .sideValue{font-size: 38px}
}

/* =========================
   Reduced motion
   ========================= */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .blob{animation:none !important}
  .reveal{opacity:1 !important; transform:none !important; transition:none !important}
  .btn, .ycard, .ph, .waFloat{transition:none !important}
}
