/* ============================================================
   SaltAIr — shared stylesheet
   Light theme, Fraunces + Inter Tight, dune-blue + seafoam accents
   ============================================================ */
:root{
  --paper:#ffffff;
  --salt:rgba(168,208,227,.08);
  --sand:rgba(168,208,227,.18);

  --ink:#0a1628;
  --ink-soft:rgba(10,22,40,.72);
  --ink-faint:rgba(10,22,40,.58);
  --hero-ink:#0a2540;

  --dune:#86afc4;
  --dune-bright:#a8d0e3;
  --dune-deep:#3a6781;
  --sea:#1c4a73;

  --seafoam:#4fd1a5;
  --seafoam-deep:#1a7a5c;

  --gold:#e8b547;
  --gold-deep:#8a6510;
  --gold-bright:#f6d27a;

  --signal:#ff6b35;
  --signal-text:#b8421e;
  /* accent pop (was coral; now teal-emerald — keeps the brand palette tight: navy + green + gold) */
  --coral:#0e8f7a;
  --coral-soft:#5cc7b6;

  --sky-high:#c9e4f5;
  --sky-mid:#7ab8dd;

  --line:rgba(10,22,40,.08);
  --line-2:rgba(10,22,40,.14);

  --serif:'Fraunces',ui-serif,Georgia,serif;
  --sans:'Inter Tight',ui-sans-serif,system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01","cv11","liga","calt"}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
em{font-style:italic}
::selection{background:var(--dune-bright);color:var(--ink)}

.wrap{max-width:1320px;margin:0 auto;padding:0 40px}
@media(max-width:720px){.wrap{padding:0 22px}}

/* type */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:600;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--dune-deep)}
.eyebrow .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--seafoam);box-shadow:0 0 0 4px rgba(79,209,165,.2)}
.eyebrow-line{display:inline-flex;align-items:center;gap:14px;font-family:var(--sans);font-weight:600;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--dune-deep)}
.eyebrow-line::before{content:"";width:28px;height:1px;background:currentColor;opacity:.5}
.pill{display:inline-flex;align-items:center;height:24px;padding:0 11px;border:1px solid rgba(232,181,71,.5);border-radius:999px;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);background:linear-gradient(135deg, rgba(232,181,71,.18), rgba(246,210,122,.08));font-weight:700;box-shadow:0 1px 0 rgba(255,255,255,.5) inset}

h1.display{font-family:var(--serif);font-weight:300;font-size:clamp(36px,5.5vw,80px);line-height:.95;letter-spacing:-.028em;margin:0;text-wrap:balance;color:var(--hero-ink);text-shadow:0 1px 0 rgba(255,255,255,.4)}
h1.display em{color:var(--dune-deep);font-style:italic;font-weight:300;position:relative}
h1.display .uline{position:relative;display:inline-block}
h1.display .uline::after{content:"";position:absolute;left:2%;right:2%;bottom:-.04em;height:.08em;background:linear-gradient(90deg,var(--gold) 0%, var(--coral) 100%);border-radius:999px;transform-origin:left center;transform:scaleX(0);animation:drawline 1.1s cubic-bezier(.65,0,.35,1) .9s forwards}
@keyframes drawline{to{transform:scaleX(1)}}
h2.section{font-family:var(--serif);font-weight:300;font-size:clamp(40px,5.5vw,80px);line-height:1.02;letter-spacing:-.022em;margin:0;text-wrap:balance;color:var(--ink)}
h2.section em{color:var(--dune-deep);font-style:italic;font-weight:300}
.lede{font-size:clamp(17px,1.3vw,19px);line-height:1.6;color:var(--ink-soft);max-width:60ch}
.lede strong{color:var(--ink);font-weight:600}

/* nav */
.nav{position:fixed;inset:0 0 auto 0;z-index:50;backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);background:rgba(244,241,234,.85);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:84px}
.logo{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-size:28px;letter-spacing:-.01em;font-weight:400;color:var(--hero-ink)}
.logo .ic{width:38px;height:42px;flex:none}
.logo em{font-style:italic;font-weight:300;color:var(--dune-deep)}

/* SaltAIr wordmark — per BRAND.md
   Structure: Salt (navy) + A (dune) + custom SVG I (dune double-bar) + r (navy).
   The capital I is intentionally NOT the Fraunces native glyph. */
.wordmark{
  font-family:var(--serif);
  font-weight:300;
  font-style:normal;
  font-optical-sizing:auto;
  font-variation-settings:"opsz" 144;
  letter-spacing:-.015em;
  line-height:1;
  display:inline-flex;
  align-items:baseline;
  white-space:nowrap;
}
.wordmark .wm-salt,.wordmark .wm-r{color:#0a1628}
.wordmark .wm-a{color:#86afc4}
.wordmark .wm-i{
  height:.70em;            /* match Fraunces cap-height */
  width:auto;
  margin:0 .02em;
  fill:#86afc4;
  align-self:baseline;
  transform:translateY(.02em);
  display:inline-block;
  overflow:visible;
}
.nav-links{display:flex;gap:36px;font-size:16.5px;color:var(--ink-soft);align-items:center;font-weight:500}
.nav .btn{font-size:15px;padding:14px 24px;gap:10px}
.nav-links a{transition:color .2s;position:relative;padding:6px 0}
.nav-links a:hover{color:var(--hero-ink)}
.nav-links a.active{color:var(--hero-ink);font-weight:600}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--dune-deep);border-radius:2px}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-toggle{display:none;width:38px;height:38px;border-radius:10px;border:1px solid var(--line-2);background:#fff;align-items:center;justify-content:center}
.nav-toggle svg{width:18px;height:18px}
@media(max-width:980px){
  .nav-links{display:none;position:absolute;left:0;right:0;top:84px;background:rgba(244,241,234,.98);backdrop-filter:blur(14px);flex-direction:column;align-items:stretch;padding:18px 40px 28px;gap:0;border-bottom:1px solid var(--line);box-shadow:0 24px 36px -24px rgba(28,74,115,.18)}
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 0;border-top:1px solid var(--line);font-size:16px}
  .nav-links a:first-child{border-top:0}
  .nav-links a.active::after{display:none}
  .nav-toggle{display:inline-flex}
  .nav-cta .btn-ghost{display:none}
}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.005em;transition:transform .15s ease, background .2s, color .2s, border-color .2s, box-shadow .2s;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--hero-ink);color:#fff;box-shadow:0 8px 18px -8px rgba(10,22,40,.4)}
.btn-primary:hover{background:var(--sea);box-shadow:0 12px 24px -8px rgba(28,74,115,.45)}
.btn-ghost{border:1px solid var(--line-2);color:var(--ink);background:rgba(255,255,255,.7)}
.btn-ghost:hover{background:#fff;border-color:var(--dune-deep)}
.btn-sm{padding:10px 16px;font-size:13px}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(3px)}

/* hero (home) */
.hero{position:relative;min-height:48vh;overflow:hidden;padding:108px 0 24px;background:linear-gradient(180deg,var(--sky-high) 0%, var(--sky-mid) 55%, rgba(201,228,245,.5) 88%, #ffffff 100%)}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:24px;background:linear-gradient(180deg, transparent, #ffffff);pointer-events:none;z-index:2}
.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-bg::before{content:"";position:absolute;top:-8%;right:-6%;width:60%;height:70%;background:radial-gradient(circle at 70% 30%, rgba(255,250,230,.9) 0%, rgba(255,235,180,.5) 18%, rgba(255,220,150,.14) 38%, transparent 60%);filter:blur(4px);animation:sunPulse 6s ease-in-out infinite alternate}
@keyframes sunPulse{0%{opacity:.85;transform:scale(1)}100%{opacity:1;transform:scale(1.06)}}
.cursor-light{position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(420px circle at var(--mx, 50%) var(--my, 35%), rgba(255,235,180,.55), rgba(255,220,150,.25) 24%, transparent 60%);mix-blend-mode:screen;opacity:0;transition:opacity .6s ease}
.hero:hover .cursor-light{opacity:1}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 480px 80px at 18% 22%, rgba(255,255,255,.9), rgba(255,255,255,0) 70%),
    radial-gradient(ellipse 360px 60px at 78% 16%, rgba(255,255,255,.78), rgba(255,255,255,0) 70%),
    radial-gradient(ellipse 520px 70px at 42% 30%, rgba(255,255,255,.6), rgba(255,255,255,0) 70%),
    radial-gradient(ellipse 280px 50px at 88% 36%, rgba(255,255,255,.55), rgba(255,255,255,0) 70%),
    radial-gradient(ellipse 600px 90px at 28% 54%, rgba(255,255,255,.4), rgba(255,255,255,0) 70%);
  filter:blur(2px);
  animation:drift 60s ease-in-out infinite alternate;
}
@keyframes drift{0%{transform:translateX(0) translateY(0)}100%{transform:translateX(-30px) translateY(-8px)}}
.hero-horizon{position:absolute;left:0;right:0;bottom:14%;height:1px;background:linear-gradient(90deg,transparent 0%, rgba(255,255,255,.35) 20%, rgba(255,255,255,.6) 50%, rgba(255,255,255,.35) 80%, transparent 100%);z-index:1;pointer-events:none}
.hero-reflection{position:absolute;bottom:0;right:18%;width:14%;height:14%;background:linear-gradient(180deg, rgba(255,235,180,.55) 0%, rgba(255,220,150,.3) 30%, rgba(255,200,120,.12) 60%, transparent 100%);filter:blur(8px);z-index:1;pointer-events:none;transform:skewX(-2deg)}

.hero-boat{position:absolute;left:30%;bottom:14.2%;width:30px;height:28px;z-index:2;opacity:.42;pointer-events:none}
.hero-boat-2{position:absolute;left:64%;bottom:14.4%;width:22px;height:20px;z-index:2;opacity:.32;pointer-events:none}
.hero-boat-sail{position:absolute;bottom:13.6%;width:46px;height:42px;z-index:2;pointer-events:none;animation:sailAcross 38s linear infinite}
.hero-boat-sail svg{animation:bob 4s ease-in-out infinite}
@keyframes sailAcross{0%{left:-6%;opacity:0}5%{opacity:.55}50%{opacity:.7}95%{opacity:.55}100%{left:106%;opacity:0}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}
.hero-boat svg, .hero-boat-2 svg{animation:bob 6s ease-in-out infinite}
.hero-boat-2 svg{animation-duration:8s;animation-delay:-1.5s}

/* gull flock */
.gull-flock{position:absolute;top:14%;left:0;width:100%;height:80px;z-index:2;pointer-events:none}
.gull-flock svg{position:absolute;animation:flock 36s linear infinite}
.gull-flock svg:nth-child(1){left:-10%;top:0;animation-delay:0s}
.gull-flock svg:nth-child(2){left:-10%;top:18px;animation-delay:-3s;transform:scale(.8)}
.gull-flock svg:nth-child(3){left:-10%;top:32px;animation-delay:-6s;transform:scale(.7)}
.gull-flock svg:nth-child(4){left:-10%;top:14px;animation-delay:-19s;transform:scale(.9)}
.gull-flock svg:nth-child(5){left:-10%;top:40px;animation-delay:-22s;transform:scale(.75)}
@keyframes flock{0%{transform:translateX(0) translateY(0)}25%{transform:translateX(30vw) translateY(-12px)}50%{transform:translateX(60vw) translateY(6px)}75%{transform:translateX(90vw) translateY(-8px)}100%{transform:translateX(120vw) translateY(0)}}

.hero-inner{position:relative;z-index:3;display:grid;grid-template-columns:1fr 420px;gap:56px;align-items:start}
@media(max-width:1080px){.hero-inner{grid-template-columns:1fr}}

.hero-headline{margin-top:12px}
.hero-headline .l1,.hero-headline .l2{display:block}

.hero-meta{margin-top:18px;display:grid;grid-template-columns:1fr;gap:14px;max-width:680px}
.hero-meta .lede{color:var(--hero-ink);opacity:.85;font-size:17px}
.hero-meta .lede strong{color:var(--hero-ink);font-weight:600}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.hero-trust{margin-top:10px;display:flex;gap:32px;flex-wrap:wrap;font-size:18px;font-weight:700;letter-spacing:-.005em;color:var(--hero-ink);opacity:1}
.hero-trust span{display:inline-flex;align-items:center;gap:10px}
.hero-trust span::before{content:"✓";color:var(--seafoam-deep);font-weight:800;font-size:18px}

.fit-ticket{position:relative;align-self:start;margin-top:38px;border-radius:20px;padding:22px;background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.88) 100%);border:1px solid rgba(26,122,92,.3);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 18px 40px -18px rgba(28,74,115,.4);transition:transform .25s, box-shadow .25s;cursor:pointer;color:var(--ink);display:block}
.fit-ticket:hover{transform:translateY(-2px);box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 24px 50px -18px rgba(28,74,115,.55)}
.fit-ticket .ft-eye{display:inline-flex;align-items:center;gap:8px;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--seafoam-deep);font-weight:700;margin-bottom:10px}
.fit-ticket .ft-eye .pip{width:6px;height:6px;border-radius:50%;background:var(--seafoam-deep)}
.fit-ticket h4{font-family:var(--serif);font-size:22px;line-height:1.1;margin:0 0 6px;color:var(--hero-ink);font-weight:400;letter-spacing:-.01em}
.fit-ticket h4 em{color:var(--dune-deep);font-style:italic;font-weight:300}
.fit-ticket p{font-size:13.5px;line-height:1.5;color:var(--ink-soft);margin:0}
.fit-ticket .ft-cta{color:var(--dune-deep);font-weight:600;white-space:nowrap;font-size:13px}

.scroll-ind, .scroll-ind::before, .scroll-ind::after{display:none !important}

/* sub-page hero (shorter) */
.page-hero{position:relative;padding:114px 0 36px;background:linear-gradient(180deg,var(--sky-high) 0%, var(--sky-mid) 70%, rgba(201,228,245,.6) 95%, #ffffff 100%);overflow:hidden}
.page-hero .hero-bg::before{content:"";position:absolute;top:-8%;right:-6%;width:60%;height:70%;background:radial-gradient(circle at 70% 30%, rgba(255,250,230,.9) 0%, rgba(255,235,180,.5) 18%, rgba(255,220,150,.14) 38%, transparent 60%);filter:blur(4px)}
.page-hero .hero-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 480px 80px at 18% 22%, rgba(255,255,255,.85), rgba(255,255,255,0) 70%),radial-gradient(ellipse 360px 60px at 78% 16%, rgba(255,255,255,.7), rgba(255,255,255,0) 70%),radial-gradient(ellipse 520px 70px at 42% 30%, rgba(255,255,255,.55), rgba(255,255,255,0) 70%);filter:blur(2px);animation:drift 60s ease-in-out infinite alternate}
.page-hero-inner{position:relative;z-index:3;max-width:1100px}
.page-hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(36px,5vw,72px);line-height:1.02;letter-spacing:-.022em;margin:14px 0 14px;color:var(--hero-ink);text-shadow:0 1px 0 rgba(255,255,255,.4)}
.page-hero h1 em{color:var(--dune-deep);font-style:italic;font-weight:300}
.page-hero .sub{font-size:clamp(15px,1.2vw,18px);line-height:1.5;color:var(--hero-ink);opacity:.85;max-width:54ch}
.page-hero .sub strong{color:var(--hero-ink);font-weight:600}

50%{transform:translateX(-50%) translateY(8px);opacity:.2}100%{transform:translateX(-50%) translateY(0);opacity:1}}

/* position strip */
.position{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:36px 0;position:relative;z-index:2}
.position-inner{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center}
@media(max-width:720px){.position-inner{grid-template-columns:1fr;gap:14px}}
.position .lbl{font-family:var(--sans);font-weight:700;font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-faint);padding:6px 12px;border:1px solid var(--line-2);border-radius:999px;justify-self:start;background:var(--salt)}
.position p{font-family:var(--serif);font-size:clamp(26px,3.2vw,46px);line-height:1.15;letter-spacing:-.012em;margin:0;color:var(--ink);text-wrap:balance;font-weight:400}
.position p .strike{position:relative;color:var(--ink-faint)}
.position p .strike::after{content:"";position:absolute;left:-4px;right:-4px;top:54%;height:2px;background:var(--signal);transform:rotate(-1.5deg)}
.position p em{color:var(--dune-deep);font-style:italic;font-weight:400}

/* sections */
section{position:relative}
.sect{padding:64px 0;border-top:1px solid var(--line)}
.sect-paper{background:var(--paper)}
.sect-salt{background:var(--salt)}
.sect-sand{background:var(--sand)}
.sect-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:36px}
.sect-head .sub{justify-self:end;max-width:46ch;color:var(--ink-soft);font-size:16px;line-height:1.6}
.sect-head .sub strong{color:var(--ink);font-weight:600}
@media(max-width:900px){.sect-head{grid-template-columns:1fr;gap:20px}.sect-head .sub{justify-self:start}}
.sect-eyebrow{margin-bottom:22px;display:block}

/* ownership */
.ownership-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:start}
@media(max-width:1000px){.ownership-grid{grid-template-columns:1fr;gap:48px}}
.own-list{list-style:none;padding:0;margin:36px 0 0;border-top:1px solid var(--line-2)}
.own-row{display:grid;grid-template-columns:170px 1fr auto;gap:28px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line);transition:padding .25s, background .25s}
.own-row:hover{padding-left:12px;padding-right:12px;background:var(--salt)}
.own-row:hover .lbl{color:var(--dune-deep)}
.own-row .lbl{font-family:var(--sans);font-weight:600;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);transition:color .25s}
.own-row .text{font-family:var(--serif);font-size:clamp(20px,1.8vw,26px);line-height:1.25;color:var(--ink);font-weight:400;letter-spacing:-.015em}
.own-row .text em{color:var(--dune-deep);font-style:italic;font-weight:400}
.own-row .tag{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--seafoam-deep);font-weight:700;padding:6px 12px;border:1px solid rgba(79,209,165,.32);border-radius:999px;white-space:nowrap;background:rgba(79,209,165,.1)}
@media(max-width:720px){.own-row{grid-template-columns:1fr;gap:8px;padding:20px 0}.own-row .tag{justify-self:start}}

.vessel{position:sticky;top:100px;background:linear-gradient(180deg, rgba(168,208,227,.14) 0%, rgba(255,255,255,.96) 100%);border:1px solid rgba(90,138,163,.2);border-radius:20px;padding:28px;box-shadow:inset 0 1px 0 rgba(255,255,255,.95), 0 16px 32px -16px rgba(28,74,115,.18);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.vessel-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:20px}
.vessel-head .title{font-family:var(--serif);font-weight:500;font-size:16px;color:var(--ink)}
.vessel-head .live{display:inline-flex;align-items:center;gap:8px;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--seafoam-deep);font-weight:700}
.vessel-head .live .pip{width:7px;height:7px;border-radius:50%;background:var(--seafoam);box-shadow:0 0 0 4px rgba(79,209,165,.22);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.7}50%{opacity:1}}
.vessel-svg{width:100%;height:200px;margin-bottom:16px}
.vessel-stack{display:flex;flex-direction:column;gap:8px}
.vessel-layer{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:rgba(168,208,227,.1);border:1px solid var(--line);border-radius:10px;font-size:13px}
.vessel-layer .nm{color:var(--ink);font-weight:500;display:flex;align-items:center;gap:10px}
.vessel-layer .nm::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--seafoam)}
.vessel-layer .ow{color:var(--seafoam-deep);font-size:10.5px;text-transform:uppercase;letter-spacing:.16em;font-weight:700}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:980px){.pillars{grid-template-columns:1fr}}
.pillar{position:relative;background:#fff;border:1px solid var(--line-2);border-radius:22px;padding:28px;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s, border-color .3s, box-shadow .3s;box-shadow:0 1px 0 var(--line)}
.pillar:hover{transform:translateY(-4px);border-color:rgba(90,138,163,.3);box-shadow:0 22px 44px -22px rgba(28,74,115,.28)}
.pillar::before{content:"";position:absolute;left:0;top:0;width:80px;height:2px;background:var(--dune-deep)}
.pillar-num{display:flex;justify-content:space-between;align-items:center}
.pillar-num .n{font-family:var(--serif);font-size:52px;color:var(--dune-deep);line-height:1;font-weight:300;letter-spacing:-.02em}
.pillar-num .badge{font-family:var(--sans);font-weight:700;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);padding:6px 10px;border:1px solid var(--line-2);border-radius:999px;background:var(--salt)}
.pillar h3{font-family:var(--serif);font-weight:300;font-size:34px;line-height:1.02;letter-spacing:-.022em;margin:18px 0 12px;color:var(--ink)}
.pillar h3 em{color:var(--dune-deep);font-style:italic;font-weight:300}
.pillar p{color:var(--ink-soft);font-size:14px;line-height:1.55;margin:0 0 18px;flex:1}
.pillar-detail{border-top:1px solid var(--line);padding-top:4px}
.pillar-detail .row{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--line);font-size:13px}
.pillar-detail .row:last-child{border-bottom:0}
.pillar-detail .row span:first-child{color:var(--ink-faint);font-weight:500}
.pillar-detail .row span:last-child{color:var(--ink);font-weight:600}

/* stats */
.stats{background:linear-gradient(135deg, rgba(168,208,227,.16), rgba(168,208,227,.05));border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 200% at 50% 100%, rgba(168,208,227,.25), transparent 60%);pointer-events:none}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
@media(max-width:880px){.stats-grid{grid-template-columns:1fr 1fr}}
.stat-cell{padding:48px 24px;border-right:1px solid var(--line);position:relative}
.stat-cell:last-child{border-right:0}
@media(max-width:880px){
  .stat-cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .stat-cell:nth-child(2n){border-right:0}
  .stat-cell:nth-last-child(-n+2){border-bottom:0}
}
.stat-cell .num{font-family:var(--serif);font-size:clamp(56px,6.5vw,100px);line-height:.9;color:var(--ink);font-weight:300;display:flex;align-items:baseline;gap:4px;letter-spacing:-.04em}
.stat-cell .num em{color:var(--dune-deep);font-style:italic;font-weight:300}
.stat-cell .num sup{font-size:.45em;color:var(--dune-deep);font-weight:300;vertical-align:super;letter-spacing:0}
.stat-cell .num .unit{font-size:.32em;color:var(--ink-soft);margin-left:6px;letter-spacing:-.02em;font-style:normal}
.stat-cell .desc{font-size:13.5px;line-height:1.5;color:var(--ink-soft);margin-top:14px;max-width:32ch}

/* crew */
.crew{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1px solid var(--line-2);border-radius:22px;overflow:hidden;background:#fff;box-shadow:0 18px 36px -18px rgba(28,74,115,.18)}
@media(max-width:1100px){.crew{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.crew{grid-template-columns:1fr}}
.crew-card{padding:30px;border-right:1px solid var(--line);position:relative;display:flex;flex-direction:column;min-height:380px;transition:background .25s}
.crew-card:last-child{border-right:0}
.crew-card:hover{background:var(--salt)}
@media(max-width:1100px){
  .crew-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .crew-card:nth-child(2n){border-right:0}
}
.crew-num{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.22em;color:var(--dune-deep);margin-bottom:24px}
.crew-icon{width:46px;height:46px;display:grid;place-items:center;color:var(--dune-deep);margin-bottom:18px;background:rgba(168,208,227,.18);border-radius:12px}
.crew-card h3{font-family:var(--serif);font-size:30px;line-height:1.02;letter-spacing:-.015em;margin:0 0 4px;color:var(--ink);font-weight:400}
.crew-card .role{font-family:var(--sans);font-weight:600;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--seafoam-deep);margin-bottom:16px}
.crew-card p{font-size:13.5px;line-height:1.55;color:var(--ink-soft);margin:0;flex:1}

/* expanded crew profile (crew page) */
.crew-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:820px){.crew-grid{grid-template-columns:1fr}}
.crew-tile{background:#fff;border:1px solid var(--line-2);border-radius:20px;padding:30px;box-shadow:0 1px 0 var(--line);transition:transform .3s, border-color .3s, box-shadow .3s;display:flex;flex-direction:column}
.crew-tile:hover{transform:translateY(-3px);border-color:rgba(90,138,163,.3);box-shadow:0 20px 40px -22px rgba(28,74,115,.25)}
.crew-tile .role{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--seafoam-deep);display:block;margin-bottom:8px}
.crew-tile h3{font-family:var(--serif);font-size:40px;line-height:.98;letter-spacing:-.022em;margin:0 0 12px;color:var(--ink);font-weight:400}
.crew-tile .tagline{font-family:var(--serif);font-size:18px;line-height:1.32;color:var(--ink);font-style:italic;font-weight:400;letter-spacing:-.01em;margin:0 0 16px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.crew-tile p{font-size:14.5px;line-height:1.6;color:var(--ink-soft);margin:0 0 12px}
.crew-tile p:last-child{margin:0}
.crew-tile em{color:var(--dune-deep);font-style:italic;font-weight:500}
.crew-tile-wide{grid-column:1/-1}
@media(max-width:820px){.crew-tile-wide{grid-column:auto}}

/* keep legacy class as no-op fallback */
.crew-profile{display:none}

/* workflow */
.workflow{display:flex;flex-direction:column;gap:0}
.wf-step{display:grid;grid-template-columns:120px 1fr 1.8fr;gap:40px;padding:36px 0;border-bottom:1px solid var(--line);align-items:start}
.wf-step:last-child{border-bottom:0}
@media(max-width:980px){.wf-step{grid-template-columns:1fr;gap:18px}}
.wf-num{font-family:var(--serif);font-size:64px;line-height:.9;color:var(--dune-deep);font-weight:300;letter-spacing:-.04em}
.wf-num small{display:block;font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);font-weight:700;margin-top:6px}
.wf-step h3{font-family:var(--serif);font-size:30px;line-height:1.05;letter-spacing:-.018em;margin:0 0 10px;color:var(--ink);font-weight:400}
.wf-step h3 em{color:var(--dune-deep);font-style:italic;font-weight:300}
.wf-step .short{font-size:15px;line-height:1.55;color:var(--ink-soft);margin:0}
.wf-detail{display:grid;grid-template-columns:1fr;gap:0}
.wf-detail .row{display:grid;grid-template-columns:140px 1fr;gap:18px;padding:12px 0;border-top:1px solid var(--line)}
.wf-detail .row:first-child{border-top:0;padding-top:0}
.wf-detail .row .k{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--dune-deep);padding-top:4px}
.wf-detail .row .v{font-size:14px;line-height:1.55;color:var(--ink)}
.wf-detail code{font-family:'Inter Tight',monospace;font-size:.92em;color:var(--dune-deep);background:rgba(168,208,227,.18);padding:1px 7px;border-radius:4px;font-weight:600}
.checkpoint{display:inline-flex;align-items:center;gap:8px;margin-top:14px;padding:7px 14px;background:rgba(79,209,165,.12);border:1px solid rgba(79,209,165,.3);border-radius:999px;color:var(--seafoam-deep);font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:700}
.checkpoint .pip{width:6px;height:6px;border-radius:50%;background:var(--seafoam);animation:pulse 2s ease-in-out infinite}
@media(max-width:980px){.wf-detail .row{grid-template-columns:1fr;gap:6px;padding:12px 0}}

/* comparison */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:880px){.compare{grid-template-columns:1fr}}
.col{border-radius:22px;padding:36px;position:relative;background:#fff;border:1px solid var(--line-2);box-shadow:0 1px 0 var(--line)}
.col.good{background:linear-gradient(180deg, rgba(79,209,165,.08), rgba(79,209,165,.02));border-color:rgba(79,209,165,.3)}
.col h4{font-family:var(--serif);font-size:30px;line-height:1.05;margin:0 0 24px;display:flex;justify-content:space-between;align-items:baseline;gap:18px;color:var(--ink);font-weight:400;letter-spacing:-.015em}
.col h4 .tag{font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--ink-faint);padding:5px 10px;border:1px solid var(--line-2);border-radius:999px;background:var(--salt)}
.col.good h4 .tag{color:var(--seafoam-deep);border-color:rgba(79,209,165,.4);background:rgba(79,209,165,.1)}
.col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:13px}
.col ul li{display:grid;grid-template-columns:20px 1fr;gap:12px;font-size:14.5px;line-height:1.5;color:var(--ink-soft);align-items:flex-start}
.col.bad ul li::before{content:"×";font-family:var(--serif);font-size:22px;color:var(--signal);line-height:1;padding-top:0;font-weight:600}
.col.good ul li::before{content:"✓";color:var(--seafoam-deep);font-weight:700;font-size:14px;padding-top:2px}
.col.good ul li{color:var(--ink)}

/* audience */
.audience{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:1100px){.audience{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.audience{grid-template-columns:1fr}}
.aud{position:relative;background:#fff;border:1px solid var(--line-2);border-radius:20px;padding:26px;display:flex;flex-direction:column;transition:transform .3s, border-color .3s, box-shadow .3s;min-height:240px;box-shadow:0 1px 0 var(--line)}
.aud:hover{transform:translateY(-4px);border-color:rgba(90,138,163,.3);box-shadow:0 22px 44px -22px rgba(28,74,115,.28)}
.aud .ord{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--seafoam-deep)}
.aud h3{font-family:var(--serif);font-size:26px;line-height:1.1;letter-spacing:-.015em;margin:16px 0 10px;color:var(--ink);font-weight:400;text-wrap:balance}
.aud p{font-size:14px;line-height:1.55;color:var(--ink-soft);margin:0 0 22px;flex:1}
.aud .cta{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--dune-deep);font-weight:600;align-self:flex-start;transition:transform .2s}
.aud:hover .cta{transform:translateX(4px);color:var(--sea)}

/* persona grid (teams page) — also used inside .stepper */
.persona-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:820px){.persona-grid{grid-template-columns:1fr}}
.stepper .persona-tile{flex:0 0 min(380px, 86vw);scroll-snap-align:start}
.persona-tile{background:#fff;border:1px solid var(--line-2);border-radius:20px;padding:28px;display:flex;flex-direction:column;box-shadow:0 1px 0 var(--line);transition:transform .3s, border-color .3s, box-shadow .3s}
.persona-tile:hover{transform:translateY(-3px);border-color:rgba(90,138,163,.3);box-shadow:0 20px 40px -22px rgba(28,74,115,.25)}
.persona-tile .who{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--seafoam-deep);margin-bottom:8px;display:block}
.persona-tile h3{font-family:var(--serif);font-size:26px;line-height:1.08;letter-spacing:-.018em;margin:0 0 12px;color:var(--ink);font-weight:400;text-wrap:balance}
.persona-tile p{font-size:14.5px;line-height:1.55;color:var(--ink-soft);margin:0 0 14px}
.persona-tile p.fit{color:var(--ink)}
.persona-tile p.fit em{color:var(--dune-deep);font-style:italic}
.persona-tile .pains{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:6px}
.persona-tile .pains li{position:relative;padding-left:18px;font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.persona-tile .pains li::before{content:"—";position:absolute;left:0;color:var(--dune-deep);font-weight:600}
.persona-tile .pains li em{color:var(--ink);font-style:italic}
.persona-tile .outcome{font-family:var(--serif);font-size:15px;line-height:1.4;color:var(--ink);font-style:italic;border-top:1px dashed var(--line-2);padding-top:14px;margin:auto 0 0}

/* legacy persona block - hide */
.persona, .persona-body{display:none}

/* about */
.about-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
@media(max-width:980px){.about-inner{grid-template-columns:1fr;gap:32px}}
.about-q{font-family:var(--serif);font-size:clamp(36px,4.5vw,64px);line-height:1.05;letter-spacing:-.022em;color:var(--ink);font-weight:300;margin:8px 0 0}
.about-q em{color:var(--dune-deep);font-style:italic;font-weight:300}
.about-body{font-size:16px;line-height:1.7;color:var(--ink-soft)}
.about-body p{margin:0 0 14px}
.about-body p:last-of-type{margin:0;color:var(--ink)}
.about-body em{color:var(--ink);font-weight:500}
.about-body blockquote{margin:24px 0;padding:20px 24px;border-left:3px solid var(--dune-deep);font-family:var(--serif);font-size:22px;line-height:1.32;color:var(--ink);font-style:italic;font-weight:400;background:var(--salt);border-radius:0 12px 12px 0}
.about-sig{margin-top:20px;display:flex;align-items:center;gap:16px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;font-style:italic}
.about-sig .l{width:40px;height:1px;background:var(--line-2)}

/* tour cards (home) */
.tour{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.tour{grid-template-columns:1fr}}
.tour-card{display:block;background:#fff;border:1px solid var(--line-2);border-radius:20px;padding:26px;box-shadow:0 1px 0 var(--line);transition:transform .3s, border-color .3s, box-shadow .3s}
.tour-card:hover{transform:translateY(-4px);border-color:rgba(90,138,163,.3);box-shadow:0 22px 44px -22px rgba(28,74,115,.28)}
.tour-card .eye{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--dune-deep);margin-bottom:12px;display:block}
.tour-card h3{font-family:var(--serif);font-size:26px;line-height:1.08;letter-spacing:-.015em;margin:0 0 10px;color:var(--ink);font-weight:400;text-wrap:balance}
.tour-card h3 em{color:var(--dune-deep);font-style:italic;font-weight:300}
.tour-card p{font-size:14px;line-height:1.5;color:var(--ink-soft);margin:0 0 16px}
.tour-card .cta{font-size:13.5px;color:var(--dune-deep);font-weight:600;display:inline-flex;align-items:center;gap:8px}
.tour-card .cta .arr{transition:transform .2s}
.tour-card:hover .cta .arr{transform:translateX(4px)}

/* contact form */
.contact-form{background:#fff;border:1px solid var(--line-2);border-radius:22px;padding:36px;box-shadow:0 18px 36px -18px rgba(28,74,115,.18);display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:720px){.contact-form{grid-template-columns:1fr;padding:24px}}
.contact-form .field{display:flex;flex-direction:column;gap:8px}
.contact-form .field.full{grid-column:1/-1}
.contact-form label{font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--dune-deep)}
.contact-form input, .contact-form textarea, .contact-form select{font-family:var(--sans);font-size:15px;padding:12px 14px;border:1px solid var(--line-2);border-radius:10px;background:#fff;color:var(--ink);transition:border-color .2s, box-shadow .2s}
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus{outline:none;border-color:var(--dune-deep);box-shadow:0 0 0 3px rgba(58,103,129,.16)}
.contact-form textarea{min-height:140px;resize:vertical;font-family:var(--sans)}
.contact-form .hp{position:absolute;left:-9999px}
.contact-form .submit{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:10px;padding-top:18px;border-top:1px solid var(--line)}
.contact-form .submit .note{font-size:12.5px;color:var(--ink-faint)}

/* final CTA */
.final{padding:64px 0 56px;text-align:center;position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%, var(--sky-high) 100%);border-top:1px solid var(--line)}
.final::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:700px;height:700px;background:radial-gradient(circle, rgba(255,250,230,.7), rgba(255,235,180,.25) 30%, transparent 60%);pointer-events:none;filter:blur(4px)}
.final h2{font-family:var(--serif);font-size:clamp(34px,4.5vw,64px);line-height:.98;letter-spacing:-.028em;margin:14px 0 14px;font-weight:300;color:var(--hero-ink)}
.final h2 em{font-style:italic;color:var(--dune-deep);font-weight:300}
.final .lede{margin:0 auto 28px;text-align:center;color:var(--hero-ink);opacity:.85;font-size:17px}
.final .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final-inner{position:relative;z-index:2}

/* footer */
footer{padding:56px 0 32px;border-top:1px solid var(--line);background:#f4f1ea;color:var(--ink)}
.foot{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:48px}
@media(max-width:880px){.foot{grid-template-columns:1fr 1fr;gap:32px}}
.foot h5{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 16px;font-weight:700}
.foot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px}
.foot ul a{color:var(--ink-soft);transition:color .2s}
.foot ul a:hover{color:var(--dune-deep)}
.foot p.tag{font-family:var(--serif);font-size:20px;line-height:1.35;margin:14px 0 0;max-width:24ch;color:var(--ink);font-style:italic;font-weight:400}
.foot p.tag em{color:var(--dune-deep)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:60px;padding-top:24px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink-faint);flex-wrap:wrap;gap:16px}
.foot-bottom .ml{display:flex;gap:24px;flex-wrap:wrap}

/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .hero-bg::after{animation:none}
}


/* === EXCITEMENT PACK === */

/* typing PRD card */
.prd-card{align-self:start;background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.88));border:1px solid rgba(58,103,129,.22);border-radius:18px;padding:0;box-shadow:0 18px 40px -18px rgba(28,74,115,.35), inset 0 1px 0 rgba(255,255,255,.9);overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.prd-card .prd-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line);background:rgba(168,208,227,.12)}
.prd-card .prd-bar .dot{width:10px;height:10px;border-radius:50%}
.prd-card .prd-bar .dot.r{background:#ff7a59}
.prd-card .prd-bar .dot.y{background:#e8b547}
.prd-card .prd-bar .dot.g{background:#4fd1a5}
.prd-card .prd-bar .label{margin-left:8px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.prd-card .prd-bar .live{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--seafoam-deep);font-weight:700}
.prd-card .prd-bar .live .pip{width:6px;height:6px;border-radius:50%;background:var(--seafoam);animation:pulse 1.4s ease-in-out infinite;box-shadow:0 0 0 3px rgba(79,209,165,.25)}
.prd-card .prd-body{padding:18px 18px 16px;min-height:220px;font-size:14px;line-height:1.5;color:var(--ink)}
.prd-line{display:block;padding:5px 0}
.prd-line .k{display:inline-block;min-width:62px;font-family:var(--sans);font-weight:700;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--dune-deep);margin-right:8px;vertical-align:middle}
.prd-line .v{color:var(--ink)}
.prd-line.you .k{color:var(--coral)}
.prd-line.salt .k{color:var(--seafoam-deep)}
.prd-line .v em{color:var(--dune-deep);font-style:italic}
.prd-cursor{display:inline-block;width:8px;height:14px;background:var(--dune-deep);vertical-align:-2px;margin-left:2px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.prd-card .prd-foot{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-top:1px solid var(--line);background:rgba(168,208,227,.06);font-size:11px;color:var(--ink-faint);font-weight:500;letter-spacing:.04em}
.prd-card .prd-foot .ok{color:var(--seafoam-deep);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:10.5px}

/* marquee strip */
.why-anchor{position:relative;height:0;scroll-margin-top:80px}
#why{scroll-margin-top:96px}
.marquee{background:linear-gradient(90deg, var(--hero-ink) 0%, var(--sea) 50%, var(--hero-ink) 100%);color:#fff;padding:18px 0;overflow:hidden;position:relative;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee-track{display:flex;gap:36px;animation:marquee 32s linear infinite;width:max-content;font-family:var(--serif);font-size:clamp(20px,2.4vw,32px);font-weight:300;letter-spacing:-.005em;align-items:center;white-space:nowrap}
.marquee-track .dot{width:8px;height:8px;border-radius:50%;background:var(--coral);flex:none;display:inline-block}
.marquee-track em{color:var(--gold-bright);font-style:italic}
.marquee-track .light{color:rgba(255,255,255,.65)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* voyage section */
.voyage{position:relative;padding:40px 0 64px;overflow:hidden;background:linear-gradient(180deg, #ffffff 0%, var(--sky-high) 100%);border-top:1px solid var(--line)}
.voyage::after{content:"";position:absolute;left:0;right:0;bottom:0;height:34%;background:linear-gradient(180deg, transparent, rgba(28,74,115,.06));pointer-events:none}
.voyage .v-head{text-align:center;margin-bottom:24px;position:relative;z-index:2}
.voyage h2{margin:8px auto 0;max-width:18ch}
.voyage .v-sub{margin:16px auto 0;max-width:54ch;color:var(--hero-ink);opacity:.85;font-size:17px;line-height:1.55}
.voyage-chart{position:relative;max-width:1500px;margin:36px auto 0;height:880px}
.voyage-chart svg.route{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none}
.voyage-route{fill:none;stroke:var(--dune-deep);stroke-width:2.5;stroke-dasharray:6 8;stroke-linecap:round;opacity:.4}
.voyage-route-fill{fill:none;stroke:url(#voyage-grad);stroke-width:6;stroke-linecap:round;stroke-dasharray:2200;stroke-dashoffset:2200;filter:drop-shadow(0 6px 14px rgba(232,181,71,.45))}
.voyage-chart.in .voyage-route-fill{animation:drawRoute 5s cubic-bezier(.6,0,.35,1) forwards}
@keyframes drawRoute{to{stroke-dashoffset:0}}
.voyage-boat{position:absolute;top:0;left:0;width:120px;height:120px;transform:translate(-50%,-50%);offset-path:path("M 60 640 C 250 530, 400 500, 600 440 S 950 380, 1110 280 S 1320 130, 1380 60");offset-rotate:0deg;opacity:0;z-index:3;filter:drop-shadow(0 10px 18px rgba(28,74,115,.4))}
.voyage-chart.in .voyage-boat{animation:sailBoat 5s cubic-bezier(.6,0,.35,1) forwards}
@keyframes sailBoat{0%{offset-distance:0%;opacity:0}5%{opacity:1}95%{opacity:1}100%{offset-distance:100%;opacity:0}}
.voyage-stop{position:absolute;transform:translate(-50%,-50%);text-align:center;color:var(--hero-ink);z-index:2;max-width:170px}
.voyage-stop .pin{width:36px;height:36px;border-radius:50%;background:#fff;border:4px solid var(--dune-deep);margin:0 auto 18px;box-shadow:0 10px 20px -6px rgba(28,74,115,.5)}
.voyage-stop.start .pin{border-color:var(--coral);background:var(--coral)}
.voyage-stop.end .pin{background:var(--gold);border-color:var(--gold-deep);width:46px;height:46px;animation:pulseBig 2s ease-in-out infinite}
@keyframes pulseBig{0%,100%{box-shadow:0 0 0 0 rgba(232,181,71,.6)}50%{box-shadow:0 0 0 14px rgba(232,181,71,0)}}
.voyage-stop .num{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);margin-bottom:8px}
.voyage-stop .ttl{font-family:var(--serif);font-size:40px;line-height:1.02;letter-spacing:-.022em;font-weight:400;color:var(--ink)}
.voyage-stop .ttl em{color:var(--dune-deep);font-style:italic}
.voyage-stop p{font-size:16px;line-height:1.45;color:var(--ink-soft);margin:10px 0 0;max-width:240px}
@media(max-width:880px){
  .voyage-chart{height:auto;display:flex;flex-direction:column;gap:18px;margin-top:24px;padding:0 8px}
  .voyage-chart svg.route, .voyage-boat{display:none}
  .voyage-stop{position:relative;top:auto !important;left:auto !important;transform:none;text-align:left;display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;max-width:100%}
  .voyage-stop .pin{margin:6px 0 0;flex:none}
}

/* wave divider */
.wave-divider{position:relative;height:60px;margin-top:-1px;pointer-events:none;line-height:0}
.wave-divider svg{width:100%;height:100%;display:block}
.wave-divider.flip svg{transform:scaleY(-1)}

/* 3d tilt */
.tilt{transform-style:preserve-3d;transform:perspective(900px) rotateX(var(--tx,0deg)) rotateY(var(--ty,0deg));transition:transform .2s ease-out, box-shadow .25s ease-out, border-color .25s}
.tilt:hover{box-shadow:0 30px 50px -22px rgba(28,74,115,.35);border-color:rgba(58,103,129,.4)}

/* color pops */
.pillar::before{background:linear-gradient(90deg, var(--coral), var(--gold));height:3px;width:96px}
.tour-card .eye{color:var(--coral)}
.crew-tile .role{color:var(--coral)}
.persona-tile .who{color:var(--coral)}
.eyebrow{color:var(--coral)}
.eyebrow .dot{background:var(--coral);box-shadow:0 0 0 4px rgba(255,122,89,.2)}
.position p .strike::after{background:var(--coral)}
.checkpoint{background:rgba(232,181,71,.14);border-color:rgba(232,181,71,.4);color:var(--gold-deep)}
.checkpoint .pip{background:var(--gold);box-shadow:0 0 0 3px rgba(232,181,71,.22)}


/* === HORIZONTAL STEPPER (How It Works) === */
.stepper-frame{position:relative;margin-top:24px}
.stepper{display:flex;gap:18px;overflow-x:auto;overflow-y:visible;scroll-snap-type:x mandatory;padding:8px 8px 28px 8px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.stepper::-webkit-scrollbar{height:6px}
.stepper::-webkit-scrollbar-track{background:transparent}
.stepper::-webkit-scrollbar-thumb{background:rgba(58,103,129,.25);border-radius:3px}
.step-card{flex:0 0 min(440px, 86vw);scroll-snap-align:start;background:#fff;border:1px solid var(--line-2);border-radius:20px;padding:28px;display:flex;flex-direction:column;box-shadow:0 1px 0 var(--line), 0 18px 36px -22px rgba(28,74,115,.18);transition:transform .25s, box-shadow .25s, border-color .25s}
.step-card:hover{transform:translateY(-3px);border-color:rgba(90,138,163,.32)}
.step-card .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;border-bottom:1px solid var(--line);padding-bottom:14px}
.step-card .num{font-family:var(--serif);font-size:52px;line-height:.85;color:var(--dune-deep);font-weight:300;letter-spacing:-.04em}
.step-card .verb{font-family:var(--sans);font-weight:700;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);padding:6px 12px;border:1px solid rgba(255,122,89,.3);border-radius:999px;background:rgba(255,122,89,.08)}
.step-card h3{font-family:var(--serif);font-size:28px;line-height:1.05;letter-spacing:-.018em;margin:0 0 8px;color:var(--ink);font-weight:400}
.step-card h3 em{color:var(--dune-deep);font-style:italic;font-weight:300}
.step-card .short{font-size:14px;line-height:1.5;color:var(--ink-soft);margin:0 0 16px}
.step-card .rows{border-top:1px dashed var(--line-2);padding-top:14px;display:flex;flex-direction:column;gap:10px}
.step-card .rows .row{display:grid;grid-template-columns:1fr;gap:4px}
.step-card .rows .row .k{font-family:var(--sans);font-weight:700;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--dune-deep)}
.step-card .rows .row .v{font-size:13.5px;line-height:1.5;color:var(--ink)}
.step-card .rows .row .v em{color:var(--dune-deep);font-style:italic}
.step-card .rows code{font-family:var(--sans);font-size:.92em;color:var(--dune-deep);background:rgba(168,208,227,.18);padding:1px 7px;border-radius:4px;font-weight:600}
.step-card .checkpoint{margin-top:16px;align-self:flex-start}

.stepper-nav{display:flex;justify-content:center;align-items:center;margin-top:14px;gap:18px}
.stepper-nav .dots{display:flex;gap:8px;justify-content:center}
.stepper-nav .dots span{width:8px;height:8px;border-radius:50%;background:var(--line-2);transition:background .25s, width .25s}
.stepper-nav .dots span.on{background:var(--dune-deep);width:24px;border-radius:4px}
.stepper-nav button{width:48px;height:48px;border-radius:50%;background:var(--hero-ink);border:0;display:grid;place-items:center;color:#fff;box-shadow:0 10px 22px -8px rgba(28,74,115,.5);transition:transform .15s, background .2s}
.stepper-nav button:hover{transform:translateY(-2px) scale(1.06);background:var(--sea)}
.stepper-nav button:disabled{opacity:.3;cursor:not-allowed;transform:none;background:var(--ink-faint)}
.stepper-nav button svg{width:22px;height:22px;stroke-width:2.4}

.peek-hint{position:relative;text-align:center;padding:12px 0 28px;font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-faint);pointer-events:none}
.peek-hint::after{content:"";display:block;width:1px;height:18px;margin:8px auto 0;background:linear-gradient(180deg,var(--ink-faint),transparent)}

/* === ABOUT 2-COL === */
.about-cols{column-count:2;column-gap:48px;font-size:15px;line-height:1.65;color:var(--ink-soft)}
@media(max-width:760px){.about-cols{column-count:1}}
.about-cols p{margin:0 0 14px;break-inside:avoid}
.about-cols p:last-child{margin:0;color:var(--ink)}
.about-cols em{color:var(--ink);font-weight:500}
.about-cols blockquote{break-inside:avoid;margin:18px 0;padding:18px 22px;border-left:3px solid var(--dune-deep);font-family:var(--serif);font-size:20px;line-height:1.32;color:var(--ink);font-style:italic;font-weight:400;background:var(--salt);border-radius:0 12px 12px 0}


/* === Fit card (auto-cycling persona preview in hero) === */
.fit-card{position:relative;align-self:start;display:block;background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.92));border:1px solid rgba(14,143,122,.4);border-radius:22px;padding:0;box-shadow:0 30px 60px -22px rgba(14,143,122,.45), 0 0 0 6px rgba(14,143,122,.08), inset 0 1px 0 rgba(255,255,255,.95);overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s;color:var(--ink);animation:fitFloat 5s ease-in-out infinite}
@keyframes fitFloat{0%,100%{transform:translateY(0) rotate(-.4deg)}50%{transform:translateY(-6px) rotate(.4deg)}}
.fit-card:hover{transform:translateY(-6px) scale(1.02) rotate(0deg) !important;animation-play-state:paused;box-shadow:0 40px 80px -24px rgba(14,143,122,.6), 0 0 0 8px rgba(14,143,122,.14), inset 0 1px 0 rgba(255,255,255,1)}
.fit-card::before{content:"";position:absolute;inset:-2px;border-radius:22px;background:conic-gradient(from 0deg, transparent 0deg, rgba(14,143,122,.6) 90deg, transparent 180deg, rgba(232,181,71,.5) 270deg, transparent 360deg);opacity:.35;animation:fitGlow 8s linear infinite;pointer-events:none;z-index:-1}
@keyframes fitGlow{to{transform:rotate(360deg)}}
.fit-card .fc-head{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;border-bottom:1px solid var(--line);background:linear-gradient(135deg, rgba(14,143,122,.12), rgba(232,181,71,.08))}
.fit-card .fc-eye{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:800;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--coral)}
.fit-card .fc-eye .pip{width:9px;height:9px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 5px rgba(14,143,122,.22);animation:pulse 1.8s ease-in-out infinite}
.fit-card .fc-cycle{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);background:rgba(14,143,122,.08);padding:4px 10px;border-radius:999px}
.fit-card .fc-stage{position:relative;padding:26px 24px 22px;min-height:240px;overflow:hidden}
.fit-slide{position:absolute;inset:26px 24px 22px 24px;display:flex;flex-direction:column;gap:12px;opacity:0;transform:translateY(10px);transition:opacity .6s ease, transform .6s ease;pointer-events:none}
.fit-slide.on{opacity:1;transform:translateY(0)}
.fit-slide .who{font-family:var(--sans);font-weight:800;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);display:inline-flex;align-items:center;gap:8px}
.fit-slide .who::before{content:"";width:18px;height:1px;background:var(--coral)}
.fit-slide h4{font-family:var(--serif);font-size:30px;line-height:1.04;letter-spacing:-.022em;margin:2px 0 4px;color:var(--ink);font-weight:400;text-wrap:balance}
.fit-slide h4 em{color:var(--dune-deep);font-style:italic;font-weight:300}
.fit-slide p{font-size:15px;line-height:1.5;color:var(--ink-soft);margin:auto 0 0}
.fit-card .fc-foot{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;border-top:1px solid var(--line);background:linear-gradient(135deg, rgba(14,143,122,.06), rgba(232,181,71,.04))}
.fit-card .fc-dots{display:flex;gap:6px}
.fit-card .fc-dots span{width:7px;height:7px;border-radius:50%;background:var(--line-2);transition:background .25s, width .25s}
.fit-card .fc-dots span.on{background:var(--coral);width:22px;border-radius:4px}
.fit-card .fc-cta{font-family:var(--sans);font-weight:700;font-size:14px;color:var(--coral);white-space:nowrap;transition:transform .2s;display:inline-flex;align-items:center;gap:6px}
.fit-card:hover .fc-cta{transform:translateX(4px)}
@media(max-width:1080px){
  .fit-card{margin-top:32px;animation:none;transform:none}
  .fit-card .fc-stage{min-height:200px}
}


/* === Read-more link on persona tiles + story modal === */
.persona-tile .story-link{margin-top:auto;padding-top:14px;display:inline-flex;align-items:center;gap:8px;color:var(--coral);font-family:var(--sans);font-weight:700;font-size:13.5px;letter-spacing:.02em;cursor:pointer;transition:transform .2s, color .2s;align-self:flex-start}
.persona-tile .story-link:hover{transform:translateX(4px);color:var(--seafoam-deep)}
.persona-tile .story-link .arr{transition:transform .2s}

.story-modal{border:0;padding:0;background:transparent;max-width:880px;width:92vw;max-height:88vh;border-radius:24px;box-shadow:0 30px 80px -20px rgba(10,22,40,.5);margin:auto}
.story-modal::backdrop{background:rgba(10,22,40,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.story-modal-inner{background:#fff;border-radius:24px;padding:40px 44px 36px;max-height:88vh;overflow-y:auto;position:relative}
.story-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:12px;background:rgba(10,22,40,.05);color:var(--ink);border:0;display:grid;place-items:center;cursor:pointer;transition:background .2s, transform .15s;z-index:2}
.story-close:hover{background:rgba(10,22,40,.12);transform:scale(1.05)}
.story-meta{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:22px;flex-wrap:wrap}
.story-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:800;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--coral)}
.story-eyebrow .pip{width:8px;height:8px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px rgba(14,143,122,.2)}
.story-outcome{font-family:var(--sans);font-weight:700;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--seafoam-deep);background:rgba(79,209,165,.12);border:1px solid rgba(79,209,165,.3);padding:6px 12px;border-radius:999px;white-space:nowrap;max-width:60%;text-align:right}
.story-title{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.6vw,46px);line-height:1.02;letter-spacing:-.022em;color:var(--ink);margin:0 0 12px;text-wrap:balance}
.story-title em{color:var(--dune-deep);font-style:italic;font-weight:300}
.story-sub{font-family:var(--serif);font-style:italic;font-size:18px;line-height:1.35;color:var(--ink-soft);margin:0 0 24px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.story-body{font-size:15.5px;line-height:1.65;color:var(--ink-soft)}
.story-body p{margin:0 0 14px}
.story-body p em{color:var(--ink);font-weight:500;font-style:italic}
.story-body h4{font-family:var(--sans);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--dune-deep);margin:22px 0 10px;font-weight:700}
.story-foot{display:flex;justify-content:flex-start;align-items:center;gap:12px;margin-top:28px;padding-top:20px;border-top:1px solid var(--line);flex-wrap:wrap}
.story-foot .story-close-bot{padding:14px 22px;border-radius:999px;background:transparent;border:1px solid var(--line-2);color:var(--ink);font-weight:600;cursor:pointer;font-size:14px;transition:background .2s, border-color .2s}
.story-foot .story-close-bot:hover{background:rgba(10,22,40,.05);border-color:var(--dune-deep)}
@media(max-width:640px){
  .story-modal{width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0}
  .story-modal-inner{border-radius:0;padding:32px 22px;max-height:100vh}
  .story-outcome{max-width:none;text-align:left}
}

/* WHY SALTAIR */
.why-cards{display:flex;flex-direction:column;gap:16px;margin-bottom:48px}
.why-card{background:#fff;border:1px solid var(--line-2);border-radius:22px;padding:28px 32px;box-shadow:0 1px 0 var(--line);transition:transform .3s, border-color .3s, box-shadow .3s}
.why-card:hover{transform:translateY(-2px);border-color:rgba(90,138,163,.3);box-shadow:0 22px 44px -22px rgba(28,74,115,.2)}
.why-card h3{font-family:var(--serif);font-weight:600;font-size:26px;line-height:1.15;letter-spacing:-.015em;margin:0 0 12px;color:var(--ink)}
.why-card h3 em{color:var(--dune-deep);font-style:italic;font-weight:600}
.why-card p{color:var(--ink-soft);font-size:15.5px;line-height:1.6;margin:0}
.why-card--highlight{background:linear-gradient(180deg, rgba(168,208,227,.18), rgba(168,208,227,.05));border-color:rgba(58,103,129,.3)}
.why-card--highlight h3{color:var(--sea)}
.why-card--highlight h3 em{color:var(--dune-deep)}
.why-card--highlight p{color:var(--ink)}
.why-contrast{text-align:center;font-family:var(--sans);font-size:16px;line-height:1.6;color:var(--ink-soft);margin:0 0 40px;max-width:60ch;margin-left:auto;margin-right:auto}
.why-crew{text-align:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 16px;margin-bottom:36px}
.why-crew p{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.4vw,40px);line-height:1.15;letter-spacing:-.018em;margin:0;color:var(--ink)}
.why-crew p em{color:var(--dune-deep);font-style:italic;font-weight:300}
.why-closer{text-align:center;font-family:var(--serif);font-weight:400;font-size:clamp(22px,2.4vw,30px);line-height:1.2;letter-spacing:-.015em;color:var(--ink);margin:0}
@media(max-width:760px){
  .why-card{padding:24px 22px}
  .why-card h3{font-size:22px}
}
