/* ============================================================
   Saint-Séraphim-de-Sarov — Polish overlay (v2)
   - Raffinement des tons burgundy/or/crème
   - Mode jour/nuit
   - Variantes de hero (hero-v1 stoique / hero-v2 iconique / hero-v3 immersif)
   - Page Saint Séraphin
   - Tweaks panel
   ============================================================ */

/* ── Softer palette: less saturated burgundy, stone-cream ───── */
:root {
  --stone:            #EFE9DF;     /* nouveau cream, plus neutre */
  --stone-warm:       #E6DED0;
  --ink:              #1F1510;     /* noir chaud */
  --ink-soft:         #3A2C24;
  --muted:            #6D5B4E;
  --muted-soft:       #8F7F72;
  --line:             rgba(31, 21, 16, 0.12);
  --line-soft:        rgba(31, 21, 16, 0.06);
  --burgundy-deep:    #4A1010;
  --burgundy-ink:     #2C0C0C;
  --gold-ink:         #A8894C;
  --gold-soft:        #C9A84C;
  --gold-pale:        #E6D9A8;
}

/* Force a cleaner base on all pages using site.css */
html { scroll-behavior: smooth; }
body {
  background: var(--stone);
  color: var(--ink);
}

/* Keep the existing body font, just tighten rhythm */
body { line-height: 1.7; }

/* Links */
a { color: var(--ink); }
a:hover { color: var(--gold-ink); }

/* ── Selection ─────────────────────────────────────────────── */
::selection {
  background: var(--gold-soft);
  color: var(--ink);
}

/* ── NAV polish ────────────────────────────────────────────── */
body > nav { background: color-mix(in srgb, var(--stone) 88%, transparent); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 1px solid var(--line-soft); }
body > nav.scrolled { background: color-mix(in srgb, var(--stone) 96%, transparent); }

.nav-inner { height: 74px; padding: 0 2rem; }

.site-logo svg { width: 20px; height: 28px; opacity: .45; }
.logo-name { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 1rem; color: var(--ink); font-weight: 600; letter-spacing: 0; }
.logo-sub { font-size: .58rem; color: var(--muted); letter-spacing: .18rem; opacity: .65; }

.nav-links a { font-size: .64rem; padding: .35rem .48rem; color: var(--muted); opacity: .8; white-space: nowrap; flex-shrink: 0; }
.nav-links a:hover { color: var(--ink); opacity: 1; }
.nav-links a.active { color: var(--ink); opacity: 1; }
.nav-links a.active::after { background: var(--gold-ink); bottom: -6px; left: .48rem; right: .48rem; }

/* Theme toggle + lang toggle styled together */
.nav-tools { display: flex; align-items: center; gap: .8rem; margin-left: .4rem; }
.theme-toggle {
  background: none; border: 1px solid var(--line); border-radius: 999px;
  width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--muted); transition: all .3s ease; padding: 0;
}
.theme-toggle:hover { border-color: var(--gold-ink); color: var(--gold-ink); }
.theme-toggle svg { width: 12px; height: 12px; }

/* ── DARK MODE ─────────────────────────────────────────────── */
body.dark {
  --stone:          #14100D;
  --stone-warm:     #1C1714;
  --ink:            #EDE3D4;
  --ink-soft:       #C7BAA8;
  --muted:          #8A7D6F;
  --muted-soft:     #6A5E52;
  --line:           rgba(237, 227, 212, 0.10);
  --line-soft:      rgba(237, 227, 212, 0.04);
  --burgundy-deep:  #2A0808;
  --burgundy-ink:   #1A0505;
  --gold-ink:       #C9A84C;
  --gold-soft:      #E6D9A8;
  --gold-pale:      #3A2F1A;
}

body.dark { background: var(--stone); color: var(--ink); }
body.dark > nav { background: color-mix(in srgb, var(--stone) 85%, transparent); border-bottom-color: var(--line-soft); }
body.dark > nav.scrolled { background: color-mix(in srgb, var(--stone) 95%, transparent); }
body.dark a { color: var(--ink); }
body.dark a:hover { color: var(--gold-ink); }
body.dark .logo-name { color: var(--ink); }
body.dark .nav-links a { color: var(--muted); }
body.dark .nav-links a:hover,
body.dark .nav-links a.active { color: var(--ink); }

body.dark .theme-toggle { border-color: var(--line); color: var(--muted); }
body.dark .theme-toggle:hover { border-color: var(--gold-ink); color: var(--gold-ink); }

/* Override the original CSS vars for dark */
body.dark {
  --burgundy: #4A1010;
  --burgundy-dark: #2A0808;
  --burgundy-mid: #6B1A1A;
  --cream: #14100D;
  --cream-dark: #1C1714;
  --dark-brown: #EDE3D4;
  --text-muted: #8A7D6F;
  --white: #1C1714;
}

body.dark .hero-modern { background: var(--stone); }
body.dark .hero-modern-title { color: var(--ink); }
body.dark .hero-modern-desc { color: var(--ink-soft); opacity: .7; }
body.dark .hero-modern-image::before {
  background:
    linear-gradient(to right, var(--stone) 0%, rgba(20,16,13,.6) 15%, transparent 35%),
    linear-gradient(to left, var(--stone) 0%, rgba(20,16,13,.4) 10%, transparent 25%),
    linear-gradient(to top, var(--stone) 0%, rgba(20,16,13,.7) 20%, transparent 45%),
    linear-gradient(to bottom, var(--stone) 0%, rgba(20,16,13,.3) 8%, transparent 20%);
}

body.dark .section { background: transparent; }
body.dark .section-alt { background: var(--stone-warm); }
body.dark .quote-section { background: var(--stone-warm); }
body.dark .quote-block p { color: var(--ink); }
body.dark .intro-heading { color: var(--ink); }
body.dark .intro-text { color: var(--ink-soft); opacity: .75; }
body.dark .feature-title { color: var(--ink); }
body.dark .feature-desc { color: var(--ink-soft); opacity: .7; }
body.dark .feature-item:hover { background: rgba(201, 168, 76, 0.06); }
body.dark .feature-item:hover .feature-title { color: var(--gold-ink); }

body.dark .features { border-top-color: var(--line); }
body.dark .feature-item { border-right-color: var(--line); }

body.dark .horaire-card { background: var(--stone-warm); border-color: var(--line); }
body.dark .horaire-day { color: var(--muted); }
body.dark .horaire-time { color: var(--ink); }
body.dark .horaire-name { color: var(--ink); }

body.dark footer { background: var(--burgundy-ink); }
body.dark .footer-cta { background: linear-gradient(135deg, var(--burgundy-ink), #0E0303); }
body.dark .page-header { background: var(--stone-warm); }
body.dark .page-header h1 { color: var(--ink); }
body.dark .page-header p { color: var(--ink-soft); }

body.dark .schedule-table { background: var(--stone-warm); border-color: var(--line); }
body.dark .schedule-table td { background: var(--stone-warm); color: var(--ink); border-bottom-color: var(--line); }
body.dark .schedule-table tr:hover td { background: rgba(201, 168, 76, 0.05); }
body.dark .schedule-table .day { color: var(--gold-ink); }
body.dark .prose h2 { color: var(--gold-ink); }
body.dark .prose p { color: var(--ink-soft); }
body.dark .card { background: var(--stone-warm); border-color: var(--line); border-left-color: var(--gold-ink); }
body.dark .card h3 { color: var(--gold-ink); }
body.dark .card p { color: var(--ink-soft); }
body.dark .bank-box { background: var(--stone-warm); border-color: var(--line); }
body.dark .bank-label { color: var(--muted); }
body.dark .bank-value { color: var(--ink); }
body.dark .contact-info { color: var(--ink-soft); }
body.dark .contact-info h3 { color: var(--gold-ink); }
body.dark .form-group label { color: var(--ink-soft); }
body.dark .form-group input, body.dark .form-group textarea {
  background: var(--stone-warm); color: var(--ink); border-color: var(--line);
}
body.dark .feasts-list li { border-bottom-color: var(--line); color: var(--ink-soft); }
body.dark .tl-center-title { color: var(--ink); }
body.dark .tl-center-desc { color: var(--ink-soft); }
body.dark .tl-center-desc strong { color: var(--ink); }
body.dark .tl-center-dot { background: var(--stone); }
body.dark .section-title { color: var(--gold-ink); }
body.dark .section-subtitle { color: var(--ink-soft); }

/* ── HERO V1 — "Stoïque": plein cadre avec photo extérieur, peu de texte ── */
.hero-v1 {
  position: relative;
  min-height: 92vh;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
.hero-v1-bg { position: absolute; inset: 0; }
.hero-v1-bg img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.55) saturate(.85); transition: transform 14s ease-out; }
.hero-v1:hover .hero-v1-bg img { transform: scale(1.04); }
.hero-v1-veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(20,10,8,.25) 0%, rgba(20,10,8,.35) 40%, rgba(20,10,8,.85) 100%),
    radial-gradient(ellipse at 30% 50%, transparent 0%, rgba(20,10,8,.4) 70%);
}
.hero-v1-inner { position: relative; z-index: 2; width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 3rem 4.5rem; color: var(--gold-pale); }
.hero-v1-crest {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: .68rem; letter-spacing: .45rem; text-transform: uppercase;
  color: var(--gold-soft); opacity: .8; margin-bottom: 2rem;
  display: inline-flex; align-items: center; gap: .8rem;
  animation: fadeUp .8s var(--ease-out) both;
}
.hero-v1-crest::before, .hero-v1-crest::after { content: ''; width: 18px; height: 1px; background: currentColor; display: inline-block; }
.hero-v1-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400;
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  line-height: .95;
  letter-spacing: -.015em;
  color: #F5ECD6;
  max-width: 13ch;
  margin-bottom: 1.5rem;
  animation: fadeUp .9s .15s var(--ease-out) both;
}
.hero-v1-title em {
  font-style: italic;
  font-weight: 300;
  color: var(--gold-soft);
}
.hero-v1-meta {
  display: flex; gap: 2.5rem; flex-wrap: wrap; align-items: baseline;
  border-top: 1px solid rgba(233, 217, 168, .22);
  padding-top: 1.6rem; max-width: 720px;
  animation: fadeUp .9s .35s var(--ease-out) both;
}
.hero-v1-meta-block .k {
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: .58rem; letter-spacing: .22rem; text-transform: uppercase;
  color: var(--gold-soft); opacity: .7; margin-bottom: .25rem;
}
.hero-v1-meta-block .v {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem; color: #F5ECD6;
}
.hero-v1-scroll {
  position: absolute; right: 3rem; bottom: 2rem; z-index: 3;
  font-family: 'DM Sans', sans-serif; font-size: .55rem;
  letter-spacing: .35rem; text-transform: uppercase;
  color: rgba(245, 236, 214, .5);
  display: inline-flex; flex-direction: column; align-items: center; gap: 1rem;
  animation: fadeUp .9s .55s var(--ease-out) both;
}
.hero-v1-scroll::after {
  content: ''; width: 1px; height: 32px;
  background: linear-gradient(to bottom, var(--gold-soft), transparent);
  animation: scrollHint 2.4s ease-in-out infinite;
}
@keyframes scrollHint {
  0% { transform: scaleY(0); transform-origin: top; }
  50% { transform: scaleY(1); transform-origin: top; }
  51% { transform: scaleY(1); transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

@media (max-width: 768px) {
  .hero-v1 { min-height: 78vh; }
  .hero-v1-inner { padding: 0 1.5rem 3rem; }
  .hero-v1-scroll { display: none; }
  .hero-v1-meta { gap: 1.4rem; }
}

/* ── HERO V2 — "Iconique": structure éditoriale, photo encadrée ── */
.hero-v2 {
  display: grid;
  grid-template-columns: 1.05fr 1.25fr;
  min-height: 88vh;
  background: var(--stone);
  position: relative;
  overflow: hidden;
}
.hero-v2::before {
  content: '';
  position: absolute;
  top: 0; bottom: 0; left: 50%; width: 1px;
  background: var(--line-soft);
}
.hero-v2-content {
  display: flex; flex-direction: column; justify-content: center;
  padding: 5rem 5rem 5rem 5rem;
  position: relative;
}
.hero-v2-number {
  position: absolute;
  top: 4rem; left: 5rem;
  font-family: 'Cormorant Garamond', serif;
  font-size: .68rem; letter-spacing: .3rem; text-transform: uppercase;
  color: var(--gold-ink);
}
.hero-v2-number::before { content: '— '; opacity: .5; }
.hero-v2-year {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: .72rem; letter-spacing: .3rem; text-transform: uppercase;
  color: var(--muted); margin-bottom: 1.6rem;
  display: flex; align-items: center; gap: .8rem;
}
.hero-v2-year::before {
  content: ''; width: 30px; height: 1px; background: var(--gold-ink);
}
.hero-v2-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400;
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  line-height: 1.0;
  letter-spacing: -.01em;
  color: var(--ink);
  margin-bottom: 2rem;
}
.hero-v2-title .ornate {
  font-style: italic;
  color: var(--gold-ink);
  font-weight: 300;
}
.hero-v2-desc {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 1rem; line-height: 1.85;
  color: var(--muted);
  max-width: 42ch;
  margin-bottom: 2.2rem;
}
.hero-v2-verse {
  border-left: 2px solid var(--gold-ink);
  padding: .2rem 0 .2rem 1.2rem;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.05rem;
  color: var(--ink-soft);
  max-width: 38ch;
  margin-bottom: 2.5rem;
}
.hero-v2-verse cite {
  display: block;
  font-style: normal;
  font-family: 'DM Sans', sans-serif;
  font-size: .6rem; letter-spacing: .2rem; text-transform: uppercase;
  color: var(--gold-ink); margin-top: .6rem;
}
.hero-v2-actions { display: flex; gap: 1.4rem; align-items: center; flex-wrap: wrap; }
.link-underline {
  font-family: 'DM Sans', sans-serif;
  font-size: .7rem; letter-spacing: .18rem; text-transform: uppercase;
  color: var(--ink); text-decoration: none;
  padding-bottom: 4px; position: relative;
}
.link-underline::after {
  content: ''; position: absolute; left: 0; bottom: 0; height: 1px; width: 100%;
  background: currentColor; transform-origin: right; transform: scaleX(1);
  transition: transform .4s var(--ease-out);
}
.link-underline:hover::after { transform-origin: left; transform: scaleX(1); }
.link-underline:hover { color: var(--gold-ink); }
.link-underline .arrow { display: inline-block; margin-left: .4rem; transition: transform .3s ease; }
.link-underline:hover .arrow { transform: translateX(4px); }

.hero-v2-image {
  position: relative;
  overflow: hidden;
}
.hero-v2-image img {
  width: 100%; height: 100%; object-fit: cover;
  filter: contrast(1.06) saturate(.95);
  transition: transform 16s ease;
}
.hero-v2:hover .hero-v2-image img { transform: scale(1.03); }
.hero-v2-image-caption {
  position: absolute; bottom: 2rem; left: 2rem; right: 2rem;
  font-family: 'DM Sans', sans-serif;
  font-size: .58rem; letter-spacing: .2rem; text-transform: uppercase;
  color: rgba(245, 236, 214, .85);
  display: flex; justify-content: space-between; gap: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(245, 236, 214, .3);
}
.hero-v2-image-fade {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(20, 10, 8, .55) 100%);
  pointer-events: none;
}

body.dark .hero-v2 { background: var(--stone); }
body.dark .hero-v2::before { background: var(--line-soft); }
body.dark .hero-v2-title { color: var(--ink); }
body.dark .hero-v2-title .ornate { color: var(--gold-ink); }
body.dark .hero-v2-verse { color: var(--ink-soft); }

@media (max-width: 900px) {
  .hero-v2 { grid-template-columns: 1fr; }
  .hero-v2::before { display: none; }
  .hero-v2-content { padding: 3rem 1.6rem; }
  .hero-v2-number { top: 1.5rem; left: 1.6rem; }
  .hero-v2-image { height: 50vh; }
}

/* ── HERO V3 — "Immersif icône" : photo iconostase floutée avec icône centrée ── */
.hero-v3 {
  position: relative;
  min-height: 92vh;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  background: var(--burgundy-ink);
}
.hero-v3-bg { position: absolute; inset: 0; }
.hero-v3-bg img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(.4) saturate(1.15) blur(4px);
  transform: scale(1.08);
}
.hero-v3-veil {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at center, transparent 10%, rgba(20, 5, 5, .75) 75%),
    linear-gradient(180deg, rgba(20, 5, 5, .4) 0%, rgba(20, 5, 5, .5) 50%, rgba(20, 5, 5, .8) 100%);
}
.hero-v3-inner {
  position: relative; z-index: 2;
  max-width: 780px; padding: 3rem 2rem;
  text-align: center; color: var(--gold-pale);
}
.hero-v3-icon-frame {
  width: 180px; height: 240px;
  margin: 0 auto 2.5rem;
  position: relative;
  box-shadow: 0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(201, 168, 76, .5);
  animation: fadeUp 1s var(--ease-out) both;
}
.hero-v3-icon-frame::before {
  content: ''; position: absolute; inset: -12px;
  border: 1px solid var(--gold-soft);
  opacity: .35;
}
.hero-v3-icon-frame img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
}
.hero-v3-icon-glow {
  position: absolute; inset: -40px;
  background: radial-gradient(ellipse at center, rgba(201, 168, 76, .25) 0%, transparent 60%);
  z-index: -1;
  animation: iconGlow 5s ease-in-out infinite;
}
@keyframes iconGlow {
  0%, 100% { opacity: .6; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.08); }
}
.hero-v3-greet {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: .9rem; letter-spacing: .15rem;
  color: var(--gold-soft); opacity: .85;
  margin-bottom: 1rem;
  animation: fadeUp 1s .2s var(--ease-out) both;
}
.hero-v3-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400;
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  line-height: 1.1;
  color: #F5ECD6;
  margin-bottom: 1.5rem;
  letter-spacing: -.005em;
  animation: fadeUp 1s .3s var(--ease-out) both;
}
.hero-v3-title .amp {
  font-style: italic;
  color: var(--gold-soft);
  font-weight: 300;
}
.hero-v3-quote {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.15rem;
  color: var(--gold-pale);
  opacity: .85;
  line-height: 1.65;
  max-width: 44ch;
  margin: 0 auto 1rem;
  animation: fadeUp 1s .4s var(--ease-out) both;
}
.hero-v3-quote-author {
  font-family: 'DM Sans', sans-serif;
  font-size: .58rem;
  letter-spacing: .3rem;
  text-transform: uppercase;
  color: var(--gold-soft);
  opacity: .7;
  margin-bottom: 3rem;
  animation: fadeUp 1s .5s var(--ease-out) both;
}
.hero-v3-schedule {
  display: inline-flex; gap: 3rem;
  padding: 1.5rem 2.5rem;
  border: 1px solid rgba(201, 168, 76, .3);
  background: rgba(20, 5, 5, .4);
  backdrop-filter: blur(6px);
  animation: fadeUp 1s .6s var(--ease-out) both;
}
.hero-v3-schedule-item {
  text-align: left;
}
.hero-v3-schedule-item .d {
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: .55rem; letter-spacing: .25rem; text-transform: uppercase;
  color: var(--gold-soft); opacity: .75; margin-bottom: .3rem;
}
.hero-v3-schedule-item .t {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem; color: #F5ECD6;
}
.hero-v3-schedule-item .n {
  font-family: 'Source Serif 4', serif;
  font-size: .72rem; color: var(--gold-pale); opacity: .7;
  display: block;
}

@media (max-width: 768px) {
  .hero-v3 { min-height: 85vh; }
  .hero-v3-icon-frame { width: 130px; height: 175px; }
  .hero-v3-schedule { gap: 1.5rem; padding: 1.2rem 1.5rem; }
}

/* ── FEATURE rows: subtle refinement ───────────────────────── */
.feature-item:hover .feature-title { color: var(--gold-ink); }
.feature-number { color: var(--gold-ink); }

/* Quote section refinement */
.quote-block p { opacity: .7 !important; color: var(--ink); }

/* ── TWEAKS PANEL ──────────────────────────────────────────── */
.tweaks-panel {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 280px;
  background: var(--stone);
  border: 1px solid var(--line);
  box-shadow: 0 20px 60px rgba(0,0,0,.2);
  padding: 1.4rem 1.4rem 1.2rem;
  z-index: 200;
  font-family: 'DM Sans', sans-serif;
  opacity: 0; pointer-events: none;
  transform: translateY(12px);
  transition: all .35s var(--ease-out);
}
.tweaks-panel.active { opacity: 1; pointer-events: auto; transform: translateY(0); }
.tweaks-panel-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: .2rem;
}
.tweaks-panel-sub {
  font-size: .6rem;
  letter-spacing: .15rem;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 1rem;
}
.tweaks-group {
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--line-soft);
}
.tweaks-group:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.tweaks-group-label {
  font-size: .55rem;
  letter-spacing: .2rem;
  text-transform: uppercase;
  color: var(--muted-soft);
  margin-bottom: .6rem;
  display: block;
}
.tweaks-options { display: flex; flex-direction: column; gap: .3rem; }
.tweaks-opt {
  display: flex; align-items: center; gap: .6rem;
  padding: .5rem .7rem;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--ink);
  font-family: inherit;
  font-size: .72rem;
  cursor: pointer;
  transition: all .2s ease;
  text-align: left;
}
.tweaks-opt:hover { border-color: var(--gold-ink); }
.tweaks-opt.on { background: var(--ink); color: var(--stone); border-color: var(--ink); }
.tweaks-opt .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor; opacity: .4;
}
.tweaks-opt.on .dot { opacity: 1; }

body.dark .tweaks-panel { background: var(--stone-warm); }
body.dark .tweaks-opt.on { background: var(--gold-ink); color: var(--burgundy-ink); border-color: var(--gold-ink); }

/* ── SAINT PAGE specifics ──────────────────────────────────── */
.saint-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 80vh;
  background: var(--stone-warm);
}
.saint-hero-text {
  padding: 5rem 4rem 5rem 5rem;
  display: flex; flex-direction: column; justify-content: center;
}
.saint-hero-dates {
  font-family: 'Cormorant Garamond', serif;
  font-size: .68rem; letter-spacing: .3rem; text-transform: uppercase;
  color: var(--gold-ink); margin-bottom: 1.2rem;
}
.saint-hero-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 400; line-height: 1;
  color: var(--ink); margin-bottom: .6rem;
}
.saint-hero-title em { font-style: italic; color: var(--gold-ink); font-weight: 300; }
.saint-hero-ru {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.2rem;
  color: var(--muted); margin-bottom: 2rem;
}
.saint-hero-lede {
  font-family: 'Source Serif 4', serif;
  font-size: 1rem; line-height: 1.85;
  color: var(--muted); max-width: 44ch;
  margin-bottom: 2.5rem;
}
.saint-hero-meta {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem;
  padding-top: 1.8rem; border-top: 1px solid var(--line);
}
.saint-hero-meta-block .k {
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: .55rem; letter-spacing: .2rem; text-transform: uppercase;
  color: var(--muted-soft); margin-bottom: .3rem;
}
.saint-hero-meta-block .v {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem; color: var(--ink);
}
.saint-hero-icon {
  position: relative; overflow: hidden;
}
.saint-hero-icon img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }

body.dark .saint-hero { background: var(--stone-warm); }
body.dark .saint-hero-title { color: var(--ink); }
body.dark .saint-hero-lede { color: var(--ink-soft); }

@media (max-width: 900px) {
  .saint-hero { grid-template-columns: 1fr; min-height: auto; }
  .saint-hero-text { padding: 3rem 1.5rem; }
  .saint-hero-icon { height: 60vh; }
  .saint-hero-meta { grid-template-columns: 1fr 1fr; }
}

/* Saint life sections */
.saint-life {
  padding: 6rem 2rem;
}
.saint-life-inner {
  max-width: 780px; margin: 0 auto;
}
.saint-life-chapter {
  margin-bottom: 4rem;
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 2.5rem;
  align-items: baseline;
}
.saint-life-chapter-num {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: 3.4rem;
  line-height: .9;
  color: var(--gold-ink);
  opacity: .6;
  text-align: right;
  padding-top: .3rem;
  border-top: 1px solid var(--gold-ink);
}
.saint-life-chapter h3 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 1.6rem;
  line-height: 1.2;
  color: var(--ink);
  margin-bottom: 1rem;
}
.saint-life-chapter p {
  font-family: 'Source Serif 4', serif;
  font-size: 1rem;
  line-height: 1.9;
  color: var(--muted);
}
.saint-life-chapter p + p { margin-top: .9rem; }
body.dark .saint-life-chapter h3 { color: var(--ink); }
body.dark .saint-life-chapter p { color: var(--ink-soft); }

.saint-life-figure {
  margin: 1.8rem 0 .4rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.saint-life-figure img {
  max-width: 100%;
  width: 360px;
  height: auto;
  border: 1px solid var(--gold-ink);
  padding: 6px;
  background: var(--stone-warm);
  box-shadow: 0 6px 24px rgba(0,0,0,.18);
}
.saint-life-figure figcaption {
  margin-top: .8rem;
  font-family: 'Source Serif 4', serif;
  font-style: italic;
  font-size: .88rem;
  color: var(--muted);
  text-align: center;
  max-width: 360px;
  line-height: 1.5;
}
body.dark .saint-life-figure figcaption { color: var(--ink-soft); }

@media (max-width: 768px) {
  .saint-life-chapter { grid-template-columns: 1fr; gap: 1rem; }
  .saint-life-chapter-num { text-align: left; font-size: 2.4rem; padding-top: 0; border-top: none; border-bottom: 1px solid var(--gold-ink); padding-bottom: .3rem; width: fit-content; }
}

/* Saint quotes strip */
.saint-quotes {
  background: var(--ink);
  color: var(--stone);
  padding: 5rem 2rem;
  overflow: hidden;
}
.saint-quotes-inner { max-width: 1000px; margin: 0 auto; }
.saint-quotes-label {
  font-family: 'DM Sans', sans-serif;
  font-size: .6rem; letter-spacing: .3rem; text-transform: uppercase;
  color: var(--gold-soft); opacity: .8;
  margin-bottom: 2.5rem;
  text-align: center;
}
.saint-quotes-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3rem 4rem;
}
.saint-quote {
  border-top: 1px solid rgba(237, 227, 212, .15);
  padding-top: 1.5rem;
}
.saint-quote p {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.55;
  color: var(--gold-pale);
  margin-bottom: .8rem;
}
.saint-quote-ref {
  font-family: 'DM Sans', sans-serif;
  font-size: .55rem; letter-spacing: .2rem; text-transform: uppercase;
  color: var(--gold-soft); opacity: .7;
}

body.dark .saint-quotes { background: var(--burgundy-ink); }

@media (max-width: 768px) {
  .saint-quotes-grid { grid-template-columns: 1fr; gap: 2rem; }
}

/* Saint icon description */
.saint-icon-section {
  padding: 5rem 2rem;
  background: var(--stone-warm);
}
.saint-icon-layout {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; align-items: center;
}
.saint-icon-img {
  aspect-ratio: 3/4;
  overflow: hidden;
  box-shadow: 0 30px 60px rgba(0,0,0,.18), 0 0 0 1px var(--line);
}
.saint-icon-img img { width: 100%; height: 100%; object-fit: cover; }
.saint-icon-text h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.8rem, 3.2vw, 2.6rem);
  font-weight: 500; line-height: 1.15;
  color: var(--ink); margin-bottom: 1rem;
}
.saint-icon-text .saint-icon-key {
  display: grid; gap: .8rem;
  margin-top: 1.8rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--line);
}
.saint-icon-key-row {
  display: grid; grid-template-columns: 90px 1fr;
  gap: 1.2rem; align-items: baseline;
}
.saint-icon-key-row .k {
  font-family: 'DM Sans', sans-serif;
  font-size: .55rem; letter-spacing: .18rem; text-transform: uppercase;
  color: var(--muted-soft); padding-top: .3rem;
}
.saint-icon-key-row .v {
  font-family: 'Source Serif 4', serif;
  font-size: .92rem; line-height: 1.65;
  color: var(--muted);
}
body.dark .saint-icon-text h2 { color: var(--ink); }
body.dark .saint-icon-key-row .v { color: var(--ink-soft); }

@media (max-width: 768px) {
  .saint-icon-layout { grid-template-columns: 1fr; gap: 2rem; }
}

/* ── Rector card polish ─────────────────────────────────────── */
.rector-card {
  display: grid; grid-template-columns: 160px 1fr; gap: 2rem;
  align-items: center;
  padding: 2rem;
  background: var(--stone);
  border: 1px solid var(--line);
  max-width: 560px;
  margin: 2rem auto;
}
.rector-card img {
  width: 160px; height: 200px; object-fit: cover;
  border: 1px solid var(--gold-ink);
}
.rector-card-title {
  font-family: 'DM Sans', sans-serif;
  font-size: .58rem; letter-spacing: .22rem; text-transform: uppercase;
  color: var(--gold-ink); margin-bottom: .4rem;
}
.rector-card-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem; font-weight: 500;
  color: var(--ink); margin-bottom: 1rem; line-height: 1.15;
}
.rector-card-contact {
  display: grid; gap: .4rem;
  font-family: 'Source Serif 4', serif;
  font-size: .88rem;
  color: var(--muted);
}
.rector-card-contact a { color: var(--ink); border-bottom: 1px solid var(--gold-ink); }
.rector-card-contact a:hover { color: var(--gold-ink); }
body.dark .rector-card { background: var(--stone-warm); }
body.dark .rector-card-name { color: var(--ink); }
body.dark .rector-card-contact { color: var(--ink-soft); }

@media (max-width: 640px) {
  .rector-card { grid-template-columns: 1fr; text-align: center; }
  .rector-card img { margin: 0 auto; }
}

/* ── Cartographe: wrapper map ──────────────────────────────── */
.map-wrap { border: 1px solid var(--line); overflow: hidden; }

/* Page header refinement */
.page-header { background: var(--stone-warm); padding: 5rem 2rem 3.5rem; text-align: center; }
.page-header h1 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(2rem, 4vw, 3.2rem);
  color: var(--ink); line-height: 1.1; margin-bottom: .4rem;
}
.page-header p {
  font-family: 'Source Serif 4', serif;
  font-style: italic;
  color: var(--muted);
  font-size: .95rem;
}
.page-header-kicker {
  font-family: 'DM Sans', sans-serif;
  font-size: .6rem; letter-spacing: .3rem; text-transform: uppercase;
  color: var(--gold-ink); margin-bottom: 1.2rem;
  display: inline-flex; align-items: center; gap: .8rem;
}
.page-header-kicker::before, .page-header-kicker::after {
  content: ''; width: 20px; height: 1px; background: currentColor; opacity: .5;
}

/* Cleaner icon on donation page */
.donate-hero { background: linear-gradient(180deg, var(--burgundy-ink) 0%, var(--burgundy-deep) 100%); }
body.dark .donate-hero { background: linear-gradient(180deg, #0A0202 0%, var(--burgundy-ink) 100%); }

/* Footer polish */
footer { background: var(--burgundy-ink); }
.footer-cta { background: linear-gradient(135deg, var(--burgundy-ink), var(--burgundy-deep)); }

/* ── Prayer request / liturgical feast widget ──────────────── */
.feast-banner {
  padding: 2.5rem 2rem;
  background: var(--stone);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.feast-banner[hidden], .feast-banner-next[hidden] { display: none !important; }
.feast-banner-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: auto 1fr auto; gap: 2.5rem; align-items: center;
}
.feast-banner-date {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: 3rem; line-height: .9;
  color: var(--gold-ink);
  opacity: .8;
}
.feast-banner-date .day { display: block; font-size: 2.4rem; }
.feast-banner-date .month { display: block; font-size: .65rem; letter-spacing: .25rem; text-transform: uppercase; color: var(--muted); margin-top: .3rem; font-family: 'DM Sans', sans-serif; opacity: .8; }
.feast-banner-content {
  border-left: 1px solid var(--line); padding-left: 2rem;
}
.feast-banner-kicker {
  font-family: 'DM Sans', sans-serif;
  font-size: .58rem; letter-spacing: .25rem; text-transform: uppercase;
  color: var(--gold-ink); margin-bottom: .5rem;
}
.feast-banner-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.3rem; color: var(--ink); margin-bottom: .3rem; font-weight: 500;
}
.feast-banner-desc {
  font-family: 'Source Serif 4', serif;
  font-size: .85rem; color: var(--muted); line-height: 1.65;
  max-width: 50ch;
}
.feast-banner-next {
  text-align: right;
}
.feast-banner-next .k {
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: .55rem; letter-spacing: .2rem; text-transform: uppercase;
  color: var(--muted-soft); margin-bottom: .3rem;
}
.feast-banner-next .v {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem; color: var(--ink); line-height: 1.2;
}
.feast-banner-next .v em { font-style: italic; color: var(--gold-ink); font-weight: 400; }

body.dark .feast-banner { background: var(--stone-warm); border-top-color: var(--line); border-bottom-color: var(--line); }
body.dark .feast-banner-title { color: var(--ink); }
body.dark .feast-banner-next .v { color: var(--ink); }

@media (max-width: 768px) {
  .feast-banner-inner { grid-template-columns: 1fr; gap: 1.2rem; text-align: left; }
  .feast-banner-content { border-left: none; padding-left: 0; border-top: 1px solid var(--line); padding-top: 1.2rem; }
  .feast-banner-next { text-align: left; border-top: 1px solid var(--line); padding-top: 1.2rem; }
}

/* Nav responsive: tighten the inline menu only in the 1201-1280 band so the
   8 links fit. At <=1200px the mobile panel (style.css) takes over entirely,
   so we must NOT touch .nav-links here (it would override the panel). */
@media (min-width: 1201px) and (max-width: 1280px) {
  .nav-links a { padding: .3rem .42rem; letter-spacing: .06rem; font-size: .6rem; }
  .nav-inner { padding: 0 1.2rem; }
}
.tweaks-toggle-btn {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 44px; height: 44px;
  background: var(--ink);
  color: var(--stone);
  border: none;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  z-index: 199;
  transition: all .3s ease;
  font-family: 'DM Sans', sans-serif;
  font-size: .55rem;
  letter-spacing: .18rem;
  text-transform: uppercase;
}
.tweaks-toggle-btn:hover { background: var(--gold-ink); color: var(--ink); }
.tweaks-toggle-btn svg { width: 16px; height: 16px; }
body.dark .tweaks-toggle-btn { background: var(--gold-ink); color: var(--burgundy-ink); }
body.dark .tweaks-toggle-btn:hover { background: var(--gold-soft); }

/* When tweaks panel is open, shift toggle */
.tweaks-panel.active ~ .tweaks-toggle-btn,
body:has(.tweaks-panel.active) .tweaks-toggle-btn { opacity: 0; pointer-events: none; }

/* ── Weekly liturgical bulletin (Programme de la semaine) ──────────── */
.weekly-bulletin { max-width: 760px; margin: 0 auto; }
.weekly-bulletin-empty {
  text-align: center; color: var(--ink-soft, #6b6357);
  font-style: italic; padding: 1.5rem 0;
}
.weekly-bulletin-card {
  border: 1px solid var(--gold-soft, rgba(201,168,76,.35));
  border-radius: 6px; padding: 1.6rem 1.8rem; background: var(--gold-pale, #f7efd0);
  text-align: center;
}
body.dark .weekly-bulletin-card { background: rgba(201,168,76,.07); }
.weekly-bulletin-title {
  font-family: 'Cormorant Garamond', serif; font-size: 1.5rem;
  color: var(--gold-deep, #8a6d1e); margin-bottom: .3rem;
}
.weekly-bulletin-date {
  font-family: 'DM Sans', sans-serif; font-size: .8rem; letter-spacing: .04rem;
  color: var(--ink-soft, #6b6357); margin-bottom: 1.1rem;
}
.weekly-bulletin-actions {
  display: flex; gap: 1rem; justify-content: center; align-items: center;
  flex-wrap: wrap; margin-bottom: 1.2rem;
}
.weekly-bulletin-dl {
  font-family: 'DM Sans', sans-serif; font-size: .78rem; font-weight: 600;
  letter-spacing: .12rem; text-transform: uppercase; color: var(--gold-deep, #8a6d1e);
  text-decoration: none; border-bottom: 1px solid rgba(201,168,76,.4); padding-bottom: .2rem;
}
.weekly-bulletin-dl:hover { color: var(--gold, #C9A84C); }
.weekly-bulletin-preview object {
  width: 100%; height: 70vh; min-height: 420px; border: 1px solid rgba(201,168,76,.25);
  border-radius: 4px; background: #fff;
}
@media (max-width: 640px) { .weekly-bulletin-preview { display: none; } }
