/* ============================================================
   GREEN BEAR — Outdoor Adventures, Tara National Park
   Design system: "Expedition Log"
   pine #0D1F17 · forest #16331F · bear #3E9B4F · moss #8FB573
   paper #F1EEE3 · stone #E6E1D2 · ink #15201A · honey #D9A13B
   Type: Archivo (variable width) + IBM Plex Mono
   ============================================================ */

@font-face{
  font-family:"Archivo";
  src:url("../fonts/Archivo-var.woff2") format("woff2-variations");
  font-weight:100 900;font-stretch:62% 125%;font-style:normal;font-display:swap;
}
@font-face{font-family:"IBM Plex Mono";src:url("../fonts/PlexMono-Regular.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"IBM Plex Mono";src:url("../fonts/PlexMono-Medium.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"IBM Plex Mono";src:url("../fonts/PlexMono-SemiBold.woff2") format("woff2");font-weight:600;font-display:swap}

:root{
  --pine:#0D1F17;
  --pine-90:rgba(13,31,23,.9);
  --forest:#16331F;
  --bear:#3E9B4F;
  --bear-text:#1F6B33;
  --bear-dark:#2E7A3D;
  --moss:#8FB573;
  --paper:#F1EEE3;
  --stone:#E6E1D2;
  --line:#D5CEBB;
  --line-dark:rgba(241,238,227,.14);
  --ink:#15201A;
  --ink-60:rgba(21,32,26,.74);
  --cream:#F1EEE3;
  --cream-70:rgba(241,238,227,.82);
  --honey:#D9A13B;

  --font-display:"Archivo",system-ui,sans-serif;
  --font-body:"Archivo",system-ui,sans-serif;
  --font-mono:"IBM Plex Mono",ui-monospace,monospace;

  --container:1240px;
  --gutter:clamp(20px,4vw,48px);
  --section:clamp(72px,10vw,140px);
  --radius:14px;
  --ease:cubic-bezier(.22,.61,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html:focus-within{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:17px;line-height:1.65;
  color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:3px solid var(--honey);outline-offset:3px;border-radius:4px}

.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}

/* ---------- Typography ---------- */
.display{
  font-family:var(--font-display);
  font-variation-settings:"wdth" 118;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.005em;
  line-height:.96;
}
h1.display{font-size:clamp(2.6rem,7.2vw,5.6rem)}
h2.display{font-size:clamp(2rem,4.6vw,3.4rem)}
h3{font-weight:750;line-height:1.2}

.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.65em;
  color:var(--bear-text);
}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;border-radius:2px}
.on-dark .eyebrow{color:var(--moss)}

.meta-row{
  display:flex;flex-wrap:wrap;gap:.5rem 1.6rem;
  font-family:var(--font-mono);font-size:.72rem;
  letter-spacing:.12em;text-transform:uppercase;
}
.meta-row span{display:inline-flex;align-items:center;gap:.55em}
.meta-row span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--honey);flex:none}

.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--ink-60);max-width:62ch}
.on-dark .lead{color:var(--cream-70)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-mono);font-size:.78rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.95em 1.7em;border-radius:999px;
  transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s;
  border:1.5px solid transparent;white-space:nowrap;
}
.btn svg{width:14px;height:14px;transition:transform .25s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--bear);color:#fff}
.btn-primary:hover{background:var(--bear-dark)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.on-dark .btn-ghost,.btn-ghost.on-dark{border-color:var(--cream);color:var(--cream)}
.on-dark .btn-ghost:hover,.btn-ghost.on-dark:hover{background:var(--cream);color:var(--pine)}

/* ---------- Header ---------- */
.header{
  position:fixed;inset:0 0 auto 0;z-index:90;
  background:rgba(13,31,23,.85);
  transition:background .35s,box-shadow .35s,transform .35s;
}
.header-inner{
  max-width:var(--container);margin-inline:auto;
  padding:18px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.header.scrolled{background:var(--pine);box-shadow:0 1px 0 var(--line-dark)}
.brand img{height:34px;width:auto}
.nav{display:flex;align-items:center;gap:clamp(1rem,2.4vw,2.1rem)}
.nav a{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--cream);position:relative;padding:.4em 0;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:var(--honey);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav a:hover::after,.nav a[aria-current="page"]::after{transform:scaleX(1)}
.lang-switch{
  display:inline-flex;align-items:center;justify-content:center;
  border:1.5px solid var(--line-dark);border-radius:6px;padding:4px;
  line-height:0;transition:border-color .25s,transform .2s;
}
.lang-switch .flag{width:26px;height:17px;border-radius:3px;display:block}
.lang-switch:hover{border-color:var(--cream);transform:translateY(-1px)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;z-index:100}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--cream);transition:transform .3s var(--ease),opacity .3s}

/* Mobile menu */
@media (max-width:880px){
  .nav-toggle{display:flex}
  .nav{
    position:fixed;inset:0;background:var(--pine);
    flex-direction:column;justify-content:center;align-items:flex-start;
    padding:0 var(--gutter);gap:6px;
    clip-path:circle(0 at calc(100% - 44px) 36px);
    transition:clip-path .55s var(--ease);
    visibility:hidden;
  }
  .nav.open{clip-path:circle(150% at calc(100% - 44px) 36px);visibility:visible}
  .nav a{font-family:var(--font-display);font-variation-settings:"wdth" 110;
    font-size:clamp(1.9rem,8vw,2.6rem);font-weight:800;text-transform:uppercase;
    letter-spacing:.01em;color:var(--cream);padding:.12em 0}
  .nav a::after{height:3px}
  .nav .lang-switch{margin-top:1.8rem;padding:6px}
  .nav .lang-switch .flag{width:38px;height:25px;border-radius:4px}
  body.menu-open{overflow:hidden}
  body.menu-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.menu-open .nav-toggle span:nth-child(2){opacity:0}
  body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  color:var(--cream);isolation:isolate;
}
.hero.hero-sub{min-height:72svh}
.hero{overflow-x:clip}
.display{overflow-wrap:break-word}
@media (max-width:600px){h1.display,h2.display{hyphens:auto}}
.hero-media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero-media img{width:100%;height:100%;object-fit:cover;animation:heroZoom 14s var(--ease) forwards}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(13,31,23,.42) 0%,rgba(13,31,23,.08) 38%,rgba(13,31,23,.78) 100%);
}
.hero-content{width:100%;padding-bottom:clamp(2.4rem,6vh,4.5rem)}
.hero .eyebrow{color:#DCE8CF;text-shadow:0 1px 14px rgba(13,31,23,.55)}
@media (max-width:560px){.hero .eyebrow .coords{display:none}}
.hero h1{margin:.55em 0 .4em;text-wrap:balance;text-shadow:0 2px 28px rgba(0,0,0,.35)}
.hero .lead{color:var(--cream-70)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.hero-meta{margin-top:2.2rem;padding-top:1.2rem;border-top:1px solid var(--line-dark);color:var(--cream-70)}
.hero-meta span::before{background:var(--honey)}

/* Ticker strip under hero */
.ticker{
  background:var(--pine);color:var(--cream);
  border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);
  overflow:hidden;padding:.85rem 0;
}
.ticker-track{
  display:flex;gap:3.2rem;width:max-content;
  animation:ticker 36s linear infinite;
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
}
.ticker-track span{display:inline-flex;align-items:center;gap:3.2rem;white-space:nowrap}
.ticker-track i{font-style:normal;color:var(--honey)}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ---------- Sections ---------- */
.section{padding-block:var(--section)}
.section-dark{background:var(--pine);color:var(--cream);position:relative}
.section-head{max-width:760px;margin-bottom:clamp(2.4rem,5vw,4rem)}
.section-head h2{margin:.45em 0 .4em}

/* Topographic backdrop for dark sections */
.topo{position:absolute;inset:0;pointer-events:none;opacity:.5;overflow:hidden}
.topo svg{position:absolute;inset:0;width:100%;height:100%}
.section-dark > .container{position:relative;z-index:1}

/* ---------- About split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split-media{position:relative}
.split-media img{border-radius:var(--radius);width:100%;aspect-ratio:4/3.2;object-fit:cover;box-shadow:0 26px 60px -28px rgba(13,31,23,.45)}
.split-media .photo-tag{
  position:absolute;left:14px;bottom:14px;
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;
  background:rgba(13,31,23,.78);color:var(--cream);backdrop-filter:blur(6px);
  padding:.5em .95em;border-radius:999px;
}
.split-copy h2{margin:.45em 0 .55em}
.split-copy p+p{margin-top:1em}
.split-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.9rem}
@media (max-width:880px){.split{grid-template-columns:1fr}}

.stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);margin-top:2.4rem;padding-top:1.6rem;gap:1rem;
}
.stats div strong{
  display:block;font-family:var(--font-display);font-variation-settings:"wdth" 116;
  font-weight:850;font-size:clamp(1.6rem,3vw,2.3rem);line-height:1;
}
.stats div small{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-60)}
@media (max-width:560px){.stats{grid-template-columns:repeat(3,1fr);gap:.6rem}.stats div small{font-size:.58rem}}

/* ---------- Activities index (signature) ---------- */
.activity-index{border-top:1px solid var(--line)}
.activity-row{
  display:grid;grid-template-columns:96px 1fr auto;align-items:center;
  gap:clamp(1rem,3vw,2.4rem);
  padding:clamp(1.1rem,2.6vw,1.7rem) 0;
  border-bottom:1px solid var(--line);
  position:relative;transition:padding-left .35s var(--ease);
}
.activity-row .thumb{
  width:96px;height:68px;border-radius:10px;overflow:hidden;flex:none;
}
.activity-row .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.activity-row:hover .thumb img{transform:scale(1.12)}
.activity-row h3{
  font-family:var(--font-display);font-variation-settings:"wdth" 114;
  font-weight:820;text-transform:uppercase;
  font-size:clamp(1.25rem,3.4vw,2.1rem);line-height:1.04;
  transition:color .25s;
}
.activity-row:hover h3{color:var(--bear-dark)}
.activity-row p{color:var(--ink-60);font-size:.92rem;max-width:56ch;margin-top:.3rem}
.activity-row .row-meta{
  display:flex;flex-direction:column;align-items:flex-end;gap:.55rem;text-align:right;
}
.season-tag{
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  border:1.5px solid var(--line);border-radius:999px;padding:.45em 1em;
  color:var(--ink-60);white-space:nowrap;
  transition:background .25s,color .25s,border-color .25s;
}
.activity-row:hover .season-tag{background:var(--honey);border-color:var(--honey);color:var(--pine)}
.row-arrow{
  width:38px;height:38px;border:1.5px solid var(--line);border-radius:50%;
  display:grid;place-items:center;transition:background .25s,border-color .25s,transform .35s var(--ease);
}
.row-arrow svg{width:15px;height:15px}
.activity-row:hover .row-arrow{background:var(--pine);border-color:var(--pine);color:var(--paper);transform:rotate(-45deg)}
@media (max-width:720px){
  .activity-row{grid-template-columns:72px 1fr;row-gap:.4rem}
  .activity-row .thumb{width:72px;height:54px}
  .activity-row .row-meta{grid-column:2;flex-direction:row;align-items:center;justify-content:flex-start}
  .row-arrow{display:none}
  .activity-row p{display:none}
}

/* Floating hover preview (desktop only, JS-driven) */
.hover-preview{
  position:fixed;z-index:60;width:300px;aspect-ratio:4/3;border-radius:14px;overflow:hidden;
  pointer-events:none;opacity:0;transform:scale(.85) rotate(-3deg);
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  box-shadow:0 30px 60px -20px rgba(13,31,23,.5);
}
.hover-preview.visible{opacity:1;transform:scale(1) rotate(-2deg)}
.hover-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .25s}
.hover-preview img.active{opacity:1}
@media (hover:none),(max-width:880px){.hover-preview{display:none}}

/* ---------- CTA band ---------- */
.cta-band{text-align:center}
.cta-band h2{max-width:18ch;margin-inline:auto}
.cta-band .hero-actions{justify-content:center}

/* ---------- Gallery marquee ---------- */
.marquee{overflow:hidden;display:grid;gap:14px;padding-block:.5rem}
.marquee-row{display:flex;gap:14px;width:max-content}
.marquee-row.m1{animation:marq 42s linear infinite}
.marquee-row.m2{animation:marq 42s linear infinite reverse}
@keyframes marq{to{transform:translateX(-50%)}}
.marquee-row a{
  flex:none;width:clamp(220px,30vw,380px);aspect-ratio:4/3;
  border-radius:var(--radius);overflow:hidden;position:relative;
}
.marquee-row a img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.marquee-row a:hover img{transform:scale(1.07)}
.marquee:hover .marquee-row{animation-play-state:paused}

/* ---------- Gallery grid (activity pages) ---------- */
.gallery-grid{columns:3;column-gap:14px}
.gallery-grid a{display:block;margin-bottom:14px;border-radius:12px;overflow:hidden;position:relative;break-inside:avoid}
.gallery-grid a img{transition:transform .55s var(--ease);width:100%}
.gallery-grid a:hover img{transform:scale(1.06)}
@media (max-width:880px){.gallery-grid{columns:2}}
@media (max-width:520px){.gallery-grid{columns:2;column-gap:10px}.gallery-grid a{margin-bottom:10px}}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:200;background:rgba(13,31,23,.94);
  display:none;align-items:center;justify-content:center;padding:5vmin;
}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:88vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox button{
  position:absolute;color:var(--cream);width:52px;height:52px;border-radius:50%;
  border:1.5px solid var(--line-dark);display:grid;place-items:center;
  transition:background .25s;background:rgba(13,31,23,.5);
}
.lightbox button:hover{background:var(--bear)}
.lb-close{top:18px;right:18px}
.lb-prev{left:14px;top:50%;transform:translateY(-50%)}
.lb-next{right:14px;top:50%;transform:translateY(-50%)}
.lb-count{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%);
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;color:var(--cream-70);
}

/* ---------- Offer / detail cards ---------- */
.offer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.offer-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.4rem,3vw,2.1rem);
  display:flex;flex-direction:column;gap:.9rem;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.offer-card:hover{transform:translateY(-5px);box-shadow:0 24px 50px -28px rgba(13,31,23,.35)}
.offer-card .offer-no{
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bear-text);
}
.offer-card h3{font-size:1.25rem}
.offer-card p{color:var(--ink-60);font-size:.95rem}
.offer-specs{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto;padding-top:.6rem}
.spec{
  font-family:var(--font-mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;
  background:var(--stone);border-radius:999px;padding:.5em 1em;white-space:nowrap;
}
.offer-card.wide{grid-column:1/-1}
@media (max-width:760px){.offer-grid{grid-template-columns:1fr}}

.check-list{display:grid;gap:.55rem;margin-top:.4rem}
.check-list li{display:flex;gap:.7em;align-items:baseline;color:var(--ink-60);font-size:.95rem}
.check-list li::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--bear);flex:none;transform:translateY(-1px)}

.amenities{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.amenities .spec{background:var(--paper);border:1px solid var(--line)}

/* ---------- Horizontal activity cards (cross-links) ---------- */
.card-scroller{
  display:grid;grid-auto-flow:column;grid-auto-columns:clamp(240px,26vw,330px);
  gap:16px;overflow-x:auto;padding-bottom:1rem;
  scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--bear) transparent;
}
.card-scroller::-webkit-scrollbar{height:6px}
.card-scroller::-webkit-scrollbar-thumb{background:var(--bear);border-radius:99px}
.act-card{scroll-snap-align:start;border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:3/4;display:block;color:var(--cream)}
.act-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.act-card:hover img{transform:scale(1.08)}
.act-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(13,31,23,.85))}
.act-card .card-body{position:absolute;inset:auto 0 0 0;z-index:1;padding:1.2rem;display:flex;flex-direction:column;gap:.45rem}
.act-card .season-tag{border-color:var(--line-dark);color:var(--cream-70);align-self:flex-start}
.act-card h3{font-family:var(--font-display);font-variation-settings:"wdth" 112;font-weight:800;text-transform:uppercase;font-size:1.15rem;line-height:1.1}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.5rem,3vw,2.2rem);display:flex;flex-direction:column;gap:.5rem;
}
.contact-card .icon{
  width:46px;height:46px;border-radius:12px;background:var(--pine);color:var(--moss);
  display:grid;place-items:center;margin-bottom:.6rem;
}
.contact-card .icon svg{width:20px;height:20px}
.contact-card h3{font-size:1.1rem}
.contact-card p{color:var(--ink-60);font-size:.92rem}
.contact-card a.big{
  font-family:var(--font-mono);font-size:.92rem;letter-spacing:.03em;color:var(--bear-dark);
  margin-top:.4rem;font-weight:600;word-break:break-all;
}
.contact-card a.big:hover{text-decoration:underline}
@media (max-width:680px){.contact-grid{grid-template-columns:1fr}}

/* ---------- Form ---------- */
.form-shell{
  background:#fff;border:1px solid var(--line);border-radius:calc(var(--radius) + 4px);
  padding:clamp(1.6rem,4vw,3rem);
}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem 1.2rem}
.field{display:flex;flex-direction:column;gap:.45rem}
.field.full{grid-column:1/-1}
.field label{
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-60);
}
.field input,.field select,.field textarea{
  font:inherit;font-size:.95rem;color:var(--ink);
  background:var(--paper);border:1.5px solid var(--line);border-radius:10px;
  padding:.8em 1em;transition:border-color .25s,box-shadow .25s;width:100%;
}
.field textarea{resize:vertical;min-height:110px}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--bear);box-shadow:0 0 0 3px rgba(62,155,79,.16);
}
.form-foot{display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem;margin-top:1.6rem}
.form-note{font-size:.82rem;color:var(--ink-60);max-width:46ch}
.form-success{
  display:none;margin-top:1.4rem;padding:1.1rem 1.3rem;border-radius:10px;
  background:rgba(62,155,79,.12);border:1.5px solid var(--bear);color:var(--bear-dark);
  font-size:.94rem;
}
.form-success.show{display:block}
@media (max-width:680px){.form-grid{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.footer{background:var(--pine);color:var(--cream);padding:clamp(3rem,7vw,5rem) 0 2rem;position:relative;overflow:hidden}
.footer-top{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:2.5rem;
  padding-bottom:2.6rem;border-bottom:1px solid var(--line-dark);
}
.footer-brand img{height:44px;margin-bottom:1rem}
.footer-brand p{color:var(--cream-70);font-size:.92rem;max-width:34ch}
.footer h4{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--moss);margin-bottom:1rem;font-weight:600;
}
.footer-col ul{display:grid;gap:.55rem}
.footer-col a{color:var(--cream-70);font-size:.94rem;transition:color .2s}
.footer-col a:hover{color:var(--honey)}
.footer-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;
  padding-top:1.6rem;font-family:var(--font-mono);font-size:.7rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--cream-70);
}
.footer-watermark{
  position:absolute;left:0;right:0;bottom:-.18em;
  font-family:var(--font-display);font-variation-settings:"wdth" 124;font-weight:900;
  font-size:clamp(1.5rem,9.5vw,13rem);line-height:1;text-transform:uppercase;
  color:rgba(241,238,227,.045);text-align:center;pointer-events:none;white-space:nowrap;
  user-select:none;
}
.footer{overflow:hidden}
.footer > .container{position:relative;z-index:1}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .marquee{overflow-x:auto}
  .hero-media img{animation:none}
}

/* ---------- Utilities ---------- */
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:999;background:var(--honey);color:var(--pine);
  padding:.8em 1.4em;font-family:var(--font-mono);font-size:.8rem;border-radius:0 0 10px 0;
}
.skip-link:focus{left:0}
