/* ============================================================
   BHUMI — NeuroBody™ Academy
   Design system: cream / olive / hermès orange
   Type: Fraunces (display) · Space Grotesk (tech/body UI)
   ============================================================ */

:root{
  --cream:        #F6F1E6;
  --cream-deep:   #EDE6D4;
  --cream-card:   #FBF8F0;
  --olive:        #3A4226;
  --olive-deep:   #272D18;
  --olive-mid:    #5C6542;
  --olive-soft:   #8A9070;
  --orange:       #F3701F;
  --orange-deep:  #D85C10;
  --ink:          #202514;
  --line:         rgba(58,66,38,.14);
  --line-strong:  rgba(58,66,38,.28);

  --serif: "Fraunces", Georgia, serif;
  --sans:  "Space Grotesk", "Helvetica Neue", Arial, sans-serif;

  --max: 1280px;
  --pad: clamp(20px, 4vw, 56px);
  --r: 18px;
  --ease: cubic-bezier(.22,1,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--orange);color:var(--cream)}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---------- grain ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:2000;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
}

/* ---------- typography ---------- */
h1,h2,h3,.serif{font-family:var(--serif);font-weight:430;line-height:1.08;letter-spacing:-.015em;color:var(--olive-deep)}
.d1{font-size:clamp(2.9rem,7.2vw,6.2rem)}
.d2{font-size:clamp(2.1rem,4.6vw,3.8rem)}
.d3{font-size:clamp(1.5rem,2.6vw,2.2rem);line-height:1.18}
.lede{font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.7;color:var(--olive);max-width:46em}
p{color:#43492f;max-width:62em}
em{font-style:italic}
.serif-i{font-family:var(--serif);font-style:italic;font-weight:400}

.eyebrow{
  font-family:var(--sans);font-size:.72rem;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;color:var(--olive-mid);
  display:flex;align-items:center;gap:14px;margin-bottom:26px;
}
.eyebrow .idx{color:var(--orange);letter-spacing:.1em}
.eyebrow::after{content:"";height:1px;width:64px;background:var(--line-strong)}
.mono{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;font-weight:500}

/* ---------- layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{position:relative}
.sec{padding:clamp(80px,11vw,150px) 0}
.sec-tight{padding:clamp(56px,8vw,96px) 0}
.hairline-top{border-top:1px solid var(--line)}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,84px);align-items:start}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:960px){.grid2,.grid3,.grid4{grid-template-columns:1fr}}
@media(min-width:640px) and (max-width:960px){.grid4,.grid3{grid-template-columns:1fr 1fr}}
.span2{grid-column:span 2}
@media(max-width:640px){.span2{grid-column:auto}}

/* vertical hairlines, lab-grid feel */
.lab-grid{position:absolute;inset:0;pointer-events:none;z-index:0}
.lab-grid i{position:absolute;top:0;bottom:0;width:1px;background:var(--line);opacity:.55}
.lab-grid i:nth-child(1){left:25%}.lab-grid i:nth-child(2){left:50%}.lab-grid i:nth-child(3){left:75%}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;white-space:nowrap;
  font-family:var(--sans);font-size:.8rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  padding:18px 32px;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:all .45s var(--ease);position:relative;overflow:hidden;
}
.btn .arr{transition:transform .45s var(--ease);font-weight:400}
.btn:hover .arr{transform:translateX(6px)}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--olive-deep);box-shadow:0 18px 40px -16px rgba(39,45,24,.55)}
.btn-olive{background:var(--olive-deep);color:var(--cream)}
.btn-olive:hover{background:var(--orange);color:#fff;box-shadow:0 18px 40px -16px rgba(216,92,16,.5)}
.btn-ghost{border-color:var(--line-strong);color:var(--olive-deep);background:transparent}
.btn-ghost:hover{border-color:var(--olive-deep);background:var(--olive-deep);color:var(--cream)}
.btn-light{background:var(--cream);color:var(--olive-deep)}
.btn-light:hover{background:var(--orange);color:#fff}
.tlink{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.78rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange-deep);border-bottom:1px solid rgba(243,112,31,.4);
  padding-bottom:6px;transition:gap .35s var(--ease),border-color .35s;
}
.tlink:hover{gap:16px;border-color:var(--orange)}
.cta-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}

/* ---------- header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .4s,box-shadow .4s,transform .45s var(--ease);
}
.site-header.scrolled{
  background:rgba(246,241,230,.86);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  box-shadow:0 1px 0 var(--line);
}
.site-header.hidden{transform:translateY(-100%)}
/* light header while over the cinematic photo */
.site-header.on-dark:not(.scrolled) .mark{filter:brightness(0) invert(.96)}
.site-header.on-dark:not(.scrolled) .word,
.site-header.on-dark:not(.scrolled) .nav-links a{color:var(--cream)}
.site-header.on-dark:not(.scrolled) .nav-links a.active{color:#fff}
.site-header.on-dark:not(.scrolled) .tag{color:rgba(246,241,230,.7);border-color:rgba(246,241,230,.3)}
.site-header.on-dark:not(.scrolled) .burger i{background:var(--cream)}
.nav-inner{
  max-width:var(--max);margin:0 auto;padding:0 var(--pad);
  display:flex;align-items:center;justify-content:space-between;height:84px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand .mark{height:42px;width:auto;display:block}
.brand .word{font-family:var(--serif);font-size:1.3rem;letter-spacing:.3em;color:var(--olive-deep);font-weight:430;text-transform:lowercase;transform:translateY(1px)}
/* macron over the u — drawn in CSS so letter-spacing can't detach it (bhūmi) */
.brand .word .um{position:relative}
.brand .word .um::before{content:"";position:absolute;left:0;width:.58em;height:.06em;top:.06em;background:currentColor;border-radius:.04em;pointer-events:none}
.brand .tag{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--olive-mid);border-left:1px solid var(--line-strong);padding-left:14px}
@media(max-width:840px){.brand .tag{display:none}}
@media(max-width:480px){.brand .word{display:none}}

.nav-links{display:flex;gap:20px;align-items:center}
.nav-links a{
  font-size:.74rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--olive);position:relative;padding:6px 0;white-space:nowrap;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--orange);transition:width .35s var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--olive-deep)}
.nav-links a.nav-cta{margin-left:10px;padding:14px 30px;font-size:.7rem}
@media(max-width:1280px){.nav-links{display:none}}

.burger{display:none;background:none;border:none;cursor:pointer;width:44px;height:44px;position:relative;z-index:1102}
.burger i{display:block;width:26px;height:2px;background:var(--olive-deep);margin:6px auto;transition:.4s var(--ease)}
@media(max-width:1280px){.burger{display:block}}
.burger.open i:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open i:nth-child(2){opacity:0}
.burger.open i:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:0;background:var(--olive-deep);z-index:1100;
  display:flex;flex-direction:column;justify-content:flex-start;
  padding:max(96px,env(safe-area-inset-top, 0px) + 96px) 8vw max(48px,env(safe-area-inset-bottom, 0px) + 48px);
  overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  clip-path:inset(0 0 100% 0);transition:clip-path .6s var(--ease);
}
.mobile-menu.open{clip-path:inset(0 0 0 0)}
.mobile-menu a{
  font-family:var(--serif);font-size:clamp(1.15rem,3.2vh,1.6rem);color:var(--cream);
  line-height:1.25;flex:none;
  padding:.55em 0;border-bottom:1px solid rgba(246,241,230,.1);
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.mobile-menu a .n{font-family:var(--sans);font-size:.6rem;letter-spacing:.3em;color:var(--orange);flex:none}
.mobile-menu a.active{color:var(--orange)}

/* ---------- hero (shared) ---------- */
.hero{
  min-height:88vh;display:flex;align-items:flex-end;
  padding:170px 0 clamp(56px,8vh,96px);position:relative;overflow:hidden;
}
.hero-sub{margin-top:32px}
.page-hero{min-height:64vh}
#neural-canvas,.hero-canvas,canvas.fx{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.hero .wrap{position:relative;z-index:2}
.hero-meta{
  display:flex;gap:28px;flex-wrap:wrap;margin-bottom:30px;
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--olive-mid);
}
.hero-meta b{color:var(--orange);font-weight:600}

/* supreme hero: cream, giant verbs, rotating dot-orb */
.hero-supreme{align-items:center;min-height:96svh}
.hero-supreme .wrap{flex:1 1 100%;width:100%}

/* Accreditation / credential badge */
.cred-row{display:flex;align-items:center;gap:28px;flex-wrap:wrap;margin-top:34px}
.cred-badge{height:104px;width:auto;display:block}
/* small inline credential (e.g. contact hero) */
.hero-cred{display:flex;align-items:center;gap:16px;margin-top:30px;max-width:30em}
.hero-cred img{height:54px;width:auto;flex:none}
.hero-cred span{font-size:.8rem;line-height:1.5;color:var(--olive-mid)}
.hero-cred strong{color:var(--olive-deep);font-weight:600}

/* FAQ accordion */
.faq details{border-bottom:1px solid var(--line)}
.faq details:first-child{border-top:1px solid var(--line)}
.faq summary{
  list-style:none;cursor:pointer;padding:22px 40px 22px 0;position:relative;
  font-family:var(--serif);font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-family:var(--sans);font-size:1.4rem;color:var(--orange);transition:transform .3s var(--ease)
}
.faq details[open] summary::after{content:"–"}
.faq summary:hover{color:var(--orange-deep)}
.faq details p{padding:0 40px 24px 0;max-width:62ch;color:var(--olive-mid);line-height:1.7}
.hero-supreme .orb-wrap{
  position:absolute;top:50%;right:max(-6vw,-120px);transform:translateY(-50%);
  width:min(52vw,760px);aspect-ratio:1;pointer-events:none;
}
.hero-supreme .orb-wrap::before{
  content:"";position:absolute;inset:8%;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,rgba(243,112,31,.07),rgba(92,101,66,.06) 55%,transparent 72%);
}
#orb-canvas{width:100%;height:100%;display:block}
@media(max-width:960px){
  .hero-supreme .orb-wrap{width:88vw;right:-30vw;opacity:.4}
}
.mantra{display:block}
.mantra .vrb{
  font-style:italic;color:var(--orange);
  font-size:clamp(3.4rem,9vw,8rem);line-height:.95;letter-spacing:-.02em;
  background:linear-gradient(110deg,var(--orange) 42%,#ffc296 50%,var(--orange) 58%);
  background-size:260% 100%;background-position:120% 0;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:sheen 6.5s ease-in-out infinite;
}
.mantra .ln:nth-child(2) .vrb{animation-delay:.7s}
.mantra .ln:nth-child(3) .vrb{animation-delay:1.4s}
@keyframes sheen{
  0%{background-position:120% 0}
  38%{background-position:-60% 0}
  100%{background-position:-60% 0}
}
.mantra .rest{
  font-size:clamp(1.15rem,2.3vw,2rem);color:var(--olive-deep);
  letter-spacing:.01em;margin-left:.18em;
}
.mantra .ln{padding-bottom:.05em;margin-bottom:-.02em}
.mantra .ln>span{display:flex;align-items:baseline}

/* cinematic full-bleed hero */
.hero-cinema{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding:0 0 12vh;overflow:hidden;
}
.hero-cinema .bg{position:absolute;inset:0}
.hero-cinema .bg img{
  width:138%;max-width:none;height:100%;object-fit:cover;
  animation:kenburns 36s ease-in-out infinite alternate;
}
@media(max-width:760px){.hero-cinema .bg img{width:175%;margin-left:-30%}}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.08)}}
.hero-cinema .scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(32,37,20,.38),rgba(32,37,20,.04) 34%),
    linear-gradient(90deg,rgba(32,37,20,.78),rgba(32,37,20,.42) 46%,rgba(32,37,20,.06) 78%),
    linear-gradient(180deg,transparent 56%,rgba(32,37,20,.30) 82%,var(--cream));
}
.hero-cinema .wrap{position:relative;z-index:2}
.hero-cinema .hero-meta{color:rgba(246,241,230,.75)}
.hero-cinema .hero-meta b{color:var(--orange)}
.hero-cinema h1{color:var(--cream);font-size:clamp(2.5rem,5.7vw,5.1rem)}
.hero-cinema h1 .vrb{font-style:italic;color:var(--orange)}
.hero-cinema .sub{
  margin-top:30px;color:rgba(246,241,230,.85);
  font-size:clamp(1rem,1.4vw,1.2rem);line-height:1.7;max-width:36em;
}
.hero-cinema .cta-row{margin-top:44px}
.hero-cinema .tlink-light{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.76rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cream);border-bottom:1px solid rgba(246,241,230,.45);padding-bottom:6px;
  transition:gap .35s var(--ease),border-color .35s;
}
.hero-cinema .tlink-light:hover{gap:16px;border-color:var(--orange);color:#fff}
.hero-cinema .scroll-cue{color:rgba(246,241,230,.7)}
.hero-cinema .scroll-cue::after{background:rgba(246,241,230,.7)}

/* home hero: text + arched photo */
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(36px,5vw,72px);align-items:center;width:100%}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr}}
.arch{
  position:relative;border-radius:50vw 50vw var(--r) var(--r);overflow:hidden;
  aspect-ratio:3/3.9;border:1px solid var(--line);margin:0;
  box-shadow:0 40px 80px -40px rgba(39,45,24,.35);
}
.arch img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);animation:archin 2.2s var(--ease) both}
@keyframes archin{from{transform:scale(1.14);opacity:0}to{transform:scale(1.04);opacity:1}}
.arch .arch-chip{
  position:absolute;left:18px;bottom:18px;right:18px;display:flex;justify-content:space-between;align-items:center;gap:12px;
  background:rgba(246,241,230,.82);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:999px;padding:12px 22px;
  font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--olive-deep);
}
.arch .arch-chip b{color:var(--orange-deep);font-weight:600}
@media(max-width:960px){.arch{max-width:440px;aspect-ratio:3/3.4}}

/* scroll cue */
.scroll-cue{
  position:absolute;right:var(--pad);bottom:40px;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--olive-mid);
  writing-mode:vertical-rl;
}
.scroll-cue::after{
  content:"";width:1px;height:54px;background:var(--olive-mid);
  animation:cue 2.2s var(--ease) infinite;transform-origin:top;
}
@keyframes cue{0%{transform:scaleY(0)}45%{transform:scaleY(1)}100%{transform:scaleY(1);opacity:0}}
@media(max-width:720px){.scroll-cue{display:none}}

/* ---------- marquee / proof bar ---------- */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:22px 0;background:var(--cream);
}
.marquee-track{display:flex;gap:0;width:max-content;animation:marq 36s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{
  font-family:var(--serif);font-size:1.05rem;color:var(--olive);
  padding:0 34px;display:flex;align-items:center;gap:34px;white-space:nowrap;
}
.marquee-track span::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--orange);flex:none}
.marquee-track b{font-weight:600;color:var(--olive-deep)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- stats ---------- */
.stat-band{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
@media(max-width:960px){.stat-band{grid-template-columns:repeat(2,1fr)}}
.stat .num{
  font-family:var(--serif);font-size:clamp(2.4rem,4.5vw,3.8rem);
  color:var(--olive-deep);line-height:1;display:flex;align-items:baseline;
}
.stat .num .plus{color:var(--orange);font-size:.55em;margin-left:2px}
.stat .lbl{margin-top:10px;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--olive-mid)}

/* ---------- cards ---------- */
.card{
  background:var(--cream-card);border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(28px,3vw,44px);position:relative;overflow:hidden;
  transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .4s;
  display:flex;flex-direction:column;gap:16px;
}
.card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -30px rgba(39,45,24,.35);border-color:var(--line-strong)}
.card .idx{font-size:.7rem;letter-spacing:.26em;color:var(--orange);font-weight:600}
.card h3{font-size:1.45rem}
.card p{font-size:.95rem;color:#4d5337}
.card .tlink{margin-top:auto}
.card-dark{background:var(--olive-deep);border-color:rgba(246,241,230,.12)}
.card-dark h3,.card-dark .serif{color:var(--cream)}
.card-dark p{color:rgba(246,241,230,.78)}
.card-orange{background:var(--orange);border-color:transparent}
.card-orange h3{color:#fff}
.card-orange p{color:rgba(255,255,255,.9)}
.card-orange .idx{color:rgba(255,255,255,.85)}

/* numbered list rows */
.row-list{border-top:1px solid var(--line)}
.row-item{
  display:grid;grid-template-columns:90px 1.1fr 2fr;gap:clamp(18px,3vw,48px);
  padding:clamp(28px,4vw,48px) 0;border-bottom:1px solid var(--line);
  transition:background .4s;align-items:start;
}
.row-item:hover{background:rgba(243,112,31,.035)}
.row-item .no{font-family:var(--serif);font-size:1.3rem;color:var(--orange)}
.row-item h3{font-size:clamp(1.3rem,2vw,1.7rem)}
.row-item .meta{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--olive-mid);margin-top:10px;line-height:2}
.row-item p{font-size:.97rem}
@media(max-width:820px){.row-item{grid-template-columns:1fr;gap:12px}}

/* ---------- quote ---------- */
.pull{
  font-family:var(--serif);font-size:clamp(1.5rem,3.2vw,2.5rem);
  line-height:1.3;color:var(--olive-deep);font-weight:430;letter-spacing:-.01em;
  position:relative;padding-left:clamp(24px,4vw,48px);max-width:24em;
}
.pull::before{content:"";position:absolute;left:0;top:.25em;bottom:.25em;width:2px;background:var(--orange)}
.pull .src{display:block;margin-top:24px;font-family:var(--sans);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--olive-mid)}

/* ---------- dark band ---------- */
.band-dark{background:var(--olive-deep);color:var(--cream)}
.band-dark h2,.band-dark h3,.band-dark .d1,.band-dark .d2{color:var(--cream)}
.band-dark p{color:rgba(246,241,230,.8)}
.band-dark .eyebrow{color:rgba(246,241,230,.6)}
.band-dark .eyebrow::after{background:rgba(246,241,230,.25)}
.band-dark .lede{color:rgba(246,241,230,.85)}
.band-dark .stat .num{color:var(--cream)}
.band-dark .stat .lbl{color:rgba(246,241,230,.6)}

/* closing CTA */
.closing{
  background:var(--olive-deep);color:var(--cream);
  padding:clamp(90px,13vw,170px) 0;position:relative;overflow:hidden;text-align:center;
}
.closing h2{color:var(--cream);font-size:clamp(2.4rem,5.6vw,4.6rem);max-width:14em;margin:0 auto 22px}
.closing .accent{color:var(--orange);font-style:italic}
.closing p{margin:0 auto 44px;color:rgba(246,241,230,.75)}
.closing .halo{
  position:absolute;width:80vw;height:80vw;left:50%;top:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(243,112,31,.14),transparent 60%);pointer-events:none;
}

/* ---------- footer ---------- */
.site-footer{background:var(--olive-deep);color:rgba(246,241,230,.75);border-top:1px solid rgba(246,241,230,.12)}
.foot-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;
  padding:clamp(60px,8vw,96px) 0 56px;
}
@media(max-width:960px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}
.site-footer .foot-logo{height:130px;width:auto;display:block;opacity:.95}
.site-footer h4{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(246,241,230,.5);margin-bottom:20px;font-weight:500}
.site-footer li{margin-bottom:12px}
.site-footer a{font-size:.92rem;transition:color .3s}
.site-footer a:hover{color:var(--orange)}
.foot-mantra{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:rgba(246,241,230,.85);margin-top:18px;max-width:22em}
.foot-base{
  border-top:1px solid rgba(246,241,230,.12);padding:26px 0;
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(246,241,230,.45);
}

/* ---------- photo placeholders ---------- */
.ph{
  position:relative;border-radius:var(--r);overflow:hidden;
  border:1px solid var(--line);background:var(--cream-deep);margin:0;
}
.ph img{width:100%;height:100%;object-fit:cover}
.ph .ph-fill{
  position:absolute;inset:0;display:none;flex-direction:column;justify-content:space-between;
  padding:22px;background:
    linear-gradient(135deg,rgba(58,66,38,.06),rgba(243,112,31,.07)),
    repeating-linear-gradient(45deg,transparent 0 14px,rgba(58,66,38,.05) 14px 15px);
}
.ph.missing .ph-fill{display:flex}
.ph .ph-fill .pid{font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--orange-deep);font-weight:600}
.ph .ph-fill .pdesc{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--olive-mid)}
.ph-43{aspect-ratio:4/3}.ph-34{aspect-ratio:3/4}.ph-169{aspect-ratio:16/9}.ph-11{aspect-ratio:1/1}.ph-21{aspect-ratio:21/10}

/* ---------- timeline ---------- */
.timeline{position:relative;padding-left:clamp(28px,5vw,64px)}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:1px;background:var(--line-strong)}
.t-item{position:relative;padding:0 0 clamp(48px,6vw,72px)}
.t-item::before{
  content:"";position:absolute;left:calc(8px - clamp(28px,5vw,64px));top:10px;
  width:15px;height:15px;border-radius:50%;background:var(--cream);
  border:2px solid var(--orange);transform:translateX(-7px);
}
.t-item .yr{font-family:var(--serif);font-size:clamp(1.9rem,3.4vw,2.8rem);color:var(--orange);line-height:1}
.t-item h3{margin:12px 0 12px;font-size:clamp(1.2rem,2vw,1.55rem)}
.t-item p{font-size:.97rem;max-width:42em}

/* ---------- pillar wheel (CSS) ---------- */
.pillar-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.chip{
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;
  border:1px solid var(--line-strong);border-radius:999px;padding:9px 18px;color:var(--olive);
}
.chip.hot{border-color:var(--orange);color:var(--orange-deep)}
.chip.dark{background:var(--olive-deep);color:var(--cream);border-color:var(--olive-deep)}

.status-pill{
  display:inline-block;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600;
  padding:6px 14px;border-radius:999px;margin-bottom:14px;
}
.st-active{background:rgba(92,101,66,.14);color:var(--olive-mid)}
.st-new{background:var(--orange);color:#fff}
.st-soon{background:transparent;border:1px solid var(--line-strong);color:var(--olive-mid)}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-l{opacity:0;transform:translateX(-40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-l.in{opacity:1;transform:none}
[data-stagger]>*{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-stagger].in>*{opacity:1;transform:none}

/* hero line mask reveal — rise from soft blur */
.lines .ln{display:block;overflow:hidden;padding-bottom:.08em;margin-bottom:-.08em}
.lines .ln>span{
  display:block;transform:translateY(110%);filter:blur(10px);opacity:0;
  animation:lineup 1.25s var(--ease) forwards;
}
.lines .ln:nth-child(2)>span{animation-delay:.22s}
.lines .ln:nth-child(3)>span{animation-delay:.44s}
@keyframes lineup{60%{filter:blur(2px)}100%{transform:none;filter:blur(0);opacity:1}}
.fade-late{opacity:0;animation:fadein 1s .55s var(--ease) forwards}
@keyframes fadein{to{opacity:1}}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
  .reveal,.reveal-l,[data-stagger]>*{opacity:1;transform:none}
  .lines .ln>span{transform:none}
}
