/* ============================================================
   Saint Elias Antiochian Orthodox Church — shared stylesheet
   "Ancient-yet-warm" design system. Theme-aware (light/dark).
   ============================================================ */
:root {
  --parchment: #F4EDDF;
  --parchment-2: #EDE3D0;
  --card: #FBF6EC;
  --ink: #2A2018;
  --ink-soft: #574838;
  --taupe: #8C7B66;
  --line: #E4D8C1;
  --oxblood: #7A1F2B;
  --oxblood-deep: #5E141F;
  --gold: #B8912E;
  --gold-bright: #C9A227;
  --midnight: #1B2A4A;
  --hero-1: #2A1116;
  --hero-2: #4A1B22;
  --hero-glow: rgba(201,162,39,.30);
  --on-hero: #F6ECD8;
  --on-hero-soft: #E5D2B0;
  --serif: 'Hoefler Text', 'Iowan Old Style', 'Palatino Linotype', Palatino, Georgia, 'Times New Roman', serif;
  --sans: system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --shadow: 0 1px 2px rgba(42,32,24,.06), 0 12px 34px rgba(42,32,24,.09);
  --shadow-lg: 0 24px 60px rgba(42,20,14,.18);
}
@media (prefers-color-scheme: dark) {
  :root {
    --parchment: #14100A; --parchment-2: #1C1610; --card: #211A11;
    --ink: #EFE4D0; --ink-soft: #C6B79E; --taupe: #9A8871; --line: #362A1A;
    --oxblood: #D57078; --oxblood-deep: #C05860; --gold: #D8B45A; --gold-bright: #E4C56B;
    --shadow: 0 1px 2px rgba(0,0,0,.4), 0 14px 40px rgba(0,0,0,.5);
    --shadow-lg: 0 30px 70px rgba(0,0,0,.6);
  }
}
:root[data-theme="light"] {
  --parchment: #F4EDDF; --parchment-2: #EDE3D0; --card: #FBF6EC;
  --ink: #2A2018; --ink-soft: #574838; --taupe: #8C7B66; --line: #E4D8C1;
  --oxblood: #7A1F2B; --oxblood-deep: #5E141F; --gold: #B8912E; --gold-bright: #C9A227;
  --shadow: 0 1px 2px rgba(42,32,24,.06), 0 12px 34px rgba(42,32,24,.09);
  --shadow-lg: 0 24px 60px rgba(42,20,14,.18);
}
:root[data-theme="dark"] {
  --parchment: #14100A; --parchment-2: #1C1610; --card: #211A11;
  --ink: #EFE4D0; --ink-soft: #C6B79E; --taupe: #9A8871; --line: #362A1A;
  --oxblood: #D57078; --oxblood-deep: #C05860; --gold: #D8B45A; --gold-bright: #E4C56B;
  --shadow: 0 1px 2px rgba(0,0,0,.4), 0 14px 40px rgba(0,0,0,.5);
  --shadow-lg: 0 30px 70px rgba(0,0,0,.6);
}
* { 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; background: var(--parchment); color: var(--ink); font-family: var(--sans); line-height: 1.6; -webkit-font-smoothing: antialiased; }
h1,h2,h3,h4,.serif { font-family: var(--serif); font-weight: 600; letter-spacing: -.01em; }
a { color: inherit; }
img { max-width: 100%; }
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 24px; }
.wrap-narrow { max-width: 780px; margin: 0 auto; padding: 0 24px; }
.eyebrow { font-family: var(--sans); text-transform: uppercase; letter-spacing: .2em; font-size: 12px; font-weight: 700; color: var(--gold); }
.ar { direction: rtl; unicode-bidi: isolate; }

.protobar { background: var(--midnight); color: #E9EEF7; text-align: center; font-family: var(--sans); font-size: 12.5px; letter-spacing: .02em; padding: 7px 16px; }
.protobar b { color: #fff; }

/* ---------- header ---------- */
header.site { position: sticky; top: 0; z-index: 50; background: color-mix(in srgb, var(--parchment) 88%, transparent); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.nav { display: flex; align-items: center; gap: 24px; height: 68px; }
.brand { display: flex; align-items: center; gap: 11px; text-decoration: none; margin-right: auto; }
.brand .mark { width: 34px; height: 34px; color: var(--oxblood); flex: none; }
.brand b { font-family: var(--serif); font-size: 19px; line-height: 1; color: var(--ink); }
.brand span { display: block; font-family: var(--sans); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--taupe); margin-top: 3px; }
.brand-logo { height: 46px; width: auto; display: block; }
@media (prefers-color-scheme: dark) { .brand-logo { filter: drop-shadow(0 0 1px rgba(201,162,39,.35)); } }
:root[data-theme="dark"] .brand-logo { filter: drop-shadow(0 0 1px rgba(201,162,39,.35)); }
:root[data-theme="light"] .brand-logo { filter: none; }
.nav nav { display: flex; gap: 22px; }
.nav nav a { text-decoration: none; font-size: 14.5px; color: var(--ink-soft); font-weight: 500; padding: 6px 0; border-bottom: 2px solid transparent; transition: color .15s, border-color .15s; }
.nav nav a:hover { color: var(--oxblood); border-color: var(--gold); }
.nav nav a.active { color: var(--oxblood); border-color: var(--gold); }
.btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--sans); font-weight: 600; font-size: 14.5px; text-decoration: none; padding: 10px 18px; border-radius: 100px; border: 1.5px solid transparent; cursor: pointer; transition: transform .12s ease, box-shadow .12s, background .15s; }
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--oxblood); color: #FBF6EC; box-shadow: 0 6px 18px rgba(122,31,43,.28); }
.btn-primary:hover { background: var(--oxblood-deep); }
.btn-gold { background: linear-gradient(180deg, var(--gold-bright), var(--gold)); color: #2A1810; box-shadow: 0 6px 18px rgba(184,145,46,.32); }
.btn-ghost { border-color: var(--on-hero-soft); color: var(--on-hero); }
.btn-ghost:hover { background: rgba(246,236,216,.1); }
.btn-outline { border-color: var(--line); color: var(--ink); background: var(--card); }
.btn-outline:hover { border-color: var(--gold); }
.btn-lg { padding: 14px 26px; font-size: 16px; }
.menubtn { display: none; background: var(--card); border: 1.5px solid var(--line); color: var(--ink); font-size: 18px; width: 44px; height: 44px; border-radius: 12px; cursor: pointer; align-items: center; justify-content: center; }

/* mobile drawer */
.mobile-nav { display: none; background: var(--card); border-bottom: 1px solid var(--line); }
.mobile-nav.open { display: block; }
.mobile-nav a { display: block; text-decoration: none; color: var(--ink); font-size: 16px; padding: 14px 24px; border-bottom: 1px solid var(--line); }
.mobile-nav a:last-child { border-bottom: none; }
.mobile-nav a:hover { background: var(--parchment-2); color: var(--oxblood); }
.mobile-nav a.sub { padding-left: 40px; font-size: 15px; color: var(--ink-soft); }

/* desktop ministries dropdown */
.navdrop { position: relative; display: inline-flex; align-items: center; }
.navdrop > .navdrop-toggle { display: inline-flex; align-items: center; gap: 5px; }
.navdrop > .navdrop-toggle svg { width: 11px; height: 11px; transition: transform .18s; }
.navdrop::after { content: ''; position: absolute; top: 100%; left: -8px; right: -8px; height: 14px; }
.navdrop-menu { position: absolute; top: calc(100% + 8px); left: -12px; min-width: 216px; background: var(--card); border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow); padding: 7px; opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity .16s, transform .16s, visibility .16s; z-index: 60; }
.navdrop:hover .navdrop-menu, .navdrop:focus-within .navdrop-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.navdrop:hover > .navdrop-toggle svg, .navdrop:focus-within > .navdrop-toggle svg { transform: rotate(180deg); }
.navdrop-menu a { display: block; padding: 9px 13px; border-radius: 9px; font-size: 14px; font-weight: 500; color: var(--ink-soft); border-bottom: none; white-space: nowrap; transition: background .12s, color .12s; }
.navdrop-menu a:hover { background: var(--parchment-2); color: var(--oxblood); border-color: transparent; }

/* ---------- hero (home) ---------- */
.hero { position: relative; overflow: hidden; color: var(--on-hero); background: radial-gradient(120% 130% at 50% 0%, var(--hero-2), var(--hero-1) 70%); }
.hero .glow { position: absolute; inset: 0; background: radial-gradient(50% 42% at 50% 8%, var(--hero-glow), transparent 70%); pointer-events: none; }
.hero .arches { position: absolute; inset: 0; display: flex; justify-content: center; gap: 0; opacity: .16; pointer-events: none; }
.hero .arches svg { height: 100%; width: auto; color: var(--gold-bright); }
.hero-inner { position: relative; text-align: center; padding: 72px 24px 88px; max-width: 900px; margin: 0 auto; }
.greet { font-family: var(--serif); font-style: italic; font-size: clamp(17px,2.4vw,21px); color: var(--gold-bright); margin: 0 0 6px; }
.greet .ar { font-style: normal; }
.hero h1 { font-size: clamp(38px, 7vw, 74px); line-height: 1.02; margin: 10px auto 0; max-width: 15ch; text-wrap: balance; color: #fff; }
.hero .patron { margin: 20px auto 0; max-width: 46ch; color: var(--on-hero-soft); font-size: clamp(16px,2vw,18.5px); }
.hero-cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 34px; }
.times { display: inline-flex; flex-wrap: wrap; gap: 0; margin: 40px auto 0; background: rgba(20,10,8,.34); border: 1px solid rgba(201,162,39,.34); border-radius: 16px; backdrop-filter: blur(4px); overflow: hidden; }
.times .t { padding: 15px 26px; text-align: center; border-right: 1px solid rgba(201,162,39,.22); }
.times .t:last-child { border-right: none; }
.times .t .lbl { font-size: 11px; text-transform: uppercase; letter-spacing: .14em; color: var(--gold-bright); }
.times .t .val { font-family: var(--serif); font-size: 21px; color: #fff; margin-top: 3px; }
.times .t .sub { font-size: 12px; color: var(--on-hero-soft); }

/* ---------- interior page hero ---------- */
.page-hero { position: relative; overflow: hidden; color: var(--on-hero); background: radial-gradient(120% 160% at 50% -20%, var(--hero-2), var(--hero-1) 72%); }
.page-hero .arches { position: absolute; inset: 0; display: flex; justify-content: center; opacity: .12; pointer-events: none; color: var(--gold-bright); }
.page-hero .arches svg { height: 100%; width: auto; }
.page-hero-inner { position: relative; text-align: center; padding: 58px 24px 60px; max-width: 860px; margin: 0 auto; }
.page-hero .greet { margin-bottom: 10px; }
.page-hero h1 { font-size: clamp(32px, 5.4vw, 52px); line-height: 1.05; margin: 6px auto 0; max-width: 20ch; text-wrap: balance; color: #fff; }
.page-hero .lede { margin: 18px auto 0; max-width: 54ch; color: var(--on-hero-soft); font-size: clamp(16px,2vw,18px); }

/* breadcrumb */
.crumbs { background: var(--parchment-2); border-bottom: 1px solid var(--line); }
.crumbs .wrap { display: flex; gap: 8px; align-items: center; padding-top: 11px; padding-bottom: 11px; font-size: 13px; color: var(--taupe); }
.crumbs a { text-decoration: none; color: var(--ink-soft); }
.crumbs a:hover { color: var(--oxblood); }
.crumbs span { color: var(--taupe); }

/* ---------- info bar ---------- */
.infobar { background: var(--oxblood); color: #F6ECD8; }
.infobar .wrap { display: flex; align-items: center; gap: 14px 30px; flex-wrap: wrap; padding-top: 13px; padding-bottom: 13px; font-size: 14.5px; }
.infobar .i { display: inline-flex; align-items: center; gap: 8px; }
.infobar svg { width: 17px; height: 17px; color: var(--gold-bright); flex: none; }
.infobar a { color: #F6ECD8; text-decoration: none; font-weight: 500; }
.infobar a:hover { text-decoration: underline; }
.infobar .spacer { margin-left: auto; }
.infobar .badge { font-size: 11px; text-transform: uppercase; letter-spacing: .1em; }

/* ---------- sections ---------- */
section.band { padding: 74px 0; }
section.band.tight { padding: 54px 0; }
.section-head { text-align: center; max-width: 62ch; margin: 0 auto 46px; }
.section-head h2 { font-size: clamp(28px,4vw,40px); margin: 12px 0 0; text-wrap: balance; }
.section-head p { color: var(--ink-soft); margin: 14px 0 0; font-size: 17px; }
.band.alt { background: var(--parchment-2); }

/* ---------- prose / article ---------- */
.prose { color: var(--ink-soft); font-size: 17.5px; }
.prose h2 { color: var(--ink); font-size: clamp(24px,3.2vw,32px); margin: 44px 0 0; text-wrap: balance; }
.prose h2:first-child { margin-top: 0; }
.prose h3 { color: var(--oxblood); font-size: 20px; margin: 30px 0 0; }
.prose p { margin: 16px 0 0; }
.prose ul, .prose ol { margin: 16px 0 0; padding-left: 22px; }
.prose li { margin: 7px 0; }
.prose a.link { color: var(--oxblood); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.prose blockquote { margin: 26px 0 0; padding: 4px 0 4px 22px; border-left: 3px solid var(--gold); font-family: var(--serif); font-style: italic; font-size: 20px; color: var(--ink); }
.prose blockquote cite { display: block; font-style: normal; font-family: var(--sans); font-size: 13px; letter-spacing: .04em; text-transform: uppercase; color: var(--taupe); margin-top: 8px; }
.lead { font-size: 20px; color: var(--ink); font-family: var(--serif); line-height: 1.5; }

/* ---------- full-width photo band ---------- */
.photo-band { position: relative; }
.photo-band figure { margin: 0; }
.photo-band img { width: 100%; height: clamp(260px, 42vw, 520px); object-fit: cover; object-position: 50% 32%; display: block; }
.photo-band figcaption { font-family: var(--sans); font-size: 12.5px; letter-spacing: .04em; color: var(--taupe); text-align: center; padding: 12px 20px 0; }

/* ---------- clergy welcome ---------- */
.welcome { display: grid; grid-template-columns: 300px 1fr; gap: 44px; align-items: center; }
.portrait { position: relative; aspect-ratio: 4/5; border-radius: 200px 200px 14px 14px; overflow: hidden; background: linear-gradient(160deg, #6E2530, #3A141A); box-shadow: var(--shadow-lg); border: 1px solid var(--line); display: grid; place-content: center; text-align: center; color: var(--on-hero-soft); }
.portrait .ph { font-family: var(--sans); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; padding: 0 20px; opacity: .8; }
.portrait img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 30%; display: block; }
.portrait svg { width: 80px; height: 80px; color: var(--gold-bright); opacity: .55; margin: 0 auto 10px; }
.welcome .body h2 { font-size: clamp(26px,3.4vw,36px); margin: 8px 0 0; }
.welcome .body p { color: var(--ink-soft); font-size: 17.5px; margin: 18px 0 0; }
.welcome .sig { font-family: var(--serif); font-style: italic; font-size: 20px; color: var(--oxblood); margin-top: 20px; }
.welcome .sig small { display:block; font-style: normal; font-family: var(--sans); font-size: 13px; letter-spacing: .04em; color: var(--taupe); text-transform: uppercase; margin-top: 4px; }

/* ---------- cards / feature grids ---------- */
.expect-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); gap: 16px; }
.xcard { background: var(--card); border: 1px solid var(--line); border-radius: 14px; padding: 24px; box-shadow: var(--shadow); }
.xcard .ic { width: 44px; height: 44px; border-radius: 12px; background: rgba(184,145,46,.14); color: var(--gold); display: grid; place-content: center; margin-bottom: 14px; }
.xcard .ic svg { width: 23px; height: 23px; }
.xcard h3 { font-size: 18.5px; margin: 0 0 6px; }
.xcard p { margin: 0; color: var(--ink-soft); font-size: 14.5px; }

/* ---------- schedule ---------- */
.sched { display: grid; grid-template-columns: 1.1fr 1fr; gap: 20px; }
.sched.single { grid-template-columns: 1fr; }
.sched .list { background: var(--card); border: 1px solid var(--line); border-radius: 16px; overflow: hidden; box-shadow: var(--shadow); }
.sched .row { display: flex; align-items: baseline; gap: 16px; padding: 16px 22px; border-bottom: 1px solid var(--line); }
.sched .row:last-child { border-bottom: none; }
.sched .row .day { font-family: var(--serif); font-size: 17px; width: 118px; flex: none; color: var(--oxblood); }
.sched .row .svc { flex: 1; }
.sched .row .svc b { font-weight: 600; }
.sched .row .svc span { display: block; font-size: 13px; color: var(--taupe); }
.sched .row .time { font-family: var(--serif); font-size: 17px; font-variant-numeric: tabular-nums; white-space: nowrap; }
.season { background: linear-gradient(165deg, var(--oxblood), var(--oxblood-deep)); color: #F6ECD8; border-radius: 16px; padding: 28px; box-shadow: var(--shadow-lg); display: flex; flex-direction: column; }
.season .eyebrow { color: var(--gold-bright); }
.season h3 { color: #fff; font-size: 24px; margin: 10px 0 0; }
.season p { color: var(--on-hero-soft); font-size: 15px; margin: 12px 0 0; }
.season .add { margin-top: auto; padding-top: 18px; }

/* bilingual liturgical table */
.liturgy { background: var(--card); border: 1px solid var(--line); border-radius: 16px; overflow: hidden; box-shadow: var(--shadow); }
.liturgy .lrow { display: grid; grid-template-columns: 120px 1fr auto; gap: 14px; padding: 16px 22px; border-bottom: 1px solid var(--line); align-items: center; }
.liturgy .lrow:last-child { border-bottom: none; }
.liturgy .lrow.head { background: var(--parchment-2); font-family: var(--sans); text-transform: uppercase; letter-spacing: .1em; font-size: 11px; color: var(--taupe); font-weight: 700; }
.liturgy .date { font-family: var(--serif); color: var(--oxblood); font-size: 16px; }
.liturgy .en { font-weight: 600; }
.liturgy .ars { font-family: var(--serif); font-size: 15px; color: var(--taupe); }
.liturgy .time { font-family: var(--serif); font-variant-numeric: tabular-nums; white-space: nowrap; }

/* ---------- watch ---------- */
.watch { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.screen { aspect-ratio: 16/9; border-radius: 16px; background: radial-gradient(80% 80% at 50% 40%, #3A141A, #1B0A0D); border: 1px solid var(--line); box-shadow: var(--shadow-lg); position: relative; display: grid; place-content: center; overflow: hidden; }
.screen .arches2 { position: absolute; inset: 0; opacity: .18; color: var(--gold-bright); }
.screen .play { width: 74px; height: 74px; border-radius: 50%; background: rgba(246,236,216,.14); border: 1.5px solid rgba(201,162,39,.6); display: grid; place-content: center; backdrop-filter: blur(3px); }
.screen .play svg { width: 26px; height: 26px; color: var(--gold-bright); margin-left: 4px; }
.screen .live { position: absolute; top: 14px; left: 14px; font-family: var(--sans); font-size: 11px; font-weight: 700; letter-spacing: .1em; color: #fff; background: #B4272E; padding: 4px 10px; border-radius: 100px; display: inline-flex; align-items: center; gap: 6px; }
.screen .live::before { content:""; width: 7px; height: 7px; border-radius: 50%; background: #fff; animation: pulse 1.6s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
.watch h2 { font-size: clamp(26px,3.4vw,36px); margin: 8px 0 0; }
.watch p { color: var(--ink-soft); font-size: 17px; margin: 16px 0 0; }
.platrow { display: flex; gap: 12px; margin-top: 22px; flex-wrap: wrap; }

/* ---------- giving ---------- */
.giving { background: radial-gradient(90% 140% at 15% 0%, rgba(122,31,43,.10), transparent), var(--parchment-2); }
.give-inner { display: grid; grid-template-columns: 1fr auto; gap: 40px; align-items: center; }
.give-inner h2 { font-size: clamp(26px,3.6vw,38px); margin: 8px 0 0; max-width: 18ch; text-wrap: balance; }
.give-inner p { color: var(--ink-soft); font-size: 16.5px; margin: 14px 0 0; max-width: 52ch; }
.give-card { background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 26px; width: 340px; max-width: 100%; box-shadow: var(--shadow-lg); }
.give-card .toggle { display: flex; background: var(--parchment-2); border-radius: 100px; padding: 4px; margin-bottom: 18px; }
.give-card .toggle button { flex: 1; border: none; background: none; font-family: var(--sans); font-size: 14px; font-weight: 600; padding: 9px; border-radius: 100px; cursor: pointer; color: var(--ink-soft); }
.give-card .toggle button.on { background: var(--oxblood); color: #F6ECD8; }
.tiers { display: grid; grid-template-columns: repeat(3,1fr); gap: 9px; margin-bottom: 12px; }
.tiers button { border: 1.5px solid var(--line); background: var(--parchment); border-radius: 10px; padding: 13px 0; font-family: var(--serif); font-size: 18px; cursor: pointer; color: var(--ink); transition: border-color .12s, background .12s; }
.tiers button:hover, .tiers button.on { border-color: var(--gold); background: rgba(184,145,46,.1); }
.give-card .note { font-size: 12px; color: var(--taupe); margin: 12px 0 0; text-align: center; }

/* ---------- ministries ---------- */
.mins { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 14px; }
.min { background: var(--card); border: 1px solid var(--line); border-radius: 14px; padding: 20px; box-shadow: var(--shadow); transition: transform .14s ease, box-shadow .14s; display: block; text-decoration: none; color: inherit; }
.min:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.min .ic { color: var(--oxblood); width: 26px; height: 26px; margin-bottom: 12px; }
.min h3 { font-size: 17px; margin: 0 0 5px; }
.min p { margin: 0; font-size: 13.5px; color: var(--ink-soft); }

/* ---------- events / fundraisers ---------- */
.events-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: 22px; }
.event { background: var(--card); border: 1px solid var(--line); border-radius: 18px; overflow: hidden; box-shadow: var(--shadow); display: flex; flex-direction: column; }
.event .top { padding: 26px 26px 0; }
.event .banner { position: relative; aspect-ratio: 16/7; background: linear-gradient(150deg, var(--hero-2), var(--hero-1)); color: var(--gold-bright); display: grid; place-content: center; overflow: hidden; }
.event .banner .arches3 { position: absolute; inset: 0; opacity: .16; }
.event .banner .em { font-size: 40px; position: relative; }
.event .tag { display: inline-block; font-family: var(--sans); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--gold); background: rgba(184,145,46,.14); padding: 5px 11px; border-radius: 100px; }
.event .tag.date { color: var(--oxblood); background: rgba(122,31,43,.1); }
.event .body { padding: 20px 26px 26px; display: flex; flex-direction: column; flex: 1; }
.event h3 { font-size: 22px; margin: 12px 0 0; }
.event .meta { display: flex; flex-wrap: wrap; gap: 6px 16px; margin: 12px 0 0; font-size: 13.5px; color: var(--taupe); }
.event .meta span { display: inline-flex; align-items: center; gap: 6px; }
.event p { color: var(--ink-soft); font-size: 14.5px; margin: 14px 0 0; }
.event .actions { margin-top: auto; padding-top: 20px; display: flex; gap: 10px; flex-wrap: wrap; }
.pricing { display: grid; gap: 8px; margin-top: 16px; }
.pricing .p { display: flex; justify-content: space-between; align-items: baseline; padding: 11px 15px; background: var(--parchment); border: 1px solid var(--line); border-radius: 10px; }
a.p { text-decoration: none; color: inherit; transition: border-color .15s ease, background .15s ease; }
a.p:hover { border-color: var(--gold); background: #fff; }
a.p:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }
.pricing .p .n { font-weight: 600; font-size: 14.5px; }
.pricing .p .n span { display: block; font-weight: 400; font-size: 12.5px; color: var(--taupe); }
.pricing .p .amt { font-family: var(--serif); font-size: 18px; color: var(--oxblood); font-variant-numeric: tabular-nums; white-space: nowrap; }
.pricing .p .amt .was { font-family: var(--sans); font-size: 12px; color: var(--taupe); text-decoration: line-through; margin-right: 7px; font-weight: 500; }
.pricing .p .amt .go { font-family: var(--sans); font-size: 11px; color: var(--taupe); font-weight: 600; letter-spacing: .04em; margin-left: 7px; }

/* New Year — full-width teaser box under the two event cards */
.ny-box { margin-top: 22px; display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 28px; background: var(--card); border: 1px solid var(--line); border-left: 4px solid var(--gold); border-radius: 18px; box-shadow: var(--shadow); padding: 26px 30px; }
.ny-box .ny-mark { font-size: 46px; line-height: 1; }
.ny-box .ny-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.ny-box .tag { display: inline-block; font-family: var(--sans); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--gold); background: rgba(184,145,46,.14); padding: 5px 11px; border-radius: 100px; }
.ny-box .tag.date { color: var(--oxblood); background: rgba(122,31,43,.1); }
.ny-box h3 { font-size: 24px; margin: 12px 0 0; }
.ny-box p { color: var(--ink-soft); font-size: 15px; margin: 10px 0 0; max-width: 68ch; }
.ny-box .ny-soon { color: var(--gold); font-weight: 600; }
@media (max-width: 620px) { .ny-box { grid-template-columns: 1fr; gap: 12px; text-align: left; } }

/* ---------- newsletter ---------- */
.news { background: linear-gradient(165deg, var(--midnight), #101A30); color: #E9EEF7; border-radius: 20px; padding: 44px; text-align: center; box-shadow: var(--shadow-lg); }
.news h2 { color: #fff; font-size: clamp(24px,3.2vw,32px); margin: 0; text-wrap: balance; }
.news p { color: #C3CEE2; margin: 12px auto 0; max-width: 48ch; }
.news form { display: flex; gap: 10px; max-width: 440px; margin: 24px auto 0; }
.news input { flex: 1; border: 1px solid rgba(201,162,39,.4); background: rgba(255,255,255,.06); color: #fff; border-radius: 100px; padding: 13px 20px; font-family: var(--sans); font-size: 15px; }
.news input::placeholder { color: #9FB0CC; }
.news .fine { font-size: 12.5px; color: #92A2C0; margin-top: 14px; }

/* ---------- CTA band ---------- */
.cta-band { background: linear-gradient(165deg, var(--oxblood), var(--oxblood-deep)); color: var(--on-hero); border-radius: 20px; padding: 48px; text-align: center; box-shadow: var(--shadow-lg); }
.cta-band .eyebrow { color: var(--gold-bright); }
.cta-band h2 { color: #fff; font-size: clamp(26px,3.6vw,36px); margin: 10px 0 0; text-wrap: balance; }
.cta-band p { color: var(--on-hero-soft); margin: 14px auto 0; max-width: 52ch; font-size: 17px; }
.cta-band .row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 26px; }

/* ---------- contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.contact-list { display: grid; gap: 14px; }
.cline { display: flex; gap: 14px; align-items: flex-start; background: var(--card); border: 1px solid var(--line); border-radius: 14px; padding: 18px 20px; box-shadow: var(--shadow); }
.cline .ic { width: 40px; height: 40px; flex: none; border-radius: 10px; background: rgba(122,31,43,.1); color: var(--oxblood); display: grid; place-content: center; }
.cline .ic svg { width: 20px; height: 20px; }
.cline h3 { font-size: 15px; margin: 0 0 3px; }
.cline p, .cline a { margin: 0; font-size: 14.5px; color: var(--ink-soft); text-decoration: none; }
.cline a:hover { color: var(--oxblood); text-decoration: underline; }
.mapframe { border-radius: 16px; overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow); min-height: 320px; background: var(--parchment-2); }
.mapframe iframe { display: block; width: 100%; height: 100%; min-height: 320px; border: 0; }
.form { display: grid; gap: 14px; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 26px; box-shadow: var(--shadow); }
.form label { font-size: 13px; font-weight: 600; color: var(--ink-soft); display: block; margin-bottom: 5px; }
.form input, .form textarea, .form select { width: 100%; border: 1px solid var(--line); background: var(--parchment); color: var(--ink); border-radius: 10px; padding: 12px 14px; font-family: var(--sans); font-size: 15px; }
.form textarea { min-height: 130px; resize: vertical; }
.form input:focus, .form textarea:focus, .form select:focus { outline: 2px solid var(--gold); outline-offset: 1px; border-color: var(--gold); }

/* ---------- footer ---------- */
footer.site { background: var(--card); border-top: 1px solid var(--line); margin-top: 0; }
.foot { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 34px; padding: 56px 0 30px; }
.foot .brand2 { display: flex; align-items: center; gap: 11px; margin-bottom: 14px; }
.foot .brand2 .mark { width: 40px; height: 40px; color: var(--oxblood); }
.foot .brand2 b { font-family: var(--serif); font-size: 20px; }
.foot .brand2 .brand-logo { height: 56px; }
.foot p { color: var(--ink-soft); font-size: 14.5px; margin: 4px 0; }
.foot h4 { font-family: var(--sans); text-transform: uppercase; letter-spacing: .12em; font-size: 12px; color: var(--taupe); margin: 0 0 14px; }
.foot a { color: var(--ink-soft); text-decoration: none; display: block; font-size: 14.5px; padding: 4px 0; }
.foot a:hover { color: var(--oxblood); }
.socials { display: flex; gap: 10px; margin-top: 14px; }
.socials a { width: 38px; height: 38px; border-radius: 10px; border: 1px solid var(--line); display: grid; place-content: center; color: var(--ink-soft); }
.socials a:hover { border-color: var(--gold); color: var(--oxblood); }
.socials svg { width: 18px; height: 18px; }
.subfoot { border-top: 1px solid var(--line); padding: 18px 0 30px; text-align: center; color: var(--taupe); font-size: 12.5px; }
.subfoot a { color: var(--taupe); text-decoration: none; }
.subfoot a:hover { color: var(--gold); text-decoration: underline; }

/* ---------- utilities ---------- */
.center { text-align: center; }
.mt-0 { margin-top: 0; }
.stack-lg > * + * { margin-top: 20px; }
.callout { background: var(--card); border: 1px solid var(--line); border-left: 3px solid var(--gold); border-radius: 12px; padding: 20px 24px; box-shadow: var(--shadow); }
.callout h3 { margin: 0 0 6px; font-size: 18px; }
.callout p { margin: 0; color: var(--ink-soft); font-size: 15px; }

@media (max-width: 860px) {
  .nav nav, .infobar .badge { display: none; }
  .menubtn { display: inline-flex; }
  .welcome, .sched, .watch, .give-inner, .foot, .contact-grid { grid-template-columns: 1fr; }
  .give-inner { justify-items: start; }
  .give-card { width: 100%; }
  .portrait { max-width: 260px; margin: 0 auto; }
  .liturgy .lrow { grid-template-columns: 90px 1fr; }
  .liturgy .lrow .time { grid-column: 2; }
}
