/* ============================================================
   Andre Kowlessar — The Glow Walk
   Dual-theme gallery. All color via CSS custom properties.
   ============================================================ */

/* ---------- Theme tokens ---------- */
:root{
  --ink:#0e0e10;          /* gallery dark */
  --ink-2:#141417;
  --bone:#f4efe6;         /* warm text on dark */
  --bone-dim:#b8b0a4;
  --amber:#c8923d;        /* primary accent */
  --copper:#9a5b34;
  --line:rgba(244,239,230,.14);
  --card:#161619;
  --glow:rgba(200,146,61,.30);
  --shadow:0 30px 80px rgba(0,0,0,.55);
  --frame:rgba(244,239,230,.10);
  --bg:var(--ink);
  --text:var(--bone);
  --muted:var(--bone-dim);
  --accent:var(--amber);
  --nav-bg:rgba(14,14,16,.62);
  --grain-op:.05;
}
:root[data-theme="light"]{
  --bg:#f5f1e8;           /* warm white cube */
  --ink-2:#ece6da;
  --text:#1c1b19;
  --bone:#1c1b19;
  --muted:#6c6459;
  --accent:#a86a3d;       /* copper */
  --amber:#a86a3d;
  --copper:#8a4f2c;
  --line:rgba(28,27,25,.14);
  --card:#fbf8f1;
  --glow:rgba(168,106,61,.16);
  --shadow:0 24px 60px rgba(60,45,30,.16);
  --frame:rgba(28,27,25,.10);
  --nav-bg:rgba(245,241,232,.7);
  --grain-op:0;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}

body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-weight:400;line-height:1.6;letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  transition:background .6s ease,color .6s ease;
  overflow-x:hidden;
}
/* film grain on dark */
body::after{
  content:"";position:fixed;inset:0;z-index:9;pointer-events:none;
  opacity:var(--grain-op);mix-blend-mode:overlay;transition:opacity .6s ease;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{display:block;max-width:100%}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:400;letter-spacing:-.01em;line-height:1.05;margin:0}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:var(--bg)}

.skip{position:absolute;left:-999px;top:0;background:var(--accent);color:var(--bg);padding:.6rem 1rem;z-index:100}
.skip:focus{left:1rem;top:1rem}

.eyebrow{font-family:"Hanken Grotesk",sans-serif;font-size:.72rem;letter-spacing:.26em;
  text-transform:uppercase;color:var(--accent);margin:0 0 1.1rem;font-weight:600}
.muted{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:"Hanken Grotesk",sans-serif;font-weight:500;font-size:.92rem;letter-spacing:.02em;
  padding:.95rem 1.7rem;border-radius:2rem;border:1px solid transparent;cursor:pointer;
  transition:transform .25s ease,background .25s ease,color .25s ease,border-color .25s ease;white-space:nowrap}
.btn--solid{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.btn--solid:hover{transform:translateY(-2px);background:transparent;color:var(--accent)}
.btn--ghost{background:transparent;color:var(--text);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn--block{width:100%}
.btn--sm{padding:.6rem 1.1rem;font-size:.82rem}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:20;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1.1rem,4vw,3rem);
  background:var(--nav-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .4s ease,padding .4s ease,background .6s ease}
.nav.scrolled{border-color:var(--line)}
.brand{display:flex;align-items:center;gap:.7rem}
.brand__mark{display:grid;place-items:center;width:2.1rem;height:2.1rem;border:1px solid var(--accent);
  color:var(--accent);border-radius:50%;font-family:"Fraunces",serif;font-size:.85rem;letter-spacing:.02em}
.brand__name{font-family:"Fraunces",serif;font-size:1.05rem;letter-spacing:.01em}
.nav__links{display:flex;gap:2rem}
.nav__links a{font-size:.86rem;letter-spacing:.04em;color:var(--muted);position:relative;padding:.2rem 0}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--accent);transition:width .3s ease}
.nav__links a:hover{color:var(--text)}
.nav__links a:hover::after{width:100%}

.theme-toggle{position:relative;width:3.1rem;height:1.7rem;border-radius:1rem;border:1px solid var(--line);
  background:transparent;cursor:pointer;display:flex;align-items:center;padding:0 .25rem;justify-content:space-between}
.theme-toggle__icon{font-size:.75rem;line-height:1;opacity:.45;transition:opacity .3s}
[data-theme="dark"] .theme-toggle__icon--moon{opacity:1;color:var(--accent)}
[data-theme="light"] .theme-toggle__icon--sun{opacity:1;color:var(--accent)}
.theme-toggle::after{content:"";position:absolute;top:50%;width:1.15rem;height:1.15rem;border-radius:50%;
  background:var(--accent);transform:translateY(-50%);transition:left .3s ease;left:.2rem}
[data-theme="light"] .theme-toggle::after{left:calc(100% - 1.35rem)}
.theme-toggle--text{width:auto;height:auto;border:none;color:var(--muted);font:inherit;font-size:.82rem;padding:0}
.theme-toggle--text::after{display:none}
.theme-toggle--text:hover{color:var(--accent)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  padding:7rem clamp(1.2rem,5vw,5rem) 4rem;overflow:hidden}
.hero__glow{position:absolute;inset:0;z-index:0;
  background:radial-gradient(60% 55% at 72% 42%,var(--glow),transparent 70%)}
.hero__disc{position:absolute;right:-4%;top:50%;transform:translateY(-50%);
  width:min(50vw,620px);z-index:1;opacity:.92;
  filter:drop-shadow(0 0 80px rgba(200,146,61,.35));
  animation:floaty 9s ease-in-out infinite}
[data-theme="light"] .hero__disc{filter:drop-shadow(0 30px 60px rgba(120,80,40,.3))}
@keyframes floaty{0%,100%{transform:translateY(-50%)}50%{transform:translateY(-54%)}}
.hero__inner{position:relative;z-index:2;max-width:min(600px,46vw)}
.hero__title{font-size:clamp(3.2rem,9vw,7.5rem);font-weight:300;letter-spacing:-.03em;margin:.2rem 0 1.4rem}
.hero__sub{font-size:clamp(1.05rem,2.2vw,1.4rem);max-width:30ch;color:var(--text);margin:0 0 2.2rem}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap}
.scrollcue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:3;
  width:26px;height:42px;border:1px solid var(--line);border-radius:14px;display:grid;place-items:center}
.scrollcue span{width:3px;height:8px;border-radius:2px;background:var(--accent);animation:cue 1.6s ease-in-out infinite}
@keyframes cue{0%{transform:translateY(-6px);opacity:0}40%{opacity:1}100%{transform:translateY(8px);opacity:0}}

/* ---------- Section rhythm ---------- */
section{position:relative}
.story,.collection,.process,.inquire,.step{padding:clamp(4.5rem,10vw,9rem) clamp(1.2rem,5vw,5rem)}
.collection__head,.process__head,.inquire__intro{max-width:720px;margin:0 auto clamp(2.5rem,5vw,4rem);text-align:center}
.collection__head h2,.process__head h2,.inquire__intro h2{font-size:clamp(2.4rem,6vw,4.2rem)}
.collection__lede{color:var(--muted);font-size:1.1rem;max-width:48ch;margin:1rem auto 0}

/* ---------- Story ---------- */
.story{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;max-width:1300px;margin:0 auto}
.story__media{border-radius:6px;overflow:hidden;box-shadow:var(--shadow)}
.story__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.story__text h2{font-size:clamp(2rem,4.4vw,3.4rem);margin:.4rem 0 1.4rem;font-weight:300}
.story__text p{color:var(--muted);font-size:1.08rem;margin:0 0 1.1rem;max-width:46ch}
.story__sign{font-family:"Fraunces",serif;font-style:italic;color:var(--text)!important}

/* ---------- Vertical collection (Horizons) ---------- */
.vgrid{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:clamp(3rem,7vw,7rem)}
.vcard{cursor:pointer;display:grid;gap:1rem}
.vcard:nth-child(odd){grid-template-columns:minmax(0,1fr) minmax(0,.42fr);align-items:end}
.vcard:nth-child(even){grid-template-columns:minmax(0,.42fr) minmax(0,1fr);align-items:end}
.vcard:nth-child(even) .vcard__meta{order:-1;text-align:right}
.vcard__frame{overflow:hidden;border-radius:4px;background:var(--ink-2);
  box-shadow:var(--shadow);border:1px solid var(--frame)}
.vcard__frame img{width:100%;height:auto;transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.vcard:hover .vcard__frame img{transform:scale(1.04)}
.vcard__meta{padding-bottom:.4rem}
.vcard__title{font-family:"Fraunces",serif;font-size:1.5rem;font-style:italic}
.vcard__medium{color:var(--muted);font-size:.86rem;margin-top:.3rem}
.vcard__view{color:var(--accent);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin-top:.7rem;opacity:0;transition:opacity .3s}
.vcard:hover .vcard__view{opacity:1}

/* ---------- Step Inside (pinned) ---------- */
.step{min-height:100svh;display:grid;place-items:center;text-align:center;
  position:relative;z-index:2;background:var(--bg);padding-block:8vh}
.step__glow{position:absolute;inset:0;background:radial-gradient(50% 50% at 50% 50%,var(--glow),transparent 70%);opacity:.3}
/* When the disc locks into final position, the glow breathes (organic, alive) */
.step.locked .step__glow{animation:solarPulse 3.4s ease-in-out infinite}
.step.locked .step__disc{animation:solarHalo 3.4s ease-in-out infinite}
@keyframes solarPulse{0%,100%{opacity:.34;transform:scale(1)}50%{opacity:.72;transform:scale(1.1)}}
@keyframes solarHalo{0%,100%{filter:drop-shadow(0 0 70px rgba(200,146,61,.34))}50%{filter:drop-shadow(0 0 132px rgba(200,146,61,.62))}}
.step__disc{position:relative;z-index:2;width:min(42vw,440px);
  filter:drop-shadow(0 0 90px rgba(200,146,61,.4));will-change:transform}
[data-theme="light"] .step__disc{filter:drop-shadow(0 30px 70px rgba(120,80,40,.35))}
/* Solar finale 50% larger at tablet + desktop (mobile unchanged) */
@media(min-width:768px){.step__disc{width:min(63vw,660px)}}
.step__caption{position:relative;z-index:2;margin-top:2rem}
.step__caption h2{font-size:clamp(2.4rem,6vw,4rem);font-style:italic;font-weight:300}
.step__caption p{color:var(--muted);margin:.6rem 0 0}

/* ---------- Horizontal collection (Spirit) ---------- */
.collection--horizontal{overflow:hidden}
.hscroll{position:relative;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.hscroll::-webkit-scrollbar{display:none}
.hscroll__track{display:flex;gap:clamp(1.4rem,3vw,3rem);padding:1rem clamp(1.2rem,5vw,5rem);width:max-content}
.hcard{cursor:pointer;flex:0 0 auto;width:clamp(260px,42vw,520px)}
.hcard__frame{overflow:hidden;border-radius:4px;background:var(--ink-2);box-shadow:var(--shadow);
  border:1px solid var(--frame)}
.hcard__frame img{width:100%;height:62vh;max-height:640px;object-fit:cover;transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.hcard:hover .hcard__frame img{transform:scale(1.04)}
.hcard__meta{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-top:.9rem}
.hcard__title{font-family:"Fraunces",serif;font-size:1.3rem;font-style:italic}
.hcard__medium{color:var(--muted);font-size:.82rem}
.hscroll__hint{text-align:center;color:var(--muted);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-top:1.6rem}

/* ---------- Process ---------- */
.process__grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.process__grid figure{margin:0}
.process__grid img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:4px;box-shadow:var(--shadow);border:1px solid var(--frame)}
.process__grid figcaption{color:var(--muted);font-size:.82rem;letter-spacing:.04em;margin-top:.7rem;text-align:center}

/* ---------- Inquire ---------- */
.inquire{max-width:760px;margin:0 auto}
.inquire__form{display:grid;gap:1.2rem;margin-top:1rem;background:var(--card);
  padding:clamp(1.5rem,4vw,2.6rem);border-radius:8px;border:1px solid var(--line);box-shadow:var(--shadow)}
.field{display:grid;gap:.45rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.inquire label,.intent legend{font-size:.82rem;letter-spacing:.04em;color:var(--muted)}
.opt{opacity:.7;text-transform:none;letter-spacing:0}
.inquire input,.inquire textarea{width:100%;background:var(--bg);border:1px solid var(--line);
  border-radius:6px;padding:.85rem 1rem;color:var(--text);font:inherit;font-size:.98rem;transition:border-color .25s}
.inquire input:focus,.inquire textarea:focus{outline:none;border-color:var(--accent)}
.intent{border:none;padding:0;margin:0;display:grid;gap:.6rem}
.intent legend{margin-bottom:.4rem}
.chip{display:flex;align-items:center;gap:.6rem;border:1px solid var(--line);border-radius:2rem;
  padding:.6rem 1rem;cursor:pointer;font-size:.92rem;color:var(--text);transition:border-color .25s,background .25s}
.chip input{width:auto;accent-color:var(--accent)}
.chip:has(input:checked){border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-note{margin:.2rem 0 0;font-size:.9rem;color:var(--accent);min-height:1.2em}
.form-note.err{color:#e06a5a}

/* ---------- Footer ---------- */
.foot{display:grid;grid-template-columns:1.5fr .9fr 1.1fr .9fr 1.1fr;gap:2rem;
  padding:clamp(3rem,6vw,5rem) clamp(1.2rem,5vw,5rem) 3rem;border-top:1px solid var(--line)}
.foot__col a{display:block;color:var(--muted);font-size:.92rem;margin:.3rem 0;transition:color .25s}
.foot__col a:hover{color:var(--accent)}
.foot__label{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text);margin:0 0 .8rem}
.foot__brand .brand__mark{margin-bottom:.8rem}
.foot__brand p{margin:.2rem 0}
.foot__meta{display:flex;flex-direction:column;gap:.8rem;align-items:flex-start}

/* ---------- Omniscient Group credit (sub-footer) ---------- */
.foot__credit{border-top:1px solid var(--line);padding:1.3rem 1rem;text-align:center;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.foot__credit a,.foot__credit strong{color:var(--text);font-weight:500}
.foot__credit a:hover{color:var(--accent)}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:50;background:color-mix(in srgb,var(--bg) 92%,#000);
  backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:5vh 5vw;
  opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox__fig{margin:0;max-width:1100px;width:100%;display:flex;flex-direction:column;gap:1.2rem;align-items:center}
.lightbox__img{max-height:74vh;width:auto;max-width:100%;border-radius:4px;box-shadow:var(--shadow);
  transform:scale(.96);transition:transform .45s cubic-bezier(.16,1,.3,1)}
.lightbox.open .lightbox__img{transform:scale(1)}
.lightbox__cap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;width:100%;max-width:880px;flex-wrap:wrap}
.lightbox__cap h3{font-family:"Fraunces",serif;font-style:italic;font-size:1.6rem}
.lightbox__cap p{color:var(--muted);font-size:.9rem;margin:.3rem 0 0}
.lightbox__close,.lightbox__nav{position:absolute;background:transparent;border:1px solid var(--line);
  color:var(--text);width:3rem;height:3rem;border-radius:50%;cursor:pointer;font-size:1.1rem;
  display:grid;place-items:center;transition:border-color .25s,color .25s}
.lightbox__close:hover,.lightbox__nav:hover{border-color:var(--accent);color:var(--accent)}
.lightbox__close{top:4vh;right:4vw}
.lightbox__nav{top:50%;transform:translateY(-50%);font-size:1.6rem}
.lightbox__nav--prev{left:3vw}.lightbox__nav--next{right:3vw}

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

/* ---------- Touch / mobile-first polish ---------- */
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
*{-webkit-tap-highlight-color:transparent}
.btn,.theme-toggle,.navburger,.nav__links a,.vcard,.hcard,.lightbox__nav,.lightbox__close,
.vr__swatch,.vr__thumb,.vr__spotbtn,.vr__picker,.foot__col a,.chip{touch-action:manipulation}
.navmenu,.lightbox{overscroll-behavior:contain}
/* iOS notch / safe-area on fixed chrome */
.nav{padding-top:max(1.1rem,env(safe-area-inset-top));
  padding-left:max(clamp(1.1rem,4vw,3rem),env(safe-area-inset-left));
  padding-right:max(clamp(1.1rem,4vw,3rem),env(safe-area-inset-right))}
.navmenu__close{top:max(1.3rem,env(safe-area-inset-top))}
@media (hover:none){
  /* no hover on touch: show the affordance, kill hover-only transforms */
  .vcard__view{opacity:1}
  .vcard:hover .vcard__frame img,.hcard:hover .hcard__frame img{transform:none}
  .nav__links a::after{display:none}
}
@media (max-width:860px){
  /* Spirit wall = native momentum swipe with snap */
  .hscroll{scroll-snap-type:x mandatory;scroll-padding-left:clamp(1.2rem,5vw,5rem);overscroll-behavior-x:contain}
  .hcard{scroll-snap-align:center}
  /* lightbox: swipe (not tiny arrows), bigger close, safe-area */
  .lightbox__nav{display:none}
  .lightbox__close{top:max(1.1rem,env(safe-area-inset-top));right:1rem;width:3.2rem;height:3.2rem;font-size:1.3rem}
  .lightbox{padding:5vh 4vw max(2vh,env(safe-area-inset-bottom))}
  .lightbox__img{max-height:64vh}
  .lightbox__cap{justify-content:center;text-align:center}
  .lightbox__actions{justify-content:center;width:100%}
  /* viewing-room controls clear the home indicator */
  .vr__panel{padding-bottom:max(1rem,env(safe-area-inset-bottom))}
}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .nav__links{display:none}
  .story{grid-template-columns:1fr}
  .story__media{order:-1}
  .vcard:nth-child(odd),.vcard:nth-child(even){grid-template-columns:1fr}
  .vcard__meta,.vcard:nth-child(even) .vcard__meta{text-align:left;order:0}
  .process__grid{grid-template-columns:1fr;gap:1.6rem}
  .hcard__frame img{height:48vh}
  .field-row{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr 1fr}
  .hero__disc{opacity:.42;width:min(74vw,420px)}
  .hero__inner{max-width:none}
}
@media(max-width:520px){
  .foot{grid-template-columns:1fr}
  .hero__title{font-size:clamp(3rem,16vw,5rem)}
}

/* ---------- About / Bio page ---------- */
.about-hero{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(2rem,5vw,5rem);align-items:center;
  max-width:1300px;margin:0 auto;padding:clamp(7rem,12vw,10rem) clamp(1.2rem,5vw,5rem) clamp(2.5rem,6vw,4rem)}
.about-hero__text h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:300;letter-spacing:-.02em;margin:.4rem 0 1.4rem}
.about-hero__text .lead{font-size:1.18rem;color:var(--muted);max-width:48ch}
.about-hero__portrait{position:relative;border-radius:6px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--frame)}
.about-hero__portrait img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;display:block}
.about-hero__cap{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1.4rem 1.1rem;
  background:linear-gradient(transparent,rgba(0,0,0,.6));color:#f4efe6;font-size:.82rem;letter-spacing:.04em}
.bio{max-width:840px;margin:0 auto;padding:0 clamp(1.2rem,5vw,5rem)}
.bio__block{padding:clamp(2.4rem,5vw,3.6rem) 0;border-top:1px solid var(--line)}
.bio__block h2{font-size:clamp(1.7rem,3.6vw,2.6rem);font-weight:300;margin:0 0 1.2rem}
.bio__block p{color:var(--muted);font-size:1.08rem;margin:0 0 1.1rem}
.bio__block .inline{color:var(--accent);border-bottom:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}
.bio__block .inline:hover{border-color:var(--accent)}
.bio__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.3rem}
.bio__tag{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--line);border-radius:2rem;padding:.45rem .95rem}
.pullquote{font-family:"Fraunces",serif;font-style:italic;font-size:clamp(1.6rem,3.4vw,2.6rem);
  line-height:1.28;text-align:center;max-width:900px;margin:0 auto;
  padding:clamp(3rem,7vw,6rem) clamp(1.2rem,5vw,5rem)}
.pullquote cite{display:block;font-style:normal;font-family:"Hanken Grotesk",sans-serif;
  font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-top:1.6rem}
.bio__photo{margin:1.9rem 0 .3rem;max-width:560px}
.bio__photo img{width:100%;display:block;border-radius:6px;border:1px solid var(--frame);box-shadow:var(--shadow)}
.bio__photo figcaption{color:var(--muted);font-size:.82rem;margin-top:.7rem}
.candids{max-width:1180px;margin:0 auto;padding:clamp(1rem,3vw,2rem) clamp(1.2rem,5vw,5rem);
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.candids figure{margin:0}
.candids img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:6px;border:1px solid var(--frame);box-shadow:var(--shadow)}
.candids figcaption{color:var(--muted);font-size:.8rem;margin-top:.7rem;text-align:center;letter-spacing:.02em}
@media(max-width:760px){.candids{grid-template-columns:1fr;max-width:480px}}
.connect{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.4rem}
.about-cta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;
  padding:clamp(1.5rem,4vw,3rem) 1rem clamp(4rem,8vw,7rem)}

/* ---------- Giving / The Light Fund ---------- */
.give-section{padding:clamp(2.6rem,6vw,4.5rem) clamp(1.2rem,5vw,5rem)}
.give-cards{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.give-card{border:1px solid var(--line);border-radius:8px;padding:1.9rem;background:var(--card)}
.give-card .num{font-family:"Fraunces",serif;font-style:italic;color:var(--accent);font-size:1.2rem}
.give-card h3{font-family:"Fraunces",serif;font-weight:400;font-size:1.35rem;margin:.5rem 0 .7rem}
.give-card p{color:var(--muted);font-size:.98rem;margin:0}
.give-lanes{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.give-lane{border:1px solid var(--line);border-radius:8px;padding:1.9rem;background:var(--card)}
.give-lane h3{font-family:"Fraunces",serif;font-weight:400;font-size:1.4rem;font-style:italic;margin:0 0 .7rem}
.give-lane p{color:var(--muted);font-size:1rem;margin:0 0 .8rem}
.give-lane .partners{font-size:.84rem;letter-spacing:.02em;color:var(--text)}
.give-lane .partners span{color:var(--muted)}
.give-draft{display:inline-block;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);
  border-radius:2rem;padding:.25rem .7rem;margin-left:.6rem;vertical-align:middle}
@media(max-width:760px){.give-cards{grid-template-columns:1fr}.give-lanes{grid-template-columns:1fr}}
@media(max-width:860px){.about-hero{grid-template-columns:1fr}.about-hero__portrait{order:-1;max-width:480px}}

/* ---------- Mobile hamburger + full-screen menu ---------- */
.nav__actions{display:flex;align-items:center;gap:.7rem}
.theme-label{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
@media(max-width:1000px){.theme-label{display:none}}
.navburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:2.4rem;height:2.4rem;
  background:transparent;border:none;cursor:pointer;padding:0}
.navburger span{display:block;height:2px;width:22px;background:var(--text);margin:0 auto;
  transition:transform .3s ease,opacity .3s ease}
.navmenu{position:fixed;inset:0;z-index:40;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:1.4rem;opacity:0;visibility:hidden;
  transition:opacity .35s ease,visibility .35s ease}
.navmenu.open{opacity:1;visibility:visible}
.navmenu__close{position:absolute;top:1.3rem;right:1.3rem;background:transparent;border:1px solid var(--line);
  color:var(--text);width:2.8rem;height:2.8rem;border-radius:50%;font-size:1.1rem;cursor:pointer;
  display:grid;place-items:center}
.navmenu__close:hover{border-color:var(--accent);color:var(--accent)}
.navmenu__links{display:flex;flex-direction:column;align-items:center;gap:1.7rem}
.navmenu__links a{font-family:"Fraunces",serif;font-size:2.1rem;color:var(--text);letter-spacing:-.01em}
.navmenu__links a:hover{color:var(--accent)}
@media(max-width:860px){.navburger{display:flex}}

/* ---------- About · "The work" feature (image left) ---------- */
.workfeature{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;
  max-width:1240px;margin:0 auto;padding:clamp(2.5rem,6vw,4.5rem) clamp(1.2rem,5vw,5rem)}
.workfeature__media{border-radius:6px;overflow:hidden;border:1px solid var(--frame);box-shadow:var(--shadow)}
.workfeature__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;display:block}
.workfeature__text h2{font-size:clamp(1.7rem,3.6vw,2.6rem);font-weight:300;margin:0 0 1.2rem}
.workfeature__text p{color:var(--muted);font-size:1.08rem;margin:0 0 1.1rem}
.workfeature__text .inline{color:var(--accent);border-bottom:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}
@media(max-width:860px){.workfeature{grid-template-columns:1fr}.workfeature__media{order:-1;max-width:460px}}

/* ---------- Viewing Room ---------- */
.vr{position:relative}
.vr__stage{position:relative;height:100svh;overflow:hidden;display:flex;align-items:center;justify-content:center;
  --console-w:clamp(240px,32vw,440px);--art-scale:1.05;
  background:var(--wall,#17171a);transition:background .55s ease}
.vr__spot{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .55s ease;z-index:3;
  background:
    radial-gradient(78% 62% at 50% 44%,rgba(255,244,222,.40),rgba(255,244,222,.10) 46%,transparent 70%),
    radial-gradient(130% 105% at 50% 46%,transparent 52%,rgba(0,0,0,.30) 82%,rgba(0,0,0,.52) 100%)}
.vr__stage.lit .vr__spot{opacity:1}
.vr__art{position:relative;margin:0;
  width:calc(var(--console-w) * var(--art-scale));max-width:86vw;z-index:4;transition:width .12s linear}
.vr__art img{max-height:80vh;width:100%;object-fit:contain}
.vr__art img{width:100%;height:auto;display:block;border-radius:2px;
  filter:drop-shadow(0 20px 30px rgba(0,0,0,.5)) drop-shadow(0 5px 12px rgba(0,0,0,.32));
  transition:filter .55s ease}
/* Gallery light ON — the piece reads as spotlit: brighter, warmer, soft halo */
.vr__stage.lit .vr__art img{
  filter:brightness(1.13) contrast(1.05) saturate(1.07)
    drop-shadow(0 26px 40px rgba(0,0,0,.6)) drop-shadow(0 0 34px rgba(255,236,205,.22))}
.vr__console{position:absolute;left:50%;bottom:5vh;transform:translateX(-50%);
  width:var(--console-w);height:auto;z-index:1;pointer-events:none}
.vr__panel{position:sticky;bottom:0;left:0;right:0;z-index:5;
  background:color-mix(in srgb,var(--bg) 84%,transparent);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--line);
  padding:1rem clamp(1rem,4vw,2.6rem);display:flex;flex-wrap:wrap;gap:1.1rem 2rem;
  align-items:center;justify-content:center;transition:transform .42s cubic-bezier(.4,0,.2,1)}
/* Hide-controls handle — collapse the panel for full-screen wall viewing */
.vr__handle{flex:1 1 100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  order:-1;width:100%;margin:-.35rem 0 .15rem;padding:.35rem 0;border:0;background:transparent;cursor:pointer;color:var(--muted)}
.vr__handle__grip{width:40px;height:4px;border-radius:2px;background:color-mix(in srgb,var(--text) 28%,transparent);transition:background .2s}
.vr__handle:hover .vr__handle__grip{background:var(--accent)}
.vr__handle__chev{font-size:1rem;line-height:.6;transition:transform .4s cubic-bezier(.4,0,.2,1);opacity:.85}
.vr.ctrl-hidden .vr__panel{transform:translateY(calc(100% - 2.9rem))}
.vr.ctrl-hidden .vr__handle__chev{transform:rotate(180deg)}
.vr__group{display:flex;align-items:center;gap:.7rem}
.vr__glabel{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.vr__thumbs{display:flex;gap:.5rem;overflow-x:auto;max-width:min(92vw,540px);scrollbar-width:none;padding-bottom:2px}
.vr__thumbs::-webkit-scrollbar{display:none}
.vr__thumb{width:52px;height:52px;border-radius:4px;overflow:hidden;border:1px solid var(--line);
  cursor:pointer;flex:0 0 auto;opacity:.55;transition:opacity .2s,border-color .2s;background:none;padding:0}
.vr__thumb.active,.vr__thumb:hover{opacity:1;border-color:var(--accent)}
.vr__thumb img{width:100%;height:100%;object-fit:cover}
.vr__swatches{display:flex;gap:.4rem;align-items:center}
.vr__swatch{width:24px;height:24px;border-radius:50%;border:1px solid rgba(128,128,128,.4);cursor:pointer;padding:0}
.vr__swatch.active{outline:2px solid var(--accent);outline-offset:2px}
/* Custom-colour wheel — opens the native colour picker (enter any hex to match a wall) */
.vr__picker{width:27px;height:27px;border:1px solid rgba(128,128,128,.45);border-radius:50%;overflow:hidden;
  cursor:pointer;padding:0;transition:transform .15s ease,box-shadow .2s ease;
  background:radial-gradient(circle,#fff 0 19%,rgba(255,255,255,0) 21%),
    conic-gradient(from 90deg,#ff3b30,#ff9500,#ffcc00,#34c759,#00c7be,#007aff,#5856d6,#ff2d55,#ff3b30)}
.vr__picker:hover{transform:scale(1.12);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 60%,transparent)}
.vr__picker::-webkit-color-swatch-wrapper{padding:0}
.vr__picker::-webkit-color-swatch{border:none;opacity:0}
.vr__picker::-moz-color-swatch{border:none;opacity:0}
.vr__picker::-moz-focus-inner{border:0}
.vr__range{accent-color:var(--accent);width:130px}
.vr__spotbtn{font:inherit;font-size:.84rem;color:var(--text);background:transparent;border:1px solid var(--line);
  border-radius:2rem;padding:.45rem 1rem;cursor:pointer;transition:border-color .2s,color .2s}
.vr__spotbtn[aria-pressed="true"]{border-color:var(--accent);color:var(--accent)}
.vr__hint{position:absolute;top:1rem;left:50%;transform:translateX(-50%);z-index:3;
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  background:color-mix(in srgb,var(--bg) 55%,transparent);padding:.3rem .8rem;border-radius:2rem;backdrop-filter:blur(6px)}
@media(max-width:700px){
  /* Viewing Room as a true mobile layout: art region on top, controls as an in-flow sheet below */
  .vr{display:flex;flex-direction:column;min-height:100svh}
  .vr__stage{flex:1 1 auto;height:auto;min-height:0;overflow:hidden;
    padding:calc(env(safe-area-inset-top) + 4.6rem) 1rem 1.1rem}
  .vr__console{display:none}
  .vr__hint{top:calc(env(safe-area-inset-top) + 4.7rem);font-size:.62rem;padding:.28rem .7rem}
  .vr__art{width:auto;max-width:88vw}
  .vr__art img{max-height:46svh;
    filter:drop-shadow(0 14px 22px rgba(0,0,0,.5)) drop-shadow(0 4px 9px rgba(0,0,0,.32))}

  /* Controls: stacked sheet, nothing clipped */
  .vr__panel{position:static;flex-wrap:wrap;align-items:stretch;justify-content:flex-start;
    gap:.8rem 1rem;padding:.85rem 1rem max(.95rem,env(safe-area-inset-bottom))}
  .vr__group{gap:.5rem}
  .vr__group:nth-child(2){flex:1 1 100%;flex-direction:column;align-items:flex-start}
  .vr__group:nth-child(3){flex:1 1 100%;flex-flow:row wrap;align-items:center;gap:.55rem}
  .vr__group:nth-child(3) .vr__glabel{flex:1 1 100%}
  .vr__group:nth-child(4){flex:1 1 56%;align-items:center;min-width:0}
  .vr__group:nth-child(5){flex:0 1 auto}
  .vr__glabel{font-size:.64rem}
  .vr__thumbs{width:100%;max-width:100%;gap:.55rem;padding:2px 0 5px;
    scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
  .vr__thumb{width:60px;height:60px;scroll-snap-align:start}
  .vr__swatches{flex-wrap:wrap;gap:.55rem}
  .vr__swatch{width:28px;height:28px}
  .vr__picker{width:30px;height:30px}
  .vr__range{flex:1 1 auto;width:auto;min-width:0;height:1.6rem}
  .vr__spotbtn{padding:.55rem 1.1rem;white-space:nowrap}
  .vr__handle{margin:-.15rem 0 .2rem;padding:.2rem 0 .35rem}
  /* Collapsed: panel leaves flow so the art fills the screen; handle peeks above safe area */
  .vr.ctrl-hidden .vr__panel{position:fixed;left:0;right:0;bottom:0}
  .vr.ctrl-hidden .vr__art img{max-height:76svh}
}

.lightbox__actions{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-end}
.foot__theme-note{font-size:.78rem;color:var(--muted);max-width:34ch;margin:0 0 .2rem;line-height:1.45}
.foot__theme-note a{color:var(--accent);border-bottom:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}
.foot__theme-note a:hover{border-color:var(--accent)}

/* ---------- Solar: proper finale size on phones ---------- */
@media(max-width:767px){.step__disc{width:min(82vw,360px)}}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  .hero__disc{animation:none}
}
