/* =====================================================================
   Aspen Training Centre — shared stylesheet
   Design source of truth: official Aspen Brand Book.
   Typography: Metropolis (primary/display) + Libre Baskerville
   (editorial serif accent), self-hosted from /assets/fonts/.
   Palette: Brand Book deep green, teal, gold, light blue, slate.
   ===================================================================== */

@font-face{font-family:'Metropolis';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/metropolis/metropolis-400.woff2') format('woff2')}
@font-face{font-family:'Metropolis';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/metropolis/metropolis-500.woff2') format('woff2')}
@font-face{font-family:'Metropolis';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/metropolis/metropolis-600.woff2') format('woff2')}
@font-face{font-family:'Metropolis';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/metropolis/metropolis-700.woff2') format('woff2')}
@font-face{font-family:'Metropolis';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/fonts/metropolis/metropolis-800.woff2') format('woff2')}
@font-face{font-family:'Libre Baskerville';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/baskerville/libre-baskerville-400.woff2') format('woff2')}
@font-face{font-family:'Libre Baskerville';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/baskerville/libre-baskerville-400-italic.woff2') format('woff2')}
@font-face{font-family:'Libre Baskerville';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/baskerville/libre-baskerville-700.woff2') format('woff2')}

:root{
  --font-display:'Metropolis',Helvetica,Arial,sans-serif;
  --font-body:'Metropolis',Helvetica,Arial,sans-serif;
  --font-serif:'Libre Baskerville',Georgia,'Times New Roman',serif;

  --ink:#19302a;
  --ink-2:#3c4f49;
  --muted:#575d75;
  --line:#dfe5e2;
  --line-2:#cdd6d2;
  --bg:#ffffff;
  --paper:#f7faf9;
  --paper-2:#eef3f3;
  --accent:#165549;       /* brand deep green — primary accent */
  --accent-soft:#3a9b90;  /* brand teal — secondary accent */
  --gold:#efd05c;         /* brand gold — sparing highlight */
  --dark:#102420;         /* brand deep green — dark sections / overlays */
  --shadow:0 10px 34px rgba(16,36,32,.10), 0 2px 8px rgba(16,36,32,.06);
  --shadow-sm:0 1px 2px rgba(16,36,32,.06);
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-body);
  color:var(--ink);background:var(--bg);font-size:16.5px;line-height:1.72;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.cond{font-family:var(--font-display)}
.serif{font-family:var(--font-serif)}
.wrap{max-width:1200px;margin:0 auto;padding:0 30px}

/* Skip link (accessibility) */
.skip-link{position:absolute;left:16px;top:-60px;background:var(--ink);color:#fff;padding:12px 18px;border-radius:4px;z-index:100;font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;font-size:.85rem;transition:top .2s var(--ease)}
.skip-link:focus{top:16px}

:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

.eyebrow{
  font-family:var(--font-display);font-weight:600;
  font-size:.92rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--accent-soft)}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:30px;height:1px;background:var(--accent-soft)}

/* ---- Header ---- */
header{background:rgba(255,255,255,.9);backdrop-filter:saturate(140%) blur(12px);position:sticky;top:0;z-index:50;border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 22px rgba(28,28,30,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:96px}
.brand{display:flex;align-items:center;gap:15px}
.brand .logo{width:62px;height:62px;flex:none;border-radius:50%}
.brand .wm{line-height:1.08}
.brand .wm b{display:block;font-family:var(--font-display);font-weight:700;font-size:1.62rem;letter-spacing:.18em;color:var(--ink)}
.brand .wm span{display:block;font-family:var(--font-display);font-weight:500;font-size:.94rem;letter-spacing:.30em;text-transform:uppercase;color:#7a766c;margin-top:1px}
.menu{display:flex;align-items:center;gap:34px;margin:0;padding:0}
.menu > li{list-style:none;position:relative}
.menu .top{display:inline-flex;align-items:center;gap:6px;padding:10px 0;color:var(--ink-2);cursor:pointer;font-weight:600;font-size:.86rem;letter-spacing:.10em;text-transform:uppercase;font-family:var(--font-display);background:none;border:none}
.menu .top svg{transition:transform .25s var(--ease)}
.menu li:hover .top svg,.menu li.open .top svg{transform:rotate(180deg)}
.menu .top.link{position:relative}
.menu .top.link::after{content:"";position:absolute;left:0;bottom:2px;height:1.5px;width:0;background:var(--accent);transition:width .28s var(--ease)}
.menu li:hover .top.link::after,.menu .top.link.current::after{width:100%}
.menu .top.link.current{color:var(--ink)}
.menu .sub{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);min-width:300px;padding:9px;opacity:0;visibility:hidden;transition:.24s var(--ease);border-radius:4px}
.menu li:hover .sub,.menu li.open .sub{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.menu .sub::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}
.menu .sub a{display:block;padding:12px 15px;font-weight:500;color:var(--ink-2);font-size:.92rem;border-radius:4px;transition:background .2s,color .2s}
.menu .sub a:hover,.menu .sub a:focus-visible{background:var(--paper);color:var(--accent)}
.nav-right{display:flex;align-items:center;gap:22px}
.menu-btn{display:none;background:none;border:none;padding:8px;cursor:pointer}
.menu-btn span,.menu-btn span::before,.menu-btn span::after{display:block;width:24px;height:2px;background:var(--ink);position:relative;transition:.3s}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0}
.menu-btn span::before{top:-7px}.menu-btn span::after{top:7px}
body.open-nav .menu-btn span{background:transparent}
body.open-nav .menu-btn span::before{top:0;transform:rotate(45deg)}
body.open-nav .menu-btn span::after{top:0;transform:rotate(-45deg)}

/* ---- Hero (home — cinematic, asymmetrical) ---- */
.hero{position:relative;min-height:clamp(560px,86vh,860px);display:flex;align-items:flex-end;justify-content:flex-start;text-align:left;color:#fff;overflow:hidden}
.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(8,14,11,.80) 0%,rgba(14,22,18,.42) 48%,rgba(16,22,18,.18) 78%),linear-gradient(0deg,rgba(8,14,11,.68) 0%,rgba(8,14,11,0) 48%)}
.hero .grain,.page-hero .grain{position:absolute;inset:0;z-index:1;opacity:.22;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:240px 240px}
.hero .kicker{position:absolute;z-index:2;top:clamp(120px,18vw,200px);left:clamp(20px,5vw,64px);margin:0;writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--font-display);font-weight:600;font-size:.8rem;letter-spacing:.5em;text-transform:uppercase;color:var(--accent-soft)}
.hero .inner{position:relative;z-index:2;display:block;text-align:left;max-width:760px;padding:0 clamp(20px,5vw,64px) clamp(64px,9vw,120px) clamp(60px,9vw,128px)}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2.6rem,7vw,5.6rem);letter-spacing:.04em;margin:0;text-transform:uppercase;line-height:1.04;text-shadow:0 2px 26px rgba(0,0,0,.32)}
.hero .rule{width:64px;height:2px;background:var(--accent-soft);margin:26px 0 0}
.hero p{font-family:var(--font-display);font-weight:500;font-size:clamp(1rem,2vw,1.3rem);letter-spacing:.34em;text-transform:uppercase;margin:18px 0 0;text-indent:.34em;color:#f2efe7}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.7);animation:bob 2.4s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,7px)}}
@media (max-width:680px){
  .hero{flex-wrap:wrap;align-content:flex-end}
  .hero .kicker{flex:0 0 100%;position:static;writing-mode:horizontal-tb;transform:none;margin:0 0 14px;letter-spacing:.32em;padding-left:clamp(20px,5vw,64px)}
  .hero .inner{padding-left:clamp(20px,5vw,64px)}
}

/* ---- Page hero (inner pages — same cinematic language, shorter) ---- */
.page-hero{position:relative;min-height:clamp(360px,46vw,520px);display:flex;align-items:flex-end;justify-content:flex-start;text-align:left;color:#fff;overflow:hidden}
.page-hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(8,14,11,.82) 0%,rgba(14,22,18,.48) 52%,rgba(16,22,18,.20) 82%),linear-gradient(0deg,rgba(8,14,11,.66) 0%,rgba(8,14,11,0) 50%)}
.page-hero .inner{position:relative;z-index:2;max-width:680px;padding:clamp(64px,10vw,96px) clamp(20px,5vw,64px) clamp(48px,7vw,72px) clamp(60px,9vw,128px)}
.page-hero .kicker{font-family:var(--font-display);font-weight:600;font-size:.86rem;letter-spacing:.34em;text-transform:uppercase;color:var(--accent-soft);margin:0 0 16px}
.page-hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2.2rem,5.4vw,3.8rem);letter-spacing:.03em;margin:0;text-transform:uppercase;line-height:1.1;text-shadow:0 2px 26px rgba(0,0,0,.3)}
.page-hero .rule{width:54px;height:2px;background:var(--accent-soft);margin:22px 0 0}
.page-hero .crumb{margin:18px 0 0;font-family:var(--font-display);font-size:.86rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.page-hero .crumb a{transition:color .2s}
.page-hero .crumb a:hover{color:var(--accent-soft)}
.page-hero .crumb .sep{margin:0 .6em;color:rgba(255,255,255,.45)}
@media (max-width:400px){
  .page-hero .inner{padding-left:24px;padding-right:20px}
  .page-hero h1{font-size:1.55rem}
  .page-hero .crumb{font-size:.66rem;letter-spacing:.1em}
}

/* ===== Coming soon hero ===== */
.coming-soon{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:linear-gradient(150deg,var(--dark) 0%,var(--accent) 130%);color:#fff}
.coming-soon .ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(820px,140%);opacity:.32;pointer-events:none}
.coming-soon .grain{position:absolute;inset:0;z-index:1;opacity:.18;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:240px 240px}
.coming-soon .inner{position:relative;z-index:2;max-width:680px;padding:clamp(120px,16vw,180px) 30px clamp(64px,9vw,100px)}
.coming-soon img.crest{width:auto;height:clamp(80px,10vw,108px);margin:0 auto 30px;border-radius:50%;opacity:.92}
.coming-soon .kicker{font-family:var(--font-display);font-weight:600;font-size:.86rem;letter-spacing:.5em;text-transform:uppercase;color:var(--accent-soft);margin:0}
.coming-soon h1{font-family:var(--font-display);font-weight:700;font-size:clamp(3.2rem,9vw,6.4rem);letter-spacing:.04em;text-transform:uppercase;margin:22px 0 0;line-height:1.04;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.coming-soon .rule{width:58px;height:2px;background:var(--accent-soft);margin:30px auto}
.coming-soon p.lede{font-family:var(--font-serif);font-style:italic;font-size:clamp(1.15rem,2.4vw,1.5rem);line-height:1.7;color:rgba(255,255,255,.88);max-width:480px;margin:0 auto}
.coming-soon .crumb{margin:40px 0 0;font-family:var(--font-display);font-size:.86rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.coming-soon .crumb a{transition:color .2s}
.coming-soon .crumb a:hover{color:var(--accent-soft)}
.coming-soon .crumb .sep{margin:0 .6em;color:rgba(255,255,255,.35)}

/* ---- Intro + cards ---- */
.foundations{padding:clamp(64px,9vw,108px) 0 clamp(56px,8vw,96px)}
.section{padding:clamp(56px,8vw,96px) 0}
.section.alt,.foundations.alt{background:var(--paper)}
.sec-head{text-align:center;max-width:680px;margin:0 auto clamp(44px,5vw,64px)}
.sec-head.left{text-align:left;margin:0 0 clamp(36px,4vw,52px)}
.sec-head h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.9rem,3.6vw,2.9rem);letter-spacing:.02em;line-height:1.12;margin:18px 0 0;color:var(--ink)}
.sec-head p{margin:16px 0 0;color:var(--muted);font-size:1.04rem}

/* ---- Reusable "read more" link ---- */
.link-more{margin-top:18px;font-family:var(--font-display);font-size:.86rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:9px;transition:gap .25s var(--ease),color .25s}
.link-more .ln{width:22px;height:1.5px;background:var(--accent);transition:width .25s var(--ease)}
.link-more:hover{color:var(--accent);gap:12px}
.link-more:hover .ln{width:30px}

/* ---- Editorial row list (replaces equal-width feature/fact grids) ---- */
.editorial-list{margin-top:clamp(44px,5.5vw,72px);border-top:1px solid var(--line)}
.editorial-row{display:grid;grid-template-columns:minmax(180px,300px) 1fr;gap:clamp(24px,5vw,64px);padding:clamp(34px,4.5vw,50px) 0;border-bottom:1px solid var(--line)}
.editorial-row .eyebrow{margin-bottom:14px}
.editorial-row .eyebrow::before{display:none}
.editorial-row h3{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,2.6vw,2.15rem);letter-spacing:.01em;line-height:1.18;margin:0;color:var(--ink)}
.editorial-row .row-copy{align-self:center}
.editorial-row .row-copy p{margin:0;color:var(--muted);font-size:1.02rem;max-width:560px}
.editorial-row .row-copy p + p{margin-top:12px}
@media (max-width:760px){.editorial-row{grid-template-columns:1fr;gap:14px}}

/* ---- Split (image + copy) panels — programme & course detail pages ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,84px);align-items:center}
.split.reverse .split-media{order:2}
.split-media{position:relative;border-radius:5px;overflow:hidden;aspect-ratio:4/3;background:#e9e6df}
.split-media img{width:100%;height:100%;object-fit:cover}
.split-media::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(28,28,30,.06);border-radius:5px}
.split-copy h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.7rem,3.2vw,2.5rem);letter-spacing:.02em;line-height:1.16;margin:16px 0 0;color:var(--ink)}
.split-copy p{margin:16px 0 0;color:var(--muted);font-size:1.02rem}
.split + .split{margin-top:clamp(64px,8vw,108px)}

/* ---- Feature / highlight list ---- */
.feature-list{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:14px}
.feature-list li{display:flex;align-items:flex-start;gap:14px;color:var(--ink-2);font-size:1rem}
.feature-list svg{flex:none;margin-top:4px;color:var(--accent)}


/* ---- Roots closing band (reused as site-wide CTA) ---- */
.roots{background:var(--paper);text-align:center;padding:clamp(72px,9vw,118px) 0;position:relative;overflow:hidden}
.roots .ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(720px,120%);opacity:.5;pointer-events:none}
.roots .inner{position:relative;z-index:2}
.roots img.crest{width:auto;height:clamp(120px,15vw,172px);margin:0 auto 26px;border-radius:50%}
.roots .rule{width:54px;height:2px;background:var(--accent-soft);margin:0 auto 26px}
.roots h2{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,4.4vw,3.3rem);letter-spacing:.05em;margin:0;color:var(--ink);text-transform:uppercase}
.roots p{max-width:540px;margin:18px auto 0;color:var(--muted);font-size:1.02rem}
.btn{display:inline-flex;align-items:center;gap:.6em;margin-top:32px;padding:14px 30px;border:1.5px solid var(--ink);border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:.92rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);transition:.28s var(--ease)}
.btn:hover{background:var(--ink);color:#fff;gap:.85em}
.btn svg{transition:transform .25s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
.btn-row{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.btn.ghost{border-color:var(--line-2);color:var(--ink-2)}
.btn.ghost:hover{background:var(--ink);border-color:var(--ink);color:#fff}

/* ---- Footer ---- */
footer{background:var(--dark);color:#c9c7c1;padding:64px 0 32px;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px}
.foot-brand{display:block}
.foot-brand .logo{width:172px;height:auto;display:block;margin-bottom:18px}
.foot-brand b{font-family:var(--font-display);font-size:1.4rem;letter-spacing:.16em;color:#fff;display:block}
.foot-brand .tg{letter-spacing:.26em;text-transform:uppercase;font-size:.76rem;color:#8b8881;font-family:var(--font-display);margin-top:2px;display:block}
.foot-brand .roots-line{font-family:var(--font-display);font-size:1.12rem;letter-spacing:.05em;color:#e6e3db;margin-top:22px;max-width:280px;text-transform:uppercase}
.foot-col h4{font-family:var(--font-display);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:#8b8881;margin:0 0 16px;font-weight:600}
.foot-col a{display:block;color:#c9c7c1;padding:6px 0;font-size:.9rem;transition:color .2s}
.foot-col a:hover,.foot-col a:focus-visible{color:var(--accent-soft)}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid #2f2f31;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.82rem;color:#85827b}
.foot-bottom .soc{display:flex;gap:10px}
.foot-bottom .soc a{width:34px;height:34px;border:1px solid #353537;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#aeaba4;transition:.25s}
.foot-bottom .soc a:hover,.foot-bottom .soc a:focus-visible{background:var(--accent);border-color:var(--accent);color:#1a1a1c}

/* ---- Mobile menu ---- */
.mobile{display:none;position:fixed;inset:96px 0 0;background:#fff;z-index:40;padding:24px 30px 40px;overflow-y:auto}
.mobile a,.mobile .mlabel{display:block;padding:15px 0;border-bottom:1px solid var(--line);font-family:var(--font-display);font-size:1.5rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink)}
.mobile .mlabel{color:var(--accent);font-size:.95rem;letter-spacing:.18em;border:none;padding:22px 0 4px}
.mobile .msub{font-size:1.05rem;font-family:var(--font-body);text-transform:none;letter-spacing:0;padding-left:2px;color:#555;border-bottom:1px solid var(--line)}
body.open-nav{overflow:hidden}
body.open-nav .mobile{display:block}

/* ---- Reveal ---- */
.reveal{opacity:1;transform:none}
.reveal.pending{opacity:0;transform:translateY(22px)}
.reveal.pending.in{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .7s var(--ease)}
.editorial-row.pending,.timeline-item.pending,.grove-note.pending{transition-delay:calc(var(--i,0) * .09s)}
@media (prefers-reduced-motion:reduce){.reveal,.reveal.pending{opacity:1;transform:none}}

/* ===== Video background — same visual treatment as img.bg ===== */
.hero video.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%}
.page-hero video.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media (prefers-reduced-motion:reduce){.hero video.bg,.page-hero video.bg{display:none}}

/* ===== Grove — Aspen tree story section ===== */
.grove{position:relative;padding:clamp(100px,13vw,176px) 0;overflow:hidden;color:var(--ink);background:var(--bg)}
.grove-layout{position:relative;z-index:2;display:grid;grid-template-columns:1fr .82fr;gap:clamp(48px,6vw,110px);align-items:center}
.grove-copy{max-width:440px}
.grove-copy h2{font-family:var(--font-display);font-weight:700;font-size:clamp(2.8rem,5.6vw,4.6rem);letter-spacing:.03em;text-transform:uppercase;margin:20px 0 0;line-height:1.06}
.grove-copy .rule{width:54px;height:2px;background:var(--accent-soft);margin:32px 0}
.grove-copy p{font-family:var(--font-serif);font-size:clamp(1.05rem,1.7vw,1.22rem);line-height:1.85;color:var(--ink-2);margin:0 0 26px;max-width:32ch}
.grove-copy p.lede{font-size:clamp(1.4rem,2.6vw,1.85rem);line-height:1.5;color:var(--ink);font-weight:500;max-width:24ch}
.grove-copy p:last-child{margin:0}
.grove-copy .grove-lede{font-family:var(--font-display);font-size:clamp(1.1rem,1.6vw,1.3rem);letter-spacing:.02em;text-transform:none;color:var(--ink);font-weight:700;padding-top:26px;margin-top:8px;border-top:1px solid var(--line);max-width:none}

/* ---- Tree photograph ---- */
.grove-tree{position:relative;line-height:0}
.grove-tree img{display:block;width:100%;height:auto;border-radius:2px;-webkit-mask-image:linear-gradient(to bottom,#000 72%,transparent 100%);mask-image:linear-gradient(to bottom,#000 72%,transparent 100%);animation:tree-breathe 32s ease-in-out infinite alternate;transform-origin:center}
@keyframes tree-breathe{from{transform:scale(1)}to{transform:scale(1.035)}}
@media (max-width:960px){
  .grove-layout{grid-template-columns:1fr;text-align:left}
  .grove-copy{max-width:560px}
  .grove-copy p{max-width:none}
  .grove-copy p.lede{max-width:none}
  .grove-tree{order:-1;max-width:420px;margin:0 auto clamp(40px,8vw,64px)}
}
@media (prefers-reduced-motion:reduce){.grove-tree img{animation:none}}

/* ---- Root network ---- */
.grove-roots{position:relative;margin-top:clamp(80px,10vw,136px)}
.roots-caption{display:block;text-align:center;font-family:var(--font-display);font-weight:600;font-size:clamp(.66rem,1.6vw,.78rem);letter-spacing:clamp(.14em,1.2vw,.32em);text-transform:uppercase;color:var(--accent);margin-bottom:clamp(36px,5vw,60px);padding:0 12px}
.roots-canvas{position:relative}
.roots-svg{display:block;width:100%;height:auto;overflow:visible}
.roots-svg .root-glow{opacity:.12;filter:blur(6px)}
.roots-svg .root-glow path{animation:root-glow 7s ease-in-out infinite}
.roots-svg .root-glow path:nth-child(2){animation-delay:1.4s}
.roots-svg .root-glow path:nth-child(3){animation-delay:2.8s}
.roots-svg .root-glow path:nth-child(4){animation-delay:4.2s}
@keyframes root-glow{0%,100%{opacity:.08}50%{opacity:.26}}
.roots-svg .root-paths path{stroke-dasharray:1400;stroke-dashoffset:1400;opacity:.55;transition:stroke-dashoffset 1.8s var(--ease)}
.roots-svg.in .root-paths path{stroke-dashoffset:0}
.roots-svg .root-paths path:nth-child(1){transition-delay:0s}
.roots-svg .root-paths path:nth-child(2){transition-delay:.1s}
.roots-svg .root-paths path:nth-child(3){transition-delay:.2s}
.roots-svg .root-paths path:nth-child(4){transition-delay:.2s}
.roots-svg .root-paths path:nth-child(5){transition-delay:.35s}
.roots-svg .root-paths path:nth-child(6){transition-delay:.35s}
.roots-svg .root-mesh path{opacity:0;transition:opacity 1.4s var(--ease) .9s}
.roots-svg.in .root-mesh path{opacity:.6}
.roots-svg .root-dots circle{opacity:0;transition:opacity .8s var(--ease) 1.3s}
.roots-svg.in .root-dots circle{opacity:.9}
.roots-svg .pulse{offset-rotate:0deg;opacity:0}
.roots-svg .pulse-1{offset-path:path("M900 15 C 730 70 380 160 100 405");animation:root-travel 9s linear infinite 1.5s}
.roots-svg .pulse-2{offset-path:path("M900 15 C 850 90 630 240 460 405");animation:root-travel 11s linear infinite 4s}
.roots-svg .pulse-3{offset-path:path("M900 15 C 900 110 870 280 830 405");animation:root-travel 10s linear infinite 6.5s}
.roots-svg .pulse-4{offset-path:path("M900 15 C 980 100 1140 270 1200 405");animation:root-travel 12.5s linear infinite 2.5s}
@keyframes root-travel{0%{offset-distance:0%;opacity:0}10%{opacity:1}90%{opacity:1}100%{offset-distance:100%;opacity:0}}
.root-node{position:absolute;top:88%;transform:translate(-50%,18px);width:200px;text-align:center}
.root-node h3{font-family:var(--font-display);font-weight:700;font-size:.84rem;letter-spacing:.18em;text-transform:uppercase;margin:0 0 8px;color:var(--ink)}
.root-node p{font-size:.88rem;line-height:1.65;color:var(--muted);margin:0}
.roots-mobile{display:none}
@media (prefers-reduced-motion:reduce){
  .roots-svg .root-glow path{animation:none}
  .roots-svg .root-paths path{stroke-dashoffset:0;opacity:.55;transition:none}
  .roots-svg .root-mesh path{opacity:.6;transition:none}
  .roots-svg .root-dots circle{opacity:.9;transition:none}
  .roots-svg .pulse{display:none}
}
@media (max-width:760px){
  .roots-canvas{display:none}
  .roots-mobile{display:block;position:relative;padding-left:30px;max-width:480px;margin:0 auto}
  .roots-mobile::before{content:"";position:absolute;left:4px;top:6px;bottom:6px;width:1px;background:var(--line-2)}
  .rm-item{position:relative;padding-bottom:32px}
  .rm-item:last-child{padding-bottom:0}
  .rm-item::before{content:"";position:absolute;left:-30px;top:6px;width:9px;height:9px;border-radius:50%;background:var(--accent);transform:translateX(-4.5px)}
  .rm-item h3{font-family:var(--font-display);font-weight:700;font-size:.84rem;letter-spacing:.18em;text-transform:uppercase;margin:0 0 8px;color:var(--ink)}
  .rm-item p{font-size:.92rem;line-height:1.7;color:var(--muted);margin:0}
}

/* ===== Mondragon section ===== */
.mondragon{background:var(--dark);padding:clamp(72px,9vw,116px) 0;color:#fff}
.mondragon .sec-head h2{color:#fff}
.mondragon .sec-head p{color:rgba(255,255,255,.62)}
.mondragon .eyebrow{color:var(--accent-soft)}
.mondragon .eyebrow::before,.mondragon .eyebrow::after{background:var(--accent-soft)}
.mondragon-story{max-width:780px;margin:clamp(30px,4vw,50px) auto;text-align:center}
.mondragon-story p{color:rgba(255,255,255,.72);font-size:1.02rem;line-height:1.78;margin:0 0 16px}
.mondragon-story p:last-child{margin:0}
.mondragon-story strong{color:rgba(255,255,255,.92);font-weight:600}

/* ===== Ecosystem diagram (node-and-connector) ===== */
.ecosystem{position:relative;max-width:1060px;margin:clamp(64px,8vw,108px) auto 0}
.ecosystem-svg{width:100%;height:auto;display:block}
.ecosystem-label{position:absolute;transform:translate(-50%,-50%);text-align:center;font-family:var(--font-display);font-weight:600;font-size:1.06rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);width:218px}
.ecosystem-label .sub{display:block;margin-top:10px;font-family:var(--font-body);font-weight:400;font-size:.98rem;letter-spacing:0;text-transform:none;color:var(--muted);line-height:1.55}
.ecosystem-label.node-tl{left:17%;top:9.3%}
.ecosystem-label.node-tr{left:83%;top:9.3%}
.ecosystem-label.node-bl{left:17%;top:90.7%}
.ecosystem-label.node-br{left:83%;top:90.7%}
.ecosystem-label.center{position:absolute;left:50%;top:50%;width:auto;white-space:nowrap;font-size:1.7rem;letter-spacing:.15em;font-weight:700;color:var(--dark);background:var(--gold);padding:18px 32px;border-radius:999px;box-shadow:0 0 0 10px rgba(239,208,92,.16),0 10px 26px rgba(16,36,32,.16)}
.mondragon .ecosystem-label{color:#fff}
.mondragon .ecosystem-label .sub{color:rgba(255,255,255,.78)}
.mondragon .ecosystem-label.center{color:var(--dark);box-shadow:0 0 0 10px rgba(239,208,92,.14),0 12px 30px rgba(0,0,0,.4)}
@media (max-width:960px){
  .ecosystem-label{font-size:.94rem;width:182px}
  .ecosystem-label .sub{font-size:.9rem}
  .ecosystem-label.center{font-size:1.4rem;padding:15px 26px}
}
@media (max-width:760px){
  .ecosystem-label{font-size:.86rem;width:150px}
  .ecosystem-label .sub{font-size:.84rem}
  .ecosystem-label.center{font-size:1.18rem;padding:12px 20px;letter-spacing:.13em}
}
@media (max-width:560px){
  .ecosystem-label .sub{display:none}
  .ecosystem-label{width:128px}
  .ecosystem-label.center{font-size:1.02rem;padding:10px 17px;letter-spacing:.12em}
}

/* ===== Overview grid (program / course overview) ===== */
.overview-grid{display:grid;grid-template-columns:repeat(var(--cols,2),1fr);margin-top:clamp(48px,6vw,80px);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.overview-item{position:relative;padding:clamp(36px,4.5vw,54px) clamp(28px,4vw,44px)}
.overview-item{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.overview-item .ov-num{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(2.1rem,3.6vw,3.2rem);letter-spacing:.01em;line-height:1;color:var(--line-2);margin:0 0 20px}
.overview-item .ov-tag{display:block;font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-soft);margin:0 0 14px}
.overview-item h3{font-family:var(--font-display);font-weight:600;font-size:clamp(1.15rem,1.9vw,1.45rem);letter-spacing:.01em;margin:0 0 10px;color:var(--ink);line-height:1.25}
.overview-item p{margin:0;color:var(--muted);font-size:.96rem;line-height:1.72;max-width:42ch}
.overview-item.current{background:var(--paper)}
.overview-item.current .ov-num{color:var(--accent-soft)}
.overview-item.current .ov-tag,.overview-item.current h3{color:var(--accent)}
@media (max-width:760px){.overview-grid{grid-template-columns:1fr}.overview-item{padding:30px clamp(20px,6vw,28px)}}

/* ===== Pull quote ===== */
.pull-quote{max-width:840px;margin:clamp(48px,7vw,84px) auto 0;text-align:center;padding:0 20px}
.pull-quote p{font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:clamp(1.5rem,4vw,2.5rem);line-height:1.4;color:var(--ink);margin:0}
.pull-quote cite{display:block;margin-top:18px;font-style:normal;font-family:var(--font-display);font-weight:600;font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-soft)}
.mondragon .pull-quote p{color:#fff}

/* ===== Offset split (asymmetrical overlap) ===== */
.split.offset{grid-template-columns:1.18fr .82fr;align-items:start;gap:clamp(28px,4vw,52px)}
.split.offset .split-media{margin-top:clamp(48px,6vw,80px)}
.split.offset.reverse .split-media{margin-top:0;margin-bottom:clamp(48px,6vw,80px)}
.split.offset .split-copy{padding-top:clamp(8px,1vw,16px)}
@media (max-width:980px){.split.offset{grid-template-columns:1fr}.split.offset .split-media,.split.offset.reverse .split-media{margin:0}}

/* Mondragon ecosystem — ten cooperative principles */
.mondragon-principles{max-width:760px;margin:clamp(36px,5vw,56px) auto 0;text-align:center}
.mondragon-principles h3{font-family:var(--font-display);font-weight:600;font-size:.8rem;letter-spacing:.26em;text-transform:uppercase;color:var(--accent-soft);margin:0 0 16px}
.mondragon-principles p{font-family:var(--font-serif);font-style:italic;font-size:1.04rem;line-height:2.1;color:rgba(255,255,255,.6);margin:0}
.mondragon-principles p em{font-style:italic;color:rgba(255,255,255,.92)}

.mondragon-divider{width:56px;height:1px;background:rgba(255,255,255,.18);margin:clamp(40px,5vw,60px) auto}
.timeline{position:relative;max-width:740px;margin:0 auto clamp(48px,6vw,72px);padding-left:clamp(40px,6vw,56px)}
.timeline::before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:1px;background:rgba(255,255,255,.16)}
.timeline-item{position:relative;margin-bottom:clamp(46px,6vw,76px)}
.timeline-item:last-child{margin-bottom:0}
.timeline-item::before{content:"";position:absolute;left:calc(-1 * clamp(40px,6vw,56px) + 1px);top:8px;width:11px;height:11px;border-radius:50%;background:var(--dark);border:2px solid var(--accent-soft)}
.timeline-num{display:block;font-family:var(--font-display);font-size:.8rem;letter-spacing:.26em;color:var(--accent-soft);text-transform:uppercase;margin:0 0 10px}
.timeline-item h3{font-family:var(--font-display);font-weight:600;font-size:clamp(1.3rem,2.6vw,1.8rem);letter-spacing:.04em;text-transform:uppercase;margin:0 0 12px;color:#fff;line-height:1.2}
.timeline-item p{color:rgba(255,255,255,.60);font-size:1rem;margin:0;line-height:1.74;max-width:560px}
.mondragon-cta{text-align:center}
.mondragon .btn{border-color:rgba(255,255,255,.25);color:#fff;margin-top:0}
.mondragon .btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}

@media (max-width:980px){
  .menu{display:none}
  .menu-btn{display:block}
  .foot-grid{grid-template-columns:1fr 1fr;gap:34px}
  .foot-brand{grid-column:1/-1}
  .split,.split.reverse{grid-template-columns:1fr}
  .split-media{order:1 !important}
  .timeline{padding-left:32px}
  .timeline-item::before{left:-31px}
}
@media (max-width:560px){
  .nav{height:80px}
  .mobile{inset:80px 0 0}
  .foot-grid{grid-template-columns:1fr}
}
