/* ============================================================
   KNXPLORE — Stories from the Wild
   Design tokens follow the master brief exactly.
   ============================================================ */
:root{
  --bg:#F8F7F4;
  --surface:#FFFFFF;
  --green:#556B5D;
  --slate:#5B6570;
  --earth:#8A7662;
  --gold:#C8B58A;
  --ink:#1F1F1F;
  --subink:#5C5C5C;
  --rule:#E5E5E5;

  --display:"Playfair Display",Georgia,"Times New Roman",serif;
  --body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);
  --header-h:74px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--body);font-weight:400;line-height:1.6;
  font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.12;margin:0;letter-spacing:.01em}

/* shared utilities ----------------------------------------------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.eyebrow{
  font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--earth);margin:0 0 14px;
}
.rule-gold{width:46px;height:2px;background:var(--gold);border:0;margin:0 0 22px}
.muted{color:var(--subink)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.btn{
  display:inline-flex;align-items:center;gap:.55em;font-size:13px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;padding:14px 26px;border-radius:2px;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
}
.btn-solid{background:var(--green);color:#fff}
.btn-solid:hover{background:#46594d}
.btn-ghost{border:1px solid rgba(255,255,255,.6);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-line{border:1px solid var(--ink);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--bg)}

/* ---------------------------------------------------------------------- */
/* HEADER                                                                  */
/* ---------------------------------------------------------------------- */
.site-header{
  position:sticky;top:0;z-index:60;background:rgba(248,247,244,.86);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--rule);
  transition:background .3s var(--ease);
}
.site-header.is-over-hero{background:transparent;border-color:transparent;color:#fff}
.site-header.is-over-hero .nav-link,.site-header.is-over-hero .wordmark,
.site-header.is-over-hero .nav-toggle,.site-header.is-over-hero .nav-search-btn{color:#fff}
.site-header.is-over-hero .wordmark .tld{color:var(--gold)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);
  max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.wordmark{font-family:var(--display);font-weight:600;font-size:23px;letter-spacing:.04em;color:var(--ink)}
.wordmark .tld{color:var(--earth)}
.primary-nav{display:flex;align-items:center;gap:30px}
.nav-link{font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);position:relative;padding:6px 0}
.nav-link::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;
  background:var(--gold);transition:right .3s var(--ease)}
.nav-link:hover::after,.nav-link[aria-current="page"]::after{right:0}
.nav-search-btn{display:inline-flex;align-items:center;color:var(--ink)}
.nav-toggle{display:none;width:32px;height:32px;color:var(--ink);align-items:center;justify-content:center}
.nav-toggle svg{width:26px;height:26px}
.nav-panel-head{display:none}

@media(max-width:880px){
  :root{--header-h:60px}
  .wordmark{font-size:20px}
  .primary-nav{position:fixed;inset:0 0 0 auto;width:min(86vw,340px);
    height:100vh;height:100dvh;background:var(--surface);
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;
    padding:calc(env(safe-area-inset-top) + 18px) 28px 28px;overflow-y:auto;-webkit-overflow-scrolling:touch;
    transform:translateX(100%);transition:transform .4s var(--ease);
    box-shadow:-20px 0 60px rgba(0,0,0,.14);color:var(--ink)}
  .primary-nav.open{transform:translateX(0)}
  .nav-panel-head{display:flex;align-items:center;justify-content:space-between;
    margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--rule)}
  .nav-panel-head .wordmark{color:var(--ink);font-size:20px}
  .nav-close{width:38px;height:38px;display:grid;place-items:center;color:var(--ink);border-radius:50%}
  .nav-close svg{width:22px;height:22px}
  .primary-nav .nav-link{font-size:18px;padding:16px 2px;width:100%;
    border-bottom:1px solid var(--rule);letter-spacing:.05em;color:var(--ink)}
  .primary-nav .nav-link::after{display:none}
  .nav-toggle{display:inline-flex}
  .site-header.is-over-hero .primary-nav .nav-link{color:var(--ink)}
  .nav-scrim{position:fixed;inset:0;background:rgba(31,31,31,.45);opacity:0;visibility:hidden;
    transition:opacity .4s var(--ease);z-index:55}
  .nav-scrim.open{opacity:1;visibility:visible}
  body.nav-open{overflow:hidden}
}

/* ---------------------------------------------------------------------- */
/* HERO                                                                    */
/* ---------------------------------------------------------------------- */
.hero{position:relative;height:100vh;height:100dvh;min-height:560px;margin-top:calc(-1 * var(--header-h));overflow:hidden;background:#1d211f}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.6s var(--ease);
  background-size:cover;background-position:center;transform:scale(1.06);animation:heroDrift 12s linear infinite alternate}
.hero-slide.active{opacity:1}
@keyframes heroDrift{from{transform:scale(1.02)}to{transform:scale(1.12)}}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,24,22,.5)0%,rgba(20,24,22,.15)38%,rgba(20,24,22,.62)100%)}
.hero-content{position:absolute;z-index:2;inset:auto 0 0 0;padding:0 var(--gutter) clamp(56px,10vh,120px);
  max-width:var(--maxw);margin:0 auto;color:#fff}
.hero-eyebrow{color:var(--gold);font-size:13px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;margin:0 0 18px}
.hero h1{font-size:clamp(46px,9vw,108px);font-weight:500;color:#fff;line-height:.96;margin:0 0 18px}
.hero-sub{font-size:clamp(15px,2.2vw,19px);letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.86);font-weight:400;margin:0 0 36px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.hero-scroll{position:absolute;z-index:2;left:50%;bottom:26px;transform:translateX(-50%);
  color:rgba(255,255,255,.7);font-size:11px;letter-spacing:.24em;text-transform:uppercase;display:flex;
  flex-direction:column;align-items:center;gap:8px}
.hero-scroll span{width:1px;height:34px;background:rgba(255,255,255,.5);animation:scrollPulse 2s var(--ease) infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------------------------------------------------------------------- */
/* SECTIONS                                                                */
/* ---------------------------------------------------------------------- */
.section{padding-block:clamp(64px,10vw,128px)}
.section-head{max-width:640px;margin:0 auto clamp(40px,6vw,72px);text-align:center}
.section-head.left{text-align:left;margin-inline:0}
.section-head h2{font-size:clamp(30px,4.4vw,50px)}
.section-head p{color:var(--subink);margin:18px 0 0;font-size:17px}

/* intro */
.intro{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(32px,6vw,84px);align-items:center}
.intro-portrait{position:relative}
.intro-portrait img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:50% 22%;border-radius:2px}
.intro-portrait .tag{position:absolute;left:-1px;bottom:24px;background:var(--bg);color:var(--ink);
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:10px 18px}
.intro h2{font-size:clamp(28px,3.6vw,42px);margin-bottom:8px}
.intro .lead{font-family:var(--display);font-style:italic;font-size:clamp(20px,2.6vw,26px);
  color:var(--green);line-height:1.4;margin:18px 0 22px}
.intro p+p{margin-top:16px}
@media(max-width:760px){.intro{grid-template-columns:1fr;gap:34px}}

/* featured collections */
.collections{background:var(--surface)}
.coll-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.coll-card{position:relative;display:block;aspect-ratio:3/4;overflow:hidden;background:#222}
.coll-card img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);opacity:.92}
.coll-card:hover img{transform:scale(1.07);opacity:1}
.coll-card::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0)40%,rgba(0,0,0,.72)100%)}
.coll-meta{position:absolute;z-index:2;inset:auto 0 0 0;padding:26px 24px;color:#fff}
.coll-meta .n{font-family:var(--body);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.coll-meta h3{font-size:25px;margin:8px 0 2px;color:#fff}
.coll-meta .count{font-size:13px;color:rgba(255,255,255,.78)}
@media(max-width:920px){.coll-grid{grid-template-columns:repeat(2,1fr)}}

/* featured story / field notes */
.fieldnote{display:grid;grid-template-columns:1.2fr 1fr;gap:0;background:var(--surface);overflow:hidden}
.fieldnote-img{min-height:340px;background-size:cover;background-position:center}
.fieldnote-body{padding:clamp(34px,5vw,68px)}
.fieldnote-body h2{font-size:clamp(28px,3.6vw,40px);margin:6px 0 0}
.fieldnote-body .lead{font-family:var(--display);font-style:italic;font-size:22px;color:var(--green);margin:18px 0}
@media(max-width:820px){.fieldnote{grid-template-columns:1fr}.fieldnote-img{min-height:280px}}

/* stats */
.stats{background:var(--green);color:#fff}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.stat .num{font-family:var(--display);font-size:clamp(40px,6vw,68px);line-height:1;color:#fff}
.stat .num .plus{color:var(--gold)}
.stat .label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:14px}
@media(max-width:760px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:44px 24px}}

/* ---------------------------------------------------------------------- */
/* EXPLORE                                                                 */
/* ---------------------------------------------------------------------- */
/* top row: applied filters (left) + count & trigger (right) — NOT sticky */
.explore-top{display:flex;align-items:center;justify-content:space-between;gap:14px;
  flex-wrap:wrap;padding:20px 0 8px}
.explore-actions{display:flex;align-items:center;gap:16px;margin-left:auto}
.result-count{color:var(--subink);font-size:12px;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}

.applied{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.applied:empty{display:none}
.applied .pill{display:inline-flex;align-items:center;gap:7px;background:var(--surface);
  border:1px solid var(--rule);border-radius:30px;padding:5px 7px 5px 13px;font-size:12.5px;color:var(--ink)}
.applied .pill button{display:grid;place-items:center;width:18px;height:18px;border-radius:50%;
  background:var(--bg);color:var(--slate);font-size:13px;line-height:1}
.applied .pill button:hover{background:var(--earth);color:#fff}
.applied .clear-all{font-size:12px;letter-spacing:.04em;color:var(--earth);text-decoration:underline;text-underline-offset:3px}

/* trigger button + floating button */
.filter-btn{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--ink);color:var(--ink);
  background:var(--surface);padding:10px 18px;border-radius:30px;font-size:12px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;transition:background .25s var(--ease),color .25s var(--ease)}
.filter-btn:hover{background:var(--ink);color:var(--bg)}
.filter-btn svg{width:16px;height:16px}

.filter-fab{position:fixed;z-index:70;left:50%;bottom:24px;
  transform:translateX(-50%) translateY(24px);opacity:0;pointer-events:none;
  display:inline-flex;align-items:center;gap:9px;background:var(--green);color:#fff;
  padding:13px 24px;border-radius:40px;font-size:12px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;box-shadow:0 12px 34px rgba(31,40,34,.34);
  transition:opacity .3s var(--ease),transform .3s var(--ease)}
.filter-fab svg{width:16px;height:16px}
.filter-fab.show{opacity:1;pointer-events:auto;transform:translateX(-50%)}
.filter-panel.open ~ .filter-fab{opacity:0;pointer-events:none}

/* the panel */
.filter-panel{position:fixed;inset:0;z-index:95;display:none}
.filter-panel.open{display:block}
.fp-scrim{position:absolute;inset:0;background:rgba(31,31,31,.46);opacity:0;transition:opacity .35s var(--ease)}
.filter-panel.open .fp-scrim{opacity:1}
.fp-sheet{position:absolute;top:0;right:0;height:100vh;height:100dvh;width:min(420px,92vw);
  background:var(--bg);display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:-24px 0 60px rgba(0,0,0,.18)}
.filter-panel.open .fp-sheet{transform:none}
.fp-head{display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--rule);flex:none}
.fp-head h2{font-size:22px}
.fp-close{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;color:var(--ink)}
.fp-close:hover{background:var(--surface)}
.fp-close svg{width:22px;height:22px}
.fp-body{flex:1 1 auto;overflow-y:auto;padding:24px}
.fp-group+.fp-group{margin-top:28px}
.fp-label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--slate);margin-bottom:14px;font-weight:600}
.fp-options{display:flex;flex-wrap:wrap;gap:8px}
.fp-opt{border:1px solid var(--rule);background:var(--surface);border-radius:30px;
  padding:9px 16px;font-size:13px;color:var(--ink);transition:.2s}
.fp-opt:hover{border-color:var(--earth)}
.fp-opt.active{background:var(--green);border-color:var(--green);color:#fff}
.fp-list{display:flex;flex-direction:column}
.fp-item{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;
  padding:13px 2px;border-bottom:1px solid var(--rule);font-size:15.5px;color:var(--ink);text-align:left}
.fp-item:hover{color:var(--green)}
.fp-item.active{color:var(--green);font-weight:600}
.fp-item .n{font-size:12px;color:var(--subink);letter-spacing:.04em}
.fp-item.active .n{color:var(--green)}
.wrap-chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-size:12.5px;letter-spacing:.04em;color:var(--subink);border:1px solid var(--rule);
  background:var(--surface);padding:8px 14px;border-radius:30px;transition:.2s}
.chip:hover{border-color:var(--earth);color:var(--ink)}
.chip.active{background:var(--earth);border-color:var(--earth);color:#fff}
.search-field{display:flex;align-items:center;gap:9px;border:1px solid var(--rule);background:var(--surface);
  border-radius:30px;padding:11px 16px}
.search-field input{border:0;outline:0;background:none;font-size:15px;width:100%;color:var(--ink);min-width:0}
.search-field svg{width:16px;height:16px;color:var(--slate);flex:none}
.fp-foot{flex:none;display:flex;gap:12px;padding:16px 24px calc(16px + env(safe-area-inset-bottom));
  border-top:1px solid var(--rule);background:var(--bg)}
.fp-clear{flex:none;padding:13px 20px;border:1px solid var(--rule);border-radius:30px;
  font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.fp-clear:hover{border-color:var(--ink)}
.fp-apply{flex:1 1 auto;padding:13px 20px;border-radius:30px;background:var(--green);color:#fff;
  font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.fp-apply:hover{background:#46594d}

@media(max-width:600px){
  .fp-sheet{top:auto;right:0;left:0;bottom:0;width:auto;height:auto;max-height:88dvh;
    transform:translateY(100%);border-radius:16px 16px 0 0;box-shadow:0 -20px 50px rgba(0,0,0,.22)}
  .filter-panel.open .fp-sheet{transform:none}
  .explore-top{padding:16px 0 6px}
  .filter-fab{bottom:18px}
}

/* gallery grid */
.gallery{columns:4 260px;column-gap:14px;padding:14px 0 80px}
.card{break-inside:avoid;margin-bottom:14px;position:relative;display:block;overflow:hidden;
  background:#e9e7e1;border-radius:2px;cursor:zoom-in}
.card img{width:100%;height:auto;display:block;transition:transform .9s var(--ease),opacity .6s;opacity:0}
.card img.loaded{opacity:1}
.card:hover img{transform:scale(1.05)}
.card-cap{position:absolute;inset:auto 0 0 0;padding:34px 16px 14px;color:#fff;
  background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.78));
  opacity:0;transform:translateY(8px);transition:.35s var(--ease)}
.card:hover .card-cap{opacity:1;transform:none}
.card-cap .nm{font-family:var(--display);font-style:italic;font-size:16px;line-height:1.2}
.card-cap .lc{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-top:4px}
.card .flag{position:absolute;top:10px;left:10px;z-index:2;background:var(--gold);color:#3a3326;
  font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 8px;border-radius:2px}
.card .star{position:absolute;top:10px;right:10px;z-index:2;color:var(--gold);filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}
.empty{text-align:center;color:var(--subink);padding:90px 20px}
.empty h3{font-size:24px;color:var(--ink);margin-bottom:10px}

/* ---------------------------------------------------------------------- */
/* VIEWER (lightbox) — the specimen plate                                  */
/* ---------------------------------------------------------------------- */
.viewer{position:fixed;inset:0;z-index:100;background:rgba(20,23,21,.97);
  display:none;opacity:0;transition:opacity .35s var(--ease);height:100vh;height:100dvh}
.viewer.open{display:grid;opacity:1}
.viewer{grid-template-columns:1fr 360px}
.viewer-stage{position:relative;display:flex;align-items:center;justify-content:center;padding:34px;overflow:hidden}
.viewer-stage img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:2px;
  box-shadow:0 30px 80px rgba(0,0,0,.5);cursor:zoom-in;transition:transform .35s var(--ease);user-select:none;-webkit-user-drag:none}
.viewer-stage img.zoomed{cursor:zoom-out;transform:scale(2)}
.v-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.08);color:#fff;display:grid;place-items:center;transition:background .2s}
.v-nav:hover{background:rgba(255,255,255,.2)}
.v-prev{left:18px}.v-next{right:18px}
.v-nav svg{width:24px;height:24px}
.v-close{position:absolute;top:18px;right:18px;z-index:5;width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.08);color:#fff;display:grid;place-items:center;transition:background .2s}
.v-close:hover{background:rgba(255,255,255,.2)}
.v-count{position:absolute;top:26px;left:30px;color:rgba(255,255,255,.7);font-size:12px;letter-spacing:.18em}

.plate{background:var(--bg);color:var(--ink);padding:clamp(28px,3vw,42px);overflow-y:auto;height:100vh;height:100dvh}
.plate .cat-line{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--earth)}
.plate h2{font-family:var(--display);font-style:italic;font-size:30px;line-height:1.1;margin:12px 0 0}
.plate .sci{font-style:italic;color:var(--slate);font-size:15px;margin-top:4px}
.plate .pl-rule{height:2px;width:40px;background:var(--gold);margin:20px 0}
.plate .behaviour{font-size:15px;color:var(--ink)}
.plate .loc{font-size:13px;letter-spacing:.04em;color:var(--subink);margin-top:6px}
.plate .story{margin-top:18px;font-size:15px;color:var(--ink);line-height:1.65}
.plate .fact{margin-top:18px;border-left:2px solid var(--gold);padding:4px 0 4px 16px}
.plate .fact .k{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--earth);display:block;margin-bottom:4px}
.plate .fact p{margin:0;font-size:14px;color:var(--subink)}
.exif{margin-top:26px;border-top:1px solid var(--rule);padding-top:18px}
.exif .k{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--slate);margin-bottom:12px}
.exif dl{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;margin:0}
.exif dt{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--subink)}
.exif dd{margin:0;font-size:13.5px;color:var(--ink);text-align:right}
.review-note{margin-top:18px;background:rgba(200,181,138,.16);border:1px solid var(--gold);
  border-radius:3px;padding:12px 14px;font-size:12.5px;color:#6c5e3c}
@media(max-width:900px){
  .viewer.open{grid-template-columns:1fr;grid-template-rows:58vh 1fr}
  .plate{height:auto;min-height:0}
  .viewer-stage{padding:12px 12px 8px}
  .viewer-stage img{max-height:54vh}
  .v-nav{width:44px;height:44px}
  .v-prev{left:8px}.v-next{right:8px}
  .v-close{top:12px;right:12px;width:42px;height:42px}
  .v-count{top:20px;left:16px}
  .plate h2{font-size:25px}
}

/* ---------------------------------------------------------------------- */
/* CONTENT PAGES (about, contact)                                          */
/* ---------------------------------------------------------------------- */
.page-hero{padding:clamp(70px,12vh,140px) 0 clamp(30px,5vw,56px);text-align:center}
.page-hero h1{font-size:clamp(38px,6vw,64px)}
.page-hero p{color:var(--subink);max-width:560px;margin:18px auto 0}
.prose{max-width:720px;margin:0 auto}
.prose h3{font-size:24px;margin:38px 0 10px}
.prose p{margin:0 0 16px;color:#33312e}
.prose .lead{font-family:var(--display);font-style:italic;font-size:24px;color:var(--green);line-height:1.4}
.prose .closing{font-family:var(--display);font-style:italic;font-size:22px;color:var(--green);
  line-height:1.45;margin-top:30px;padding-top:26px;border-top:1px solid var(--rule)}
.about-portrait{max-width:380px;margin:0 auto 52px}
.about-portrait img{width:100%;height:auto;border-radius:2px;display:block}
.about-portrait::after{content:"Kareri Lake, Himalaya";display:block;text-align:center;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--subink);margin-top:14px}
.gearlist{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 28px;margin:10px 0 0;padding:0;list-style:none}
.gearlist li{padding:12px 0;border-bottom:1px solid var(--rule);font-size:15px;display:flex;justify-content:space-between;gap:16px}
.gearlist li span{color:var(--subink)}
@media(max-width:620px){.gearlist{grid-template-columns:1fr}}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,72px);max-width:980px;margin:0 auto}
.contact-grid h3{font-size:22px;margin-bottom:6px}
.field{margin-bottom:18px}
.field label{display:block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);margin-bottom:7px}
.field input,.field textarea{width:100%;border:1px solid var(--rule);background:var(--surface);
  border-radius:2px;padding:13px 15px;font-family:inherit;font-size:15px;color:var(--ink)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green)}
.contact-line{display:flex;gap:12px;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--rule)}
.contact-line .k{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);min-width:90px}
.contact-line a{color:var(--green)}
@media(max-width:680px){.contact-grid{grid-template-columns:1fr}}

/* ---------------------------------------------------------------------- */
/* FOOTER                                                                  */
/* ---------------------------------------------------------------------- */
.site-footer{background:var(--surface);border-top:1px solid var(--rule);padding:clamp(48px,7vw,84px) 0 40px;margin-top:0}
.footer-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
.footer-brand .wordmark{font-size:26px}
.footer-brand p{color:var(--subink);max-width:300px;margin:14px 0 0;font-size:14px}
.footer-nav{display:flex;gap:60px;flex-wrap:wrap}
.footer-col h4{font-family:var(--body);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);margin-bottom:14px;font-weight:600}
.footer-col a{display:block;color:var(--subink);font-size:14px;padding:5px 0;transition:color .2s}
.footer-col a:hover{color:var(--green)}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-top:1px solid var(--rule);margin-top:48px;padding-top:24px;color:var(--subink);font-size:12.5px;letter-spacing:.04em}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
:focus-visible{outline:2px solid var(--green);outline-offset:3px}
