/* =========================================================
   MORII EXPEDITIONS — Cinematic luxury design system
   ========================================================= */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Jost:wght@300;400;500&family=Poppins:wght@500;600;700&display=swap');

/* ---------- Tokens ----------
   Morii brand green: #17392C
*/
:root{
  --green:#17392C;        /* OFFICIAL Morii brand green */
  --ink:#102a20;          /* base — a touch deeper than brand for cinematic depth */
  --ink-2:#17392C;        /* brand green panels */
  --ink-3:#1f4a39;        /* lighter green */
  --ink-deep:#0c2018;     /* darkest — footer / overlays */
  --bone:#f4f1ea;         /* off white */
  --bone-2:#e4e8e1;
  --mist:#9bb0a4;         /* muted sage text */
  --line:rgba(244,241,234,.15);
  --line-dark:rgba(12,15,16,.12);
  --gold:#c2a572;         /* warm champagne accent (luxe on green) */
  --gold-2:#d6bd8c;
  --sea:#2c4a47;
  --display:'Cormorant Garamond', Georgia, serif;
  --sans:'Jost', system-ui, -apple-system, sans-serif;
  --brandfont:'Poppins', var(--sans);
  --maxw:1320px;
  --ease:cubic-bezier(.16,.84,.44,1);
}

/* ---------- Intro / preloader (rotating compass) ---------- */
.intro{position:fixed;inset:0;z-index:9999;background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;
  transition:opacity 1s var(--ease),visibility 1s var(--ease);
  animation:introAuto .8s var(--ease) 3.6s forwards} /* fallback if JS is off */
.intro.hide{opacity:0;visibility:hidden;animation:none}
@keyframes introAuto{to{opacity:0;visibility:hidden}}
.intro-compass{position:relative;width:104px;height:104px;display:grid;place-items:center}
.intro-ring{position:absolute;inset:0;border:1px solid rgba(244,241,234,.12);
  border-top-color:var(--gold);border-radius:50%;animation:introspin 1.1s linear infinite}
.intro-ring::after{content:"";position:absolute;inset:11px;border:1px solid rgba(244,241,234,.07);
  border-bottom-color:rgba(214,189,140,.55);border-radius:50%;animation:introspin 1.7s linear infinite reverse}
.intro-mark{width:44px;height:52px;background:url('../assets/morii-mark.png') center/contain no-repeat;
  opacity:0;animation:intromark 1.1s var(--ease) .15s forwards}
.intro-word{font-family:var(--brandfont);font-weight:600;letter-spacing:.04em;color:var(--bone);
  font-size:1.05rem;opacity:0;animation:intromark 1.1s var(--ease) .45s forwards;text-align:center}
.intro-word small{display:block;font-family:var(--sans);font-weight:400;font-size:.5rem;
  letter-spacing:.42em;text-transform:uppercase;color:var(--gold-2);margin-top:.5em}
@keyframes introspin{to{transform:rotate(360deg)}}
@keyframes intromark{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){.intro-ring,.intro-ring::after{animation:none}}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--bone);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:1.05;letter-spacing:.01em}
.eyebrow{
  font-family:var(--sans);
  font-size:.7rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold-2);font-weight:400;
}
.lede{font-size:1.18rem;color:var(--bone-2);font-weight:300;max-width:46ch}
.muted{color:var(--mist)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 7vw}
section{position:relative}
.section-pad{padding:clamp(5rem,11vw,11rem) 0}
.center{text-align:center}
.divider{height:1px;background:var(--line);border:0;margin:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;
  padding:1.05em 2.1em;border:1px solid var(--bone);color:var(--bone);
  background:transparent;transition:all .5s var(--ease);font-weight:400;
}
.btn:hover{background:var(--bone);color:var(--ink)}
.btn--gold{border-color:var(--gold);color:var(--gold-2)}
.btn--gold:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.btn--solid{background:var(--bone);color:var(--ink)}
.btn--solid:hover{background:transparent;color:var(--bone)}
.btn--dark{border-color:var(--ink);color:var(--ink)}
.btn--dark:hover{background:var(--ink);color:var(--bone)}
.btn-row{display:flex;gap:1rem;flex-wrap:wrap}
.btn-row.center{justify-content:center}

.link-arrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-2);
  border-bottom:1px solid transparent;padding-bottom:.3em;transition:.4s var(--ease);
}
.link-arrow:hover{gap:1.1em;color:var(--bone)}

/* ---------- Navigation ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem 7vw;transition:background .6s var(--ease),padding .6s var(--ease);
}
.nav.scrolled{background:rgba(10,26,20,.82);backdrop-filter:blur(14px);padding:1.05rem 7vw;border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:.65rem}
.brand-logo{display:block;height:34px;width:auto;transition:height .5s var(--ease)}
.nav.scrolled .brand-logo{height:30px}
.foot-brand .brand-logo{height:46px;margin-bottom:1.4rem}
.brand-mark{width:26px;height:31px;flex:none}
.brand-word{font-family:var(--brandfont);font-weight:600;font-size:1.32rem;letter-spacing:.01em;color:var(--bone);line-height:1;text-transform:none}
.brand-word small{display:block;font-family:var(--sans);font-weight:400;font-size:.5rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-2);margin-top:.32em}
/* footer brand a little larger, stacked-friendly */
.foot-brand .brand-mark{width:30px;height:35px}
.foot-brand .brand-word{font-size:1.5rem}
.nav-links{display:flex;gap:2.1rem;align-items:center}
.nav-links a{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone);opacity:.8;transition:.3s;position:relative}
.nav-links a:hover,.nav-links a.active{opacity:1;color:var(--gold-2)}
.nav-cta{border:1px solid var(--line);padding:.7em 1.3em;opacity:1!important}
.nav-cta:hover{border-color:var(--gold)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;z-index:120}
.nav-toggle span{width:26px;height:1px;background:var(--bone);transition:.4s}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;background:var(--ink);z-index:110;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.6rem;
  opacity:0;pointer-events:none;transition:opacity .5s var(--ease);
}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{font-family:var(--display);font-size:2rem;color:var(--bone)}
.mobile-menu a:hover{color:var(--gold-2)}

/* ---------- Hero ---------- */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:flex-end;overflow:hidden}
.hero--short{height:78vh;min-height:520px}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover}
/* cinematic slow zoom (Ken Burns) on the hero visual */
.hero-media .ph,.hero-media img,.hero-media video{
  width:100%;height:100%;animation:kenburns 22s ease-in-out infinite alternate;transform-origin:50% 45%}
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.18)}}
.hero-media video{animation:heroZoom 26s ease-in-out infinite alternate;transform-origin:50% 50%}
@keyframes heroZoom{from{transform:scale(1.02)}to{transform:scale(1.12)}}
@media (prefers-reduced-motion: reduce){.hero-media video{animation:none}}

/* cinematic line-mask reveal for the home hero headline */
.hero h1.lines{overflow:visible}
.hero h1.lines .line{display:block;overflow:hidden;padding-bottom:.04em}
.hero h1.lines .line>span{display:block;transform:translateY(118%);animation:lineUp 1.2s var(--ease) forwards}
.hero h1.lines .line:nth-child(1)>span{animation-delay:1.55s}
.hero h1.lines .line:nth-child(2)>span{animation-delay:1.72s}
@keyframes lineUp{to{transform:translateY(0)}}
@media (prefers-reduced-motion: reduce){.hero h1.lines .line>span{transform:none;animation:none}}
/* refined hero detail line bottom-left */
.hero-meta{position:absolute;left:7vw;bottom:2rem;z-index:2;display:flex;gap:1.4rem;align-items:center;
  font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;color:var(--mist)}
.hero-meta span{opacity:0;animation:intromark 1s var(--ease) 2.1s forwards}

/* ===== Owned assets — interactive explorer (single image + list) ===== */
.assetx{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;margin-top:3rem}
.assetx-list{display:flex;flex-direction:column}
.ax-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.4rem;padding:1.7rem 0;
  border-top:1px solid var(--line);color:var(--bone);transition:padding .45s var(--ease)}
.assetx-list .ax-row:last-child{border-bottom:1px solid var(--line)}
.ax-no{font-family:var(--display);color:var(--gold-2);font-size:1rem;min-width:2rem}
.ax-info b{font-family:var(--display);font-weight:400;font-size:clamp(1.4rem,2.4vw,1.9rem);display:block;line-height:1.1;transition:color .4s var(--ease)}
.ax-info i{font-style:normal;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mist)}
.ax-go{color:var(--gold-2);font-size:1.1rem;opacity:0;transform:translateX(-8px);transition:.4s var(--ease)}
.ax-row:hover,.ax-row.is-active{padding-left:1rem}
.ax-row:hover .ax-go,.ax-row.is-active .ax-go{opacity:1;transform:none}
.ax-row:hover .ax-info b,.ax-row.is-active .ax-info b{color:var(--gold-2)}
.assetx-media{position:relative;aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line)}
.assetx-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .35s var(--ease)}
.assetx-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(10,26,20,.4))}
@media(max-width:760px){.assetx{grid-template-columns:1fr}.assetx-media{order:-1;aspect-ratio:16/10;margin-bottom:1.6rem}}

/* ===== Owned assets — cohesive duotone treatment + index numbers ===== */
.acard--asset .asset-tint{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(165deg,rgba(23,57,44,.42),rgba(12,32,24,.5));mix-blend-mode:multiply}
.acard--asset .asset-no{position:absolute;top:1.1rem;left:1.5rem;z-index:3;font-family:var(--display);
  font-size:1rem;color:var(--gold-2);letter-spacing:.12em;text-shadow:0 1px 12px rgba(6,16,12,.8)}
@media (prefers-reduced-motion: reduce){.hero-media .ph,.hero-media img,.hero-media video{animation:none}}
.hero-media::after{content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(130% 90% at 50% 28%, transparent 38%, rgba(10,26,20,.55) 100%),
    linear-gradient(180deg,rgba(10,26,20,.5) 0%,rgba(10,26,20,.08) 36%,rgba(10,26,20,.92) 100%)}
.hero-inner{position:relative;z-index:2;padding:0 7vw clamp(3.5rem,8vw,7rem);width:100%;max-width:1500px;margin:0 auto}
.hero h1{font-size:clamp(2.7rem,6.6vw,6rem);max-width:16ch;font-weight:300}
.hero .lede{margin-top:1.6rem;font-size:clamp(1rem,1.5vw,1.28rem);max-width:60ch}
.hero .btn-row{margin-top:2.6rem}
.hero-eyebrow{margin-bottom:1.6rem;display:inline-flex;align-items:center;gap:1rem}
.hero-eyebrow::before{content:"";display:inline-block;width:0;height:1px;background:var(--gold);
  animation:lineGrow 1.6s var(--ease) 1.7s forwards}
@keyframes lineGrow{to{width:56px}}
.hero h1{text-shadow:0 2px 40px rgba(8,18,14,.45)}
.hero .lede{text-shadow:0 1px 24px rgba(8,18,14,.4)}
/* richer, moody placeholder for the hero until a photo/video is added */
.hero .hero-media .ph{background:
  radial-gradient(90% 70% at 50% 25%, #2c6450 0%, #184030 42%, #0c2219 72%, #081912 100%)}
.hero .hero-media .ph::before{width:120px;height:140px;opacity:.05}
.scroll-cue{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;
  font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--mist);
  display:flex;flex-direction:column;align-items:center;gap:.7rem}
.scroll-cue::after{content:"";width:1px;height:46px;background:linear-gradient(var(--gold),transparent);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Image placeholder (swap for brand assets) ---------- */
.ph{position:relative;background:
   radial-gradient(120% 120% at 30% 20%, #21513f 0%, #163729 55%, #0c2018 100%);
   overflow:hidden}
/* clean brand placeholder — subtle centered compass, no labels/patterns */
.ph::before{content:"";position:absolute;inset:0;margin:auto;width:46px;height:54px;
  background:url('../assets/morii-mark.png') center/contain no-repeat;opacity:.06}
.ph.is-light{background:radial-gradient(120% 120% at 30% 20%,#efeadf,#ddd5c4)}
.ph.is-light::before{opacity:.12}

/* ---------- Section headers ---------- */
.sec-head{max-width:60ch}
.sec-head .eyebrow{display:block;margin-bottom:1.4rem}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.6rem);font-weight:300}
.sec-head p{margin-top:1.4rem}
.sec-head--center{margin:0 auto;text-align:center}
/* recurring Morii compass above centered headings */
.sec-head--center::before{content:"";display:block;width:30px;height:35px;margin:0 auto 1.6rem;
  background:url('../assets/morii-mark.png') center/contain no-repeat;opacity:.9}

/* ---------- Intro split ---------- */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:center}
.split--rev .split-media{order:2}
.split-media{aspect-ratio:4/5;width:100%;object-fit:cover}
.split-body h2{font-size:clamp(1.9rem,3.8vw,3.2rem);font-weight:300;margin-bottom:1.4rem}

/* ---------- Asset / fleet cards ---------- */
.cards{display:grid;gap:1.4rem}
.cards-2{grid-template-columns:repeat(2,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-4{grid-template-columns:repeat(4,1fr)}
.acard{position:relative;display:block;overflow:hidden;aspect-ratio:3/4;background:var(--ink-2)}
.acard .ph,.acard img{position:absolute;inset:0;width:100%;height:100%;transition:transform 1.1s var(--ease)}
.acard:hover .ph,.acard:hover img{transform:scale(1.06)}
.acard-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,26,20,.12) 0%,rgba(10,26,20,0) 22%,rgba(10,26,20,.5) 50%,rgba(10,26,20,.9) 100%)}
.acard-body{position:absolute;left:0;bottom:0;z-index:2;padding:1.8rem;width:100%;text-shadow:0 1px 16px rgba(6,16,12,.85)}
.acard-body .kicker{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-2)}
.acard-body h3{font-size:1.7rem;margin:.5rem 0 .2rem;font-weight:400;color:var(--bone)}
.acard-body p{font-size:.86rem;color:var(--bone-2);max-width:34ch}
.acard-body .more{margin-top:1rem;opacity:0;transform:translateY(8px);transition:.5s var(--ease)}
.acard:hover .acard-body .more{opacity:1;transform:none}

/* ---------- Wide journey/feature card ---------- */
.feature{display:grid;grid-template-columns:1.1fr 1fr;min-height:520px}
.feature--rev{grid-template-columns:1fr 1.1fr}
.feature--rev .feature-media{order:2}
.feature-media{position:relative;overflow:hidden}
.feature-media .ph,.feature-media img{position:absolute;inset:0;width:100%;height:100%}
.feature-body{background:var(--ink-2);display:flex;flex-direction:column;justify-content:center;padding:clamp(2.5rem,5vw,5rem)}
.feature-body h2{font-size:clamp(1.9rem,3.6vw,3rem);font-weight:300;margin:1rem 0 1.2rem}

/* ---------- Quiet list (philosophy / included) ---------- */
.qlist{display:grid;gap:0}
.qlist .qrow{display:flex;align-items:baseline;gap:1.4rem;padding:1.6rem 0;border-top:1px solid var(--line)}
.qlist .qrow:last-child{border-bottom:1px solid var(--line)}
.qlist .qnum{font-family:var(--display);font-size:1rem;color:var(--gold-2);min-width:2.4rem}
.qlist .qrow h3{font-size:1.5rem;font-weight:400}
.qlist .qrow p{color:var(--mist);font-size:.92rem;margin-top:.3rem}

/* big philosophy words */
.philos{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line)}
.philos div{background:var(--ink);padding:clamp(2rem,4vw,3.4rem)}
.philos h3{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:300}
.philos span{display:block;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-2);margin-bottom:1rem}

/* ---------- Pill grid (experiences / who it's for) ---------- */
.pillgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.pill{position:relative;aspect-ratio:1/1;overflow:hidden;display:flex;align-items:flex-end;background:var(--ink-2)}
.pill .ph,.pill img{position:absolute;inset:0;width:100%;height:100%;transition:transform 1s var(--ease)}
.pill:hover .ph,.pill:hover img{transform:scale(1.07)}
.pill-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,26,20,.1) 0%,rgba(10,26,20,0) 32%,rgba(10,26,20,.55) 62%,rgba(10,26,20,.92) 100%)}
.pill h3{position:relative;z-index:2;padding:1.4rem;font-size:1.35rem;font-weight:400;text-shadow:0 1px 16px rgba(6,16,12,.85)}
.pill .tag{position:relative;z-index:2;padding:0 1.4rem 1.4rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-2);text-shadow:0 1px 16px rgba(6,16,12,.85)}

/* simple text chips */
.chips{display:flex;flex-wrap:wrap;gap:.8rem}
.chip{border:1px solid var(--line);padding:.8em 1.4em;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone-2);transition:.4s}
.chip:hover{border-color:var(--gold);color:var(--gold-2)}

/* ---------- Journey overview cards ---------- */
.jgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.jcard{background:var(--ink-2);border:1px solid var(--line);display:flex;flex-direction:column;transition:.5s var(--ease)}
.jcard:hover{transform:translateY(-6px);border-color:rgba(176,141,87,.4)}
.jcard-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.jcard-media .ph,.jcard-media img{position:absolute;inset:0;width:100%;height:100%;transition:transform 1s var(--ease)}
.jcard:hover .jcard-media .ph,.jcard:hover .jcard-media img{transform:scale(1.06)}
.jcard-avail{position:absolute;top:1rem;left:1rem;z-index:2;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;
  background:rgba(10,26,20,.7);backdrop-filter:blur(6px);padding:.5em 1em;color:var(--bone)}
.jcard-avail.low{color:var(--gold-2)}
.jcard-host{position:absolute;top:1rem;right:1rem;z-index:2;font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;
  background:var(--gold);color:var(--ink);padding:.5em 1em;font-weight:500}
.jcard-next{position:absolute;bottom:1rem;left:1rem;z-index:2;font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;
  background:var(--gold);color:var(--ink);padding:.5em 1em;font-weight:600;display:inline-flex;align-items:center;gap:.5em}
.jcard-next::before{content:"";width:.45em;height:.45em;border-radius:50%;background:var(--ink);
  box-shadow:0 0 0 0 rgba(20,20,20,.5);animation:nextpulse 2s infinite}
@keyframes nextpulse{0%{box-shadow:0 0 0 0 rgba(20,20,20,.5)}70%{box-shadow:0 0 0 .5em rgba(20,20,20,0)}100%{box-shadow:0 0 0 0 rgba(20,20,20,0)}}
/* Journey tabs (Upcoming / Past) */
.jtabs{display:flex;justify-content:center;gap:2.4rem;margin:0 0 3rem;border-bottom:1px solid var(--line)}
.jtab{background:none;border:none;cursor:pointer;color:var(--mist);font-family:inherit;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  padding:0 0 1.1rem;position:relative;transition:color .3s}
.jtab:hover{color:var(--bone)}
.jtab.is-active{color:var(--gold-2)}
.jtab.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--gold)}
/* Past journey cards */
.jcard--past .jcard-media{position:relative;overflow:hidden}
.jcard--past .jcard-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.35) brightness(.82);transition:filter .5s,transform 1.2s}
.jcard--past:hover .jcard-media img{filter:grayscale(0) brightness(.95);transform:scale(1.04)}
.jpast-soon{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-2)}
/* Past journey documentary (video) cards */
.jcard--film .jcard-media{cursor:pointer}
.jpast-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:62px;height:62px;border-radius:50%;
  background:rgba(10,26,20,.55);border:1.5px solid var(--bone);backdrop-filter:blur(3px);z-index:3;transition:.35s var(--ease)}
.jpast-play::after{content:"";position:absolute;top:50%;left:54%;transform:translate(-50%,-50%);
  border-style:solid;border-width:11px 0 11px 18px;border-color:transparent transparent transparent var(--bone)}
.jpast-watch{position:absolute;bottom:1rem;left:0;right:0;text-align:center;z-index:3;color:var(--bone);
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;opacity:0;transition:.35s var(--ease)}
.jcard--film:hover .jpast-play{background:var(--gold);border-color:var(--gold);transform:translate(-50%,-50%) scale(1.08)}
.jcard--film:hover .jpast-play::after{border-color:transparent transparent transparent var(--ink)}
.jcard--film:hover .jpast-watch{opacity:1}
.jcard--film .jcard-media img{filter:grayscale(.15) brightness(.8)}
.jcard--film:hover .jcard-media img{filter:none;transform:scale(1.04)}
.jpast-cat{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-2);margin:-.4rem 0 1rem}
.jpast-actions{margin-top:auto;display:flex;flex-direction:column;gap:.9rem}
.jpast-actions--row{flex-direction:row;gap:.7rem}
.jpast-btn{flex:1 1 0;justify-content:center;text-align:center;white-space:nowrap;font-size:.6rem;padding:1em .5em}
.jpast-short{text-align:center;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mist);transition:color .3s}
.jpast-short:hover{color:var(--gold-2)}
/* ===== Destinations Atlas (hover-reveal index) ===== */
.atlas{display:grid;grid-template-columns:.9fr 1.1fr;gap:3.4rem;align-items:start}
.atlas-stage{position:sticky;top:100px;aspect-ratio:4/5;overflow:hidden;background:var(--ink-2);border:1px solid var(--line)}
.atlas-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.05);transition:opacity .8s var(--ease),transform 7s var(--ease)}
.atlas-stage img.is-on{opacity:1;transform:scale(1)}
.atlas-list{display:flex;flex-direction:column;gap:2.6rem}
.atlas-region{display:block;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-2);padding-bottom:.8rem;margin-bottom:.5rem;border-bottom:1px solid var(--line)}
.atlas-row{display:flex;align-items:center;gap:1.1rem;padding:.5rem 0;color:var(--mist);cursor:pointer;transition:padding-left .35s var(--ease)}
.atlas-thumb{display:none}
.atlas-name{font-family:var(--display);font-size:1.9rem;font-weight:400;line-height:1.05;color:var(--mist);transition:color .35s}
.atlas-sub{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mist);opacity:.55;margin-left:auto;text-align:right;transition:opacity .35s}
.atlas-row:hover{padding-left:.9rem}
.atlas-row:hover .atlas-name{color:var(--bone)}
.atlas-row.is-active .atlas-name{color:var(--gold-2)}
.atlas-row--soon{cursor:default}
.atlas-row--soon .atlas-name{opacity:.5;font-size:1.45rem}
@media(max-width:900px){
  .atlas{grid-template-columns:1fr;gap:2rem}
  .atlas-stage{display:none}
  .atlas-thumb{display:block;width:58px;height:58px;object-fit:cover;flex:0 0 auto}
  .atlas-name{font-size:1.5rem}
  .atlas-sub{display:none}
  .atlas-row{padding:.55rem 0;border-bottom:1px solid var(--line)}
  .atlas-row--soon .atlas-name{font-size:1.25rem}
}
.jcard-travel{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);
  margin:-.6rem 0 1.3rem;display:flex;align-items:center;gap:.55em}
.jcard-travel::before{content:"";width:.5em;height:.5em;border-radius:50%;border:1px solid var(--gold-2)}
.jcard-hostname{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);margin:-.4rem 0 .9rem}
.jcard-body{padding:1.7rem;display:flex;flex-direction:column;flex:1}
.jcard-dest{font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-2)}
.jcard-body h3{font-size:1.55rem;font-weight:400;margin:.5rem 0 1rem}
.jmeta{display:flex;flex-wrap:wrap;gap:.4rem 1.3rem;font-size:.78rem;color:var(--mist);margin-bottom:1.4rem}
.jmeta b{color:var(--bone);font-weight:400}
.jcard-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:1.3rem}
.jprice{font-family:var(--display);font-size:1.25rem}
.jprice small{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mist);display:block}

/* filter bar */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:3rem}
.filters button{background:none;border:1px solid var(--line);color:var(--bone-2);
  padding:.7em 1.3em;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;transition:.3s}
.filters button:hover,.filters button.active{background:var(--gold);border-color:var(--gold);color:var(--ink)}

/* ---------- Journey / fleet detail ---------- */
.detail-meta{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.detail-meta div{padding:1.8rem 0;border-left:1px solid var(--line);padding-left:1.6rem}
.detail-meta div:first-child{border-left:0;padding-left:0}
.detail-meta span{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-2);display:block;margin-bottom:.5rem}
.detail-meta b{font-family:var(--display);font-size:1.5rem;font-weight:400}
.day{display:grid;grid-template-columns:auto 1fr;gap:2rem;padding:2rem 0;border-top:1px solid var(--line)}
.day .dnum{font-family:var(--display);font-size:2.2rem;color:var(--gold-2);line-height:1}
.day h3{font-size:1.4rem;font-weight:400;margin-bottom:.5rem}
.day p{color:var(--mist);max-width:60ch}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.gallery .ph,.gallery img{aspect-ratio:1/1;width:100%;height:100%;object-fit:cover}
.gallery .ph.tall,.gallery img.tall{grid-row:span 2;aspect-ratio:1/2}
.gallery .ph.wide,.gallery img.wide{grid-column:span 2;aspect-ratio:2/1}

/* ---------- Membership tiers ---------- */
.tiers{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.tier{border:1px solid var(--line);padding:clamp(2rem,4vw,3.2rem);background:var(--ink-2)}
.tier--club{border-color:rgba(176,141,87,.45);background:linear-gradient(180deg,var(--ink-3),var(--ink-2))}
.tier .badge{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-2);margin-bottom:1.2rem;display:inline-block;border:1px solid var(--line);padding:.5em 1.1em}
.tier h3{font-size:2rem;font-weight:400;margin-bottom:1rem}
.tier ul{list-style:none;margin-top:1.6rem;display:grid;gap:.9rem}
.tier li{font-size:.9rem;color:var(--bone-2);padding-left:1.5rem;position:relative}
.tier li::before{content:"·";position:absolute;left:0;color:var(--gold-2);font-weight:700}
.tier-note{font-size:.8rem;color:var(--mist);margin-top:1.6rem;font-style:italic}

/* membership pathway steps */
.pathway{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;counter-reset:step}
.pstep{border-top:1px solid var(--line);padding-top:1.4rem}
.pstep .pn{font-family:var(--display);font-size:1rem;color:var(--gold-2)}
.pstep h4{font-family:var(--sans);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin:.8rem 0 .6rem;font-weight:400}
.pstep p{font-size:.82rem;color:var(--mist)}

/* ---------- Journal ---------- */
.jourgrid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.4rem}
.post{position:relative;overflow:hidden;display:flex;align-items:flex-end;min-height:320px;background:var(--ink-2)}
.post .ph,.post img{position:absolute;inset:0;width:100%;height:100%;transition:transform 1.1s var(--ease)}
.post:hover .ph,.post:hover img{transform:scale(1.05)}
.post-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,26,20,.12) 0%,rgba(10,26,20,0) 30%,rgba(10,26,20,.55) 60%,rgba(10,26,20,.92) 100%)}
.post-body{position:relative;z-index:2;padding:2rem;text-shadow:0 1px 16px rgba(6,16,12,.85)}
.post-cat{font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-2)}
.post-body h3{font-size:1.5rem;font-weight:400;margin-top:.6rem;max-width:22ch}
.post.lg{grid-column:span 8;min-height:520px}
.post.sm{grid-column:span 4}
.post.md{grid-column:span 6}

/* ---------- Contact / forms ---------- */
.formwrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem)}
.field{margin-bottom:1.6rem}
.field label{display:block;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-2);margin-bottom:.7rem}
.field input,.field textarea,.field select{
  width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);
  color:var(--bone);font-family:var(--sans);font-size:1rem;padding:.7rem 0;font-weight:300;transition:.4s}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--gold)}
.field textarea{resize:vertical;min-height:120px}
.field select option{background:var(--ink-2)}
.radio-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.radio-grid label{display:flex;align-items:center;gap:.7rem;border:1px solid var(--line);padding:.9em 1.1em;
  font-size:.78rem;letter-spacing:.08em;text-transform:none;color:var(--bone-2);cursor:pointer;transition:.3s;margin:0}
.radio-grid label:hover{border-color:var(--gold)}
.radio-grid input{width:auto}
.radio-grid input:checked+span{color:var(--gold-2)}

/* ---------- Modal (request to book) ---------- */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:5vw}
.modal.open{display:flex}
.modal-bg{position:absolute;inset:0;background:rgba(5,7,8,.86);backdrop-filter:blur(10px)}
.modal-card{position:relative;z-index:2;background:var(--ink-2);border:1px solid var(--line);
  max-width:560px;width:100%;padding:clamp(2rem,5vw,3.4rem);max-height:88vh;overflow:auto}
.modal-card .eyebrow{display:block;margin-bottom:1rem}
.modal-card h3{font-size:2rem;font-weight:400;margin-bottom:.6rem}
.modal-close{position:absolute;top:1.2rem;right:1.4rem;background:none;border:0;color:var(--mist);font-size:1.5rem;line-height:1}
.modal-steps{font-size:.78rem;color:var(--mist);margin:1.4rem 0 2rem;display:grid;gap:.6rem}
.modal-steps span{padding-left:1.6rem;position:relative}
.modal-steps span::before{content:counter(s);counter-increment:s;position:absolute;left:0;color:var(--gold-2);font-family:var(--display)}
.modal-steps{counter-reset:s}
.form-success{display:none;text-align:center;padding:1rem 0}
.form-success.show{display:block}
.form-success h3{margin-bottom:1rem}

/* ---------- Footer ---------- */
.footer{background:var(--ink-deep);border-top:1px solid var(--line);padding:clamp(4rem,8vw,7rem) 0 2.5rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:4rem}
.foot-brand .brand{margin-bottom:1.4rem}
.foot-brand p{color:var(--mist);font-size:.9rem;max-width:34ch}
.foot-col h4{font-family:var(--sans);font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-2);margin-bottom:1.4rem;font-weight:400}
.foot-col a{display:block;color:var(--bone-2);font-size:.86rem;margin-bottom:.85rem;opacity:.8;transition:.3s}
.foot-col a:hover{opacity:1;color:var(--gold-2)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:2rem;flex-wrap:wrap;gap:1rem}
.foot-bottom p{font-size:.74rem;color:var(--mist);letter-spacing:.06em}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center;padding:clamp(5rem,11vw,10rem) 7vw}
.cta-band .ph,.cta-band img{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover}
.cta-band::after{content:"";position:absolute;inset:0;z-index:1;background:rgba(10,26,20,.66)}
.cta-band .cta-inner{position:relative;z-index:2;max-width:40ch;margin:0 auto}
/* faint recurring compass watermark behind every CTA band */
.cta-band::before{content:"";position:absolute;z-index:1;top:50%;left:50%;
  width:min(46vw,420px);aspect-ratio:120/140;transform:translate(-50%,-58%);
  background:url('../assets/morii-mark.png') center/contain no-repeat;opacity:.06;pointer-events:none}
.cta-band .cta-inner::before{content:"";display:block;width:34px;height:40px;margin:0 auto 1.8rem;
  background:url('../assets/morii-mark.png') center/contain no-repeat;opacity:.95}
.cta-band h2{font-size:clamp(2.2rem,5vw,4rem);font-weight:300;margin-bottom:2rem}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(38px);filter:blur(7px);
  transition:opacity 1.1s var(--ease),transform 1.1s var(--ease),filter 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none;filter:none}
@media (prefers-reduced-motion: reduce){.reveal{filter:none;transform:none}}

/* ---------- Parallax images (gently shift on scroll) ---------- */
.feature-media img,.split-media img,.acard img,.pill img,.jcard-media img,.post img{
  transform:translate3d(0,0,0) scale(1.16);will-change:transform;transition:none;backface-visibility:hidden}
/* never stretch: always cover-crop */
.acard img,.feature-media img,.pill img,.jcard-media img,.post img,.cta-band img{object-fit:cover}
.split-media{overflow:hidden;position:relative}
.split-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media (prefers-reduced-motion: reduce){
  .feature-media img,.split-media img,.acard img,.pill img,.jcard-media img,.post img{transform:none!important}
}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

/* ---------- Community: moving word ribbon ---------- */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.5rem 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.marquee + .marquee{border-top:0}
.marquee-track{display:flex;gap:2.4rem;white-space:nowrap;width:max-content;animation:marq 32s linear infinite}
.marquee--rev .marquee-track{animation-direction:reverse;animation-duration:40s}
.marquee .w{font-family:var(--display);font-weight:300;font-size:clamp(1.7rem,3.6vw,3rem);color:var(--bone)}
.marquee .dot{color:var(--gold-2);font-size:clamp(1.7rem,3.6vw,3rem);line-height:1}
@keyframes marq{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.marquee-track{animation:none}}

/* ---------- Community: offers list ---------- */
.offers{display:grid;grid-template-columns:1fr 1fr;gap:0 3.5rem}
.offer{display:flex;gap:1.3rem;align-items:baseline;padding:1.5rem 0;border-top:1px solid var(--line);transition:padding .45s var(--ease)}
.offers .offer:nth-last-child(-n+1){border-bottom:1px solid var(--line)}
.offer .on{font-family:var(--display);color:var(--gold-2);font-size:1rem;min-width:2.4rem}
.offer h3{font-size:1.4rem;font-weight:400;transition:color .4s var(--ease)}
.offer:hover{padding-left:.7rem}
.offer:hover h3{color:var(--gold-2)}
@media(max-width:760px){.offers{grid-template-columns:1fr}}

/* ---------- Community: membership pathway timeline ---------- */
.ptimeline{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:1.2rem;margin-top:1.5rem}
.ptimeline::before{content:"";position:absolute;top:19px;left:8%;right:8%;height:1px;background:var(--line)}
.pstep2{position:relative}
.pstep2 .pdot{width:40px;height:40px;border-radius:50%;border:1px solid var(--gold);color:var(--gold-2);
  display:grid;place-items:center;font-family:var(--display);font-size:1rem;background:var(--ink);position:relative;z-index:1;margin-bottom:1.3rem}
.pstep2 h4{font-family:var(--sans);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.5rem;font-weight:400}
.pstep2 p{font-size:.82rem;color:var(--mist)}
@media(max-width:760px){
  .ptimeline{grid-template-columns:1fr;gap:0}
  .ptimeline::before{left:19px;right:auto;top:0;bottom:0;width:1px;height:auto}
  .pstep2{padding-left:3rem;padding-bottom:1.8rem}
  .pstep2 .pdot{position:absolute;left:0;top:0;margin:0}
}

/* ---------- Interactive fleet selector ---------- */
.fleetx{margin-top:2.6rem}
.fleetx-tabs{display:flex;flex-wrap:wrap;gap:0 2.4rem;border-bottom:1px solid var(--line);margin-bottom:2.6rem}
.fx-tab{background:none;border:0;color:var(--mist);font-family:var(--display);font-weight:300;
  font-size:clamp(1.5rem,3.2vw,2.4rem);padding:0 0 1rem;position:relative;transition:color .4s var(--ease)}
.fx-tab:hover{color:var(--bone)}
.fx-tab.is-active{color:var(--bone)}
.fx-tab.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--gold)}
.fleetx-stage{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.fleetx-media{position:relative;aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line)}
.fleetx-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .35s var(--ease)}
.fleetx-info h3{font-size:clamp(2rem,4vw,3rem);font-weight:300;margin:.2rem 0 1.2rem}
.fx-spec{margin:1.5rem 0}
.fx-spec>p{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-2);margin-bottom:.7rem}
.anchor{display:block;position:relative;top:-90px;visibility:hidden}
@media(max-width:760px){.fleetx-stage{grid-template-columns:1fr}.fleetx-media{order:-1;margin-bottom:1.5rem}}

/* ---------- Home journeys preview ---------- */
.jpreview{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:3rem}
@media(max-width:1024px){.jpreview{grid-template-columns:1fr}}

/* ---------- Interactive destinations map ---------- */
.morii-map{position:relative;border:1px solid var(--line);overflow:hidden;background:#0b1f17}
.morii-map svg{display:block;width:100%;height:auto}
.morii-map text{paint-order:stroke;stroke:#06140d;stroke-width:3px;stroke-linejoin:round}
.morii-map .mlabel{font-family:var(--sans);font-size:13px;letter-spacing:.18em;text-transform:uppercase;fill:var(--bone)}
.morii-map .msub{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;fill:#d7e2da}
.morii-map .mlabel--rsg{font-size:16px;fill:var(--gold-2);letter-spacing:.16em}

/* ---------- Page intro (interior heroes) ---------- */
.page-intro{padding:13rem 0 0}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .jgrid,.cards-3,.pillgrid{grid-template-columns:repeat(2,1fr)}
  .pathway{grid-template-columns:repeat(2,1fr)}
  .post.lg,.post.md,.post.sm{grid-column:span 12}
  .detail-meta{grid-template-columns:repeat(2,1fr)}
  .detail-meta div{border-left:0;padding-left:0}
}
@media(max-width:760px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .split,.feature,.feature--rev,.formwrap{grid-template-columns:1fr}
  .split--rev .split-media{order:0}
  .feature--rev .feature-media{order:0}
  .feature-media{min-height:60vh}
  .cards-2,.cards-3,.cards-4,.jgrid,.pillgrid,.tiers,.philos{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .radio-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .detail-meta{grid-template-columns:1fr 1fr}
  .wrap{padding:0 6vw}
}
