/* ============================================================
   BEN CALF ROBE SOCIETY — main stylesheet
   ------------------------------------------------------------
   Controls how the whole site LOOKS. The TEXT lives in the
   /content JSON files and the .html pages.
   Design matches BCRS's brochures: blue/red/cream colour
   blocks, photos topped with red angled title banners, bold
   Oswald headings, and the medicine-wheel palette.
   ============================================================ */

:root{
  --blue:#1B3A6B;   --red:#C0392B;   --tan:#E5D9C3;   --cream:#E5D9C3; /* cream = dark brochure cream now; revert to #F7F2E9 for the old light cream */
  --gold:#F6C026;   --ink:#1A1814;   --muted:#5e5749;  --white:#fff;
  --wred:#D42B2B;   --wyellow:#F6C026; --wblue:#2B3F9E;
  --bluedk:#10254a;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',sans-serif;color:var(--ink);background:var(--cream);line-height:1.6}
h1,h2,h3,h4{font-family:'Oswald',sans-serif;font-weight:600;line-height:1.05;text-transform:uppercase;letter-spacing:.5px}
img{max-width:100%;display:block}
a{color:var(--red)}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}

/* Scroll-reveal is OPT-IN: content is only hidden when JavaScript is present
   (the inline script in <head> adds the 'js' class). If JS is slow or fails
   — common on phones — everything stays visible. No blank pages. */
/* Scroll-reveal: elements ease into place as they enter view (JS adds .in).
   Variety via modifier classes so it never feels repetitive. */
.reveal{transition:opacity .7s ease,transform .8s cubic-bezier(.16,.68,.28,1)}
.js .reveal{opacity:0}
.js .reveal:not(.in){transform:translateY(28px)}            /* default: rise up   */
.js .reveal.from-left:not(.in){transform:translateX(-46px)} /* slide from left   */
.js .reveal.from-right:not(.in){transform:translateX(46px)} /* slide from right  */
.js .reveal.zoom:not(.in){transform:scale(.9)}              /* gently scale up    */
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d1{transition-delay:.12s}                        /* stagger helpers   */
.js .reveal.d2{transition-delay:.24s}
.js .reveal.d3{transition-delay:.36s}
.js .reveal.d4{transition-delay:.48s}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1!important;transform:none!important;transition:none!important}}
/* clip sideways overflow so slide-in animations never flash a horizontal scrollbar
   (header is outside #main, so its sticky behaviour is unaffected) */
#main{overflow-x:clip}

.skip{position:absolute;left:-999px;top:0;background:var(--gold);color:var(--ink);padding:10px 16px;z-index:200;font-family:'Oswald'}
.skip:focus{left:8px;top:8px}

/* ---------- geometric border band (brochure / certificate motif) ----------
   A repeating diamond band used as a respectful divider between sections. */
/* authentic band: real motif from the BCRS certificate, recolored to brand navy+red,
   tan+white knocked out, sitting on the page cream (no white ribbon) */
.border-band{height:24px;background:var(--cream) url("../img/border-pattern5.png") repeat-x center;background-size:auto 24px}

/* ---------- sticky shrinking header (utility bar + nav together) ---------- */
.site-header{position:sticky;top:0;z-index:60}

/* utility bar */
.util{background:var(--ink);color:#e8e2d5;font-size:.8rem}
.util .wrap{display:flex;justify-content:space-between;align-items:center;padding:7px 26px;flex-wrap:wrap;gap:6px;transition:padding .25s ease}
.util a{color:#e8e2d5;text-decoration:none}
.utilright{display:flex;align-items:center;gap:15px}
.usocial{display:inline-flex;color:#e8e2d5;transition:color .2s}
.usocial:hover{color:var(--wyellow)}
.usocial svg{width:17px;height:17px;display:block}
/* top-bar safety exit, now a clear filled button */
.util .safe{color:#fff;font-weight:700;background:var(--wred);border:0;font-family:'Oswald';font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;padding:5px 12px;border-radius:4px;display:inline-flex;align-items:center;gap:5px}
.util .safe:hover{background:#b3231f}
/* always-visible floating safety exit (bottom-left; opposite corner from chat) */
.safe-float{position:fixed;left:16px;bottom:16px;z-index:80;background:var(--wred);color:#fff;border:0;border-radius:8px;padding:11px 16px;font-family:'Oswald';font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;display:flex;align-items:center;gap:8px;box-shadow:0 6px 20px rgba(0,0,0,.3);transition:background .2s,transform .16s}
.safe-float:hover{background:#b3231f;transform:translateY(-2px)}
.safe-float svg{display:block}
@media(max-width:560px){.safe-float{padding:9px 13px;font-size:.8rem;left:12px;bottom:12px}}

/* nav (sits inside .site-header) */
nav{background:var(--cream);border-bottom:3px solid var(--blue)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;padding:9px 26px;transition:padding .25s ease}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none}
.brand img{height:64px;width:auto;transition:height .25s ease}

/* shrink state — JS adds .shrink to #siteHeader after you scroll down */
.site-header.shrink nav .wrap{padding-top:4px;padding-bottom:4px}
.site-header.shrink .brand img{height:46px}
.site-header.shrink .util .wrap{padding-top:3px;padding-bottom:3px}
.brand .bt{font-family:'Oswald';font-size:1.18rem;font-weight:700;color:var(--blue);line-height:1;text-transform:uppercase}
.brand .bs{display:block;font-family:'Source Sans 3';font-size:.6rem;letter-spacing:.2em;color:var(--red);font-weight:600;margin-top:3px;text-transform:uppercase}
.navlinks{display:flex;gap:23px;align-items:center}
.navlinks a{text-decoration:none;font-family:'Oswald';font-size:.92rem;font-weight:500;color:var(--ink);text-transform:uppercase;letter-spacing:.4px;transition:color .2s}
.navlinks a:hover,.navlinks a:focus{color:var(--red)}
.donate{background:var(--red);color:#fff!important;padding:9px 20px;border-radius:3px;font-weight:600}
.donate:hover{background:#a52f22}
.menubtn{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--blue)}

/* ---------- hero: full-bleed photo + diagonal colour blocks + red banner ---------- */
.hero{position:relative;min-height:600px;display:flex;align-items:center;overflow:hidden;background:var(--blue)}
.hero .heroimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(100deg,rgba(16,37,74,.93) 0%,rgba(16,37,74,.74) 36%,rgba(16,37,74,.20) 60%,rgba(16,37,74,0) 80%);}
.hero::after{content:"";position:absolute;top:0;right:0;width:30%;height:100%;z-index:1;
  background:var(--red);opacity:.80;clip-path:polygon(46% 0,100% 0,100% 100%,0 100%)}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-inner{max-width:600px;padding:78px 0;color:#fff}
.hero .eyebrow{display:inline-flex;align-items:center;gap:9px;background:var(--gold);color:var(--ink);font-family:'Oswald';font-size:.72rem;letter-spacing:.16em;padding:6px 15px;border-radius:2px;margin-bottom:22px;text-transform:uppercase;font-weight:600}
.hero h1{font-size:clamp(2.5rem,5.2vw,4rem);margin-bottom:18px;font-weight:700;text-shadow:0 2px 18px rgba(0,0,0,.25)}
.hero h1 .gold{color:var(--wyellow)}
.hero .lead{font-size:1.15rem;font-weight:300;opacity:.97;margin-bottom:30px;max-width:33rem}
.btns{display:flex;gap:13px;flex-wrap:wrap}
.btn{padding:14px 30px;border-radius:3px;text-decoration:none;font-family:'Oswald';font-weight:500;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;display:inline-block;transition:transform .16s,background .2s;cursor:pointer;border:0}
.btn:hover{transform:translateY(-2px)}
.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:#a52f22}
.btn-gold{background:var(--cream);color:var(--blue)}.btn-gold:hover{background:#d8cbae}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid #fff}
.btn-ghost:hover{background:#fff;color:var(--blue)}
.btn-blue{background:var(--blue);color:#fff}.btn-blue:hover{background:var(--bluedk)}

/* ---------- hero banner (client cover photo) + CTA strip ---------- */
.hero-banner{background:var(--bluedk);position:relative}
.hero-banner img{display:block;width:100%;max-height:460px;object-fit:cover;object-position:center 40%}
/* headline written over the hero photo; gradient fades into the blue band below */
.hero-words{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;text-align:center;pointer-events:none;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,rgba(0,0,0,.25) 32%,rgba(0,0,0,0) 60%)}
.hero-words .inner{padding:0 22px 26px}
.hero-words h1{font-family:'Oswald';font-weight:700;text-transform:uppercase;color:#fff;font-size:clamp(2.1rem,5.4vw,4rem);line-height:1.04;letter-spacing:.015em;text-shadow:0 2px 18px rgba(0,0,0,.4);margin:0}
.hero-words .rule{display:block;height:4px;width:74px;background:var(--gold);margin:16px auto 0;border-radius:2px}
.hero-cta{background:var(--blue);color:#fff;text-align:center;padding:34px 26px 40px}
.hero-cta .eyebrow{display:inline-block;background:transparent;color:var(--gold);border:1px solid var(--gold);font-family:'Oswald';font-size:.72rem;letter-spacing:.16em;padding:6px 15px;border-radius:2px;margin-bottom:16px;text-transform:uppercase;font-weight:600}
.hero-cta .lead{font-size:1.12rem;font-weight:300;max-width:42rem;margin:0 auto 22px;opacity:.96}
.hero-cta .btns{justify-content:center}

/* ---------- mission strip ---------- */
.mission{background:var(--tan);position:relative;padding:54px 0;text-align:center}
.mission .ic{font-size:1.6rem;margin-bottom:8px}
.mission p{font-family:'Oswald';font-weight:400;font-size:clamp(1.2rem,2.6vw,1.85rem);color:var(--blue);max-width:50rem;margin:0 auto;text-transform:none;line-height:1.32}
.mission p b{color:var(--red)}

/* ---------- generic section + heading ---------- */
.section{padding:74px 0}
.sec-head{text-align:center;max-width:44rem;margin:0 auto 46px}
.sec-head .kicker{font-family:'Oswald';color:var(--red);font-size:.92rem;letter-spacing:.2em;font-weight:600;display:block;margin-bottom:10px}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);color:var(--blue);font-weight:700}
.sec-head p{margin-top:12px;color:var(--muted)}
.sec-head .line{width:70px;height:4px;background:var(--gold);margin:14px auto 0}

/* ---------- Our Story (about / namesake) ---------- */
.story{background:var(--cream)}
.story .grid{max-width:780px;margin:0 auto;padding:64px 26px;text-align:center}
.story .copy{max-width:560px;margin:0 auto}
.story .kicker{font-family:'Oswald';color:var(--red);font-size:.92rem;letter-spacing:.2em;font-weight:600;display:block;margin-bottom:10px}
.story h2{font-size:clamp(1.8rem,3.4vw,2.5rem);color:var(--blue);margin-bottom:18px}
.story p{margin-bottom:14px;text-align:left}
.story .photo{position:relative;height:400px;max-width:760px;margin:0 auto 38px;background-size:cover;background-position:center;border-radius:16px;overflow:hidden}
.story .photo::before{content:"";position:absolute;inset:0;background:var(--blue);opacity:.12}

/* ---------- audience paths (photo cards) ---------- */
.paths{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pcard{position:relative;color:#fff;border-radius:7px;overflow:hidden;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;padding:28px;text-decoration:none;transition:transform .2s;box-shadow:0 6px 22px rgba(0,0,0,.12)}
.pcard:hover{transform:translateY(-6px)}
.pcard .bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transition:transform .4s}
.pcard:hover .bg{transform:scale(1.06)}
.pcard::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(16,37,74,.15) 0%,rgba(16,37,74,.55) 55%,rgba(16,37,74,.92) 100%)}
.pcard.b::after{background:linear-gradient(180deg,rgba(142,36,24,.15) 0%,rgba(142,36,24,.55) 55%,rgba(142,36,24,.92) 100%)}
.pcard.c::after{background:linear-gradient(180deg,rgba(154,114,9,.18) 0%,rgba(120,80,5,.6) 55%,rgba(80,52,3,.93) 100%)}
.pcard>*{position:relative;z-index:2}
.pcard h3{font-size:1.5rem;margin-bottom:6px}
.pcard p{font-size:.92rem;opacity:.95;font-weight:300;margin-bottom:10px}
.pcard .go{font-family:'Oswald';font-size:.8rem;letter-spacing:.1em;font-weight:600;text-transform:uppercase}

/* ---------- programs grid (brochure tiles) ---------- */
.programs{background:var(--blue);color:#fff;position:relative}
.programs .sec-head h2{color:#fff}
.programs .sec-head .kicker{color:var(--wyellow)}
.programs .sec-head p{color:#cdd7e6}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.prog{display:flex;flex-direction:column;background:#fff;border-radius:9px;overflow:hidden;text-decoration:none;transition:transform .18s,box-shadow .2s;box-shadow:0 6px 20px rgba(0,0,0,.18)}
.prog:hover{transform:translateY(-5px);box-shadow:0 14px 30px rgba(0,0,0,.30)}
.prog .ph{height:140px;background-size:cover;background-position:center}
.prog .pbody{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.prog .tag{align-self:flex-start;display:inline-block;font-family:'Oswald';font-size:.6rem;letter-spacing:.1em;font-weight:600;padding:3px 9px;border-radius:2px;margin-bottom:10px;text-transform:uppercase;background:var(--blue);color:#fff}
.prog .tag.free{background:var(--gold);color:var(--ink)}
.prog .tag.fee{background:var(--red);color:#fff}
.prog h3{font-size:1.12rem;margin-bottom:7px;color:var(--blue);line-height:1.12}
.prog p{font-size:.88rem;color:var(--muted);font-weight:400;flex:1}
.prog .more{margin-top:12px;font-family:'Oswald';font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--red);font-weight:600}
.programs .viewall{text-align:center;margin-top:38px}

/* ---------- Rooted in Culture strip ---------- */
.culture{background:var(--tan)}
.culture .row{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.culture .row figure{position:relative;aspect-ratio:1/1;overflow:hidden}
.culture .row img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.culture .row figure:hover img{transform:scale(1.07)}
.culture .row figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px;color:#fff;font-family:'Oswald';text-transform:uppercase;letter-spacing:.06em;font-size:.92rem;background:linear-gradient(transparent,rgba(0,0,0,.72))}

/* ---------- Pow Wow feature ---------- */
.powwow{position:relative;color:#fff;overflow:hidden;background:var(--bluedk)}
.powwow .bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;z-index:0;opacity:.5}
.powwow::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(16,37,74,.92),rgba(16,37,74,.55))}
.powwow .wrap{position:relative;z-index:2;padding:84px 26px}
.powwow .inner{max-width:560px}
.powwow .kicker{font-family:'Oswald';color:var(--wyellow);font-size:.92rem;letter-spacing:.2em;font-weight:600;display:block;margin-bottom:10px}
.powwow h2{font-size:clamp(1.9rem,3.6vw,2.7rem);margin-bottom:14px}
.powwow p{font-size:1.06rem;font-weight:300;opacity:.96;margin-bottom:24px}

/* ---------- impact stats ---------- */
.impact{background:var(--red);color:#fff;text-align:center;padding:46px 0}
.impact .row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.impact .n{font-family:'Oswald';font-weight:700;font-size:2.6rem;line-height:1;color:var(--wyellow)}
.impact .l{font-size:.92rem;opacity:.95;margin-top:6px;text-transform:uppercase;letter-spacing:.08em;font-family:'Oswald'}

/* ---------- events / news split ---------- */
.en{display:grid;grid-template-columns:1fr 1fr;gap:0}
.en .events{background:var(--red);color:#fff;padding:64px 54px}
.en .news{background:var(--tan);color:var(--ink);padding:64px 54px}
.en h2{font-size:1.95rem;margin-bottom:10px}
.en .events h2{color:#fff}.en .news h2{color:var(--blue)}
.en .kicker{font-family:'Oswald';font-size:.88rem;letter-spacing:.18em;font-weight:600;display:block;margin-bottom:8px}
.en .events .kicker{color:var(--wyellow)}.en .news .kicker{color:var(--red)}
.eitem,.nitem{padding:16px 0;border-bottom:1px solid rgba(0,0,0,.12)}
.en .events .eitem{border-color:rgba(255,255,255,.25)}
.eitem .d,.nitem .d{font-family:'Oswald';font-size:.78rem;opacity:.85;letter-spacing:.05em}
.eitem h4,.nitem h4{font-size:1.08rem;margin:3px 0;text-transform:none;font-weight:600}
.eitem p,.nitem p{font-size:.85rem;opacity:.9;font-weight:300}

/* ---------- donate CTA ---------- */
.cta{position:relative;background:var(--blue) url("../img/donate-bg.jpg") center/cover;color:#fff;text-align:center;padding:76px 26px;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(16,37,74,.88),rgba(16,37,74,.84))}
.cta .wrap{position:relative;z-index:1}
.cta h2{font-size:2.2rem;margin-bottom:12px}
.cta p{max-width:36rem;margin:0 auto 24px;font-size:1.06rem;opacity:.95}
.cta .fineprint{margin-top:16px;font-size:.82rem;opacity:.8}

/* ---------- footer ---------- */
footer{background:var(--ink);color:#b7ad9c}
.fbar{display:flex;height:8px}
.fbar i{flex:1}
.fbar i:nth-child(1){background:var(--wred)}.fbar i:nth-child(2){background:var(--wyellow)}
.fbar i:nth-child(3){background:var(--wblue)}.fbar i:nth-child(4){background:#000}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding:48px 0 30px}
.fgrid .fbrand img{height:74px;margin-bottom:14px}
.fgrid h4{color:#fff;font-size:1rem;margin-bottom:14px;font-family:'Oswald';letter-spacing:.04em}
.fgrid a{display:block;color:#b7ad9c;text-decoration:none;font-size:.9rem;margin-bottom:8px}
.fgrid a:hover{color:var(--wyellow)}
.fgrid p{font-size:.9rem;line-height:1.7}
.fsocial{display:flex;gap:12px;margin-top:6px}
.fsocial a{font-size:1.3rem}
.fcopy{text-align:center;font-size:.8rem;opacity:.6;border-top:1px solid rgba(255,255,255,.1);padding:20px 0 26px}

/* ---------- chatbot widget ---------- */
.chatbtn{position:fixed;bottom:22px;right:22px;z-index:70;background:var(--red);color:#fff;border:0;border-radius:50px;padding:14px 22px;font-family:'Oswald';font-weight:600;font-size:.92rem;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.3);display:flex;gap:8px;align-items:center;text-transform:uppercase;letter-spacing:.5px}
.chatbtn:hover{background:#a52f22}
.chatpanel{position:fixed;bottom:84px;right:22px;z-index:70;width:344px;max-width:calc(100vw - 44px);background:var(--cream);border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.32);overflow:hidden;display:none;flex-direction:column}
.chatpanel.open{display:flex}
.chathead{background:var(--blue);color:#fff;padding:15px 18px;display:flex;gap:11px;align-items:center}
.chathead .av{width:38px;height:38px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}
.chathead .av img{width:34px;height:auto}
.chathead b{font-family:'Oswald';font-size:1.05rem}
.chathead span{display:block;font-size:.72rem;opacity:.8}
.chathead .x{margin-left:auto;background:none;border:0;color:#fff;font-size:1.3rem;cursor:pointer;line-height:1}
.chatbody{padding:18px;height:288px;overflow-y:auto;font-size:.9rem}
.msg{margin-bottom:12px;max-width:86%}
.msg.bot{background:#fff;border:1px solid var(--tan);padding:10px 13px;border-radius:11px 11px 11px 2px}
.msg.me{background:var(--blue);color:#fff;padding:10px 13px;border-radius:11px 11px 2px 11px;margin-left:auto}
.msg.typing{opacity:.6;font-style:italic}
.chatfoot{display:flex;border-top:1px solid var(--tan)}
.chatfoot input{flex:1;border:0;padding:13px;font-family:inherit;outline:none;background:transparent}
.chatfoot button{background:var(--blue);color:#fff;border:0;padding:0 18px;font-family:'Oswald';cursor:pointer}
.chatfoot button:disabled{opacity:.5;cursor:default}
.disclaim{font-size:.67rem;color:var(--muted);text-align:center;padding:7px;background:var(--tan)}

/* ============================================================
   SUBPAGE COMPONENTS (About, Programs, Events, News, Contact)
   ============================================================ */

/* page banner (compact hero for inner pages) */
.pagehead{position:relative;background:var(--blue);color:#fff;overflow:hidden;min-height:240px;display:flex;align-items:center}
.pagehead .bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;opacity:.45}
.pagehead::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(16,37,74,.92),rgba(16,37,74,.6))}
.pagehead::after{content:"";position:absolute;top:0;right:0;width:28%;height:100%;z-index:1;background:var(--red);opacity:.8;clip-path:polygon(46% 0,100% 0,100% 100%,0 100%)}
.pagehead .wrap{position:relative;z-index:2;padding:54px 26px}
.pagehead .crumb{font-family:'Oswald';font-size:.88rem;letter-spacing:.16em;text-transform:uppercase;color:var(--wyellow);margin-bottom:8px}
.pagehead h1{font-size:clamp(2rem,4.4vw,3rem);font-weight:700}
.pagehead p{max-width:38rem;margin-top:10px;font-weight:300;opacity:.95}

/* prose blocks (About) */
.prose{max-width:48rem;margin:0 auto}
.prose p{margin-bottom:16px}
.prose h3{color:var(--blue);font-size:1.4rem;margin:30px 0 10px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.two-col .photo{border-radius:8px;overflow:hidden;box-shadow:0 8px 26px rgba(0,0,0,.12)}
.two-col .photo img{width:100%;height:100%;object-fit:cover}

/* Treaty 6 acknowledgement band */
.acknowledge{background:var(--blue);color:#fff;text-align:center;padding:54px 0}
.acknowledge .wrap{max-width:50rem}
.acknowledge p{font-family:'Oswald';font-weight:300;font-size:clamp(1.05rem,2.2vw,1.4rem);line-height:1.5;text-transform:none}

/* values cards (medicine-wheel colours) */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.vcard{border-radius:8px;padding:26px;color:#fff;min-height:170px}
.vcard h4{font-size:1.15rem;margin-bottom:8px}
.vcard p{font-size:.9rem;font-weight:300;opacity:.95}
.vcard.r{background:linear-gradient(160deg,var(--wred),#9e1f1f)}
.vcard.y{background:var(--gold);color:var(--ink)}
.vcard.b{background:linear-gradient(160deg,var(--wblue),#1a2a6b)}
.vcard.k{background:linear-gradient(160deg,#3a3a3a,#111)}

/* programs full listing */
.plist{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.pfull{background:#fff;border:1px solid var(--tan);border-radius:9px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 5px 18px rgba(0,0,0,.06);border-top:4px solid var(--blue)}
.pfull .ph{height:188px;background-size:cover;background-position:center}
.pfull .body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.pfull .tag{align-self:flex-start;font-family:'Oswald';font-size:.62rem;letter-spacing:.1em;font-weight:600;padding:3px 9px;border-radius:2px;margin-bottom:10px;text-transform:uppercase;background:var(--blue);color:#fff}
.pfull .tag.free{background:var(--gold);color:var(--ink)}
.pfull .tag.fee{background:var(--red);color:#fff}
.pfull h3{color:var(--blue);font-size:1.25rem;line-height:1.1}
.pfull .sub{font-family:'Oswald';font-size:.78rem;letter-spacing:.06em;color:var(--red);text-transform:uppercase;margin:4px 0 10px}
.pfull p{font-size:.92rem;margin-bottom:14px}
.pfull .contact{margin-top:auto;border-top:1px solid var(--tan);padding-top:12px;font-size:.86rem}
.pfull .contact a{color:var(--red);text-decoration:none;font-weight:600}
.pfull .contact a:hover{text-decoration:underline}
.pfull .contact .who{font-weight:600;color:var(--ink)}

/* contact page */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.infocard{background:#fff;border:1px solid var(--tan);border-radius:9px;padding:28px;box-shadow:0 5px 18px rgba(0,0,0,.06)}
.inforow{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.1)}
.inforow:last-child{border-bottom:0}
.inforow .lab{font-family:'Oswald';text-transform:uppercase;font-size:.74rem;letter-spacing:.08em;color:var(--red);min-width:84px;padding-top:2px}
.inforow .val{font-size:.95rem}
.inforow .val a{color:var(--blue);text-decoration:none}
.inforow .val a:hover{text-decoration:underline}
.cform label{display:block;font-family:'Oswald';font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;color:var(--blue);margin:14px 0 5px}
.cform input,.cform textarea{width:100%;border:1.5px solid var(--tan);border-radius:5px;padding:11px 13px;font-family:inherit;font-size:.95rem;background:#fff}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--blue)}
.cform textarea{min-height:130px;resize:vertical}
.cform .btn{margin-top:18px;border:0;cursor:pointer}
.cform .formnote{margin-top:16px;padding:13px 15px;background:var(--cream);border:1px solid var(--tan);border-left:4px solid var(--gold);border-radius:6px;color:var(--ink);font-size:.92rem;line-height:1.5}
.cform .formnote a{color:var(--red);font-weight:600}
.mapwrap{margin-top:18px;border-radius:9px;overflow:hidden;border:1px solid var(--tan)}
.mapwrap iframe{display:block;width:100%;height:300px;border:0}
.emaillist{display:grid;grid-template-columns:1fr 1fr;gap:8px 22px;margin-top:6px}
.emaillist a{font-size:.9rem;color:var(--blue);text-decoration:none}
.emaillist a:hover{text-decoration:underline}

/* simple list rows for Events/News pages */
.feed{max-width:50rem;margin:0 auto;display:flex;flex-direction:column;gap:0}
.feed .item{display:flex;gap:22px;padding:15px 18px;margin-bottom:12px;background:#fff;border:1px solid var(--tan);border-left:5px solid var(--tan);border-radius:8px;box-shadow:0 3px 10px rgba(0,0,0,.05)}
.feed .item .when{font-family:'Oswald';color:var(--red);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;min-width:140px;padding-top:3px}
.feed .item h3{color:var(--blue);font-size:1.25rem;margin-bottom:5px}
.feed .item p{font-size:.95rem}

/* ---------- "What's On" calendar (calendar.html) ---------- */
.calfilters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:50rem;margin:0 auto 6px}
.calchip{font-family:'Oswald';font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;padding:7px 17px;border-radius:30px;border:1.5px solid var(--tan);background:#fff;color:var(--blue);cursor:pointer;transition:background .2s,color .2s,border-color .2s}
.calchip:hover{border-color:var(--blue)}
.calchip.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.calgroup{max-width:50rem;margin:0 auto}
.calmonth{font-family:'Oswald';color:var(--red);text-transform:uppercase;letter-spacing:.1em;font-size:.9rem;font-weight:600;margin:30px 0 0;padding-bottom:8px;border-bottom:2px solid var(--tan)}
.ctag{display:inline-block;font-family:'Oswald';font-size:.64rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:2px 9px;border-radius:3px;margin-bottom:7px}
.ctag.dropin{background:var(--gold);color:var(--ink)}
.ctag.event{background:var(--blue);color:#fff}
.ctag.news{background:var(--red);color:#fff}
/* feed + calendar rows are outlined white cards; left stripe colored by type/page */
.feed .item.calitem[data-type="dropin"]{border-left-color:var(--gold)}
.feed .item.calitem[data-type="event"]{border-left-color:var(--blue)}
.feed .item.calitem[data-type="news"]{border-left-color:var(--red)}
[data-content="events-feed"] .item{border-left-color:var(--blue)}
[data-content="news-feed"] .item{border-left-color:var(--red)}
/* calendar call-to-action band on the Programs page */
.calcta{text-align:center;padding-top:34px;padding-bottom:0}
.calcta p{color:var(--muted);margin:0 0 15px;font-size:1rem}

/* ============================================================
   MOBILE / RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .values{grid-template-columns:repeat(2,1fr)}
  .plist{grid-template-columns:1fr}
  .culture .row{grid-template-columns:repeat(2,1fr)}
  .impact .row{grid-template-columns:repeat(2,1fr);gap:28px}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .navlinks{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;gap:0;border-bottom:3px solid var(--blue);padding:8px 0}
  .navlinks.open{display:flex}
  .navlinks a{padding:12px 26px;width:100%}
  .menubtn{display:block}
  .hero::after{display:none}
  .hero::before{background:linear-gradient(180deg,rgba(16,37,74,.85),rgba(16,37,74,.9))}
  .hero-inner{padding:56px 0}
  .paths{grid-template-columns:1fr}
  .pgrid{grid-template-columns:1fr}
  .story .grid{padding:48px 20px}
  .story .copy{max-width:none}
  .story .photo{height:240px;margin-bottom:28px;border-radius:14px}
  .story .photo::after{display:none}
  .en{grid-template-columns:1fr}
  .en .events,.en .news{padding:44px 26px}
  .pagehead::after{display:none}
  .two-col{grid-template-columns:1fr;gap:28px}
  .contact-grid{grid-template-columns:1fr;gap:30px}
  .feed .item{flex-direction:column;gap:4px}
  .feed .item .when{min-width:0}
  .emaillist{grid-template-columns:1fr}
}
@media(max-width:560px){
  .culture .row{grid-template-columns:1fr 1fr}
  .fgrid{grid-template-columns:1fr}
  /* tidy the top bar: hide the long address/phone/hours text on phones
     (it's not tappable, and the info lives in the footer + Contact page) */
  .util .wrap > span:first-child{display:none}
  .util .wrap{justify-content:flex-end}
  /* full-width stacked hero buttons: even layout + big tap targets */
  .hero-cta .btns{flex-direction:column;align-items:stretch}
  .hero-cta .btns .btn{width:100%;text-align:center}
  /* medicine-wheel value cards: keep the 2x2, give the text more room */
  .vcard{padding:18px;min-height:0}
}
@media(min-width:861px) and (max-width:1040px){
  .pgrid{grid-template-columns:repeat(2,1fr)}
}
