/* ===== Tokens ===== */
:root{
  --ink:#0a3344;          /* deep teal-navy (text + dark sections) */
  --ink-2:#072734;
  --brand:#0e6286;        /* MAG logo blue */
  --teal:#16b9a7;         /* MAG logo turquoise (accent) */
  --teal-dk:#0fa092;
  --sand:#eef5f5;         /* cool off-white */
  --paper:#fafdfd;
  --line:rgba(10,51,68,.12);
  --muted:#516b75;
  --white:#fff;
  --shadow:0 18px 50px -20px rgba(10,51,68,.38);
  --radius:14px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;line-height:1.12;letter-spacing:.2px}
h1{font-size:clamp(2.6rem,6.5vw,5rem)}
h2{font-size:clamp(2rem,4.2vw,3.2rem)}
h3{font-size:1.5rem}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  background:var(--teal);color:#fff;
  padding:.85em 1.6em;border-radius:50px;border:1px solid var(--teal);
  font-weight:600;font-size:.92rem;letter-spacing:.3px;cursor:pointer;
  transition:transform .25s var(--ease),background .25s,box-shadow .25s;
}
.btn:hover{background:var(--teal-dk);border-color:var(--teal-dk);transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(22,185,167,.7)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;box-shadow:none}
.btn-sm{padding:.6em 1.2em;font-size:.82rem}

/* ===== Nav ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .35s,box-shadow .35s,padding .35s}
.nav-inner{max-width:1320px;margin:0 auto;padding:18px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav.scrolled{background:rgba(250,253,253,.94);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.nav.scrolled .nav-links a{color:var(--ink)}
.nav.scrolled .lang{color:var(--ink);border-color:var(--line)}
.brand{display:flex;align-items:center}
.logo-img{height:46px;width:auto;display:block}
.brand .logo-color{display:none}
.nav.scrolled .brand .logo-white{display:none}
.nav.scrolled .brand .logo-color{display:block}
.nav-links{display:flex;gap:30px}
.nav-links a{color:#fff;font-size:.9rem;font-weight:500;position:relative;transition:color .35s;opacity:.95}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--teal);transition:width .3s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:none}
.nav-actions{display:flex;align-items:center;gap:14px}
.lang{display:flex;gap:4px;align-items:center;background:transparent;border:1px solid rgba(255,255,255,.45);color:#fff;border-radius:50px;padding:.4em .8em;font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;transition:color .35s,border-color .35s}
.lang span[data-lang]{opacity:.5;transition:opacity .2s}
.lang span[data-lang].active{opacity:1;color:var(--teal)}
.lang .sep{opacity:.4}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:currentColor;color:#fff;transition:.3s}
.nav.scrolled .burger span{background:var(--ink)}

/* ===== Hero ===== */
.hero{position:relative;height:100svh;min-height:600px;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-slide{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;opacity:0;transform:scale(1.06);transition:opacity 1.4s var(--ease),transform 7s var(--ease)}
.hero-slide.active{opacity:1;transform:scale(1)}
@keyframes slowzoom{to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,36,51,.55) 0%,rgba(12,36,51,.25) 35%,rgba(12,36,51,.7) 100%)}
.hero-content{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.eyebrow{text-transform:uppercase;letter-spacing:5px;font-size:.78rem;font-weight:600;color:var(--teal);margin-bottom:18px}
.hero h1{max-width:14ch;margin-bottom:22px;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero-sub{max-width:46ch;font-size:1.12rem;font-weight:300;color:rgba(255,255,255,.92);margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:#fff;opacity:.85;animation:bob 2s infinite}
.scroll-cue svg{width:30px;height:30px;display:block}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ===== Section primitives ===== */
section{position:relative}
.section-eyebrow{text-transform:uppercase;letter-spacing:4px;font-size:.75rem;font-weight:600;color:var(--brand);margin-bottom:14px}
.section-eyebrow.light{color:var(--teal)}
.section-head{max-width:640px;margin-bottom:54px}
.lead{color:var(--muted);font-size:1.1rem;font-weight:300;margin-top:18px}

/* Intro */
.intro{padding:120px 0 90px;text-align:center}
.intro h2{max-width:18ch;margin:0 auto}
.intro .lead{max-width:62ch;margin:24px auto 0}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:64px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:38px 0}
.stat{display:flex;flex-direction:column;gap:6px}
.stat .num{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:600;color:var(--ink);line-height:1}
.stat .num small{font-size:1rem;color:var(--muted);font-family:'Inter',sans-serif;font-weight:400}
.stat .lbl{font-size:.78rem;text-transform:uppercase;letter-spacing:2px;color:var(--muted)}

/* Split sections */
.yacht{padding:90px 0;background:var(--sand)}
.yacht .split{align-items:flex-start}
.crew{padding:100px 0}
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.crew .split{grid-template-columns:1fr 1.05fr}
.split-media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform .8s var(--ease)}
.split-media:hover img{transform:scale(1.04)}
.media-tag{position:absolute;left:22px;bottom:20px;color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.6rem;letter-spacing:4px;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.media-cap{position:absolute;left:16px;bottom:16px;background:rgba(10,51,68,.62);backdrop-filter:blur(4px);color:#fff;padding:.45em .95em;border-radius:50px;font-size:.85rem;font-weight:500;border:1px solid rgba(255,255,255,.25)}

/* Yacht media gallery (main + thumbs) */
.yacht-main{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:var(--shadow);margin:0}
.yacht-main img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .8s var(--ease)}
.yacht-main:hover img{transform:scale(1.04)}
.yacht-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:10px}
.ythumb{padding:0;border:0;background:none;border-radius:10px;overflow:hidden;cursor:pointer;aspect-ratio:4/3;position:relative}
.ythumb img{width:100%;height:100%;object-fit:cover;opacity:.9;transition:transform .5s var(--ease),opacity .3s}
.ythumb:hover img{transform:scale(1.07);opacity:1}
.split-text h2{margin:6px 0 20px}
.split-text p{color:var(--muted);font-weight:300}
.specs{list-style:none;margin-top:30px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.specs li{display:flex;flex-direction:column;gap:4px;padding:14px 16px;background:var(--paper);border:1px solid var(--line);border-radius:10px}
.specs li > span{color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:1.4px}
.specs li b{font-weight:600;font-size:1.02rem;color:var(--ink);line-height:1.25}

/* Experience cards */
.experience{padding:100px 0}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:34px 26px;transition:transform .35s var(--ease),box-shadow .35s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-ic{margin-bottom:18px;color:var(--teal)}
.card-ic svg{width:34px;height:34px}
.card h3{margin-bottom:10px;font-size:1.35rem}
.card p{color:var(--muted);font-size:.94rem;font-weight:300}

/* Cabins */
.cabins{padding:100px 0;background:var(--sand)}
.cabin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:16px}
.cabin-grid figure{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:var(--shadow);margin:0}
.cabin-grid img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .7s var(--ease)}
.cabin-grid figure:hover img{transform:scale(1.06)}
.cabin-grid figcaption{position:absolute;left:0;right:0;bottom:0;padding:32px 16px 14px;color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:500;background:linear-gradient(transparent,rgba(12,36,51,.85))}

/* Crew */
.crew{background:var(--sand)}

/* Gallery */
.gallery{padding:100px 0 110px}
.masonry{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:0 24px;max-width:1320px;margin:0 auto}
.masonry .gitem{border-radius:12px;overflow:hidden;cursor:pointer;position:relative;aspect-ratio:4/3}
.masonry img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .4s}
.masonry .gitem:hover img{transform:scale(1.05)}
.masonry .gitem::after{content:"⤢";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;background:rgba(12,36,51,.35);opacity:0;transition:opacity .35s}
.masonry .gitem:hover::after{opacity:1}

/* Instagram */
.instagram{padding:90px 0;background:var(--sand);text-align:center}
.instagram .section-head{max-width:none;text-align:center;margin:0 auto 36px}
.ig-handle{display:inline-block;margin-top:10px;color:var(--brand);font-weight:600;font-size:1.05rem;letter-spacing:.3px}
.ig-handle:hover{color:var(--teal)}
.ig-embed{max-width:1120px;margin:0 auto}
.ig-cta{margin-top:34px}

/* FAQ */
.faq{padding:100px 0;background:var(--paper)}
.wrap.narrow{max-width:840px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 44px 22px 0;position:relative;font-family:'Cormorant Garamond',serif;font-size:1.4rem;line-height:1.3;color:var(--ink);transition:color .2s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:4px;top:22px;font-size:1.6rem;line-height:1.3;color:var(--teal);transition:transform .3s var(--ease)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--brand)}
.faq-a{padding:0 44px 24px 0;color:var(--muted);font-weight:300;max-width:70ch}
.faq-a p{margin:0}

/* Reservation form */
.booking{padding:100px 0;background:var(--sand)}
.booking-form{max-width:680px;margin:42px auto 0;background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px;box-shadow:var(--shadow);display:grid;gap:18px;text-align:left}
.booking .field{display:flex;flex-direction:column}
.booking label,.booking .field-label{font-size:.8rem;font-weight:600;color:var(--ink);margin-bottom:7px}
.booking input,.booking textarea{width:100%;padding:.72em .85em;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:.95rem;background:#fff;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.booking input:focus,.booking textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(22,185,167,.15)}
.booking textarea{resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.seg{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.seg label{display:flex;align-items:center;justify-content:center;text-align:center;padding:.72em .5em;margin:0;border:1px solid var(--line);border-radius:10px;cursor:pointer;font-size:.88rem;font-weight:500;color:var(--muted);transition:background .2s,color .2s,border-color .2s}
.seg label:hover{border-color:var(--teal);color:var(--ink)}
.seg input{position:absolute;opacity:0;pointer-events:none}
.seg label:has(input:checked){background:var(--teal);color:#fff;border-color:var(--teal)}
.booking-form .btn{width:100%;justify-content:center;margin-top:4px}
.form-note{font-size:.8rem;color:var(--muted);text-align:center;margin:0}
.form-error{font-size:.85rem;color:#c0392b;text-align:center;margin:0;font-weight:500}
.field-hint{display:block;margin-top:6px;font-size:.78rem;color:var(--muted);transition:color .2s}
.field-hint.flash{color:var(--teal);font-weight:600}
#singleDateField[hidden],#rangeDateField[hidden]{display:none!important}

/* Flatpickr — brand (teal) theme overrides */
.flatpickr-calendar{border-radius:14px;box-shadow:var(--shadow);font-family:'Inter',sans-serif;border:1px solid var(--line)}
.flatpickr-day{border-radius:8px;color:var(--ink)}
.flatpickr-day:hover,.flatpickr-day:focus{background:var(--sand);border-color:var(--sand)}
.flatpickr-day.today{border-color:var(--teal)}
.flatpickr-day.today:hover{background:var(--teal);border-color:var(--teal);color:#fff}
.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange,
.flatpickr-day.selected:hover,.flatpickr-day.startRange:hover,.flatpickr-day.endRange:hover,
.flatpickr-day.selected:focus,.flatpickr-day.startRange:focus,.flatpickr-day.endRange:focus{
  background:var(--teal);border-color:var(--teal);color:#fff;box-shadow:none
}
.flatpickr-day.inRange{
  background:rgba(22,185,167,.14);border-color:rgba(22,185,167,.14);
  box-shadow:-5px 0 0 rgba(22,185,167,.14),5px 0 0 rgba(22,185,167,.14)
}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:var(--muted);opacity:.45}
.flatpickr-months .flatpickr-month,.flatpickr-current-month input.cur-year,span.flatpickr-weekday{color:var(--ink);fill:var(--ink)}
.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:var(--teal)}
.flatpickr-monthDropdown-months{color:var(--ink)}

/* Contact */
.contact{position:relative;padding:120px 0;color:#fff;text-align:center;overflow:hidden}
.contact-bg{position:absolute;inset:0;background:url('../img/gallery/aerial-wake.webp') center/cover fixed no-repeat}
.contact-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(12,36,51,.82),rgba(10,91,102,.82))}
.contact-inner{position:relative;z-index:1;max-width:860px}
.contact h2{margin:6px 0 16px}
.contact .lead{color:rgba(255,255,255,.85);max-width:50ch;margin:0 auto}
.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.contact-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius);padding:28px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;backdrop-filter:blur(4px);transition:transform .3s var(--ease),background .3s}
.contact-card:hover{transform:translateY(-5px);background:rgba(255,255,255,.16)}
.cc-ic{color:var(--teal);height:30px;display:flex;align-items:center}
.cc-ic svg{width:28px;height:28px}
.cc-lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:2px;color:var(--teal)}
.cc-val{font-size:.92rem;font-weight:500}

/* Footer */
.footer{background:var(--ink);color:rgba(255,255,255,.8);padding:54px 0 26px}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.12)}
.brand-foot .logo-img{height:54px}
.footer-links{display:flex;gap:26px}
.footer-links a{font-size:.9rem;opacity:.85;transition:opacity .2s}
.footer-links a:hover{opacity:1;color:var(--teal)}
.socials{display:flex;gap:18px}
.socials a{font-size:.85rem;color:var(--teal)}
.copy{text-align:center;font-size:.8rem;opacity:.6;margin-top:24px}

/* Floating WhatsApp */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:55;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px -8px rgba(37,211,102,.7);transition:transform .3s}
.wa-float:hover{transform:scale(1.08)}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(8,22,31,.94);display:none;align-items:center;justify-content:center;padding:40px}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-close{position:absolute;top:22px;right:30px;font-size:2.4rem;color:#fff;background:none;border:0;cursor:pointer;line-height:1}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:3rem;color:#fff;background:none;border:0;cursor:pointer;padding:0 18px;opacity:.7;transition:opacity .2s}
.lb-nav:hover{opacity:1}
.lb-prev{left:8px}.lb-next{right:8px}

/* Reveal (only hidden when JS is active, so content never disappears if JS fails) */
.js .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .reveal.in{opacity:1;transform:none}

/* Focus states for keyboard users */
a:focus-visible,button:focus-visible,summary:focus-visible,.gitem:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--teal);outline-offset:3px;border-radius:4px;
}

/* Respect reduced-motion preference */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero-bg,.hero-slide{transform:none!important}
  .js .reveal{opacity:1!important;transform:none!important}
}

/* ===== Responsive ===== */
@media(max-width:980px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:var(--ink);flex-direction:column;justify-content:center;gap:28px;padding:60px 40px;transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:-20px 0 60px rgba(0,0,0,.4)}
  .nav-links.open{transform:none}
  .nav-links a{color:#fff;font-size:1.1rem}
  .nav-cta{display:inline-flex;margin-top:14px;width:100%;justify-content:center;font-size:.95rem}
  .nav-cta::after{display:none}
  .burger{display:flex}
  .nav.scrolled .burger span{background:var(--ink)}
  .cards,.contact-grid{grid-template-columns:repeat(2,1fr)}
  .masonry{grid-template-columns:repeat(3,1fr)}
  .contact-bg{background-attachment:scroll}
}
@media(max-width:680px){
  .split,.crew .split{grid-template-columns:1fr;gap:34px}
  .split-media img{aspect-ratio:16/11}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px 20px}
  .cards,.contact-grid{grid-template-columns:1fr}
  .seg,.field-row{grid-template-columns:1fr}
  .masonry{grid-template-columns:repeat(2,1fr);padding:0 16px}
  .intro{padding:90px 0 70px}
  .nav-actions .btn-sm{display:none}
  .footer-inner{flex-direction:column;text-align:center}
}
