/* ============================================================
   Organic Church — Fresh. Real. Jesus.
   Redesign concept stylesheet
   ============================================================ */

:root{
  --ink:        #1e7545;
  --ink-700:    #186138;
  --ink-800:    #114b2b;
  --ink-900:    #0c3a21;
  --ink-950:    #082a18;
  --lime:       #84cc2c;
  --lime-600:   #6cae20;
  --lime-300:   #b6e879;
  --lime-200:   #d3f0a8;
  --cream:      #f3fbeb;
  --cream-200:  #e9f6d8;
  --paper:      #ffffff;
  --text:       #143524;
  --muted:      #50705c;
  --muted-light:#bfe0c9;

  --maxw: 1180px;
  --radius: 20px;
  --radius-lg: 32px;
  --shadow-sm: 0 6px 20px rgba(12,58,33,.08);
  --shadow:    0 22px 50px -20px rgba(12,58,33,.32);
  --shadow-lg: 0 40px 80px -30px rgba(12,58,33,.45);

  --font-display: "Staatliches", "Arial Narrow", sans-serif;
  --font-body: "Sarabun", system-ui, -apple-system, sans-serif;

  --ease: cubic-bezier(.22,1,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  color:var(--text);
  background:var(--cream);
  line-height:1.7;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul,ol{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:400; line-height:.98; letter-spacing:.01em; }
h2{ font-size:clamp(2.1rem,5.2vw,3.6rem); color:var(--ink-800); }
h3{ font-size:clamp(1.5rem,3vw,2rem); }
.section h2{ margin-bottom:.5em; }
p{ font-size:clamp(1rem,1.6vw,1.08rem); }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-body); font-weight:700; text-transform:uppercase;
  letter-spacing:.18em; font-size:.78rem; color:var(--ink);
  margin-bottom:1.1rem;
}
.eyebrow .dot{ width:9px; height:9px; border-radius:50%; background:var(--lime); box-shadow:0 0 0 4px rgba(132,204,44,.25); }
.eyebrow--light{ color:var(--lime-300); }
.eyebrow--light .dot{ background:var(--lime); box-shadow:0 0 0 4px rgba(132,204,44,.2); }

.section{ padding-block:clamp(70px,9vw,130px); position:relative; }
.section-head{ max-width:760px; margin-bottom:clamp(40px,5vw,64px); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .eyebrow{ justify-content:center; }
.section-head__sub{ color:var(--muted); margin-top:.6rem; }
.section-head.light h2{ color:var(--cream); }
.section-head.light .section-head__sub{ color:var(--muted-light); }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  padding:.92em 1.7em; border-radius:100px;
  font-weight:700; font-size:.98rem; letter-spacing:.01em;
  background:var(--bg); color:var(--fg);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .25s;
  box-shadow:0 12px 26px -12px rgba(12,58,33,.5);
  will-change:transform;
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 20px 34px -14px rgba(12,58,33,.6); }
.btn:active{ transform:translateY(-1px); }
.btn--lime{ --bg:var(--lime); --fg:var(--ink-900); box-shadow:0 14px 30px -12px rgba(132,204,44,.7); }
.btn--lime:hover{ background:var(--lime-300); }
.btn--dark{ --bg:var(--ink-900); --fg:#fff; }
.btn--ghost{ --bg:transparent; --fg:#fff; box-shadow:inset 0 0 0 2px rgba(255,255,255,.35); }
.btn--ghost:hover{ background:rgba(255,255,255,.12); box-shadow:inset 0 0 0 2px rgba(255,255,255,.6); }
.btn--outline-dark{ --bg:transparent; --fg:var(--ink-800); box-shadow:inset 0 0 0 2px rgba(30,117,69,.4); }
.btn--outline-dark:hover{ background:rgba(30,117,69,.08); }
.btn--lg{ padding:1.05em 2.3em; font-size:1.1rem; }
.play-ico{ font-size:.7em; }

/* ============================================================
   Header
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  transition:background .35s, box-shadow .35s, padding .35s;
  padding-block:.5rem;
}
.site-header.scrolled{
  background:rgba(243,251,235,.85);
  backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  box-shadow:0 6px 30px -18px rgba(12,58,33,.5);
}
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; gap:1rem; }

.brand{ display:flex; align-items:center; gap:.7rem; }
.brand__mark{ width:46px; height:46px; transition:transform .5s var(--ease); }
.brand:hover .brand__mark{ transform:rotate(-8deg) scale(1.06); }
.brand__text{ display:flex; flex-direction:column; line-height:1; }
.brand__name{ font-family:var(--font-display); font-size:1.5rem; color:var(--ink-800); letter-spacing:.02em; }
.brand__tag{ font-size:.62rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--lime-600); margin-top:.25em; }

.nav{ display:flex; align-items:center; gap:.4rem; }
.nav a{
  position:relative; padding:.55em .9em; border-radius:100px;
  font-weight:600; font-size:.95rem; color:var(--ink-800);
  transition:color .25s, background .25s;
}
.nav a:not(.nav__cta)::after{
  content:""; position:absolute; left:.9em; right:.9em; bottom:.35em; height:2px;
  background:var(--lime); border-radius:2px; transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav a:not(.nav__cta):hover::after{ transform:scaleX(1); }
.nav a:not(.nav__cta):hover{ color:var(--ink); }
.nav__cta{
  background:var(--ink); color:#fff !important; margin-left:.5rem;
  box-shadow:0 10px 22px -12px rgba(12,58,33,.6); transition:transform .3s var(--ease), background .25s;
}
.nav__cta:hover{ background:var(--lime); color:var(--ink-900) !important; transform:translateY(-2px); }

.hamburger{ display:none; flex-direction:column; gap:5px; padding:.55em; border-radius:12px; }
.hamburger span{ width:26px; height:2.5px; background:var(--ink-800); border-radius:3px; transition:.3s var(--ease); }
.hamburger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.hamburger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

/* ============================================================
   Hero
   ============================================================ */
.hero{
  position:relative; isolation:isolate; overflow:hidden;
  min-height:clamp(620px,92vh,940px);
  display:flex; align-items:center;
  background:linear-gradient(165deg,var(--ink-950) 0%,var(--ink-800) 45%,var(--ink) 100%);
  color:#fff;
  padding-block:clamp(70px,10vw,120px);
}
.hero__bg{ position:absolute; inset:0; z-index:-1; }
.blob{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.55; }
.blob--1{ width:46vw; height:46vw; max-width:640px; max-height:640px; top:-12%; right:-8%;
  background:radial-gradient(circle at 30% 30%,var(--lime),transparent 70%); animation:drift 18s ease-in-out infinite; }
.blob--2{ width:40vw; height:40vw; max-width:520px; max-height:520px; bottom:-18%; left:-12%;
  background:radial-gradient(circle at 60% 40%,#2bbd6b,transparent 70%); opacity:.4; animation:drift 22s ease-in-out infinite reverse; }
.grain{ position:absolute; inset:0; opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:22px 22px; mask-image:radial-gradient(ellipse at center,#000,transparent 80%); }

.float-leaf{ position:absolute; fill:var(--lime); opacity:.16; width:120px; }
.leaf-a{ top:14%; left:8%; width:90px; animation:floaty 9s ease-in-out infinite; }
.leaf-b{ top:62%; left:16%; width:60px; opacity:.12; animation:floaty 11s ease-in-out infinite .6s; }
.leaf-c{ top:22%; right:14%; width:130px; opacity:.14; animation:floaty 13s ease-in-out infinite 1.2s; }
.leaf-d{ bottom:14%; right:9%; width:80px; opacity:.1; animation:floaty 10s ease-in-out infinite .3s; }

.hero__inner{ position:relative; max-width:880px; }
.hero__title{
  font-family:var(--font-display); font-size:clamp(2.9rem,8.5vw,6.4rem); line-height:.92;
  letter-spacing:.01em; text-shadow:0 14px 40px rgba(0,0,0,.25); margin-bottom:.35em;
}
.hero__title-accent{ position:relative; color:var(--lime); }
.hero__title-accent::after{
  content:""; position:absolute; left:-2%; right:-2%; bottom:.08em; height:.16em;
  background:var(--lime); opacity:.32; border-radius:6px; transform:scaleX(0); transform-origin:left;
  animation:underline 1.1s var(--ease) .8s forwards;
}
.hero__tagline{ display:flex; gap:.5em; flex-wrap:wrap; font-family:var(--font-display);
  font-size:clamp(1.4rem,3.5vw,2.2rem); letter-spacing:.04em; margin-bottom:.7em; }
.tag-word{ color:var(--lime-300); opacity:0; transform:translateY(14px);
  animation:tagIn .6s var(--ease) forwards; animation-delay:calc(.9s + var(--i)*.18s); }
.hero__lead{ max-width:560px; font-size:clamp(1.05rem,2vw,1.22rem); color:rgba(255,255,255,.86); margin-bottom:2rem; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-bottom:2.2rem; }
.hero__chip{
  display:inline-flex; flex-direction:column; gap:.1em;
  padding:.85em 1.4em; border-radius:16px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(6px);
}
.hero__chip strong{ font-size:1.05rem; color:#fff; }
.hero__chip span{ font-size:.85rem; color:var(--lime-300); }

.scroll-cue{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:2;
  width:26px; height:42px; border:2px solid rgba(255,255,255,.4); border-radius:14px; }
.scroll-cue span{ position:absolute; top:8px; left:50%; width:4px; height:8px; border-radius:3px;
  background:var(--lime); transform:translateX(-50%); animation:scrolly 1.6s infinite; }

@keyframes drift{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(4%,4%) scale(1.08);} }
@keyframes floaty{ 0%,100%{ transform:translateY(0) rotate(0);} 50%{ transform:translateY(-26px) rotate(8deg);} }
@keyframes tagIn{ to{ opacity:1; transform:translateY(0);} }
@keyframes underline{ to{ transform:scaleX(1);} }
@keyframes scrolly{ 0%{ opacity:0; top:8px;} 40%{ opacity:1;} 80%{ opacity:0; top:22px;} 100%{ opacity:0;} }

/* ============================================================
   Marquee
   ============================================================ */
.marquee{ background:var(--lime); color:var(--ink-900); overflow:hidden; padding:.7em 0; border-block:3px solid var(--ink-900); }
.marquee__track{ display:flex; align-items:center; gap:1.6rem; width:max-content;
  font-family:var(--font-display); font-size:1.5rem; letter-spacing:.05em; white-space:nowrap;
  animation:scrollx 26s linear infinite; }
.marquee i{ color:var(--ink-700); font-style:normal; font-size:.8em; }
@keyframes scrollx{ to{ transform:translateX(-50%);} }

/* ============================================================
   Welcome
   ============================================================ */
.welcome{ background:var(--cream); }
.welcome__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(36px,6vw,80px); align-items:center; }
.welcome__copy p{ color:var(--muted); margin-bottom:1.1rem; }
.welcome__copy h2{ margin-bottom:.55em; }

.stats{ display:flex; gap:clamp(20px,4vw,46px); margin-top:2rem; flex-wrap:wrap; }
.stat{ display:flex; flex-direction:column; }
.stat__num{ font-family:var(--font-display); font-size:clamp(2.2rem,4.5vw,3rem); color:var(--ink); line-height:1; }
.stat__label{ font-size:.82rem; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); margin-top:.4em; font-weight:600; }

.welcome__art{ position:relative; }
.art-card{ position:relative; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-lg); aspect-ratio:4/3.4; background:var(--cream-200); }
.art-card img{ width:100%; height:100%; object-fit:cover; }
.art-card__glow{ position:absolute; inset:0; background:radial-gradient(circle at 70% 20%,rgba(132,204,44,.35),transparent 60%); mix-blend-mode:multiply; }
.art-quote{ position:absolute; bottom:-26px; left:-20px; background:var(--ink); color:#fff;
  padding:1.1em 1.4em; border-radius:18px; max-width:240px; box-shadow:var(--shadow); }
.art-quote p{ font-family:var(--font-display); font-size:1.35rem; line-height:1.05; color:var(--lime-300); }
.art-quote span{ font-size:.78rem; color:rgba(255,255,255,.7); display:block; margin-top:.4em; }

/* ============================================================
   Pillars
   ============================================================ */
.pillars{ background:var(--paper); }
.pillar-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,32px); }
.pillar{ position:relative; padding:clamp(28px,3.4vw,42px); border-radius:var(--radius-lg);
  background:linear-gradient(170deg,var(--cream),#fff); border:1px solid var(--cream-200);
  box-shadow:var(--shadow-sm); transition:transform .4s var(--ease), box-shadow .4s var(--ease); overflow:hidden; }
.pillar::before{ content:""; position:absolute; inset:0 0 auto 0; height:5px; background:linear-gradient(90deg,var(--ink),var(--lime)); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.pillar:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.pillar:hover::before{ transform:scaleX(1); }
.pillar__icon{ width:64px; height:64px; display:grid; place-items:center; border-radius:18px;
  background:var(--ink); color:#fff; margin-bottom:1.2rem; transition:transform .4s var(--ease); }
.pillar:hover .pillar__icon{ transform:rotate(-8deg) scale(1.05); }
.pillar__icon svg{ width:34px; height:34px; fill:var(--lime); }
.pillar__icon svg[stroke]{ fill:none; stroke:var(--lime); }
.pillar h3{ color:var(--ink-800); margin-bottom:.45em; }
.pillar p{ color:var(--muted); }

/* ============================================================
   Gatherings
   ============================================================ */
.gatherings{ background:linear-gradient(165deg,var(--ink-900),var(--ink-800)); color:#fff; }
.gather-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.5vw,26px); }
.gcard{ position:relative; padding:clamp(26px,3vw,38px); border-radius:var(--radius-lg);
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  transition:transform .4s var(--ease), background .4s, border-color .4s; overflow:hidden; }
.gcard:hover{ transform:translateY(-8px); background:rgba(255,255,255,.09); border-color:rgba(132,204,44,.5); }
.gcard--feature{ background:linear-gradient(165deg,var(--lime),var(--lime-600)); color:var(--ink-900); border-color:transparent; }
.gcard--feature .gcard__day{ color:var(--ink-800); }
.gcard--feature .gcard__badge{ background:rgba(12,58,33,.18); color:var(--ink-900); }
.gcard--feature p{ color:rgba(8,42,24,.82); }
.gcard__day{ font-family:var(--font-body); font-weight:800; text-transform:uppercase; letter-spacing:.16em; font-size:.78rem; color:var(--lime-300); }
.gcard__time{ display:block; font-family:var(--font-display); font-size:clamp(1.9rem,3.4vw,2.5rem); line-height:1; margin:.2em 0 .5em; }
.gcard h3{ font-size:1.45rem; margin-bottom:.5em; }
.gcard p{ color:rgba(255,255,255,.8); font-size:.98rem; margin-bottom:1.3rem; }
.gcard__badge{ display:inline-block; padding:.45em 1em; border-radius:100px; font-size:.76rem; font-weight:700;
  letter-spacing:.04em; background:rgba(132,204,44,.18); color:var(--lime-300); }
.gather-note{ text-align:center; margin-top:2.4rem; color:rgba(255,255,255,.75); font-size:.95rem; }
.gather-note a{ color:var(--lime-300); font-weight:700; border-bottom:1px solid rgba(132,204,44,.5); }
.gather-note a:hover{ color:#fff; }

/* ============================================================
   Story
   ============================================================ */
.story{ background:var(--cream); }
.story__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(40px,6vw,80px); align-items:start; }
.story__intro p{ color:var(--muted); }
.mission{ margin-top:1.8rem; padding:1.4em 1.5em; border-left:4px solid var(--lime);
  background:#fff; border-radius:0 18px 18px 0; box-shadow:var(--shadow-sm);
  font-family:var(--font-body); font-style:italic; color:var(--ink-800); font-size:1.05rem; }
.mission cite{ display:block; margin-top:.8em; font-style:normal; font-weight:700; font-size:.85rem;
  letter-spacing:.1em; text-transform:uppercase; color:var(--lime-600); }

.timeline{ position:relative; padding-left:2.4rem; }
.timeline::before{ content:""; position:absolute; left:9px; top:6px; bottom:6px; width:2px;
  background:linear-gradient(var(--lime),var(--ink)); }
.timeline li{ position:relative; padding-bottom:2.4rem; }
.timeline li:last-child{ padding-bottom:0; }
.timeline li::before{ content:""; position:absolute; left:-2.4rem; top:4px; width:20px; height:20px;
  border-radius:50%; background:var(--paper); border:3px solid var(--lime); box-shadow:0 0 0 4px var(--cream); transition:transform .3s; }
.timeline li:hover::before{ transform:scale(1.15); background:var(--lime); }
.timeline__year{ font-family:var(--font-display); font-size:1.5rem; color:var(--ink); letter-spacing:.03em; }
.timeline h3{ font-size:1.4rem; color:var(--ink-800); margin:.1em 0 .35em; }
.timeline p{ color:var(--muted); }

/* ============================================================
   Cupboard of Hope
   ============================================================ */
.cupboard{ background:var(--paper); }
.cupboard__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(36px,6vw,80px); align-items:center; }
.cupboard__art{ position:relative; aspect-ratio:1; max-width:420px; margin-inline:auto;
  border-radius:var(--radius-lg); display:grid; place-items:center;
  background:radial-gradient(circle at 50% 40%,var(--lime-200),var(--cream)); box-shadow:var(--shadow); overflow:hidden; }
.basket{ position:relative; color:var(--ink); }
.basket svg{ width:clamp(120px,22vw,180px); height:auto; }
.basket__pulse{ position:absolute; inset:-30% ; border-radius:50%; border:2px solid var(--lime); opacity:0; animation:ring 3s ease-out infinite; }
@keyframes ring{ 0%{ transform:scale(.6); opacity:.6;} 100%{ transform:scale(1.2); opacity:0;} }
.cupboard__stat{ position:absolute; bottom:18px; right:18px; background:var(--ink); color:#fff;
  padding:.8em 1.1em; border-radius:16px; text-align:right; box-shadow:var(--shadow); }
.cupboard__stat strong{ display:block; font-family:var(--font-display); font-size:1.8rem; color:var(--lime-300); line-height:1; }
.cupboard__stat span{ font-size:.74rem; color:rgba(255,255,255,.8); }
.cupboard__copy p{ color:var(--muted); margin-bottom:1.1rem; }

/* ============================================================
   Podcast
   ============================================================ */
.podcast{ background:linear-gradient(165deg,var(--ink-800),var(--ink)); color:#fff; }
.podcast__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,72px); align-items:center; }
.podcast__copy p{ color:rgba(255,255,255,.82); margin-bottom:1.4rem; }
.podcast__copy h2{ color:#fff; }
.player{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius-lg); padding:clamp(22px,3vw,32px); box-shadow:var(--shadow-lg); backdrop-filter:blur(8px); }
.player__head{ display:flex; align-items:center; gap:.9rem; margin-bottom:1.4rem; }
.player__head img{ width:52px; height:52px; background:var(--cream); border-radius:14px; padding:6px; }
.player__head strong{ display:block; font-size:1.15rem; font-family:var(--font-display); letter-spacing:.02em; }
.player__head span{ font-size:.8rem; color:var(--lime-300); }
.player__wave{ display:flex; align-items:center; gap:3px; height:60px; margin-bottom:1.3rem; }
.player__wave i{ flex:1; background:var(--lime); border-radius:3px; opacity:.55;
  height:30%; animation:wave 1.2s ease-in-out infinite; }
.player__wave i:nth-child(odd){ animation-duration:1.5s; }
.player__wave i:nth-child(3n){ animation-duration:.9s; opacity:.8; }
.player__wave i:nth-child(4n){ animation-delay:.2s; }
.player__wave i:nth-child(5n){ animation-delay:.4s; }
@keyframes wave{ 0%,100%{ height:25%;} 50%{ height:95%;} }
.player__bar{ display:flex; align-items:center; gap:1rem; }
.player__play{ width:42px; height:42px; flex:none; display:grid; place-items:center; border-radius:50%;
  background:var(--lime); color:var(--ink-900); font-size:.85rem; }
.player__track{ flex:1; height:6px; border-radius:6px; background:rgba(255,255,255,.18); overflow:hidden; }
.player__track span{ display:block; width:42%; height:100%; background:var(--lime); border-radius:6px; }
.player__time{ font-size:.85rem; color:rgba(255,255,255,.7); font-variant-numeric:tabular-nums; }

/* ============================================================
   Give
   ============================================================ */
.give{ background:var(--cream); }
.give__inner{ position:relative; overflow:hidden; text-align:center;
  background:linear-gradient(135deg,var(--ink-900),var(--ink-700) 60%,var(--ink));
  color:#fff; border-radius:var(--radius-lg); padding:clamp(48px,7vw,84px) clamp(28px,5vw,60px);
  box-shadow:var(--shadow-lg); }
.give__inner::before, .give__inner::after{ content:""; position:absolute; border-radius:50%;
  background:radial-gradient(circle,var(--lime),transparent 70%); opacity:.35; filter:blur(30px); }
.give__inner::before{ width:280px; height:280px; top:-120px; right:-80px; }
.give__inner::after{ width:240px; height:240px; bottom:-130px; left:-70px; opacity:.25; }
.give__inner h2{ color:#fff; position:relative; }
.give__inner p{ position:relative; max-width:560px; margin:1rem auto 2rem; color:rgba(255,255,255,.85); }

/* ============================================================
   Visit
   ============================================================ */
.visit{ background:var(--paper); }
.visit__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,6vw,72px); align-items:center; }
.visit__copy p{ color:var(--muted); }
.visit__list{ margin:1.6rem 0; display:grid; gap:.7rem; }
.visit__list li{ position:relative; padding-left:1.7rem; color:var(--muted); }
.visit__list li::before{ content:""; position:absolute; left:0; top:.55em; width:10px; height:10px;
  border-radius:50%; background:var(--lime); box-shadow:0 0 0 4px rgba(132,204,44,.2); }
.visit__list strong{ color:var(--ink-800); }
.visit__where{ display:flex; align-items:center; gap:.6em; font-weight:700; color:var(--ink-800); margin-top:1rem; }
.visit__where svg{ width:22px; height:22px; color:var(--lime-600); flex:none; }

.visit__card{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); background:var(--ink-900); }
.visit__map{ position:relative; aspect-ratio:16/12; background:
  linear-gradient(135deg,var(--ink-800),var(--ink)); overflow:hidden; }
.map-grid{ position:absolute; inset:0; opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:36px 36px; }
.map-leaf{ position:absolute; width:160px; right:-20px; bottom:-20px; fill:var(--lime); opacity:.14; }
.map-pin{ position:absolute; left:50%; top:46%; width:20px; height:20px; border-radius:50% 50% 50% 0;
  background:var(--lime); transform:translate(-50%,-50%) rotate(-45deg);
  box-shadow:0 0 0 0 rgba(132,204,44,.5); animation:pinpulse 2s infinite; }
.map-pin::after{ content:""; position:absolute; inset:5px; background:var(--ink-900); border-radius:50%; }
@keyframes pinpulse{ 0%,100%{ box-shadow:0 8px 18px rgba(0,0,0,.35),0 0 0 0 rgba(132,204,44,.5);} 50%{ box-shadow:0 8px 18px rgba(0,0,0,.35),0 0 0 14px rgba(132,204,44,0);} }
.visit__cardfoot{ padding:clamp(20px,3vw,28px); color:#fff; }
.visit__cardfoot p{ color:var(--lime-300); margin-bottom:1rem; font-family:var(--font-display); font-size:1.3rem; letter-spacing:.02em; }

/* ============================================================
   Footer
   ============================================================ */
.footer{ background:var(--ink-950); color:rgba(255,255,255,.75); padding-top:clamp(56px,7vw,88px); }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.1fr; gap:clamp(28px,4vw,48px); padding-bottom:3rem; }
.footer__brand img{ width:210px; max-width:60%; margin-bottom:1.1rem;
  filter:brightness(0) invert(1); opacity:.92; }
.footer__brand p{ font-size:.92rem; max-width:300px; }
.footer h4{ font-family:var(--font-body); font-weight:800; text-transform:uppercase; letter-spacing:.14em;
  font-size:.78rem; color:var(--lime-300); margin-bottom:1rem; }
.footer__nav{ display:flex; flex-direction:column; gap:.55rem; }
.footer__nav a{ font-size:.95rem; transition:color .2s, transform .2s; width:fit-content; }
.footer__nav a:hover{ color:var(--lime-300); transform:translateX(3px); }
.footer__times p{ font-size:.95rem; margin-bottom:.45rem; }
.footer__times strong{ color:#fff; display:inline-block; width:2.6em; }
.footer__bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:.6rem;
  padding-block:1.6rem; border-top:1px solid rgba(255,255,255,.1); font-size:.84rem; }
.footer__beta{ color:var(--lime-600); }

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

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:980px){
  .welcome__grid, .story__grid, .cupboard__grid, .podcast__grid, .visit__grid{ grid-template-columns:1fr; }
  .welcome__art{ max-width:520px; }
  .pillar-grid, .gather-grid{ grid-template-columns:1fr; max-width:560px; margin-inline:auto; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .cupboard .cupboard__art{ order:-1; }
  .podcast__player{ max-width:560px; }
}
@media (max-width:760px){
  .nav{ position:fixed; inset:0 0 0 auto; width:min(82vw,330px); flex-direction:column; align-items:stretch;
    justify-content:flex-start; gap:.3rem; padding:6rem 1.6rem 2rem; background:var(--ink-900);
    transform:translateX(100%); transition:transform .4s var(--ease); box-shadow:var(--shadow-lg); }
  .nav.open{ transform:translateX(0); }
  .nav a{ color:#fff; font-size:1.1rem; padding:.7em .9em; }
  .nav a:not(.nav__cta):hover{ color:var(--lime-300); background:rgba(255,255,255,.06); }
  .nav a:not(.nav__cta)::after{ display:none; }
  .nav__cta{ margin-left:0; margin-top:.6rem; text-align:center; }
  .hamburger{ display:flex; z-index:55; }
  .site-header.scrolled .hamburger span{ background:var(--ink-800); }
  body.menu-open{ overflow:hidden; }
  .nav-scrim{ position:fixed; inset:0; background:rgba(8,42,24,.5); opacity:0; visibility:hidden;
    transition:.3s; z-index:40; backdrop-filter:blur(2px); }
  .nav-scrim.show{ opacity:1; visibility:visible; }
  .art-quote{ left:0; }
  .footer__grid{ grid-template-columns:1fr; }
}
@media (max-width:420px){
  .brand__tag{ display:none; }
  .hero__actions .btn{ flex:1; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .tag-word{ opacity:1; transform:none; }
}
