:root{
  --shell:oklch(0.972 0.013 86);
  --cream:oklch(0.952 0.016 84);
  --sand:oklch(0.905 0.024 82);
  --ink:oklch(0.255 0.014 70);
  --ink-soft:oklch(0.455 0.015 72);
  --ink-faint:oklch(0.605 0.018 74);
  --gold:oklch(0.715 0.078 76);
  --gold-deep:oklch(0.605 0.083 72);
  --marine:oklch(0.305 0.045 206);
  --marine-deep:oklch(0.255 0.040 208);
  --teal:oklch(0.640 0.097 196);
  --teal-deep:oklch(0.520 0.085 200);
  --line:color-mix(in oklch, var(--ink) 13%, transparent);
  --line-soft:color-mix(in oklch, var(--ink) 7%, transparent);
  --pad-x:clamp(1.25rem,6vw,7.5rem);
  --maxw:1240px;
  --f-d:"Epunda Slab",Georgia,serif;
  --f-b:"Schibsted Grotesk",system-ui,sans-serif;
  --f-m:"Spline Sans Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
body{
  font-family:var(--f-b);color:var(--ink);background:var(--shell);
  line-height:1.6;font-size:clamp(1rem,.965rem + .18vw,1.06rem);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;font-weight:400;
}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--f-d);font-weight:600;line-height:1.05;letter-spacing:-.01em}
::selection{background:var(--teal);color:#fff}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
.pad{padding-block:clamp(4.5rem,9.5vw,8rem)}

.coord{font-family:var(--f-m);font-size:.7rem;letter-spacing:.04em;color:var(--gold-deep);font-weight:400}
.kicker{font-family:var(--f-m);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);
  display:inline-flex;align-items:center;gap:.6rem}
.kicker::before{content:"";width:22px;height:1px;background:currentColor;opacity:.6}
.smallcaps{font-family:var(--f-b);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--ink-faint)}

.title{font-size:clamp(2.05rem,4.4vw,3.3rem);font-weight:600;letter-spacing:-.018em;line-height:1.06}
.lead{color:var(--ink-soft);font-size:1.08rem;max-width:60ch;line-height:1.62}

/* ── boat wake reveal (signature) ── */
.wake{position:relative;display:block}
.wt{display:inline-block;clip-path:inset(0 103% 0 -2%);transition:clip-path 1.25s cubic-bezier(.22,1,.36,1)}
.wake.in .wt{clip-path:inset(0 -2% 0 -2%)}
.wake::after{content:"";position:absolute;left:0;bottom:-0.5rem;height:2px;width:0;border-radius:2px;
  background:linear-gradient(90deg,var(--teal) 0%,color-mix(in oklch,var(--teal) 55%,transparent) 65%,transparent);
  box-shadow:0 0 10px color-mix(in oklch,var(--teal) 40%,transparent);
  transition:width var(--sail,1.5s) cubic-bezier(.33,.12,.22,1) .04s}
.wake.in::after{width:var(--wakew,72%)}
.boat{position:absolute;bottom:-0.5rem;left:0;width:46px;height:23px;transform:translateX(-55%);opacity:0;
  color:var(--teal-deep);pointer-events:none;z-index:2}
.boat svg{width:100%;height:100%;display:block;filter:drop-shadow(0 5px 7px rgba(20,30,30,.3))}
.wake.in .boat{animation:sail var(--sail,1.5s) cubic-bezier(.33,.12,.22,1) forwards}
.wake.in .boat svg{animation:bob 1.6s ease-in-out infinite}
@keyframes sail{0%{left:0;opacity:0}7%{opacity:1}88%{opacity:1}100%{left:var(--wakew,100%);opacity:0}}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-1.2deg)}50%{transform:translateY(-2.5px) rotate(1.6deg)}}
.on-dark .boat{color:var(--gold)}
.on-dark .wake::after{background:linear-gradient(90deg,var(--gold),transparent)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--f-b);font-weight:600;
  font-size:.92rem;letter-spacing:.005em;padding:.9rem 1.55rem;border-radius:2px;cursor:pointer;
  border:1px solid transparent;transition:transform .4s cubic-bezier(.16,1,.3,1),background .3s,color .3s,border-color .3s;white-space:nowrap}
.btn:focus-visible{outline:2px solid var(--teal);outline-offset:3px}
.btn-fill{background:var(--ink);color:var(--shell)}
.btn-fill:hover{background:var(--marine-deep);transform:translateY(-2px)}
.btn-line{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-line:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-glass{background:color-mix(in oklch,#fff 14%,transparent);color:#fff;border-color:color-mix(in oklch,#fff 42%,transparent);backdrop-filter:blur(6px)}
.btn-glass:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}
.tlink{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;font-size:.86rem;letter-spacing:.01em;
  color:var(--teal-deep);border-bottom:1px solid color-mix(in oklch,var(--teal) 45%,transparent);padding-bottom:2px;
  transition:gap .35s,border-color .3s,color .3s}
.tlink:hover{gap:.8rem;border-color:var(--teal);color:var(--teal)}

.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.7rem 1.1rem;z-index:200}
.skip:focus{left:0}

.contours{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5}
.contours svg{width:100%;height:100%}
.contours path{fill:none;stroke:currentColor;stroke-width:1;vector-effect:non-scaling-stroke}

/* nav — dark, footer-style (solid by default; transparent-over-hero variant below) */
.nav{position:fixed;inset:0 0 auto 0;z-index:120;background:var(--marine-deep);overflow:hidden;
  border-bottom:1px solid color-mix(in oklch,#fff 12%,transparent);transition:background .45s ease,border-color .45s ease}
.nav .contours{color:#fff;opacity:.07;transition:opacity .4s}
/* over a dark hero: start transparent, fade to the marine color on scroll */
.nav.over-hero{background:transparent;border-color:transparent}
.nav.over-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(12,26,28,.5),transparent);transition:opacity .4s}
.nav.over-hero:not(.scrolled) .contours{opacity:0}
.nav.over-hero.scrolled{background:var(--marine-deep);border-color:color-mix(in oklch,#fff 12%,transparent)}
.nav.over-hero.scrolled::before{opacity:0}
.nav-in{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.65rem var(--pad-x)}
.nav-logo img{height:40px;width:auto;filter:brightness(0) invert(1)}
.nav-links{display:flex;align-items:center;gap:2.1rem}
.nav-links a{font-size:.84rem;font-weight:500;color:color-mix(in oklch,var(--shell) 78%,transparent);position:relative;letter-spacing:.01em;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;height:1px;width:0;background:var(--gold);transition:width .35s}
.nav-links a:hover{color:#fff}.nav-links a:hover::after{width:100%}
.nav-links a[aria-current="page"]{color:#fff}
.nav-links a[aria-current="page"]::after{width:100%}
.nav-right{display:flex;align-items:center;gap:1rem}
.lang{display:inline-flex;border:1px solid color-mix(in oklch,#fff 30%,transparent);border-radius:2px;overflow:hidden;font-family:var(--f-m);font-size:.72rem;flex:none}
.lang button{background:none;border:0;cursor:pointer;padding:.34rem .6rem;color:color-mix(in oklch,#fff 80%,transparent);font-family:inherit;width:2.4rem}
.lang button.active{background:#fff;color:var(--marine-deep)}
.nav .btn{padding:.55rem 1.05rem;font-size:.82rem}
.nav .btn-fill{background:var(--gold);color:var(--marine-deep)}
.nav .btn-fill:hover{background:#fff;color:var(--marine-deep);transform:translateY(-2px)}
.hamb{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.hamb span{width:23px;height:2px;background:#fff;transition:.3s}
body.mm-open .hamb{opacity:0;pointer-events:none}
body.mm-open{position:fixed;left:0;right:0;width:100%;overflow:hidden}

/* hero */
.hero{min-height:100vh;min-height:100svh;min-height:var(--app-vh,100svh);display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;color:#fff;
  padding-top:calc(64px + clamp(1.5rem,5vh,3rem));padding-bottom:clamp(2.5rem,6vh,4rem)}
.hero .kicker{margin-bottom:.2rem}
.hero-media{position:absolute;inset:0;z-index:-2;overflow:hidden;background:#0e1c1e}
.hero-media .kb{position:absolute;inset:-6%;background:url('assets/images/hero-poster.webp') center/cover;
  animation:kenburns 30s ease-in-out infinite alternate;will-change:transform}
.hero-media img,.hero-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:transparent}
@keyframes kenburns{0%{transform:scale(1.05)}100%{transform:scale(1.17) translate(-2.5%,-2%)}}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,color-mix(in oklch,var(--marine-deep) 32%,transparent) 0%,transparent 22%,transparent 46%,color-mix(in oklch,var(--marine-deep) 26%,transparent) 70%,color-mix(in oklch,var(--marine-deep) 68%,transparent) 100%)}
.hero-in{padding-inline:var(--pad-x);max-width:1080px}
.hero .kicker{color:#f3e7c6}
.hero h1{color:#fff;font-size:clamp(2.9rem,7.6vw,5.9rem);font-weight:600;margin:1.3rem 0 2.6rem;max-width:15ch;line-height:1.0;
  letter-spacing:-.026em;text-shadow:0 1px 2px color-mix(in oklch,var(--marine-deep) 65%,transparent),0 2px 8px color-mix(in oklch,var(--marine-deep) 45%,transparent)}
.hero h1 .hl{color:#f6ead0}
.hero .boat{color:#fff;bottom:-1.3rem}
.hero .wake::after{background:linear-gradient(90deg,#f6ead0,transparent);bottom:-1.3rem}
.hero p.lead{color:color-mix(in oklch,#fff 94%,transparent);max-width:48ch;font-size:clamp(1.02rem,1.4vw,1.18rem);text-shadow:0 1px 4px color-mix(in oklch,var(--marine-deep) 55%,transparent)}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.hero-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;
  padding-inline:var(--pad-x);margin-top:clamp(2rem,5vh,3.4rem)}
.hero-foot .coord{color:color-mix(in oklch,#fff 75%,transparent)}
.scroll-hint{font-family:var(--f-m);font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;
  color:color-mix(in oklch,#fff 70%,transparent);display:flex;align-items:center;gap:.7rem}
.scroll-hint i{width:34px;height:1px;background:color-mix(in oklch,#fff 60%,transparent);display:inline-block;position:relative;overflow:hidden}
.scroll-hint i::after{content:"";position:absolute;inset:0;width:12px;background:#fff;animation:slide 2.2s infinite}
@keyframes slide{0%{transform:translateX(-12px)}100%{transform:translateX(40px)}}

/* instruments strip */
.strip{background:var(--cream);color:var(--ink);position:relative;overflow:hidden;border-bottom:1px solid var(--line-soft)}
.strip .contours{color:var(--marine);opacity:.05}
.strip-in{position:relative;z-index:1;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 0;padding:1.15rem var(--pad-x)}
.strip-item{display:flex;align-items:center;gap:.7rem;padding-right:clamp(1.2rem,3.4vw,2.8rem)}
.strip-item + .strip-item{padding-left:clamp(1.2rem,3.4vw,2.8rem);border-left:1px solid var(--line)}
.strip-item .lbl{font-family:var(--f-b);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.strip-item b{font-family:var(--f-m);font-weight:500;color:var(--marine-deep);font-size:1.02rem;letter-spacing:.01em}
.dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 color-mix(in oklch,var(--teal) 60%,transparent);animation:pulse 2.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in oklch,var(--teal) 55%,transparent)}70%{box-shadow:0 0 0 9px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* about */
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,5vw,5.5rem);align-items:center}
.about-copy .title{margin:1.1rem 0 1.5rem}
.about-copy p + p{margin-top:1.05rem}
.crew{display:flex;gap:2.4rem;margin-top:2.2rem;flex-wrap:wrap}
.crew .role{font-family:var(--f-m);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep)}
.crew .nm{font-family:var(--f-d);font-size:1.35rem;font-weight:600;margin-top:.2rem}
.about-fig{position:relative}
.about-fig img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center 30%;border-radius:2px}
.about-fig figcaption{position:absolute;left:1rem;bottom:1rem;color:#fff;font-family:var(--f-m);font-size:.66rem;letter-spacing:.05em;
  background:color-mix(in oklch,var(--marine-deep) 55%,transparent);backdrop-filter:blur(3px);padding:.35rem .6rem}

/* signature band */
.sig{min-height:78vh;display:flex;align-items:center;position:relative;overflow:hidden;color:#fff;padding-inline:var(--pad-x)}
.sig-media{position:absolute;inset:-12% 0;z-index:-2;will-change:transform}
.sig-media img{width:100%;height:124%;object-fit:cover;object-position:center 50%}
.sig::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,color-mix(in oklch,var(--marine-deep) 62%,transparent),transparent 72%)}
.sig .contours{color:#fff;opacity:.2;z-index:0}
.sig-in{position:relative;z-index:1;max-width:26ch}
.sig h2{color:#fff;font-size:clamp(2.1rem,5vw,3.6rem);font-weight:600;line-height:1.08;text-shadow:0 2px 40px color-mix(in oklch,#000 30%,transparent)}
.sig h2 .hl{color:#f6ead0}
.sig .coord{color:color-mix(in oklch,#fff 80%,transparent);margin-top:1.4rem;display:block}

/* tours — editorial catalogue */
.tours-head{display:grid;grid-template-columns:.8fr 1.2fr;gap:2rem;align-items:end;margin-bottom:clamp(2.5rem,5vw,4rem)}
.tours-head .lead{margin-top:1.5rem}
.tour-row{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1.5rem,4vw,3.5rem);align-items:center;
  padding-block:clamp(2.2rem,4vw,3.4rem);border-top:1px solid var(--line)}
.tour-fig{grid-column:1/6;overflow:hidden;border-radius:2px}
.tour-fig img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.tour-row:hover .tour-fig img{transform:scale(1.04)}
.tour-txt{grid-column:7/13}
.tour-row:nth-child(even) .tour-fig{grid-column:8/13;order:2}
.tour-row:nth-child(even) .tour-txt{grid-column:1/7}
.tour-no{font-family:var(--f-m);font-size:.72rem;color:var(--gold-deep);letter-spacing:.04em}
.tour-txt h3{font-size:clamp(1.7rem,3vw,2.4rem);font-weight:600;margin:.5rem 0 .7rem}
.tour-txt p{color:var(--ink-soft);max-width:46ch;margin-bottom:1rem}
.tour-meta{display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;margin-bottom:1.3rem}
.tour-meta span{font-family:var(--f-m);font-size:.7rem;letter-spacing:.02em;color:var(--ink-faint)}
.combo{margin-top:clamp(2.5rem,5vw,4rem);background:color-mix(in oklch,var(--teal) 13%,var(--shell));color:var(--ink);position:relative;overflow:hidden;
  display:grid;grid-template-columns:1.1fr 1fr;align-items:stretch;border-radius:2px;border:1px solid color-mix(in oklch,var(--teal) 24%,transparent)}
.combo .contours{color:var(--marine);opacity:.05}
.combo-txt{position:relative;z-index:1;padding:clamp(2rem,4vw,3.4rem)}
.combo .smallcaps{color:var(--gold-deep)}
.combo h3{color:var(--marine-deep);font-size:clamp(1.8rem,3.2vw,2.5rem);font-weight:600;margin:.8rem 0 1rem;line-height:1.1}
.combo h3 .hl{color:var(--teal-deep)}
.combo p{color:var(--ink-soft);max-width:42ch;margin-bottom:1.6rem}
.combo-fig{position:relative;min-height:300px}
.combo-fig img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%}

/* why — manifesto with margin labels */
.why{background:var(--cream);border-block:1px solid var(--line-soft)}
.why-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2.5rem,5vw,5rem)}
.why-intro .title{margin-top:1rem}
.reasons{display:flex;flex-direction:column}
.reason{display:grid;grid-template-columns:auto 1fr;gap:clamp(1rem,3vw,2.4rem);padding-block:1.7rem}
.reason + .reason{border-top:1px solid var(--line)}
.reason .mk{font-family:var(--f-m);font-size:.66rem;letter-spacing:.04em;color:var(--gold-deep);padding-top:.4rem;white-space:nowrap}
.reason h3{font-size:1.4rem;font-weight:600;margin-bottom:.45rem}
.reason p{color:var(--ink-soft);max-width:54ch}

/* boat — spec sheet */
.boat-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:stretch}
.boat-fig{display:flex}
.boat-fig img{width:100%;height:100%;min-height:340px;object-fit:cover;object-position:center 45%;border-radius:2px}
.boat-copy{align-self:center}
.boat-copy .title{margin:1rem 0 1.3rem}
.specs{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:2rem;border-top:1px solid var(--line)}
.spec{padding:1.1rem 0;border-bottom:1px solid var(--line)}
.spec:nth-child(odd){padding-right:1.5rem}
.spec:nth-child(even){padding-left:1.5rem;border-left:1px solid var(--line)}
.spec .k{font-family:var(--f-m);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep)}
.spec .v{font-family:var(--f-d);font-size:1.12rem;font-weight:600;margin-top:.25rem;line-height:1.2}

/* travel — route line */
.travel{background:var(--cream);color:var(--ink);position:relative;overflow:hidden;border-block:1px solid var(--line-soft)}
.travel .contours{color:var(--marine);opacity:.05}
.travel-in{position:relative;z-index:1}
.travel .kicker{color:var(--gold-deep)}
.travel .title{color:var(--marine-deep);margin-top:1rem;max-width:18ch}
.route{display:grid;grid-template-columns:repeat(3,1fr);margin-top:clamp(2.5rem,5vw,4rem);position:relative}
.route::before{content:"";position:absolute;top:14px;left:8%;right:8%;height:1px;background:color-mix(in oklch,var(--marine) 28%,transparent)}
.leg{position:relative;padding:0 1rem}
.leg .pin{width:30px;height:30px;border-radius:50%;background:var(--shell);border:1px solid var(--marine);
  display:grid;place-items:center;color:var(--marine-deep);position:relative;z-index:1}
.leg .pin svg{width:15px;height:15px}
.leg .mode{font-family:var(--f-m);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);margin-top:1.3rem}
.leg .path{font-family:var(--f-d);font-size:1.3rem;font-weight:600;color:var(--marine-deep);margin:.3rem 0 .5rem;line-height:1.15}
.leg .dur{font-family:var(--f-m);font-size:.92rem;color:var(--ink-soft)}

/* gallery — mosaic */
.gal-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:2.4rem}
.mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:8.5vw;gap:12px;grid-auto-flow:dense}
.mosaic a{overflow:hidden;border-radius:2px;position:relative;background:var(--sand)}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.mosaic a:hover img{transform:scale(1.06)}
.mz-tall{grid-row:span 3}.mz-tall2{grid-row:span 4}.mz-wide{grid-column:span 2;grid-row:span 2}
.mz-big{grid-column:span 2;grid-row:span 3}.mz-sm{grid-row:span 2}
.mz-col2{grid-column:span 2}

/* booking */
.book{background:var(--cream);border-block:1px solid var(--line-soft)}
.book-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:stretch}
.steps{counter-reset:s;margin-top:2rem;display:flex;flex-direction:column}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.3rem;padding-block:1.5rem}
.step + .step{border-top:1px solid var(--line)}
.step .idx{counter-increment:s;font-family:var(--f-d);font-size:1.5rem;font-weight:600;color:var(--gold-deep);line-height:1}
.step .idx::before{content:counter(s,decimal-leading-zero)}
.step h4{font-size:1.2rem;font-weight:600;margin-bottom:.3rem}
.step p{font-size:.95rem;color:var(--ink-soft);max-width:48ch}
.pay{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.8rem}
.pay span{font-family:var(--f-m);font-size:.74rem;border:1px solid var(--line);padding:.4rem .85rem;color:var(--ink-soft)}
.policy{background:var(--marine-deep);color:var(--shell);padding:clamp(1.8rem,3.2vw,2.6rem);border-radius:2px;
  display:flex;flex-direction:column;position:relative;overflow:hidden}
.policy .contours{color:#fff;opacity:.1}
.policy-in{position:relative;z-index:1;display:flex;flex-direction:column;height:100%}
.policy .smallcaps{color:var(--gold)}
.policy h3{color:#fff;font-size:1.5rem;font-weight:600;margin:.7rem 0 1.1rem}
.policy p{font-size:.9rem;color:color-mix(in oklch,var(--shell) 82%,transparent);line-height:1.7}
.policy .promise{margin-top:auto;padding-top:1.4rem;font-family:var(--f-d);font-size:1.05rem;font-weight:500;color:#fff;line-height:1.4;
  border-top:1px solid color-mix(in oklch,#fff 16%,transparent)}

/* founding */
.found-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:center}
.found .title{margin:1rem 0 1.3rem}
.found-handle{font-family:var(--f-d);font-weight:600;font-size:clamp(1.5rem,2.8vw,2.1rem);display:inline-flex;align-items:center;gap:.7rem;margin-top:1.6rem;color:var(--ink);line-height:1}
.found-handle:hover{color:var(--teal-deep)}
.found-handle svg{width:28px;height:28px;color:var(--gold-deep);flex:none;display:block}
.found-aside{font-family:var(--f-d);font-weight:500;font-size:clamp(1.4rem,2.5vw,2rem);line-height:1.34;color:var(--ink)}
.found-aside .u{color:var(--teal-deep)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:stretch}
.contact-copy .title{margin:1rem 0 1.3rem}
.cinfo{margin-top:1.9rem;display:flex;flex-direction:column;gap:1.4rem}
.cinfo .row{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:start}
.cinfo svg{width:19px;height:19px;color:var(--gold-deep);margin-top:3px}
.cinfo .k{font-family:var(--f-m);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}
.cinfo .v{font-size:1rem;margin-top:.15rem}
.socials{display:flex;gap:.7rem;margin-top:2rem}
.socials a{width:44px;height:44px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;transition:.3s}
.socials a:hover{background:var(--ink);color:var(--shell);border-color:var(--ink);transform:translateY(-2px)}
.socials svg{width:18px;height:18px}
.map{overflow:hidden;border-radius:2px;min-height:360px;border:1px solid var(--line)}
.map iframe{width:100%;height:100%;min-height:360px;border:0;filter:grayscale(.25) sepia(.06)}

/* footer */
.footer{background:var(--marine-deep);color:color-mix(in oklch,var(--shell) 72%,transparent);position:relative;overflow:hidden}
.footer .contours{color:#fff;opacity:.06}
.footer-in{position:relative;z-index:1;padding-block:clamp(2.6rem,5vw,3.6rem);display:flex;flex-direction:column;gap:clamp(1.8rem,3.5vw,2.4rem)}
.footer-top{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}
.footer-brand{display:flex;flex-direction:column;gap:.9rem;max-width:32ch}
.footer img{height:40px;width:auto;filter:brightness(0) invert(1);align-self:flex-start}
.footer-tag{font-family:var(--f-d);font-weight:600;font-size:clamp(1.3rem,2.4vw,1.7rem);line-height:1.15;color:#fff;letter-spacing:-.01em}
.footer-tag .hl{color:#f6ead0}
.footer .fnav{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.9rem}
.footer .fnav a{color:color-mix(in oklch,var(--shell) 78%,transparent);transition:color .3s}
.footer .fnav a:hover{color:#fff}
.footer-bot{border-top:1px solid color-mix(in oklch,#fff 14%,transparent);padding-top:1.3rem;display:flex;align-items:center;
  justify-content:space-between;gap:1rem 1.4rem;flex-wrap:wrap;font-family:var(--f-m);font-size:.72rem;color:color-mix(in oklch,var(--shell) 52%,transparent)}
.footer-bot a{color:var(--gold)}
.footer-social{display:flex;gap:.55rem}
.footer-social a{width:34px;height:34px;border:1px solid color-mix(in oklch,#fff 22%,transparent);border-radius:50%;display:grid;place-items:center;color:color-mix(in oklch,var(--shell) 82%,transparent);transition:.3s}
.footer-social a:hover{background:#fff;color:var(--marine-deep);border-color:#fff;transform:translateY(-2px)}
.footer-social svg{width:15px;height:15px}

/* float WA */
.wa-float{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom,0px));z-index:130;width:56px;height:56px;border-radius:50%;background:#1fa153;
  display:grid;place-items:center;box-shadow:0 12px 30px -8px color-mix(in oklch,#1fa153 70%,transparent)}
.wa-float svg{width:29px;height:29px;color:#fff}
.wa-float::before{content:"";position:absolute;inset:0;border-radius:50%;background:#1fa153;z-index:-1;animation:pulse2 2.6s infinite}
@keyframes pulse2{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.5);opacity:0}100%{opacity:0}}

/* back to top */
.to-top{position:fixed;right:23px;bottom:calc(86px + env(safe-area-inset-bottom,0px));z-index:129;width:46px;height:46px;border-radius:50%;
  background:color-mix(in oklch,var(--marine-deep) 92%,#000);color:#fff;border:1px solid color-mix(in oklch,#fff 22%,transparent);
  display:grid;place-items:center;cursor:pointer;opacity:0;transform:translateY(10px) scale(.92);pointer-events:none;
  transition:opacity .35s,transform .35s cubic-bezier(.16,1,.3,1);box-shadow:0 12px 30px -10px rgba(10,20,22,.6)}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{background:var(--marine-deep);transform:translateY(-2px)}
.to-top:focus-visible{outline:2px solid var(--teal);outline-offset:3px}
.to-top svg{width:20px;height:20px}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* hero — editorial top rail + concierge bar */
.hero-top{position:absolute;top:0;left:0;right:0;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding:clamp(5rem,8vh,6.5rem) var(--pad-x) 0}
.hero-top .kicker{color:#f3e7c6}
.hero-coord{color:color-mix(in oklch,#fff 78%,transparent)}
.hero-bar{position:relative;z-index:1;margin:clamp(1.8rem,4vh,2.8rem) var(--pad-x) 0;display:flex;align-items:center;gap:.4rem 0;flex-wrap:wrap;
  background:color-mix(in oklch,#fff 13%,transparent);backdrop-filter:blur(10px) saturate(140%);
  border:1px solid color-mix(in oklch,#fff 30%,transparent);border-radius:3px;padding:.9rem 1.1rem}
.hb-item{display:flex;align-items:center;gap:.7rem;padding-right:clamp(1rem,3vw,2.4rem)}
.hb-item + .hb-item{padding-left:clamp(1rem,3vw,2.4rem);border-left:1px solid color-mix(in oklch,#fff 24%,transparent)}
.hb-item .lbl{font-family:var(--f-b);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:#f3e7c6;font-weight:600}
.hb-item b{font-family:var(--f-m);font-weight:500;color:#fff;font-size:1rem;letter-spacing:.01em}
.hb-cta{margin-left:auto;padding-left:1rem}
.hb-cta .btn{padding:.72rem 1.3rem;font-size:.82rem}

/* gallery — auto marquee */
.pad-y{padding-block:clamp(4.5rem,9.5vw,8rem)}
.gal-head2{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:2.6rem}
.gal-head2 .title{margin-top:.8rem}
.gal-tip{font-family:var(--f-m);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);white-space:nowrap;display:inline-flex;align-items:center;gap:.5rem}
.gal-tip::before{content:"";width:18px;height:1px;background:currentColor;opacity:.6}
.marquee{display:flex;flex-direction:column;gap:14px;overflow:hidden}
.mrow{display:flex;gap:14px;width:max-content;will-change:transform}
.mrow.a{animation:scrollL 64s linear infinite}
.mrow.b{animation:scrollR 80s linear infinite}
.marquee:hover .mrow{animation-play-state:paused}
@keyframes scrollL{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes scrollR{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.mtile{flex:none;height:clamp(210px,25vw,310px);aspect-ratio:3/2;border:0;padding:0;border-radius:2px;overflow:hidden;position:relative;background:var(--sand);cursor:pointer}
.mtile.tall{aspect-ratio:4/5}
.mtile img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.16,1,.3,1);pointer-events:none}
.mtile::after{content:"";position:absolute;inset:0;background:color-mix(in oklch,var(--marine-deep) 0%,transparent);transition:background .4s}
.mtile:hover img{transform:scale(1.06)}
.mtile:hover::after{background:color-mix(in oklch,var(--marine-deep) 12%,transparent)}
.mtile .zoom{position:absolute;right:.7rem;bottom:.7rem;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  background:color-mix(in oklch,#fff 16%,transparent);border:1px solid color-mix(in oklch,#fff 50%,transparent);backdrop-filter:blur(4px);
  color:#fff;opacity:0;transform:translateY(6px);transition:.35s}
.mtile:hover .zoom{opacity:1;transform:none}
.mtile .zoom svg{width:14px;height:14px}
@media (prefers-reduced-motion:reduce){.mrow{animation:none!important}}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:clamp(1rem,5vw,3.5rem);
  background:color-mix(in oklch,var(--marine-deep) 86%,#000);backdrop-filter:blur(10px);opacity:0;transition:opacity .3s}
.lb.open{display:flex;opacity:1}
.lb figure{position:relative;max-width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center;gap:.9rem}
.lb img{max-width:100%;max-height:82vh;border-radius:2px;box-shadow:0 40px 90px -25px rgba(0,0,0,.7)}
.lb figcaption{font-family:var(--f-m);font-size:.7rem;letter-spacing:.1em;color:color-mix(in oklch,#fff 70%,transparent)}
.lb-btn{position:absolute;border:1px solid color-mix(in oklch,#fff 32%,transparent);background:color-mix(in oklch,#fff 10%,transparent);
  color:#fff;cursor:pointer;display:grid;place-items:center;border-radius:50%;backdrop-filter:blur(6px);transition:.25s}
.lb-btn:hover{background:#fff;color:var(--marine-deep)}
.lb-close{top:clamp(1rem,3vw,1.6rem);right:clamp(1rem,3vw,1.6rem);width:46px;height:46px;font-size:1.5rem;line-height:1}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:50px;height:50px;font-size:1.5rem;line-height:1}
.lb-prev{left:clamp(.6rem,2vw,1.6rem)}
.lb-next{right:clamp(.6rem,2vw,1.6rem)}

/* custom cursor — pointer → anchor */
html.cc-on, html.cc-on *{cursor:none!important}
.cursor{position:fixed;top:0;left:0;width:26px;height:26px;pointer-events:none;z-index:300;opacity:0;transition:opacity .25s;will-change:transform}
.cursor::after{content:"";position:absolute;inset:-10px;border-radius:50%;opacity:0;transform:scale(.5);z-index:-1;
  background:radial-gradient(circle at 36% 30%,#fffaf0,#efe4cf);
  box-shadow:0 5px 16px rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.06),inset 0 0 0 1.5px color-mix(in oklch,var(--gold) 48%,transparent);
  transition:opacity .3s,transform .42s cubic-bezier(.16,1,.3,1)}
.cursor.big::after{opacity:1;transform:scale(1)}
.cur-arrow{position:absolute;top:0;left:0;width:24px;height:24px;overflow:visible;display:block;
  transition:opacity .25s,transform .3s cubic-bezier(.16,1,.3,1);transform-origin:3px 2px}
.cur-arrow path{fill:#fbf6ea;stroke:var(--marine-deep);stroke-width:1.5;stroke-linejoin:round;paint-order:stroke}
.cur-anchor{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transform:scale(.4);transition:opacity .3s,transform .42s cubic-bezier(.16,1,.3,1)}
.cur-anchor svg{width:24px;height:24px;color:var(--marine-deep);stroke-width:2.3}
.cursor.on{opacity:1}
.cursor.big .cur-arrow{opacity:0;transform:scale(.5)}
.cursor.big .cur-anchor{opacity:1;transform:scale(1)}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

@media (max-width:600px){
  .hb-item + .hb-item{padding-left:1rem;border-left:0}
  .hb-cta{margin-left:0;padding-left:0;width:100%;margin-top:.3rem}
  .hb-cta .btn{width:100%}
  .mtile{height:clamp(170px,42vw,230px)}
  /* lighter hero text block on phones → más aire para el video */
  .hero h1{font-size:clamp(2.3rem,8.4vw,3.2rem);margin:.8rem 0 1.3rem;line-height:1.05}
  .hero p.lead{font-size:1rem}
  .hero-cta{margin-top:1.35rem;gap:.6rem}
}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:140;display:none;flex-direction:column;justify-content:center;
  gap:.4rem;padding:var(--pad-x);transform:translateY(-100%);transition:transform .55s cubic-bezier(.16,1,.3,1);overflow-y:auto;overscroll-behavior:contain;
  background:linear-gradient(155deg,color-mix(in oklch,var(--marine-deep) 78%,transparent),color-mix(in oklch,var(--teal-deep) 62%,transparent) 88%);
  backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%)}
.mobile-menu::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(80% 55% at 80% 12%,color-mix(in oklch,var(--teal) 30%,transparent),transparent 60%)}
.mobile-menu .contours{color:#fff;opacity:.13;z-index:0}
.mobile-menu.open{display:flex;transform:none}
.mobile-menu a{position:relative;z-index:1;font-family:var(--f-d);font-weight:600;font-size:clamp(2rem,8vw,2.7rem);color:#fff;
  width:max-content;letter-spacing:-.01em;text-shadow:0 2px 24px color-mix(in oklch,var(--marine-deep) 60%,transparent);
  transition:color .3s,padding-left .35s}
.mobile-menu a:not(.btn)::before{content:"";position:absolute;left:-1.1rem;top:50%;width:0;height:2px;background:var(--gold);transform:translateY(-50%);transition:width .35s}
.mobile-menu a:not(.btn):hover{padding-left:1.1rem;color:#f6ead0}
.mobile-menu a:not(.btn):hover::before{width:.7rem}
.mobile-menu .mm-cta{margin-top:1.4rem;font-size:1rem;background:#fff;color:var(--marine-deep);border-color:#fff}
.mobile-menu .mm-cta:hover{background:#f6ead0;color:var(--marine-deep);border-color:#f6ead0;transform:translateY(-2px)}
.mobile-menu .close{position:absolute;top:1.1rem;right:var(--pad-x);background:color-mix(in oklch,#fff 12%,transparent);border:1px solid color-mix(in oklch,#fff 30%,transparent);
  width:44px;height:44px;border-radius:50%;font-size:1.6rem;cursor:pointer;color:#fff;z-index:5;line-height:1;display:grid;place-items:center}
.mobile-menu .close:hover{background:#fff;color:var(--marine-deep)}
.mobile-menu .mm-lang{position:relative;z-index:1;align-self:flex-start;margin-top:1.9rem;border-color:color-mix(in oklch,#fff 38%,transparent)}
.mobile-menu .mm-lang button{color:color-mix(in oklch,#fff 86%,transparent);width:3.1rem;padding:.55rem .9rem;font-size:.8rem}
.mobile-menu .mm-lang button.active{background:#fff;color:var(--marine-deep)}

@media (max-width:920px){
  .about-grid,.boat-grid,.book-grid,.contact-grid,.found-grid,.tours-head,.why-grid{grid-template-columns:1fr}
  .combo{grid-template-columns:1fr}.combo-fig{min-height:240px;order:-1}
  .tour-row,.tour-row:nth-child(even){display:block}
  .tour-fig,.tour-row:nth-child(even) .tour-fig{margin-bottom:1.4rem}
  .tour-fig img{aspect-ratio:3/2}
  .tour-fig img.fig-sunset{object-position:center 72%}
  .nav-links,.nav .btn-fill{display:none}
  .hamb{display:flex}
  .about-fig img{aspect-ratio:3/2}
  .boat-fig img{min-height:280px}
  .map,.map iframe{min-height:320px}
  .mosaic{grid-auto-rows:15vw}
}
@media (max-width:560px){
  .why-grid,.specs{grid-template-columns:1fr}
  .specs{grid-template-columns:1fr}
  .spec:nth-child(even){padding-left:0;border-left:0}
  .spec:nth-child(odd){padding-right:0}
  .route{grid-template-columns:1fr;gap:1.6rem}
  .route::before{top:8%;bottom:8%;left:14px;right:auto;width:1px;height:auto}
  .strip-item + .strip-item{padding-left:1rem;border-left:0}
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:34vw}
  .mz-wide,.mz-big,.mz-col2{grid-column:span 2}
  .mz-tall,.mz-tall2,.mz-big,.mz-sm,.mz-wide{grid-row:span 1}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important}
  .reveal{opacity:1 !important;transform:none !important;transition:none !important}
  .wt{clip-path:none !important}.boat{display:none !important}.wake::after{width:min(100%,9rem) !important;transition:none !important}
}

/* ── multipage additions ── */
/* sub-page header (clears the fixed nav) */
.subhead{padding-top:calc(64px + clamp(2.5rem,7vw,5rem));padding-bottom:clamp(1.5rem,4vw,2.5rem)}
.subhead .title{margin-top:1rem;max-width:22ch}
.subhead .lead{margin-top:1.3rem}

/* sub-page hero band (cinematic header, e.g. Por qué Malix) */
.bandhead{position:relative;min-height:62vh;min-height:62svh;display:flex;align-items:flex-end;overflow:hidden;color:#fff;
  padding:calc(64px + clamp(2rem,6vh,4rem)) var(--pad-x) clamp(2.5rem,6vw,4rem)}
.bandhead-media{position:absolute;inset:0;z-index:-2;background:#0e1c1e}
.bandhead-media img{width:100%;height:100%;object-fit:cover}
.bandhead::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,color-mix(in oklch,var(--marine-deep) 30%,transparent),transparent 35%,color-mix(in oklch,var(--marine-deep) 70%,transparent))}
.bandhead .kicker{color:#f3e7c6}
.bandhead h1{color:#fff;font-size:clamp(2.4rem,6vw,4.4rem);font-weight:600;margin-top:1rem;max-width:18ch;line-height:1.02;letter-spacing:-.022em}
.bandhead h1 .hl{color:#f6ead0}
.bandhead .lead{color:color-mix(in oklch,#fff 90%,transparent);margin-top:1.3rem;max-width:52ch}

/* home connect block — social only */
.connect{background:var(--marine-deep);color:var(--shell);position:relative;overflow:hidden;text-align:center}
.connect .contours{color:#fff;opacity:.08}
.connect-in{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.1rem}
.connect h2{color:#fff}
.connect .lead{color:color-mix(in oklch,var(--shell) 82%,transparent);margin-inline:auto;text-align:center}
.connect-socials{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}
.connect-socials a{width:56px;height:56px;border:1px solid color-mix(in oklch,#fff 26%,transparent);border-radius:50%;display:grid;place-items:center;color:#fff;transition:.3s}
.connect-socials a:hover{background:#fff;color:var(--marine-deep);border-color:#fff;transform:translateY(-3px)}
.connect-socials svg{width:23px;height:23px}
