:root{
  --paper:#F5F1E6;
  --paper-2:#EDE7D6;
  --green:#2E5E3A;
  --green-deep:#244B2E;
  --navy:#1E3A5F;
  --honey:#D98A2B;
  --honey-deep:#BE741D;
  --ink:#1A2421;
  --ink-soft:#42514A;
  --line:rgba(30,58,95,.16);

  --display:'Bricolage Grotesque','Inter',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --script:'Bricolage Grotesque','Inter',sans-serif;

  --wrap:1180px;
  --r:14px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}

body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.08;margin:0}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}

/* paper grain on the whole page */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}
.page{position:relative;z-index:1}

/* ---------- signature: torn brush band ---------- */
.brush{
  display:inline-block;color:#fff;font-family:var(--display);font-weight:600;
  padding:.28em 1.1em;position:relative;letter-spacing:.01em;
}
.brush::before{
  content:"";position:absolute;inset:0;z-index:-1;background:var(--green);
  /* hand-torn edges */
  clip-path:polygon(2% 18%,8% 4%,22% 12%,38% 2%,55% 14%,72% 4%,86% 16%,97% 6%,99% 40%,98% 70%,99% 92%,88% 86%,72% 96%,55% 84%,40% 96%,24% 86%,10% 96%,3% 82%,1% 52%);
  border-radius:4px;
}

/* ============ TOP BAR ============ */
.topbar{
  background:var(--green-deep);color:#EAF0E6;font-size:.82rem;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;height:40px}
.topbar a{color:#EAF0E6;text-decoration:none;opacity:.9}
.topbar a:hover{opacity:1}
.topbar .tb-r{display:flex;gap:18px;align-items:center}
.topbar .tb-l{display:flex;gap:8px;align-items:center;font-weight:500}
.topbar .dot{width:6px;height:6px;border-radius:50%;background:var(--honey);display:inline-block}

/* ============ NAV ============ */
header.nav{
  position:sticky;top:0;z-index:50;background:rgba(245,241,230,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
header.nav .wrap{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:80px;gap:24px}
.brand{display:flex;align-items:center;text-decoration:none;color:var(--ink);justify-self:start}
.brand .bt{line-height:.9;display:flex;flex-direction:column}
.brand .bt b{font-family:var(--display);font-weight:800;font-size:1.7rem;letter-spacing:-.03em;color:var(--green);text-transform:lowercase}
.brand .bt span{font-size:.64rem;letter-spacing:.34em;text-transform:uppercase;color:var(--honey-deep);font-weight:700;margin-top:5px;margin-left:2px}

nav.main{display:flex;gap:2px;align-items:center;justify-self:center}
nav.main a{
  position:relative;
  text-decoration:none;font-weight:600;font-size:.95rem;color:var(--navy);
  padding:9px 16px;border-radius:8px;transition:color .15s;
}
/* animated underline (excludes the mobile CTA button) */
nav.main a:not(.cta)::after{
  content:"";position:absolute;left:16px;right:16px;bottom:5px;height:2px;
  background:var(--green);border-radius:2px;
  transform:scaleX(0);transform-origin:center;transition:transform .22s ease;
}
nav.main a:not(.cta):hover{color:var(--green)}
nav.main a:not(.cta):hover::after{transform:scaleX(1)}
nav.main a[aria-current="page"]{color:var(--green)}
nav.main a[aria-current="page"]::after{transform:scaleX(1)}
nav.main a.cta-mobile{display:none}

.nav-right{display:flex;align-items:center;gap:12px;justify-self:end}
.cta{
  background:var(--honey);color:#fff;text-decoration:none;font-weight:700;font-size:.92rem;
  padding:10px 20px;border-radius:50px;box-shadow:0 1px 0 var(--honey-deep);transition:background .15s;white-space:nowrap;
}
.cta:hover{background:var(--honey-deep);color:#fff}

.menu-btn{display:none;background:none;border:1.5px solid var(--line);border-radius:9px;
  width:46px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.menu-btn span,.menu-btn span::before,.menu-btn span::after{
  content:"";display:block;width:20px;height:2px;background:var(--navy);position:relative;transition:.2s}
.menu-btn span::before{position:absolute;top:-6px}
.menu-btn span::after{position:absolute;top:6px}

/* ============ HERO / BANNER ============ */
.hero{position:relative;overflow:hidden;background:var(--navy)}
.hero img.bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:saturate(1.04) brightness(.82);
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(105deg,rgba(12,26,18,.72) 0%,rgba(12,26,18,.5) 42%,rgba(12,26,18,.22) 72%,rgba(12,26,18,.32) 100%),
    linear-gradient(180deg,rgba(12,26,18,.28) 0%,rgba(12,26,18,0) 30%,rgba(20,40,33,.55) 100%);
}
.hero .wrap{position:relative;z-index:2;padding:118px 24px 132px;color:#fff}
.hero .kick{
  display:inline-flex;align-items:center;gap:9px;font-size:.78rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:#fff;
  background:rgba(217,138,43,.92);padding:7px 15px;border-radius:50px;margin-bottom:22px;
}
.hero h1{
  font-size:clamp(2.6rem,6.2vw,4.6rem);font-weight:700;max-width:15ch;
  text-shadow:0 2px 28px rgba(8,18,12,.55);letter-spacing:-.025em;
}
.hero h1 em{font-style:normal;color:#F4C988;font-weight:800}
.hero p.lede{
  margin:22px 0 34px;font-size:clamp(1.05rem,2vw,1.28rem);max-width:48ch;
  color:rgba(255,255,255,.94);text-shadow:0 1px 12px rgba(10,22,16,.45);
}
.hero .actions{display:flex;flex-wrap:wrap;gap:14px}
.btn{
  display:inline-flex;align-items:center;gap:9px;text-decoration:none;font-weight:600;
  font-size:1rem;padding:14px 26px;border-radius:50px;transition:transform .15s,box-shadow .15s,background .15s;
}
.btn-honey{background:var(--honey);color:#fff;box-shadow:0 6px 18px rgba(190,116,29,.4)}
.btn-honey:hover{background:var(--honey-deep);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}

/* ============ SECTION SHELL ============ */
section{position:relative;padding:96px 0}
.eyebrow{
  font-family:var(--body);font-weight:700;font-size:.76rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--honey-deep);margin-bottom:14px;display:flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--honey);display:inline-block}
.script{font-family:var(--display);color:var(--honey-deep);font-weight:800}

/* split sections */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split .photo{position:relative}
.split .photo img{border-radius:var(--r);width:100%;height:100%;max-height:520px;object-fit:cover;
  box-shadow:0 20px 50px rgba(20,40,33,.16)}
.split h2{font-size:clamp(2rem,3.6vw,2.9rem);color:var(--ink);margin-bottom:8px}
.split p{color:var(--ink-soft);font-size:1.06rem;margin:0 0 18px}
.split .body p:first-of-type{margin-top:18px}

.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.tag{font-size:.8rem;font-weight:600;color:var(--navy);background:var(--paper-2);
  border:1px solid var(--line);border-radius:50px;padding:6px 13px}

/* ============ MARKET ============ */
#market{background:var(--green);color:#EAF3E8;overflow:hidden;padding-bottom:112px}
#market::before{
  content:"";position:absolute;inset:0;opacity:.06;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 20h40M20 0v40' stroke='%23fff' stroke-width='1'/%3E%3C/svg%3E");
}
#market .eyebrow{color:#F4C988}
#market .eyebrow::before{background:var(--honey)}
#market .split{align-items:center}
#market h2{color:#fff;font-size:clamp(2.2rem,4vw,3.2rem)}
#market p{color:rgba(234,243,232,.9)}
#market .photo img{box-shadow:0 24px 60px rgba(10,30,16,.5)}

.market-meta{display:flex;flex-wrap:wrap;gap:28px;margin:22px 0 26px}
.mm{display:flex;gap:11px;align-items:flex-start}
.mm svg{width:22px;height:22px;flex:none;color:#F4C988;margin-top:2px}
.mm b{display:block;color:#fff;font-weight:600;font-size:.98rem}
.mm span{font-size:.86rem;color:rgba(234,243,232,.82)}

.dates{
  display:flex;flex-wrap:wrap;gap:7px;margin:4px 0 28px;
}
.dates .d{
  font-size:.82rem;font-weight:600;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:7px 11px;color:#EAF3E8;
}
.dates .d.tw{background:var(--honey);border-color:var(--honey);color:#fff}

#market .btn-honey{box-shadow:0 6px 18px rgba(10,30,16,.4)}
#market .btn-ghost{border-color:rgba(255,255,255,.55)}

/* ============ WHAT'S ON (tiles) ============ */
#whats-on{background:var(--paper-2)}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:44px;flex-wrap:wrap}
.section-head h2{font-size:clamp(2rem,3.6vw,2.9rem)}
.section-head p{color:var(--ink-soft);margin:8px 0 0;max-width:42ch}
.section-head .all{text-decoration:none;font-weight:600;color:var(--green);white-space:nowrap;
  border-bottom:2px solid var(--honey);padding-bottom:3px}
.section-head .all:hover{color:var(--honey-deep)}

.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tile{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  text-decoration:none;color:var(--ink);display:flex;flex-direction:column;
  transition:transform .18s,box-shadow .18s;position:relative;
}
.tile:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(20,40,33,.16)}
.tile .ph{aspect-ratio:3/2;overflow:hidden;background:var(--paper-2)}
.tile .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.tile:hover .ph img{transform:scale(1.05)}
.tile .date-chip{
  position:absolute;top:14px;left:14px;z-index:2;background:var(--paper);border-radius:10px;
  text-align:center;line-height:1;padding:9px 12px;box-shadow:0 4px 12px rgba(20,40,33,.18);
}
.tile .date-chip .m{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--honey-deep)}
.tile .date-chip .day{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--navy);display:block;margin-top:1px}
.tile .body{padding:20px 20px 22px;display:flex;flex-direction:column;gap:7px;flex:1}
.tile .cat{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
.tile h3{font-size:1.22rem;color:var(--ink)}
.tile .meta{font-size:.86rem;color:var(--ink-soft);margin-top:auto;display:flex;gap:7px;align-items:center}
.tile .meta svg{width:15px;height:15px;color:var(--honey-deep)}

/* recurring (non-dated) item style */
.tile.rec .date-chip{background:var(--green);color:#fff}
.tile.rec .date-chip .m{color:#F4C988}
.tile.rec .date-chip .day{color:#fff;font-size:1.05rem;padding:2px 0}

/* ============ QUICK LINKS ============ */
#links{background:var(--paper)}
.links-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.qlink{
  text-decoration:none;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);
  border-radius:var(--r);padding:26px 22px;display:flex;flex-direction:column;gap:13px;
  transition:transform .16s,box-shadow .16s,border-color .16s;
}
.qlink:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(20,40,33,.14);border-color:var(--honey)}
.qlink .ic{width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--green)}
.qlink .ic svg{width:24px;height:24px}
.qlink b{font-family:var(--display);font-weight:600;font-size:1.15rem}
.qlink span{font-size:.88rem;color:var(--ink-soft)}
.qlink .go{margin-top:auto;font-weight:600;font-size:.85rem;color:var(--honey-deep);display:flex;align-items:center;gap:5px}

/* ============ FIND US ============ */
#find{background:var(--navy);color:#EAF0F6;overflow:hidden}
#find .eyebrow{color:#F4C988}
#find .eyebrow::before{background:var(--honey)}
.find-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
#find h2{color:#fff;font-size:clamp(2rem,3.6vw,2.9rem);margin-bottom:18px}
#find .lede{color:rgba(234,240,246,.86);font-size:1.08rem;margin-bottom:30px;max-width:46ch}
.info-list{display:flex;flex-direction:column;gap:20px}
.info{display:flex;gap:15px;align-items:flex-start}
.info .ic{width:42px;height:42px;border-radius:11px;flex:none;background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;color:#F4C988}
.info .ic svg{width:21px;height:21px}
.info b{display:block;color:#fff;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  font-weight:700;margin-bottom:3px;opacity:.7}
.info a,.info span{color:#EAF0F6;text-decoration:none;font-size:1.04rem}
.info a:hover{color:#F4C988}
.map-card{background:var(--paper);border-radius:var(--r);overflow:hidden;
  box-shadow:0 22px 54px rgba(10,22,40,.4)}
.map-card iframe{display:block;width:100%;height:380px;border:0;filter:saturate(.92)}
.map-card .cap{padding:16px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.map-card .cap b{font-family:var(--display);font-weight:600;color:var(--ink);font-size:1.05rem}
.map-card .cap a{font-weight:600;color:var(--green);text-decoration:none;font-size:.88rem;white-space:nowrap}
.map-card .cap a:hover{color:var(--honey-deep)}

/* ============ FOOTER ============ */
footer{background:var(--green-deep);color:#D7E3D4;padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px;margin-bottom:44px}
.foot-brand .brand .bt b{color:#fff}
.foot-brand .brand .bt span{color:#A9C2A5}
.foot-brand p{color:#A9C2A5;font-size:.95rem;margin:18px 0 0;max-width:36ch}
.foot-social{display:flex;gap:11px;margin-top:20px}
.foot-social a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:#EAF3E8;text-decoration:none;transition:background .15s}
.foot-social a:hover{background:var(--honey)}
.foot-social svg{width:19px;height:19px}
.foot-col h4{font-family:var(--body);font-weight:700;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:#fff;margin:0 0 16px}
.foot-col a{display:block;color:#C4D6C0;text-decoration:none;font-size:.95rem;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:#F4C988}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  font-size:.85rem;color:#9DB39A}
.foot-bottom a{color:#9DB39A;text-decoration:none}
.foot-bottom a:hover{color:#fff}

/* ============ RESPONSIVE ============ */
@media (max-width:1000px){
  .links-grid{grid-template-columns:repeat(2,1fr)}
  .tiles{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:880px){
  header.nav .wrap{grid-template-columns:1fr auto}
  nav.main{display:none}
  nav.main.open{
    display:flex;flex-direction:column;align-items:stretch;position:absolute;top:80px;left:0;right:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:12px 24px 18px;gap:2px;
    box-shadow:0 18px 30px rgba(20,40,33,.12);
  }
  nav.main.open a{padding:13px 12px}
  /* stacked menu: swap the underline for a left-aligned pill/active tint */
  nav.main.open a:not(.cta)::after{display:none}
  nav.main.open a:not(.cta):hover,
  nav.main.open a:not(.cta)[aria-current="page"]{background:var(--paper-2);color:var(--green)}
  nav.main.open a.cta-mobile{display:flex;margin:8px 0 0;text-align:center;justify-content:center}
  .nav-right .cta{display:none}
  .menu-btn{display:flex}
  .split,.find-grid{grid-template-columns:1fr;gap:36px}
  #market .split .photo,.split.rev .photo{order:-1}
  .section-head{flex-direction:column;align-items:flex-start}
  section{padding:72px 0}
}
@media (max-width:560px){
  .tiles{grid-template-columns:1fr}
  .links-grid{grid-template-columns:1fr}
  .topbar .tb-l span.hide-sm{display:none}
  .hero .wrap{padding:84px 24px 110px}
  .foot-grid{grid-template-columns:1fr;gap:32px}
}

/* ============================================================
   INNER PAGES
   ============================================================ */

/* page banner (compact hero for inner pages) */
.page-hero{position:relative;background:var(--navy);overflow:hidden}
.page-hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.55) saturate(1.02)}
.page-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,26,18,.5),rgba(20,40,33,.72))}
.page-hero .wrap{position:relative;z-index:2;padding:84px 24px 78px;color:#fff}
.page-hero .crumb{font-size:.82rem;font-weight:600;letter-spacing:.04em;color:rgba(255,255,255,.78);margin-bottom:14px}
.page-hero .crumb a{color:rgba(255,255,255,.78);text-decoration:none}
.page-hero .crumb a:hover{color:#F4C988}
.page-hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.3rem,5vw,3.6rem);
  letter-spacing:-.025em;max-width:18ch;text-shadow:0 2px 22px rgba(8,18,12,.5)}
.page-hero p{margin:16px 0 0;font-size:clamp(1.02rem,2vw,1.2rem);max-width:54ch;color:rgba(255,255,255,.92);
  text-shadow:0 1px 12px rgba(8,18,12,.45)}

/* generic content section */
.content{padding:80px 0}
.content.alt{background:var(--paper-2)}
.lead-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.lead-row.rev .photo{order:2}
.lead-row .photo img{width:100%;border-radius:var(--r);object-fit:cover;max-height:460px;
  box-shadow:0 20px 50px rgba(20,40,33,.16)}
.prose{max-width:62ch}
.prose h2{font-family:var(--display);font-weight:700;font-size:clamp(1.7rem,3vw,2.4rem);
  letter-spacing:-.02em;color:var(--ink);margin:0 0 18px}
.prose h3{font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--green);margin:32px 0 10px}
.prose p{color:var(--ink-soft);font-size:1.06rem;margin:0 0 16px}
.prose ul{color:var(--ink-soft);font-size:1.06rem;margin:0 0 18px;padding-left:22px}
.prose li{margin:6px 0}
.prose a{color:var(--green);font-weight:600;text-decoration:underline;text-decoration-color:var(--honey)}
.prose a:hover{color:var(--honey-deep)}

/* directory / listing cards (clubs, groups) */
.dir{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.dir.one{grid-template-columns:1fr;max-width:760px}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:30px 30px 28px;scroll-margin-top:100px;
}
.content.alt .card{background:#fff}
.card .ct{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.card .ct .pip{width:34px;height:34px;border-radius:9px;flex:none;background:var(--green);
  display:flex;align-items:center;justify-content:center;color:#fff}
.card .ct .pip svg{width:18px;height:18px}
.card h3{font-family:var(--display);font-weight:700;font-size:1.35rem;color:var(--ink);margin:0;letter-spacing:-.01em}
.card .sub{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--honey-deep);margin:2px 0 0}
.card p{color:var(--ink-soft);font-size:1rem;margin:14px 0 0}
.card .rows{margin:16px 0 0;display:flex;flex-direction:column;gap:9px}
.card .row{display:flex;gap:10px;font-size:.95rem;color:var(--ink)}
.card .row b{color:var(--ink-soft);font-weight:600;min-width:78px;flex:none}
.card .row a{color:var(--green);text-decoration:none;font-weight:600}
.card .row a:hover{color:var(--honey-deep)}
.card .chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.card .chips .tag{font-size:.78rem;font-weight:600;color:var(--navy);background:var(--paper-2);
  border:1px solid var(--line);border-radius:50px;padding:5px 12px}
.content.alt .card .chips .tag{background:var(--paper)}

/* section intro heading */
.sec-intro{max-width:60ch;margin-bottom:42px}
.sec-intro .eyebrow{margin-bottom:14px}
.sec-intro h2{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,3.4vw,2.7rem);
  letter-spacing:-.02em;color:var(--ink);margin:0 0 12px}
.sec-intro p{color:var(--ink-soft);font-size:1.08rem;margin:0}

/* market date board */
.date-board{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-top:8px}
.date-board .dcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 14px;text-align:center}
.content:not(.alt) .date-board .dcard{background:var(--paper-2)}
.date-board .dcard .mo{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--honey-deep)}
.date-board .dcard .dy{font-family:var(--display);font-weight:800;font-size:1.7rem;color:var(--navy);line-height:1.1}
.date-board .dcard.tw{background:var(--green);border-color:var(--green)}
.date-board .dcard.tw .mo{color:#F4C988}
.date-board .dcard.tw .dy{color:#fff}
.date-board .dcard.tw .nt{font-size:.68rem;color:rgba(255,255,255,.85);font-weight:600;margin-top:2px}

/* stall types grid */
.stalls{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:14px;margin-top:8px}
.stall{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:20px 14px;text-align:center}
.content.alt .stall{background:#fff}
.stall .si{width:40px;height:40px;margin:0 auto 10px;border-radius:10px;background:var(--paper-2);
  display:flex;align-items:center;justify-content:center;color:var(--green)}
.content.alt .stall .si{background:var(--paper)}
.stall .si svg{width:22px;height:22px}
.stall b{font-size:.92rem;font-weight:600;color:var(--ink)}

/* callout band */
.band{background:var(--green);color:#EAF3E8;border-radius:var(--r);padding:44px 44px;
  display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
.band h3{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,2.6vw,2rem);color:#fff;margin:0 0 8px;letter-spacing:-.01em}
.band p{color:rgba(234,243,232,.9);margin:0;max-width:46ch;font-size:1.04rem}
.band .band-actions{display:flex;gap:12px;flex-wrap:wrap}
.band .btn-honey{box-shadow:0 6px 18px rgba(10,30,16,.4)}
.band .btn-ghost{border-color:rgba(255,255,255,.55)}

/* FAQ */
.faq{max-width:780px}
.faq details{border-bottom:1px solid var(--line);padding:4px 0}
.faq summary{cursor:pointer;list-style:none;padding:18px 0;font-family:var(--display);font-weight:600;
  font-size:1.12rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--honey-deep);font-weight:400;transition:transform .2s;flex:none}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--ink-soft);font-size:1.02rem;margin:0 0 18px;max-width:64ch}

/* simple stat row */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.stat-row .st{background:var(--paper);padding:28px 22px;text-align:center}
.content.alt .stat-row .st{background:#fff}
.stat-row .st b{display:block;font-family:var(--display);font-weight:800;font-size:2rem;color:var(--green);line-height:1}
.stat-row .st span{display:block;margin-top:7px;font-size:.86rem;color:var(--ink-soft);font-weight:500}

@media (max-width:880px){
  .lead-row{grid-template-columns:1fr;gap:34px}
  .lead-row.rev .photo{order:-1}
  .dir{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  .band{flex-direction:column;align-items:flex-start}
  .content{padding:60px 0}
}
