/* Kamana — shared styles. Warm editorial luxury. Native scroll, no jank. */
:root{
  --sand:oklch(0.962 0.012 83); --sand-2:oklch(0.944 0.016 80); --paper:oklch(0.985 0.008 85);
  --ink:oklch(0.255 0.024 56); --ink-soft:oklch(0.392 0.028 58); --faint:oklch(0.560 0.030 60);
  --brass:oklch(0.760 0.108 78); --brass-deep:oklch(0.640 0.112 70); --brass-ink:oklch(0.470 0.090 70);
  --glow-apricot:oklch(0.840 0.120 64); --glow-rose:oklch(0.770 0.130 28);
  --indigo:oklch(0.255 0.060 276); --indigo-2:oklch(0.205 0.055 276);
  --on-dark:oklch(0.962 0.014 84); --on-dark-soft:oklch(0.800 0.020 80);
  --line:oklch(0.880 0.012 80); --line-dark:oklch(0.380 0.040 276);
  --max:1240px; --pad:clamp(1.25rem, 0.6rem + 3vw, 4.5rem); --radius:5px;
  --ease:cubic-bezier(0.16,1,0.3,1);
  --s--1:clamp(0.82rem, 0.79rem + 0.15vw, 0.92rem);
  --s-0:clamp(1rem, 0.96rem + 0.22vw, 1.14rem);
  --s-1:clamp(1.2rem, 1.07rem + 0.5vw, 1.5rem);
  --s-2:clamp(1.62rem, 1.3rem + 1.4vw, 2.5rem);
  --s-3:clamp(2.1rem, 1.55rem + 2.6vw, 3.7rem);
  --s-4:clamp(2.5rem, 1.7rem + 3.9vw, 5.1rem);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--sand);color:var(--ink);font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-size:var(--s-0);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.serif{font-family:"Fraunces",Georgia,serif;font-optical-sizing:auto;font-weight:380;
  line-height:1.05;letter-spacing:-0.015em;text-wrap:balance}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin-inline:auto;padding-inline:var(--pad)}
.narrow{max-width:760px}
.eyebrow{font-family:"Hanken Grotesk";text-transform:uppercase;letter-spacing:0.24em;
  font-size:var(--s--1);font-weight:600;color:var(--brass-ink)}
.lede{font-size:var(--s-1);color:var(--ink-soft);line-height:1.55;max-width:56ch}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--sand);padding:10px 16px;z-index:300;border-radius:0 0 6px 0}
.skip:focus{left:0}
.center{text-align:center}.center .lede{margin-inline:auto}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:"Hanken Grotesk";font-weight:600;
  font-size:var(--s--1);letter-spacing:.02em;padding:.95em 1.6em;border-radius:var(--radius);
  border:1px solid transparent;cursor:pointer;transition:background .25s,color .25s,border-color .25s}
.btn--solid{background:var(--ink);color:var(--sand)}
.btn--solid:hover{background:var(--brass-deep)}
.btn--ghost{border-color:var(--ink);color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--sand)}
.btn--light{border-color:var(--on-dark-soft);color:var(--on-dark)}
.btn--light:hover{background:var(--on-dark);color:var(--indigo)}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* nav (solid on scroll, no blur) */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:17px var(--pad);transition:transform .4s var(--ease),background .3s,border-color .3s,padding .3s;
  border-bottom:1px solid transparent}
.nav.is-stuck{background:var(--sand);border-bottom-color:var(--line);padding-top:12px;padding-bottom:12px}
.nav.is-hidden{transform:translateY(-105%)}
.brand{display:flex;align-items:center;gap:11px;font-family:"Fraunces";font-weight:420;font-size:1.45rem;letter-spacing:-.01em;color:var(--ink)}
.brand svg{width:26px;height:27px;flex:none}
.nav-links{display:flex;align-items:center;gap:clamp(14px,1.8vw,28px)}
.nav-links a.link{font-size:var(--s--1);font-weight:500;color:var(--ink-soft);position:relative;padding:4px 0;transition:color .2s}
.nav-links a.link::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--brass);transition:right .3s var(--ease)}
.nav-links a.link:hover,.nav-links a.link[aria-current="page"]{color:var(--ink)}
.nav-links a.link:hover::after,.nav-links a.link[aria-current="page"]::after{right:0}
.nav-cta{margin-left:6px}
.nav-toggle{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:20px;height:1.6px;background:var(--ink)}
.nav-drawer{display:none}

/* hero (home) — content fully visible, ridgeline as a band behind */
.hero{position:relative;min-height:90vh;min-height:90svh;display:flex;align-items:center;
  padding:140px var(--pad) 210px;overflow:hidden}
.hero__ridge{position:absolute;left:0;right:0;bottom:0;height:230px;z-index:0;pointer-events:none}
.hero__ridge svg{width:100%;height:100%}
.hero__inner{position:relative;z-index:2;max-width:var(--max);margin-inline:auto;width:100%}
.hero h1{font-size:var(--s-4);font-weight:360;max-width:17ch}
.hero__sub{margin-top:1.6rem;max-width:46ch;font-size:var(--s-1);color:var(--ink-soft);line-height:1.5}
.hero__cta{margin-top:2.1rem;display:flex;gap:14px;flex-wrap:wrap}

/* page hero (subpages) */
.phero{position:relative;padding:170px var(--pad) clamp(3rem,6vw,5.5rem);background:var(--sand-2);border-bottom:1px solid var(--line)}
.phero__inner{max-width:var(--max);margin-inline:auto}
.phero .eyebrow{margin-bottom:1rem}
.phero h1{font-size:var(--s-3);max-width:18ch}
.phero p{margin-top:1.2rem;max-width:52ch;font-size:var(--s-1);color:var(--ink-soft);line-height:1.5}

/* sections */
section{position:relative}
.band{padding-block:clamp(4rem, 2.5rem + 7vw, 8.5rem)}
.band--tight{padding-block:clamp(3rem, 2rem + 5vw, 6rem)}
.sec-head{max-width:60ch}
.sec-head h2{font-size:var(--s-3);margin-top:.7rem}
.sec-head p{margin-top:1rem}

/* feature quote (the line Joel wants up top) */
.feature{background:var(--sand-2)}
.feature .q{max-width:26ch;margin-inline:auto;text-align:center}
.feature .q p{font-family:"Fraunces";font-style:italic;font-size:var(--s-3);line-height:1.18;color:var(--ink);font-weight:360}
.feature .q .hr{width:46px;height:2px;background:var(--brass);margin:0 auto 1.8rem}
.feature .q cite{display:block;margin-top:1.4rem;font-style:normal;font-family:"Hanken Grotesk";letter-spacing:.22em;text-transform:uppercase;font-size:var(--s--1);color:var(--brass-ink)}

/* founder */
.founder .grid{display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.founder__media .frame{aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:linear-gradient(150deg,var(--glow-apricot),var(--glow-rose))}
.founder__media img{width:100%;height:100%;object-fit:cover}
.founder h2{font-size:var(--s-3);margin:.6rem 0 1.3rem}
.founder p+p{margin-top:1.1rem}
.facts{margin-top:2rem;border-top:1px solid var(--line)}
.facts div{display:flex;justify-content:space-between;gap:1rem;padding:.85rem 0;border-bottom:1px solid var(--line);font-size:var(--s--1)}
.facts dt{color:var(--faint);text-transform:uppercase;letter-spacing:.16em;font-weight:600}
.facts dd{font-family:"Fraunces";font-style:italic;color:var(--ink);font-size:var(--s-0)}
.sign{font-family:"Fraunces";font-style:italic;font-size:var(--s-1);color:var(--brass-ink);margin-top:1.6rem}

/* pillars index */
.pillars .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,2.6rem);margin-top:3rem}
.pindex{display:block}
.pindex .num{font-family:"Fraunces";font-size:var(--s-2);color:var(--brass)}
.pindex h3{font-size:var(--s-1);margin:.5rem 0 .6rem}
.pindex p{color:var(--ink-soft);font-size:var(--s--1);max-width:32ch}
.pindex .peek{margin-top:1.2rem;aspect-ratio:5/3.4;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--sand-2)}
.pindex .peek img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.pindex:hover .peek img{transform:scale(1.05)}
.pindex .more{margin-top:1rem;font-size:var(--s--1);font-weight:600;color:var(--brass-ink);display:inline-flex;align-items:center;gap:.4em}
.pindex:hover .more .arr{transform:translateX(4px)}
.more .arr{transition:transform .25s var(--ease)}

/* spreads (service detail) */
.spread .grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.spread.rev .grid{direction:rtl}.spread.rev .grid>*{direction:ltr}
.spread__media{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3.05;background:var(--sand-2)}
.spread__media img{width:100%;height:100%;object-fit:cover}
.marker{font-family:"Fraunces";color:var(--brass);font-size:var(--s-1);display:flex;align-items:baseline;gap:.6rem}
.marker .rn{font-size:var(--s-2)}
.spread h2{font-size:var(--s-3);margin:.5rem 0 1.2rem}
.spread .lede{margin-bottom:1.6rem}
.tlist{list-style:none;margin:0 0 1.9rem;border-top:1px solid var(--line)}
.tlist li{padding:.7rem 0;border-bottom:1px solid var(--line);font-size:var(--s--1);color:var(--ink-soft);display:flex;align-items:center;gap:.7rem}
.tlist li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--brass);flex:none}

/* offer cards (subpage detail) */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:clamp(1.2rem,2.5vw,2rem);margin-top:3rem}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.card__img{aspect-ratio:3/2;overflow:hidden;background:var(--sand-2)}
.card__img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.card:hover .card__img img{transform:scale(1.05)}
.card__body{padding:1.5rem 1.6rem 1.7rem}
.card__body h3{font-size:var(--s-1);margin-bottom:.5rem}
.card__body p{font-size:var(--s--1);color:var(--ink-soft)}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(1.5rem,3vw,3rem);margin-top:3rem}
.step .rn{font-family:"Fraunces";font-size:var(--s-2);color:var(--brass)}
.step h3{font-size:var(--s-1);margin:.5rem 0 .5rem}
.step p{color:var(--ink-soft);font-size:var(--s--1);max-width:30ch}

/* itinerary (heritage) */
.itin{margin-top:3rem;border-top:1px solid var(--line)}
.itin__day{display:grid;grid-template-columns:140px 1fr;gap:clamp(1rem,3vw,3rem);padding:1.6rem 0;border-bottom:1px solid var(--line)}
.itin__day .d{font-family:"Fraunces";color:var(--brass);font-size:var(--s-1)}
.itin__day h3{font-size:var(--s-1);margin-bottom:.4rem}
.itin__day p{font-size:var(--s--1);color:var(--ink-soft);max-width:60ch}

/* voices (static band, no parallax) */
.voices{position:relative;background:var(--indigo);color:var(--on-dark);overflow:hidden;text-align:center}
.voices__bg{position:absolute;inset:0;z-index:0;opacity:.22}
.voices__bg img{width:100%;height:100%;object-fit:cover}
.voices .wrap{position:relative;z-index:2;max-width:24ch;margin-inline:auto}
.voices blockquote{font-family:"Fraunces";font-style:italic;font-size:var(--s-3);line-height:1.18;font-weight:360}
.voices cite{display:block;margin-top:1.5rem;font-family:"Hanken Grotesk";font-style:normal;letter-spacing:.22em;text-transform:uppercase;font-size:var(--s--1);color:var(--brass)}

/* gallery */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:2.6rem}
.mosaic figure{position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--line);background:var(--sand-2)}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.mosaic figure:hover img{transform:scale(1.05)}
.mosaic figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px;color:#fff;font-size:var(--s--1);
  background:linear-gradient(transparent,rgba(20,16,12,.62));transform:translateY(101%);transition:transform .4s var(--ease)}
.mosaic figure:hover figcaption{transform:translateY(0)}
.m-a{grid-column:span 2;grid-row:span 2}.m-d{grid-column:span 2}

/* enquiry / contact form */
.enquiry{background:var(--sand-2)}
.enquiry .grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(2rem,5vw,5rem)}
.enquiry h2{font-size:var(--s-3);margin:.6rem 0 1.2rem}
.enquiry .direct{margin-top:2rem;font-size:var(--s--1)}
.enquiry .direct a{color:var(--brass-ink);font-weight:600;border-bottom:1px solid var(--line)}
form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
form label{display:block;font-size:var(--s--1);font-weight:600;color:var(--ink-soft);margin-bottom:6px}
form .field{margin-bottom:16px}
form input,form select,form textarea{width:100%;font-family:inherit;font-size:var(--s-0);color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:13px 14px;transition:border-color .2s,box-shadow .2s}
form textarea{min-height:120px;resize:vertical}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px oklch(0.760 0.108 78 / .18)}
form button{margin-top:6px;width:100%;justify-content:center}
.form__thanks{display:none;font-family:"Fraunces";font-style:italic;font-size:var(--s-1);color:var(--brass-ink);padding:1rem 0}
form.is-sent .form__fields{display:none}form.is-sent .form__thanks{display:block}

/* footer */
.foot{background:var(--indigo);color:var(--on-dark-soft);padding-block:clamp(3.5rem,2rem+5vw,6rem)}
.foot a{color:var(--on-dark-soft)}.foot a:hover{color:var(--on-dark)}
.foot__top{display:flex;justify-content:space-between;gap:2.5rem;flex-wrap:wrap;align-items:flex-start}
.foot__brand{display:flex;align-items:center;gap:13px;color:var(--on-dark)}
.foot__brand .wm{font-family:"Fraunces";font-size:1.7rem;font-weight:420}
.foot__ring{width:52px;height:54px;flex:none}
.foot__tag{font-family:"Fraunces";font-style:italic;color:var(--on-dark);font-size:var(--s-1);margin-top:.8rem;max-width:22ch}
.foot__cols{display:flex;gap:clamp(2rem,5vw,4rem);flex-wrap:wrap}
.foot__cols h4{font-size:var(--s--1);text-transform:uppercase;letter-spacing:.2em;color:var(--brass);margin-bottom:1rem;font-weight:600}
.foot__cols a{display:block;padding:5px 0;font-size:var(--s--1)}
.foot__base{margin-top:3.5rem;padding-top:1.6rem;border-top:1px solid var(--line-dark);display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;font-size:var(--s--1)}
.acknowledge{max-width:62ch;color:var(--on-dark-soft);font-size:var(--s--1);line-height:1.6;margin-top:1.4rem}

/* cursor accent (kept — Joel likes it) */
.cursor{position:fixed;top:0;left:0;width:32px;height:32px;border:1px solid var(--brass);border-radius:50%;
  pointer-events:none;z-index:300;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,opacity .25s;opacity:0}
.cursor.is-on{opacity:.85}
.cursor.is-hot{width:50px;height:50px;background:oklch(0.840 0.120 64 / .15);border-color:transparent}

/* reveal (cheap, once; content visible without JS, only hidden under .js) */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
/* footer ring: draws closed on enter, but complete without JS */
.foot__ring .ring,.foot__ring .close{fill:none;stroke:var(--brass);stroke-width:2.4;stroke-linecap:round}
.foot__ring .wish{fill:var(--brass)}
.js .foot__ring .close{stroke-dasharray:118;stroke-dashoffset:118;transition:stroke-dashoffset 1.1s var(--ease)}
.js .foot.in .foot__ring .close{stroke-dashoffset:0}
.js .foot__ring .wish{transform:scale(0);transform-origin:60px 23px;transition:transform .5s var(--ease) .25s}
.js .foot.in .foot__ring .wish{transform:scale(1)}

@media (max-width:900px){
  .founder .grid,.spread .grid,.spread.rev .grid,.enquiry .grid{grid-template-columns:1fr;direction:ltr}
  .pillars .grid{grid-template-columns:1fr}
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}.m-a{grid-column:span 2;grid-row:span 1}
  .founder__media{max-width:440px}
  .itin__day{grid-template-columns:1fr;gap:.4rem}
}
@media (max-width:760px){
  .nav-links .link,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav-drawer{display:block;position:fixed;inset:0;z-index:99;background:var(--sand);transform:translateX(100%);transition:transform .4s var(--ease);padding:88px var(--pad) var(--pad)}
  .nav-drawer.is-open{transform:translateX(0)}
  .nav-drawer a{display:block;font-family:"Fraunces";font-size:var(--s-2);padding:13px 0;border-bottom:1px solid var(--line);color:var(--ink)}
  .nav-drawer .btn{margin-top:22px;display:inline-flex}
  .hero{min-height:auto;padding:130px var(--pad) 180px}
  form .row,.row{grid-template-columns:1fr}
  .foot__top{flex-direction:column}
  .cursor{display:none}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}
