/* =====================================================================
   MonacoUSA — site styles  (v2: light theme)
   Palette: WHITE backgrounds + Monaco RED accents, regal gold hairlines.
   No dark/black backgrounds — red is the only strong colour band.
   Display/accent font: Cinzel (regal). Subheads/leads: Cormorant Garamond.
   Body: Inter, softened to grey. Offline-safe system fallbacks.
   ===================================================================== */

:root {
  --red:        #CE1126;   /* Monaco flag red */
  --red-dark:   #A50E1F;
  --red-tint:   #FBEDED;   /* faint red wash for placeholders */
  --gold:       #B08D57;   /* regal accent / hairlines */
  --gold-light: #DFCBA4;
  --ink:        #54535F;   /* headings, nav & wordmark — soft dark grey (never black) */
  --body:       #6B6B74;   /* body text — light-medium grey */
  --body-soft:  #6E6E78;
  --cream:      #FBF8F4;   /* warm off-white section background */
  --white:      #FFFFFF;
  --line:       #ECE6DD;
  --shadow:     0 10px 30px rgba(43,42,46,.07);
  --shadow-lg:  0 20px 50px rgba(43,42,46,.12);
  --maxw:       1180px;
  --radius:     10px;
  --display: "Cormorant Garamond", "Playfair Display", Georgia, serif;  /* regal headings (mixed case) */
  --accent:  "Cinzel", Georgia, serif;                                  /* engraved caps — brand, eyebrows, numerals */
  --serif:   "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* ---------- reset / base ---------- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--sans);
  color: var(--body);
  background: var(--white);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--red); text-decoration: none; transition: color .2s; }
a:hover { color: var(--red-dark); }

h1, h2, h3, h4 { font-family: var(--display); font-weight: 700; line-height: 1.14; color: var(--ink); margin: 0 0 .5em; letter-spacing: 0; }
h1 { font-size: clamp(2.4rem, 5.4vw, 4rem); }
h2 { font-size: clamp(1.9rem, 3.6vw, 2.8rem); }
h3 { font-family: var(--display); font-weight: 600; font-size: 1.5rem; letter-spacing: 0; }
p  { margin: 0 0 1rem; }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding: 58px 0; }
.section--tight { padding: 40px 0; }
.bg-white { background: var(--white); }
.bg-cream { background: var(--cream); }

/* RED feature band (replaces the old dark band) */
.bg-ink { background: linear-gradient(160deg, var(--red), var(--red-dark)); color: #fff; }
.bg-ink h1, .bg-ink h2, .bg-ink h3 { color: #fff; }
.bg-ink .lead { color: rgba(255,255,255,.92); }
.bg-ink .rule { background: #fff; }
.bg-ink .eyebrow { color: var(--gold-light); }
.bg-ink .stat .num { color: #fff; }
.bg-ink .stat .lbl { color: rgba(255,255,255,.85); }

.eyebrow {
  display: none;   /* eyebrow labels removed site-wide per request */
  font-family: var(--accent); font-weight: 600; letter-spacing: .18em;
  text-transform: uppercase; font-size: .8rem; color: var(--gold);
  margin: 0 0 .9rem;
}
.eyebrow.keep { display: block; }   /* exceptions: eyebrows we keep */
.lead { font-family: var(--serif); font-size: 1.35rem; line-height: 1.5; color: var(--body); max-width: 60ch; }
.center { text-align: center; }
.center .lead { margin-left: auto; margin-right: auto; }
.rule { width: 64px; height: 3px; background: var(--red); border: 0; margin: 1.1rem 0; }
.center .rule { margin-left: auto; margin-right: auto; }

/* ---------- buttons ---------- */
.btn {
  display: inline-block; font-family: var(--sans); font-weight: 600;
  font-size: .92rem; letter-spacing: .03em; padding: 13px 28px;
  border-radius: 6px; cursor: pointer; transition: all .2s; border: 2px solid transparent;
}
.btn--primary { background: var(--red); color: #fff; }
.btn--primary:hover { background: var(--red-dark); color: #fff; transform: translateY(-2px); }
.btn--outline { background: transparent; color: var(--red); border-color: var(--red); }
.btn--outline:hover { background: var(--red); color: #fff; }
.btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.7); }  /* on red bands */
.btn--ghost:hover { background: #fff; color: var(--red); }
.btn--dark { background: var(--ink); color: #fff; }
.btn--dark:hover { background: #1f1e24; color: #fff; transform: translateY(-2px); }

/* ---------- header / nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.97); backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 76px; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand img { width: 42px; height: 42px; }
.brand b { font-family: var(--display); font-size: 1.5rem; letter-spacing: .01em; color: var(--ink); font-weight: 700; line-height: 1; }
.brand .tag { display: block; font-family: var(--sans); font-size: .58rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); font-weight: 600; line-height: 1.5; margin-top: 4px; }
.brand .tag::after { content: "Since 1973"; display: block; }
.nav-links { display: flex; align-items: center; gap: 17px; list-style: none; margin: 0; padding: 0; }
.nav-links a { color: var(--ink); font-weight: 500; font-size: .9rem; }
.nav-links a:hover { color: var(--red); }
.nav-links .btn { padding: 9px 20px; font-size: .88rem; }
.nav-links a.btn--primary, .nav-links a.btn--primary:hover { color: #fff; }  /* Join stays white (beats .nav-links a) */
.nav-links a.btn--outline { color: var(--red); }
.nav-links a.btn--outline:hover { color: #fff; }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--ink); margin: 5px 0; transition: .25s; }

/* ---------- hero (light) ---------- */
.hero {
  position: relative; color: var(--ink); text-align: center;
  background:
    linear-gradient(rgba(255,255,255,.60), rgba(250,245,239,.78)),
    url("../img/photos/monaco-hero.jpg");
  background-size: cover; background-position: center;
  padding: 104px 0 96px; overflow: hidden; border-bottom: 1px solid var(--line);
}
.hero::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 5px;
  background: linear-gradient(90deg, var(--red) 0 50%, #fff 50% 100%); }
.hero h1 { color: var(--gold); max-width: 20ch; margin-inline: auto; }
.nowrap { white-space: nowrap; }
.hero .lead { color: var(--body); margin: 1.1rem auto 2rem; }
.hero-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.hero .crest { width: 78px; margin: 0 auto 18px; }

/* ---------- page hero (interior, light) ---------- */
.page-hero { position: relative; text-align: center; padding: 42px 0 34px;
  background: linear-gradient(180deg, #FCF3F2 0%, #ffffff 100%); border-bottom: 1px solid var(--line); }
.page-hero::after { content:""; position:absolute; left:0;right:0;bottom:0;height:5px;
  background: linear-gradient(90deg,var(--red) 0 50%,#fff 50% 100%); }
.page-hero h1 { display: none; }  /* page title duplicates the menu — hidden; subtitle remains */
.page-hero p { color: var(--body); max-width: 60ch; margin: 0 auto; font-family: var(--serif); font-size: 1.25rem; }
.breadcrumb { font-size:.78rem; color: var(--gold); letter-spacing:.16em; text-transform:uppercase; margin-bottom:14px; font-weight:600; }

/* ---------- cards / grid ---------- */
.grid { display: grid; gap: 28px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.card {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; box-shadow: var(--shadow); transition: transform .25s, box-shadow .25s;
  display: flex; flex-direction: column;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.card .thumb { aspect-ratio: 16/10; background: linear-gradient(135deg, var(--red-tint), #F3DCDC);
  color: var(--red); display: grid; place-items: center; font-family: var(--display); letter-spacing:.1em; font-size:.8rem; border-bottom:1px solid var(--line); }
.card .body { padding: 22px 24px 26px; flex: 1; display: flex; flex-direction: column; }
.card .date { font-size: .8rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--red); margin-bottom: 6px; }
.card h3 { margin-bottom: .4rem; }
.card p { color: var(--body); font-size: .98rem; }
.card .card-foot { margin-top: auto; padding-top: 14px; }

/* CTA quad cards — light, red/gold accents */
.cta-card {
  position: relative; border-radius: var(--radius); overflow: hidden; min-height: 168px;
  display: flex; align-items: flex-end; padding: 24px; color: var(--ink);
  background: var(--white); border: 1px solid var(--line); border-top: 4px solid var(--red);
  box-shadow: var(--shadow); transition: transform .25s, box-shadow .25s;
}
.cta-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.cta-card h3 { color: var(--ink); margin: 0; }
.cta-card small { display:block; color: var(--gold); letter-spacing:.16em; text-transform:uppercase; font-size:.68rem; font-weight:600; margin-bottom:6px; font-family:var(--sans); }
.cta-card.is-gold, .cta-card.is-grey { border-top-color: var(--gold); }

/* ---------- horizontal timeline (heritage) ---------- */
.timeline-wrap { overflow-x: auto; padding: 8px 0 14px; -webkit-overflow-scrolling: touch; }
.timeline-h { display: flex; min-width: 100%; position: relative; padding-top: 4px; }
.timeline-h::before { content:""; position:absolute; top: 56px; left: 8%; right: 8%; height: 2px; background: var(--gold-light); }
.tl-item { flex: 1 1 0; min-width: 186px; text-align: center; padding: 0 16px; position: relative; }
.tl-year { font-family: var(--accent); font-weight: 700; font-size: 1.4rem; color: var(--red); height: 42px; }
.tl-dot { width: 18px; height: 18px; border-radius: 50%; background: var(--red);
  border: 4px solid #fff; box-shadow: 0 0 0 2px var(--gold-light); margin: 5px auto 24px; position: relative; z-index: 1; }
.tl-item h3 { font-size: 1.12rem; margin-bottom: .3rem; color: var(--ink); }
.tl-item p { font-size: .92rem; color: var(--body); margin: 0; }

/* ---------- gallery ---------- */
.gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.gallery .tile {
  aspect-ratio: 1/1; border-radius: 8px; overflow: hidden; position: relative;
  background: linear-gradient(135deg, var(--red-tint), #F1D9D9); color: var(--red);
  display: grid; place-items: center; text-align: center; padding: 12px; border: 1px solid var(--line);
}
.gallery .tile span { font-family: var(--serif); font-weight:600; font-size: 1rem; }
.gallery img { width:100%; height:100%; object-fit: cover; }

/* ---------- testimonials / spotlights ---------- */
.quote { background: var(--white); border: 1px solid var(--line); border-left: 4px solid var(--red);
  border-radius: 8px; padding: 26px 28px; box-shadow: var(--shadow); }
.quote p { font-family: var(--serif); font-size: 1.2rem; font-style: italic; color: var(--ink); margin-bottom: 14px; }
.quote .who { font-size: .9rem; color: var(--body-soft); font-weight: 600; font-style: normal; }
.quote .who span { color: var(--red); }

/* ---------- press strip ---------- */
.press { display:flex; gap: 40px; flex-wrap:wrap; justify-content:center; align-items:center; }
.press a { font-family: var(--display); font-size: 1.15rem; color: var(--ink); opacity:.7; transition: opacity .2s; }
.press a:hover { opacity: 1; color: var(--red); }

/* ---------- board ---------- */
.person { text-align: center; }
.person .avatar { width: 132px; height: 132px; border-radius: 50%; margin: 0 auto 14px;
  background: linear-gradient(135deg, var(--red-tint), #F1D9D9); color: var(--red);
  display:grid; place-items:center; font-family:var(--display); font-size:1.8rem; border: 3px solid var(--gold-light); }
.person img.avatar { object-fit: cover; }
.person h3 { margin-bottom: .1rem; }
.person .role { color: var(--red); font-weight: 600; font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; font-family: var(--sans); }

/* ---------- stats ---------- */
.stats { display:grid; grid-template-columns: repeat(4,1fr); gap: 24px; text-align:center; }
.stat .num { font-family: var(--accent); font-weight:700; font-size: 2.5rem; color: var(--red); line-height:1; }
.stat .lbl { color: var(--body); font-size: .85rem; letter-spacing:.08em; text-transform: uppercase; margin-top:6px; }

/* ---------- map ---------- */
.map-placeholder { border: 2px dashed var(--gold-light); border-radius: var(--radius);
  background: var(--cream); padding: 64px 24px; text-align: center; color: var(--body-soft); }

/* ---------- join / benefits ---------- */
.benefits { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.benefits li { padding-left: 34px; position: relative; color: var(--body); }
.benefits li::before { content:"✦"; position:absolute; left:0; top:0; color: var(--gold); font-size: 1.1rem; }

/* ---------- newsletter (footer) ---------- */
.newsletter { display:flex; gap:10px; flex-wrap:wrap; max-width:460px; }
.newsletter input { flex:1; min-width: 200px; padding: 12px 14px; border:1px solid var(--line); border-radius:6px; background:#fff; color:var(--ink); }

/* ---------- footer (light) ---------- */
.site-footer { background: var(--cream); color: var(--body); padding: 60px 0 26px; border-top: 3px solid var(--red); }
.site-footer h4 { color:var(--ink); font-family: var(--sans); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; }
.site-footer .brand b { color: var(--ink); font-family: var(--display); font-size: 1.32rem; letter-spacing:.01em; }
.footer-grid { display:grid; grid-template-columns: 2fr 1fr 1.4fr; gap:40px; }
.footer-grid ul { list-style:none; padding:0; margin:0; }
.footer-grid li { margin-bottom:8px; }
.footer-grid a { color:var(--body); }
.footer-grid a:hover { color:var(--red); }
.socials { display:flex; gap:12px; margin-top:14px; }
.socials a { width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--ink); background:#fff; }
.socials a:hover { background: var(--red); border-color: var(--red); color:#fff; }
.footer-bottom { border-top:1px solid var(--line); margin-top:40px; padding-top:22px; font-size:.82rem; color:var(--body-soft); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }

/* ---------- made-up illustration "photos" ---------- */
.photo-grid .card .thumb { color: transparent; background-size: cover; background-position: center; }
.photo-grid .card:nth-child(4n+1) .thumb { background-image: url("../img/photos/fireworks.svg"); }
.photo-grid .card:nth-child(4n+2) .thumb { background-image: url("../img/photos/soiree.svg"); }
.photo-grid .card:nth-child(4n+3) .thumb { background-image: url("../img/photos/dinner.svg"); }
.photo-grid .card:nth-child(4n+4) .thumb { background-image: url("../img/photos/harbour.svg"); }

.gallery .tile { background-size: cover; background-position: center; }
.gallery .tile span { color:#fff; text-shadow: 0 1px 6px rgba(0,0,0,.6); position: relative; z-index: 1; }
.gallery .tile:nth-child(5n+1) { background-image: linear-gradient(rgba(20,18,22,.18),rgba(20,18,22,.5)), url("../img/photos/harbour.svg"); }
.gallery .tile:nth-child(5n+2) { background-image: linear-gradient(rgba(20,18,22,.18),rgba(20,18,22,.5)), url("../img/photos/fireworks.svg"); }
.gallery .tile:nth-child(5n+3) { background-image: linear-gradient(rgba(20,18,22,.18),rgba(20,18,22,.5)), url("../img/photos/soiree.svg"); }
.gallery .tile:nth-child(5n+4) { background-image: linear-gradient(rgba(20,18,22,.18),rgba(20,18,22,.5)), url("../img/photos/dinner.svg"); }
.gallery .tile:nth-child(5n+5) { background-image: linear-gradient(rgba(20,18,22,.18),rgba(20,18,22,.5)), url("../img/photos/founding.svg"); }

/* ---------- note banner (prototype placeholders) ---------- */
.note { background:#FFF8E6; border:1px solid var(--gold-light); border-left:4px solid var(--gold); padding:13px 18px; border-radius:6px; font-size:.88rem; color:#6b5a2e; margin: 18px 0; }
.note code { background: rgba(0,0,0,.05); padding: 1px 5px; border-radius: 3px; }

/* ---------- "needs verification" inline flag ---------- */
.flag-check { display:inline-block; background:#FFF3CD; color:#8a6d1a; border:1px solid var(--gold-light);
  border-radius:4px; font-family:var(--sans); font-size:.55em; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; padding:2px 6px; vertical-align:middle; margin-left:8px; }

/* ---------- real photo gallery (figures + captions) ---------- */
.gallery-fig { display:grid; grid-template-columns: repeat(3,1fr); gap:18px; }
.gfig { margin:0; border:1px solid var(--line); border-radius:10px; overflow:hidden; background:#fff; box-shadow:var(--shadow); transition:transform .25s, box-shadow .25s; }
.gfig:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.gfig img { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.gfig figcaption { padding:13px 15px; font-size:.93rem; color:var(--body); font-family:var(--serif); font-size:1.02rem; }

/* event advert (flyer) — shown uncropped */
.advert { display:grid; grid-template-columns: 360px 1fr; gap:34px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:12px; padding:26px; box-shadow:var(--shadow); }
.advert img { width:100%; border-radius:8px; border:1px solid var(--line); }
@media (max-width:760px){ .advert { grid-template-columns:1fr; } }

/* logo sizing tweaks */
.brand img { object-fit: contain; }
.hero .crest { width: 96px; }

/* ---------- gallery: event-group accordion ---------- */
.gallery-controls { display:flex; justify-content:flex-end; margin-bottom:18px; }
.event-group { border:1px solid var(--line); border-radius:12px; overflow:hidden; margin-bottom:18px; background:#fff; box-shadow:var(--shadow); }
.event-card { width:100%; border:0; background:#fff; cursor:pointer; display:grid; grid-template-columns:120px 1fr auto; gap:18px; align-items:center; padding:14px 18px; text-align:left; font-family:inherit; }
.event-card:hover { background:var(--cream); }
.event-card img { width:120px; height:84px; object-fit:cover; border-radius:8px; border:1px solid var(--line); }
.event-card-meta h3 { margin:0 0 2px; color:var(--ink); }
.event-card-meta span { color:var(--body); font-size:.9rem; }
.event-card .chev { font-size:1.4rem; color:var(--red); transition:transform .25s; }
.event-card[aria-expanded="true"] .chev { transform:rotate(180deg); }
.event-photos { padding:6px 18px 20px; }
.event-photos[hidden] { display:none; }

/* ---------- forms (account / members) ---------- */
.form-card { background:#fff; border:1px solid var(--line); border-radius:12px; padding:32px; box-shadow:var(--shadow); max-width:560px; }
.form-grid { display:grid; gap:15px; }
.form-grid label { font-size:.85rem; font-weight:600; color:var(--ink); display:block; margin-bottom:5px; }
.form-grid input, .form-grid textarea, .form-grid select { width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:6px; font-family:inherit; color:var(--ink); background:#fff; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:15px; }
.avatar-upload { display:flex; align-items:center; gap:16px; }
.avatar-upload .ring { width:74px; height:74px; border-radius:50%; border:2px dashed var(--gold-light); display:grid; place-items:center; color:var(--gold); font-family:var(--display); }

/* ---------- members dashboard ---------- */
.dash { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.dash-card { background:#fff; border:1px solid var(--line); border-left:4px solid var(--red); border-radius:10px; padding:20px 22px; box-shadow:var(--shadow); }
.dash-card h4 { font-family:var(--sans); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin:0 0 8px; }
.dash-card .big { font-family:var(--display); font-size:1.6rem; color:var(--ink); }

/* ---------- member spotlight optional link ---------- */
.quote .spot-link { display:inline-block; margin-top:8px; font-size:.85rem; font-weight:600; }

/* ---------- member map ---------- */
#memberMap { height:460px; border-radius:12px; border:1px solid var(--line); box-shadow:var(--shadow); z-index:0; }
.leaflet-tooltip.country-label { background:transparent; border:0; box-shadow:none; color:#6f6f78; font-family:var(--sans); font-size:10px; letter-spacing:.1em; text-transform:uppercase; font-weight:700; padding:0; white-space:nowrap; text-shadow:0 1px 2px rgba(255,255,255,.8); }
.leaflet-tooltip.country-label::before { display:none; border:0; }

/* ---------- honours / medal (heritage) ---------- */
.honour { display:flex; gap:18px; align-items:center; background:#fff; border:1px solid var(--line); border-left:4px solid var(--gold); border-radius:10px; padding:20px 22px; box-shadow:var(--shadow); }
.honour .medal { font-size:2.2rem; }

/* ---------- breadcrumb removed sitewide (page is obvious from the menu) ---------- */
.breadcrumb { display: none; }

/* ---------- events: upcoming vs greyed past + accordion ---------- */
.acc { border:1px solid var(--line); border-radius:10px; overflow:hidden; margin-bottom:12px; background:#fff; box-shadow:var(--shadow); }
.acc-head { width:100%; border:0; background:#fff; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:14px; padding:15px 18px; text-align:left; font-family:inherit; }
.acc-head:hover { background:var(--cream); }
.acc-head .t { font-family:var(--display); font-size:1.2rem; color:var(--ink); }
.acc-head .d { color:var(--red); font-weight:600; font-size:.86rem; font-family:var(--accent); }
.acc-head .chev { color:var(--red); font-size:1.2rem; transition:transform .25s; }
.acc-head[aria-expanded="true"] .chev { transform:rotate(180deg); }
.acc-body { padding:2px 18px 18px; color:var(--body); }
.acc-body[hidden]{ display:none; }
.acc.past { opacity:.62; filter:saturate(.6); }       /* greyed past events */
.acc.past:hover { opacity:1; filter:none; }
.acc.past .acc-head .d { color:var(--body-soft); }

/* ---------- press: media list (non-card) ---------- */
.press-list { border-top:1px solid var(--line); }
.press-item { display:grid; grid-template-columns:160px 1fr auto; gap:22px; align-items:center; padding:22px 0; border-bottom:1px solid var(--line); }
.press-pub { display:flex; align-items:center; gap:10px; font-family:var(--display); font-size:1.1rem; color:var(--ink); }
.press-pub img { height:26px; width:auto; border-radius:4px; }
.press-item .headline { font-family:var(--serif); font-size:1.25rem; color:var(--ink); }
.press-item .headline a { color:var(--ink); }
.press-item .headline a:hover { color:var(--red); }
.press-item .yr { color:var(--body-soft); font-size:.9rem; white-space:nowrap; }
@media (max-width:680px){ .press-item { grid-template-columns:1fr; gap:6px; } }

/* ---------- objectives (non-card) ---------- */
.objective { text-align:center; padding: 6px 16px; }
.obj-num { font-family: var(--display); font-weight:700; font-size:2.7rem; color: var(--gold); line-height:1; }
.objective .bar { width:36px; height:3px; background:var(--red); margin:10px auto 14px; }
.objective p { font-family: var(--serif); font-size:1.24rem; font-style:italic; color: var(--ink); margin:0; }

/* ---------- community comments (non-card) ---------- */
.comment { text-align:center; padding: 20px 22px 6px; margin:0; }
.comment::before { content:"\201C"; font-family: var(--display); font-size:3rem; color: var(--gold-light); line-height:.5; display:block; }
.comment p { font-family: var(--serif); font-style:italic; font-size:1.26rem; color: var(--ink); margin:8px 0 0; }
.comment cite { display:block; margin-top:12px; font-style:normal; font-family: var(--sans); font-size:.85rem; color: var(--body-soft); font-weight:600; }

/* ---------- centred columns (e.g. charity / connections) ---------- */
.cols-center { text-align:center; }
.cols-center .rule { margin-left:auto; margin-right:auto; }
.cols-center .benefits { display:block; }
.cols-center .benefits li { padding-left:0; text-align:center; }
.cols-center .benefits li::before { position:static; margin-right:8px; }
.cols-center .benefits li::after { content:"✦"; margin-left:8px; color:var(--gold); }

/* ---------- member spotlight (photo · name · bio · link) ---------- */
.spotlight { text-align:center; background:#fff; border:1px solid var(--line); border-radius:12px; padding:28px 24px 24px; box-shadow:var(--shadow); }
.spotlight .avatar { width:108px; height:108px; border-radius:50%; margin:0 auto 14px; background:linear-gradient(135deg,var(--red-tint),#F1D9D9); color:var(--red); display:grid; place-items:center; font-family:var(--display); font-size:1.7rem; border:3px solid var(--gold-light); }
.spotlight img.avatar { object-fit:cover; }
.spotlight h3 { margin:0 0 3px; font-size:1.25rem; }
.spotlight .cat { color:var(--red); font-size:.76rem; text-transform:uppercase; letter-spacing:.1em; font-weight:600; font-family:var(--sans); }
.spotlight p { font-family:var(--serif); font-size:1.08rem; color:var(--body); margin:14px 0; }
.spotlight a { font-weight:600; font-size:.9rem; }

/* member spotlights — row layout (matches events list; scales to many) */
.spotlight-list { border-top:1px solid var(--line); }
.spotlight-row { display:grid; grid-template-columns:92px 1fr auto; gap:26px; align-items:center; padding:22px 6px; border-bottom:1px solid var(--line); transition:background .2s; }
.spotlight-row:hover { background:#fff; }
.spotlight-row .avatar { width:82px; height:82px; border-radius:50%; margin:0; background:linear-gradient(135deg,var(--red-tint),#F1D9D9); color:var(--red); display:grid; place-items:center; font-family:var(--display); font-size:1.5rem; border:3px solid var(--gold-light); }
.spotlight-row img.avatar { object-fit:cover; }
.spotlight-row h3 { margin:0; font-size:1.32rem; }
.spotlight-row .cat { color:var(--red); font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; font-weight:600; font-family:var(--sans); }
.spotlight-row p { margin:5px 0 0; color:var(--body); font-size:.98rem; }
.spotlight-row a { font-weight:600; font-size:.9rem; white-space:nowrap; }
@media (max-width:760px){ .spotlight-row { grid-template-columns:1fr; gap:12px; text-align:center; justify-items:center; } }

/* ---------- gallery: expanded event intro (advert + description) ---------- */
.event-intro { display:grid; grid-template-columns: 300px 1fr; gap:30px; align-items:center; padding: 6px 0 24px; border-bottom:1px solid var(--line); margin-bottom:22px; }
.event-intro img { width:100%; border-radius:10px; border:1px solid var(--line); box-shadow: var(--shadow); }
.event-intro h3 { margin:0 0 8px; font-size:1.4rem; }
.event-intro p { font-family: var(--serif); font-size:1.18rem; color: var(--ink); margin:0; }
@media (max-width:680px){ .event-intro { grid-template-columns:1fr; } }

/* ---------- events: sequential list (Vivanova-inspired, not a copy) ---------- */
.event-list { border-top: 1px solid var(--line); }
.event-row { display:grid; grid-template-columns: 92px 150px 1fr auto; gap:26px; align-items:center; padding:22px 6px; border-bottom:1px solid var(--line); transition: background .2s; }
.event-row:hover { background: #fff; }
.event-row .date-box { text-align:center; }
.event-row .date-box .m { font-family: var(--accent); color: var(--red); font-weight:700; font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; }
.event-row .date-box .big { font-family: var(--display); font-size:1.5rem; color: var(--ink); line-height:1.05; }
.event-row .ev-thumb { height:86px; border-radius:8px; background-size:cover; background-position:center; border:1px solid var(--line); }
.event-row h3 { margin:0 0 3px; font-size:1.35rem; }
.event-row .ev-meta p { margin:0; color: var(--body); font-size:.98rem; }
@media (max-width:760px){ .event-row { grid-template-columns:1fr; gap:12px; text-align:center; } .event-row .ev-thumb { height:170px; } }

/* ---------- decorative page frame ---------- */
/* decorative page frame removed (was causing content to show in the top/bottom margins while scrolling) */

/* ---------- press logos / icons ---------- */
.press a { display:inline-flex; align-items:center; gap:10px; }
.press img { height:30px; width:auto; border-radius:5px; }

/* ---------- about: portrait images ---------- */
.portrait-frame { border:1px solid var(--line); border-radius:10px; overflow:hidden; box-shadow:var(--shadow); background:var(--cream); }
.portrait-frame img { width:100%; display:block; }
.portrait-ph { aspect-ratio:3/4; display:grid; place-items:center; text-align:center; color:var(--body-soft); padding:24px; background:linear-gradient(135deg,#f3efe7,#e9e1d2); }

/* ---------- home: partners / news ---------- */
.partners { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; align-items:center; }
.partner { background:#fff; border:1px solid var(--line); border-radius:8px; height:74px; display:grid; place-items:center; color:var(--body-soft); font-family:var(--display); font-size:1rem; box-shadow:var(--shadow); }
.news-card .thumb { aspect-ratio:16/9; background:linear-gradient(135deg,var(--red-tint),#F1D9D9); }
@media (max-width:920px){ .partners{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:680px){ .partners{ grid-template-columns:repeat(2,1fr); } }

/* ---------- responsive ---------- */
@media (max-width: 920px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .gallery-fig { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .stats { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 680px) {
  .nav-links {
    position: fixed; inset: 76px 0 auto 0; background:#fff; flex-direction: column;
    gap: 0; padding: 10px 24px 24px; border-bottom:1px solid var(--line);
    transform: translateY(-130%); transition: transform .3s; box-shadow: var(--shadow);
  }
  .nav-links.open { transform: translateY(0); }
  .nav-links li { width:100%; padding: 10px 0; border-bottom:1px solid var(--line); }
  .nav-toggle { display: block; }
  .grid-2, .grid-3, .grid-4, .gallery, .gallery-fig { grid-template-columns: 1fr; }
  .dash { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .event-card { grid-template-columns: 76px 1fr auto; }
  .footer-grid { grid-template-columns: 1fr; }
  .section { padding: 58px 0; }
  .tl-item { min-width: 160px; }  /* timeline scrolls horizontally on mobile */
}
