/* Juggling Water — Outdoor Editorial Atlas
   Palette: forest ink, sage, water-blue, mist, cream */

:root{
  --bg:#f5f7f1;
  --paper:#fbfcf8;
  --mist:#e9efe6;
  --ink:#142421;
  --moss:#234538;
  --sage:#6f8f7c;
  --sage-2:#a7bfae;
  --water:#3f7f9a;
  --water-2:#7eb2c7;
  --sun:#d8c069;
  --rust:#b66a3e;
  --line:rgba(20,36,33,.14);
  --line-soft:rgba(20,36,33,.07);
  --shadow:0 30px 60px -30px rgba(20,36,33,.25);
  --r:18px;
  --r-lg:28px;
  --maxw:1280px;
  --gutter:clamp(20px,4vw,56px);
  --serif:"Cormorant Garamond","Source Serif Pro",Georgia,serif;
  --display:"Fraunces","Cormorant Garamond",Georgia,serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  min-height:100vh;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;cursor:pointer;color:inherit}
input,textarea,select{font:inherit;color:inherit}
ul,ol{list-style:none}

/* paper grain texture overlay */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;z-index:1;
  background-image:
    radial-gradient(rgba(35,69,56,.04) 1px,transparent 1.5px),
    radial-gradient(rgba(63,127,154,.03) 1px,transparent 1.2px);
  background-size:140px 140px,260px 260px;
  background-position:0 0,70px 70px;
  mix-blend-mode:multiply;
  opacity:.7;
}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,247,241,.82);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
}
.nav{
  max-width:var(--maxw);
  margin:0 auto;padding:18px var(--gutter);
  display:flex;align-items:center;gap:32px;
}
.logo{
  display:flex;align-items:center;gap:12px;
  font-family:var(--display);font-weight:600;
  font-size:22px;letter-spacing:-.02em;
}
.logo-mark{
  width:38px;height:38px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,var(--water-2),var(--water) 60%,var(--moss));
  position:relative;flex:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.4),0 6px 14px -4px rgba(63,127,154,.45);
}
.logo-mark::after{
  content:"";position:absolute;inset:6px;border-radius:50%;
  border:1px dashed rgba(255,255,255,.55);
}
.nav-links{
  display:flex;gap:6px;margin-left:auto;align-items:center;flex-wrap:wrap;
}
.nav-links a{
  font-size:13.5px;font-weight:500;
  padding:9px 14px;border-radius:99px;
  letter-spacing:.01em;color:#3a4a44;
  transition:.2s;
}
.nav-links a:hover{background:var(--mist);color:var(--moss)}
.nav-links a.active{
  background:var(--moss);color:#f3f8f1;
}
.nav-cta{
  background:var(--ink);color:var(--bg)!important;
  padding:11px 18px!important;border-radius:99px;
}
.nav-cta:hover{background:var(--moss)!important}

.menu-btn{display:none;width:42px;height:42px;border-radius:50%;background:var(--mist);align-items:center;justify-content:center}
.menu-btn span{display:block;width:18px;height:2px;background:var(--ink);position:relative}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
.menu-btn span::before{top:-6px}.menu-btn span::after{top:6px}

@media (max-width:880px){
  .nav-links{
    position:fixed;inset:72px 0 0;background:var(--bg);
    flex-direction:column;align-items:stretch;
    padding:24px var(--gutter);gap:4px;
    transform:translateX(100%);transition:transform .35s;
    overflow:auto;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{padding:14px 16px;font-size:16px;border-radius:14px}
  .menu-btn{display:flex;margin-left:auto}
}

/* ============ HERO ============ */
.hero{
  max-width:var(--maxw);margin:0 auto;
  padding:60px var(--gutter) 80px;
  position:relative;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;
}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;gap:40px}}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11.5px;text-transform:uppercase;
  letter-spacing:.18em;color:var(--moss);font-weight:500;
  padding:8px 14px;background:var(--mist);border-radius:99px;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--water);box-shadow:0 0 0 4px rgba(63,127,154,.18)}

h1.title,.title-xl{
  font-family:var(--display);font-weight:400;
  font-size:clamp(44px,7vw,96px);
  line-height:.96;letter-spacing:-.025em;
  margin-top:20px;color:var(--ink);
}
.title-xl em{font-style:italic;color:var(--water);font-weight:500}
.title-xl .sketch{
  position:relative;display:inline-block;
}
.title-xl .sketch::after{
  content:"";position:absolute;left:-4%;right:-4%;bottom:.05em;height:.12em;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 18' preserveAspectRatio='none'><path d='M2 12 C 80 2, 160 18, 240 8 S 380 14, 398 6' stroke='%236f8f7c' stroke-width='3' fill='none' stroke-linecap='round'/></svg>") center/100% 100% no-repeat;
  opacity:.85;
}

.lede{
  margin-top:24px;font-size:18px;line-height:1.65;
  color:#3a4a44;max-width:55ch;
}

.hero-actions{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:99px;
  font-weight:500;font-size:14.5px;letter-spacing:.01em;
  transition:.25s;
}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--moss);transform:translateY(-1px)}
.btn-ghost{border:1px solid var(--line);background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--mist);border-color:var(--moss)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}

/* hero collage */
.hero-collage{
  position:relative;aspect-ratio:1/1.1;max-width:520px;justify-self:end;width:100%;
}
@media (max-width:900px){.hero-collage{justify-self:start;max-width:440px}}
.hc-img{
  position:absolute;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow);
}
.hc-img img{width:100%;height:100%;object-fit:cover}
.hc-1{left:0;top:0;width:64%;height:62%;transform:rotate(-2deg)}
.hc-2{right:0;top:18%;width:46%;height:52%;border-radius:50%;box-shadow:0 30px 70px -25px rgba(63,127,154,.55)}
.hc-3{left:14%;bottom:0;width:60%;height:42%;transform:rotate(1.5deg)}
.hc-badge{
  position:absolute;right:-6%;bottom:14%;
  width:140px;height:140px;border-radius:50%;
  background:var(--moss);color:var(--bg);
  display:flex;align-items:center;justify-content:center;
  text-align:center;padding:18px;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.18em;text-transform:uppercase;line-height:1.4;
  animation:spin 26s linear infinite;
  z-index:2;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* hero stats */
.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  margin-top:90px;background:var(--line-soft);
  border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;
}
.hero-stats .s{
  background:var(--paper);padding:24px 22px;
}
.hero-stats .num{font-family:var(--display);font-size:42px;line-height:1;letter-spacing:-.03em;color:var(--moss)}
.hero-stats .lbl{margin-top:8px;font-size:12.5px;color:#5a6963;letter-spacing:.04em}
@media (max-width:760px){.hero-stats{grid-template-columns:repeat(2,1fr)}}

/* ============ SECTIONS ============ */
.section{
  max-width:var(--maxw);margin:0 auto;
  padding:90px var(--gutter);
  position:relative;
}
.section--alt{
  background:var(--paper);
  max-width:none;
}
.section--alt > .inner{
  max-width:var(--maxw);margin:0 auto;
  padding:90px var(--gutter);
}

.section-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:56px}
@media (max-width:820px){.section-head{grid-template-columns:1fr;gap:20px}}
.section-head h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(34px,5vw,60px);line-height:1.02;letter-spacing:-.02em;
}
.section-head h2 em{font-style:italic;color:var(--water)}
.section-head p{color:#3a4a44;font-size:16.5px;max-width:48ch;justify-self:end}
@media (max-width:820px){.section-head p{justify-self:start}}

/* wave divider */
.wave{
  display:block;width:100%;height:64px;color:var(--paper);
}

/* ============ CARDS GRID — STORIES ============ */
.story-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
}
.story-card{
  grid-column:span 4;
  background:var(--paper);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line-soft);
  transition:.35s;display:flex;flex-direction:column;
}
.story-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.story-card .ph{aspect-ratio:4/3;overflow:hidden;position:relative}
.story-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.story-card:hover .ph img{transform:scale(1.06)}
.story-card .ph::after{
  content:"";position:absolute;inset:auto 0 0 0;height:40%;
  background:linear-gradient(to top,rgba(20,36,33,.45),transparent);
}
.story-card .meta{position:absolute;left:14px;bottom:14px;color:#fff;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;z-index:2;display:flex;gap:10px;align-items:center}
.story-card .meta .pill{background:rgba(255,255,255,.18);backdrop-filter:blur(6px);padding:4px 10px;border-radius:99px;border:1px solid rgba(255,255,255,.3)}
.story-card .body{padding:24px 24px 28px;flex:1;display:flex;flex-direction:column;gap:10px}
.story-card h3{font-family:var(--display);font-weight:500;font-size:24px;line-height:1.15;letter-spacing:-.01em}
.story-card p{font-size:14.5px;color:#4a5953;line-height:1.55}
.story-card .more{margin-top:auto;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--moss);display:inline-flex;gap:8px;align-items:center}
.story-card.size-lg{grid-column:span 6}
.story-card.size-sm{grid-column:span 3}
.story-card.size-half{grid-column:span 6}
@media (max-width:980px){.story-card,.story-card.size-lg,.story-card.size-sm,.story-card.size-half{grid-column:span 6}}
@media (max-width:560px){.story-card,.story-card.size-lg,.story-card.size-sm,.story-card.size-half{grid-column:span 12}}

/* ============ ROUTE NOTES ============ */
.routes{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
@media (max-width:900px){.routes{grid-template-columns:1fr}}
.route{
  background:var(--paper);border-radius:var(--r-lg);
  padding:30px;border:1px solid var(--line-soft);
  position:relative;overflow:hidden;
  transition:.3s;
}
.route:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--sage-2)}
.route .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--water);
}
.route h3{font-family:var(--display);font-weight:500;font-size:28px;line-height:1.1;margin-top:14px;letter-spacing:-.01em}
.route p{margin-top:14px;font-size:15px;color:#4a5953}
.route .row{margin-top:24px;display:flex;justify-content:space-between;padding-top:18px;border-top:1px dashed var(--line);font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:#5a6963;text-transform:uppercase}
.route .row span:last-child{color:var(--moss)}
.route .path{
  position:absolute;right:-30px;bottom:-30px;width:160px;height:160px;opacity:.18;
  color:var(--moss);
}

/* ============ EDITORIAL SPLIT ============ */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:36px}}
.split-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:5/6;box-shadow:var(--shadow);position:relative}
.split-img img{width:100%;height:100%;object-fit:cover}
.split-img .tag{position:absolute;left:20px;top:20px;background:rgba(20,36,33,.78);color:#f3f8f1;padding:8px 14px;border-radius:99px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;backdrop-filter:blur(8px)}
.split-text h3{font-family:var(--display);font-weight:400;font-size:clamp(30px,4vw,48px);line-height:1.04;letter-spacing:-.02em}
.split-text h3 em{font-style:italic;color:var(--water)}
.split-text p{margin-top:18px;color:#3a4a44;font-size:16px;line-height:1.65}
.split-text .list{margin-top:24px;display:flex;flex-direction:column;gap:14px}
.split-text .list li{display:flex;gap:14px;padding:14px 0;border-bottom:1px dashed var(--line);font-size:15px}
.split-text .list .n{font-family:var(--mono);color:var(--water);font-size:12.5px;letter-spacing:.1em;min-width:40px}

/* ============ FIELD JOURNAL ============ */
.journal{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
@media (max-width:780px){.journal{grid-template-columns:1fr}}
.journal-entry{
  background:var(--paper);border-radius:var(--r);
  padding:30px;border-left:3px solid var(--sage);
  position:relative;
}
.journal-entry .date{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--water)}
.journal-entry h4{font-family:var(--display);font-size:24px;font-weight:500;margin-top:10px;line-height:1.15}
.journal-entry p{margin-top:14px;color:#4a5953;font-size:15px;line-height:1.65}
.journal-entry .geo{margin-top:18px;font-size:13px;color:var(--moss);display:flex;align-items:center;gap:8px;font-family:var(--mono);letter-spacing:.06em}

/* ============ THEMATIC GRID ============ */
.theme-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
@media (max-width:980px){.theme-grid{grid-template-columns:repeat(2,1fr)}}
.theme{
  grid-column:span 2;background:var(--paper);
  border-radius:var(--r);padding:28px;
  border:1px solid var(--line-soft);
  transition:.3s;display:flex;flex-direction:column;justify-content:space-between;
  min-height:200px;
}
.theme:hover{background:var(--moss);color:#f3f8f1;transform:translateY(-4px)}
.theme:hover .ic{color:var(--sun)}
.theme:hover .count{border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.7)}
.theme .ic{width:42px;height:42px;color:var(--moss);transition:.3s}
.theme h4{font-family:var(--display);font-weight:500;font-size:22px;margin-top:16px;line-height:1.1}
.theme p{font-size:13.5px;margin-top:8px;opacity:.85;line-height:1.5}
.theme .count{margin-top:20px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;border-top:1px solid var(--line-soft);padding-top:14px;color:#5a6963}
.theme.wide{grid-column:span 3}
.theme.big{grid-column:span 4;min-height:280px}
@media (max-width:980px){.theme.wide,.theme.big{grid-column:span 2}}

/* ============ MAP ============ */
.map-section{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:center;
}
@media (max-width:900px){.map-section{grid-template-columns:1fr}}
.map-wrap{
  border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:5/4;box-shadow:var(--shadow);
  background:var(--mist);
}
.map-wrap iframe{width:100%;height:100%;border:0;filter:hue-rotate(-15deg) saturate(.78) brightness(1.02)}

/* ============ FAQ ============ */
.faq-list{display:flex;flex-direction:column;gap:14px;max-width:880px;margin:0 auto}
.faq{
  background:var(--paper);border-radius:var(--r);
  border:1px solid var(--line-soft);overflow:hidden;
  transition:.2s;
}
.faq[open]{box-shadow:var(--shadow);border-color:var(--sage-2)}
.faq summary{
  list-style:none;cursor:pointer;
  padding:24px 28px;display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--display);font-size:21px;font-weight:500;line-height:1.2;
}
.faq summary::-webkit-details-marker{display:none}
.faq .plus{
  flex:none;width:34px;height:34px;border-radius:50%;
  background:var(--mist);display:grid;place-items:center;
  transition:.25s;color:var(--moss);
}
.faq[open] .plus{transform:rotate(45deg);background:var(--moss);color:var(--bg)}
.faq .ans{padding:0 28px 28px;color:#4a5953;font-size:15.5px;line-height:1.7;max-width:72ch}

/* ============ TESTIMONIAL / QUOTE ============ */
.pull{
  max-width:980px;margin:0 auto;text-align:center;
}
.pull blockquote{
  font-family:var(--display);font-weight:400;font-style:italic;
  font-size:clamp(28px,4vw,46px);line-height:1.2;letter-spacing:-.01em;
  color:var(--ink);
}
.pull blockquote::before{content:"«";color:var(--water);font-size:1.4em;line-height:0;display:block;margin-bottom:.1em}
.pull cite{display:block;margin-top:24px;font-style:normal;font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--moss)}

/* ============ CONTACT / FORM ============ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:start}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:36px}}
.contact-info{display:flex;flex-direction:column;gap:24px}
.contact-info .block{
  background:var(--paper);border-radius:var(--r);
  padding:24px;border:1px solid var(--line-soft);
}
.contact-info .block .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--water)}
.contact-info .block .val{margin-top:8px;font-family:var(--display);font-size:22px;font-weight:500;line-height:1.25}

.contact-form{
  background:var(--paper);border-radius:var(--r-lg);
  padding:36px;border:1px solid var(--line-soft);box-shadow:var(--shadow);
}
.contact-form h3{font-family:var(--display);font-size:30px;font-weight:500;line-height:1.1}
.contact-form p{margin-top:8px;color:#4a5953;font-size:14.5px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
@media (max-width:540px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#5a6963}
.field input,.field textarea,.field select{
  padding:14px 16px;border-radius:14px;border:1px solid var(--line);
  background:#fff;transition:.2s;font-size:15px;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--moss);box-shadow:0 0 0 4px rgba(35,69,56,.1)}
.field textarea{min-height:130px;resize:vertical;font-family:var(--sans)}
.form-full{grid-column:1/-1}
.form-actions{margin-top:24px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.form-actions .hint{font-size:12.5px;color:#5a6963;font-family:var(--mono);letter-spacing:.06em}

/* ============ FOOTER ============ */
footer.site-footer{
  background:#0e1a18;color:#cfd9d3;
  padding:80px var(--gutter) 32px;margin-top:80px;
}
.footer-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.3fr 1fr 1fr 1.1fr;gap:48px}
@media (max-width:900px){.footer-inner{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:560px){.footer-inner{grid-template-columns:1fr}}
.footer-brand .logo{color:#f3f8f1}
.footer-brand p{margin-top:18px;font-size:14px;line-height:1.65;color:#9ba8a3;max-width:38ch}
.footer-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#9ba8a3;margin-bottom:18px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col li a{font-size:14.5px;color:#cfd9d3;transition:.2s}
.footer-col li a:hover{color:var(--sage-2)}
.footer-contact .row{font-size:14px;color:#cfd9d3;margin-bottom:10px;display:flex;gap:10px}
.footer-contact .row .ic{flex:none;color:var(--sage-2);margin-top:3px}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{
  width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;background:rgba(255,255,255,.06);
  color:#cfd9d3;transition:.25s;
}
.socials a:hover{background:var(--sage);color:#0e1a18;transform:translateY(-2px)}
.footer-bottom{
  max-width:var(--maxw);margin:48px auto 0;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;font-size:12.5px;color:#7a857f;flex-wrap:wrap;gap:12px;
  font-family:var(--mono);letter-spacing:.06em;
}

/* ============ COOKIE BANNER ============ */
.cookie{
  position:fixed;left:24px;right:24px;bottom:24px;z-index:80;
  background:#0e1a18;color:#cfd9d3;
  border-radius:18px;padding:20px 24px;
  display:flex;gap:18px;align-items:center;justify-content:space-between;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.4);
  transform:translateY(140%);transition:transform .5s cubic-bezier(.5,1.4,.3,1);
  flex-wrap:wrap;
  max-width:760px;margin:0 auto;
}
.cookie.show{transform:translateY(0)}
.cookie p{font-size:13.5px;line-height:1.55;flex:1;min-width:260px}
.cookie a{color:var(--sage-2);text-decoration:underline}
.cookie button{padding:10px 18px;border-radius:99px;background:var(--sage);color:#0e1a18;font-weight:500;font-size:13px}
.cookie button:hover{background:#a7bfae}
.cookie .x{background:transparent;color:#9ba8a3;padding:8px 12px}

/* ============ BACK TO TOP ============ */
.b2t{
  position:fixed;right:24px;bottom:24px;z-index:60;
  width:48px;height:48px;border-radius:50%;
  background:var(--moss);color:#f3f8f1;
  display:grid;place-items:center;
  box-shadow:0 14px 30px -10px rgba(35,69,56,.4);
  opacity:0;pointer-events:none;transform:translateY(20px);
  transition:.35s;
}
.b2t.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.b2t:hover{background:var(--ink)}

/* ============ ANIMATIONS (no opacity-0 hide!) ============ */
.fx-up{will-change:transform}
.fx-fade{will-change:opacity,transform}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ============ DECORATIVE SVG WAVES ============ */
.water-divider{
  position:relative;height:80px;margin:40px 0;
}
.water-divider svg{position:absolute;inset:0;width:100%;height:100%}

/* ============ PAGE-SPECIFIC HEADER ============ */
.page-hero{
  padding:60px var(--gutter) 50px;
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:end;
}
@media (max-width:900px){.page-hero{grid-template-columns:1fr}}
.page-hero .crumb{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--water);display:flex;gap:10px;align-items:center}
.page-hero h1{
  font-family:var(--display);font-weight:400;
  font-size:clamp(40px,6vw,76px);line-height:.98;letter-spacing:-.025em;
  margin-top:20px;
}
.page-hero h1 em{font-style:italic;color:var(--water)}
.page-hero .intro{font-size:17.5px;color:#3a4a44;line-height:1.65}

/* ============ GALLERY MASONRY ============ */
.masonry{
  columns:3;column-gap:18px;
}
@media (max-width:880px){.masonry{columns:2}}
@media (max-width:540px){.masonry{columns:1}}
.masonry figure{
  break-inside:avoid;margin-bottom:18px;border-radius:var(--r);overflow:hidden;position:relative;
  cursor:pointer;
}
.masonry figure img{width:100%;height:auto;display:block;transition:transform .8s}
.masonry figure:hover img{transform:scale(1.04)}
.masonry figcaption{
  position:absolute;left:14px;bottom:14px;
  background:rgba(20,36,33,.75);color:#f3f8f1;backdrop-filter:blur(6px);
  padding:6px 12px;border-radius:99px;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  opacity:0;transform:translateY(10px);transition:.3s;
}
.masonry figure:hover figcaption{opacity:1;transform:translateY(0)}

/* ============ TIMELINE ============ */
.timeline{
  position:relative;padding-left:42px;
}
.timeline::before{
  content:"";position:absolute;left:14px;top:8px;bottom:8px;width:2px;
  background:linear-gradient(to bottom,var(--water),var(--sage-2),transparent);
}
.tl-item{position:relative;padding-bottom:48px}
.tl-item::before{
  content:"";position:absolute;left:-34px;top:8px;width:14px;height:14px;border-radius:50%;
  background:var(--paper);border:2px solid var(--water);box-shadow:0 0 0 6px rgba(63,127,154,.12);
}
.tl-item .year{font-family:var(--mono);font-size:12px;color:var(--water);letter-spacing:.12em;text-transform:uppercase}
.tl-item h4{font-family:var(--display);font-size:24px;font-weight:500;margin-top:8px;line-height:1.2}
.tl-item p{margin-top:10px;color:#4a5953;font-size:15px;line-height:1.65;max-width:64ch}

/* ============ FEATURE STRIP ============ */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media (max-width:900px){.features{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.features{grid-template-columns:1fr}}
.feature{
  padding:24px;border-radius:var(--r);background:var(--paper);
  border:1px solid var(--line-soft);
}
.feature .ic{width:38px;height:38px;color:var(--water);margin-bottom:14px}
.feature h4{font-family:var(--display);font-size:20px;font-weight:500;line-height:1.2}
.feature p{font-size:14px;color:#5a6963;margin-top:8px;line-height:1.55}

/* ============ MARQUEE ============ */
.marquee{
  overflow:hidden;mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);
  padding:30px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  margin:60px 0;background:var(--paper);
}
.marquee-track{
  display:flex;gap:60px;animation:scroll 40s linear infinite;
  font-family:var(--display);font-size:34px;font-weight:400;color:var(--moss);
  white-space:nowrap;
}
.marquee-track span{display:inline-flex;align-items:center;gap:60px}
.marquee-track span::after{content:"✦";color:var(--water);font-size:24px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============ ARCHIVE LIST ============ */
.archive{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.archive .item{
  display:grid;grid-template-columns:60px 1fr auto 80px;gap:24px;align-items:center;
  padding:24px 8px;border-bottom:1px solid var(--line);
  transition:.2s;cursor:pointer;
}
.archive .item:hover{background:var(--mist);padding-left:24px}
.archive .item .yr{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--water)}
.archive .item h4{font-family:var(--display);font-size:22px;font-weight:500;line-height:1.2}
.archive .item .cat{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#5a6963;padding:6px 12px;border-radius:99px;background:var(--mist)}
.archive .item .arr{color:var(--moss);transition:transform .2s}
.archive .item:hover .arr{transform:translateX(6px)}
@media (max-width:680px){.archive .item{grid-template-columns:60px 1fr;gap:14px}.archive .item .cat,.archive .item .arr{display:none}}

/* ============ INFO LIST ============ */
.info-rows{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.info-rows .row{
  display:grid;grid-template-columns:240px 1fr;gap:24px;padding:24px 0;
  border-bottom:1px solid var(--line);align-items:start;
}
@media (max-width:680px){.info-rows .row{grid-template-columns:1fr;gap:8px}}
.info-rows .row .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--water);padding-top:4px}
.info-rows .row .v{font-size:16px;color:var(--ink);line-height:1.6}

/* ============ STICKY SIDE ============ */
.aside-layout{display:grid;grid-template-columns:1fr 280px;gap:48px;align-items:start}
@media (max-width:900px){.aside-layout{grid-template-columns:1fr}}
.aside-layout aside{position:sticky;top:100px}
.aside-layout aside h5{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--water);margin-bottom:14px}
.aside-layout aside ul li{padding:10px 14px;border-radius:10px;font-size:14px;color:#4a5953;cursor:pointer;transition:.2s}
.aside-layout aside ul li:hover{background:var(--mist);color:var(--moss)}
.aside-layout aside ul li.active{background:var(--moss);color:var(--bg)}

/* misc */
.note{font-size:12.5px;color:#5a6963;font-family:var(--mono);letter-spacing:.06em}
.center{text-align:center}
.muted{color:#5a6963}
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.tag-row .tg{
  background:var(--mist);color:var(--moss);padding:7px 13px;border-radius:99px;
  font-size:12px;font-family:var(--mono);letter-spacing:.06em;
}
