/* VOYAGES — brand system per 220809 Brand Guidelines
   Blue (Pantone 2736C) #2d2b74 · Cream (9043C) #eae8e5 · Grey (9103C) #c8c8c3
   Type: Avenir Next (Nunito Sans fallback) */
:root{
  --blue:#2d2b74; --cream:#eae8e5; --grey:#c8c8c3;
  --ink:var(--blue);
  --dim:rgba(45,43,116,.62);
  --line:rgba(45,43,116,.25);
  --sans:"Avenir Next","Avenir","Nunito Sans","Helvetica Neue",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:var(--sans);font-size:16.5px;line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:3px;transition:opacity .2s}
a:hover{opacity:.65}
img{display:block;max-width:100%}
code{font-size:.82em;color:var(--dim);word-break:break-all}
hr{border:0;border-top:1px solid var(--line);margin:2.6rem 0}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;backdrop-filter:blur(14px);background:rgba(234,232,229,.82);border-bottom:1px solid var(--blue)}
.nav-in{max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:2rem;padding:.7rem 1.5rem}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.b-sym{height:30px}
.b-wm{height:13px}
.nav nav{display:flex;gap:1.4rem;flex:1;flex-wrap:wrap}
.nav nav a{color:var(--dim);font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;text-decoration:none}
.nav nav a.on,.nav nav a:hover{color:var(--blue);opacity:1}
.nav-x{display:flex;gap:1rem}
.nav-x a{color:var(--blue);font-size:.95rem;text-decoration:none}

/* hero */
.hero{position:relative;margin:0;height:100vh;min-height:540px;overflow:hidden}
.hero>img{width:100%;height:100%;object-fit:cover}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 12s ease}
.hero video.go{opacity:1}
.vband{position:relative;margin:0;height:52vh;min-height:280px;overflow:hidden;background:var(--grey)}
.vband>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vband video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 12s ease}
.vband video.go{opacity:1}
.vband::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(45,43,116,.08) 0%,rgba(234,232,229,0) 55%,#eae8e5 100%);pointer-events:none}
.prose.banded{padding-top:1.2rem}
.hero-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(45,43,116,.2) 0%,rgba(45,43,116,.06) 35%,rgba(234,232,229,0) 78%,#eae8e5 100%);pointer-events:none}
.hero-txt{position:absolute;left:0;right:0;top:46%;transform:translateY(-50%);text-align:center;padding:0 1.5rem;display:flex;flex-direction:column;align-items:center;z-index:2}
.h-logo{height:clamp(140px,24vh,230px);filter:drop-shadow(0 2px 18px rgba(45,43,116,.45))}
.hero-txt .tag{text-shadow:0 1px 12px rgba(45,43,116,.5)}
.hero-txt .tag{color:var(--cream);opacity:.92;margin-top:1.1rem;font-size:.82rem;font-weight:700;letter-spacing:.32em;text-transform:uppercase}
.btn{display:inline-block;border:1px solid var(--blue);color:var(--blue);padding:.65rem 1.6rem;font-size:.74rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;transition:all .25s}
.btn:hover{background:var(--blue);color:var(--cream);opacity:1}

/* welcome accordion */
.welcome{max-width:680px;margin:0 auto;padding:4rem 1.5rem 1rem}
.welcome summary{cursor:pointer;list-style:none;font-size:1.12rem;font-weight:600;line-height:1.8;text-align:left;color:var(--ink);transition:opacity .2s;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:1.3rem .2rem}
.welcome summary::-webkit-details-marker{display:none}
.welcome summary::after{content:"";flex:0 0 auto;width:.62rem;height:.62rem;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-25%) rotate(45deg);transition:transform .25s}
.welcome details[open] summary::after{transform:translateY(15%) rotate(225deg)}
.welcome summary:hover{opacity:.7}
.welcome-body{padding-top:2rem}
.welcome-body p{margin-bottom:1.1rem}
.welcome-body .sign{font-style:italic;margin-top:1.6rem}

/* gallery */
.gallery-wrap{max-width:1280px;margin:0 auto;padding:2.5rem 14px 6rem}
.filters{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:center;margin-bottom:2rem;position:sticky;top:3.2rem;z-index:40;background:rgba(234,232,229,.9);backdrop-filter:blur(10px);padding:.8rem 0}
.chip{background:none;border:1px solid var(--line);color:var(--dim);padding:.35rem 1rem;border-radius:99px;font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:all .2s;font-family:var(--sans)}
.chip:hover{border-color:var(--blue);color:var(--blue)}
.chip.on{background:var(--blue);color:var(--cream);border-color:var(--blue)}
.fdiv{width:1px;height:1.2rem;background:var(--line);margin:0 .4rem}
.search{display:inline-flex;align-items:center;gap:.4rem}
.s-btn{display:inline-flex;align-items:center;justify-content:center;padding:.38rem .6rem}
.search input{width:0;opacity:0;padding:.3rem 0;border:none;border-bottom:1px solid var(--line);background:none;color:var(--ink);font-family:var(--sans);font-size:.8rem;letter-spacing:.04em;transition:width .3s ease,opacity .3s ease;outline:none}
.search input::placeholder{color:var(--dim);font-size:.72rem;letter-spacing:.06em}
.search.open input{width:min(290px,58vw);opacity:1}
.search.open .s-btn{background:var(--blue);color:var(--cream);border-color:var(--blue)}
.search input:focus{border-bottom-color:var(--blue)}
.grid{display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap}
.gcol{flex:1;min-width:0;display:flex;flex-direction:column;gap:18px}
.card{display:block;text-decoration:none}
.grid>.card{width:calc(33.33% - 10px)} /* no-JS fallback */
.card img{width:100%;border:1px solid var(--line);transition:opacity .3s}
.card:hover img{opacity:.88}
.card:hover{opacity:1}
.card-cap{padding:.5rem .1rem .9rem;background:var(--cream);display:flex;justify-content:space-between;align-items:baseline;gap:.6rem}
.cap-n{font-weight:700;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;display:flex;flex-direction:column;gap:.15rem}
.cap-note{font-weight:400;font-size:.66rem;letter-spacing:.04em;text-transform:none;color:var(--dim);font-style:italic}
.cap-s{font-size:.66rem;color:var(--dim);letter-spacing:.06em;text-transform:uppercase;text-align:right}

/* work page — single-viewport viewer */
.work{min-height:100vh;box-sizing:border-box;padding:4.4rem clamp(1.5rem,4vw,4rem) 1.3rem;display:flex;flex-direction:column}
.work-stage{flex:1 1 auto;min-height:0;display:flex;align-items:center;gap:clamp(2rem,4vw,4.5rem)}
.work figure{flex:1 1 60%;min-width:0;min-height:0;height:100%;margin:0;padding:0;display:flex;align-items:center;justify-content:center}
.work figure img{max-height:100%;max-width:100%;width:auto;object-fit:contain;border:1px solid var(--blue);box-shadow:0 24px 60px rgba(45,43,116,.18)}
.work-info{flex:0 0 340px;max-width:340px;min-width:0;margin:0;padding:0;display:flex;flex-direction:column;justify-content:center}
.eyebrow{font-size:.66rem;font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--dim)}
.work-title{font-weight:600;font-size:2.1rem;letter-spacing:.02em;margin:.3rem 0 1.4rem}
.row{display:flex;gap:1.5rem;padding:.8rem 0;border-top:1px solid var(--line);font-size:.95rem}
.row:last-of-type{border-bottom:1px solid var(--line)}
.row .k{width:8.5rem;flex-shrink:0;color:var(--dim);font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding-top:.25rem}
.badge{font-size:.64rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:.24rem .75rem;border:1px solid var(--blue)}
.badge.claimed{background:var(--blue);color:var(--cream)}
.badge.reserved{background:var(--grey);color:var(--blue);border-color:var(--grey)}
.badge.available{background:none;color:var(--blue)}
.work-name{font-size:1.35rem;font-weight:400;font-style:italic;color:var(--dim);margin:-1rem 0 1.6rem;line-height:1.4}
.work-info .btn{margin-top:1.6rem}
.pn{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.1rem;padding-top:1.1rem;border-top:1px solid var(--line);font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.pn a{text-decoration:none}
.pn a:nth-child(2){color:var(--dim)}
@media (max-width:820px){
  .work{min-height:0;display:block;padding:4.4rem 1.3rem 1.3rem}
  .work-stage{flex-direction:column;gap:1.3rem;height:auto}
  .work figure{flex:none;height:auto}
  .work figure img{max-height:62vh}
  .work-info{flex:none;max-width:100%;width:100%;justify-content:flex-start}
}

/* prose pages */
.prose{max-width:680px;margin:0 auto;padding:7.5rem 1.5rem 6rem}
.prose h1{font-weight:600;font-size:2.3rem;letter-spacing:.01em;margin-bottom:1.4rem;line-height:1.25}
.prose h2{font-weight:600;font-size:1.4rem;margin:2.6rem 0 .9rem}
.prose h3{font-weight:600;font-size:1.1rem;margin:2rem 0 .6rem}
.prose p{margin-bottom:1.15rem}
.prose ul,.prose ol{margin:0 0 1.15rem 1.4rem}
.prose li{margin-bottom:.55rem}
.prose .lede{font-size:1.25rem;font-weight:600;line-height:1.65}
.prose .dim{color:var(--dim);font-size:.9rem}
.prose blockquote{border-left:2px solid var(--blue);padding:.4rem 0 .4rem 1.4rem;margin:1.8rem 0;font-size:1.18rem;font-weight:600;line-height:1.65}
.fig{margin:2.2rem 0}
.fig img{border:1px solid var(--line);width:100%}
.fig figcaption{font-size:.82rem;color:var(--dim);padding-top:.6rem;line-height:1.6}
.imgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin:1.6rem 0}
.imgrid .fig{margin:0}
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:2rem 0}
.tile{border:1px solid var(--blue);padding:1.5rem}
.tile h3{margin:0 0 .4rem}
.tile p{color:var(--dim);font-size:.88rem;margin:0}

/* about sub-nav */
.subnav{display:flex;flex-wrap:wrap;gap:.4rem 1.5rem;border-bottom:1px solid var(--blue);padding-bottom:.9rem;margin-bottom:2.6rem}
.subnav a{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);text-decoration:none}
.subnav a.on,.subnav a:hover{color:var(--blue);opacity:1}
.csubnav{position:sticky;top:2.9rem;z-index:40;display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem .7rem;background:rgba(234,232,229,.92);backdrop-filter:blur(10px);border-top:1px solid var(--blue);border-bottom:1px solid var(--blue);padding:.85rem 1rem;margin:0 0 2.6rem}
.csubnav a{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);text-decoration:none;padding:.4rem 1rem;border:1px solid var(--line);border-radius:99px;transition:all .2s}
.csubnav a:hover{color:var(--cream);background:var(--blue);border-color:var(--blue);opacity:1}
.prose h2[id]{scroll-margin-top:7rem}
.claim-ctx{border:1px solid var(--blue);background:rgba(45,43,116,.06);padding:.95rem 1.2rem;margin:0 0 1.5rem;font-size:1.02rem;line-height:1.55}

/* footer — inverts to blue per guidelines */
.foot{background:var(--blue);color:var(--cream);text-align:center;padding:4rem 1.5rem 3.5rem;display:flex;flex-direction:column;align-items:center;margin-top:3rem}
.f-logo{height:110px}
.foot p{color:var(--cream);opacity:.85;font-size:.85rem;margin-top:1.4rem}
.foot .dim{opacity:.6;margin-top:.4rem}
.foot a{color:var(--cream)}

@media (max-width:720px){
  .nav nav{gap:.8rem}
  .nav-in{gap:1rem}
  .grid{gap:8px}
  .gcol{gap:12px}
  .grid>.card{width:calc(50% - 4px)}
  .row .k{width:6.5rem}
}
