/* =========================================================
   RESET & BASE
========================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
    font-family: var(--font-body);
    color: var(--color-ink);
    background: var(--color-cream);
    line-height: 1.75;
    -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--color-gold-dim); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-gold); }

ul { list-style: none; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    line-height: 1.15;
    color: var(--color-ink);
    letter-spacing: .04em;
}

/* =========================================================
   UTILITIES
========================================================= */
.container { max-width: var(--max-width); margin: 0 auto; padding: 0 2rem; }
.section { padding: 6rem 0; }
.section--alt { background: var(--color-cream-dark); }
.section--dark { background: var(--color-navy-mid); }
.text-center { text-align: center; }
.text-gold { color: var(--color-gold); }

/* Ornamental rule */
.orn-rule {
    display: flex; align-items: center; gap: 1rem;
    width: fit-content; margin: 1rem auto 2.5rem;
}
.orn-rule::before, .orn-rule::after {
    content: ''; display: block; height: 1px;
    width: 56px; background: var(--grad-gold); opacity: .7;
}
.orn-cross {
    width: 12px; height: 12px; background: var(--color-gold);
    clip-path: polygon(40% 0%,60% 0%,60% 40%,100% 40%,100% 60%,60% 60%,60% 100%,40% 100%,40% 60%,0% 60%,0% 40%,40% 40%);
}

.section-label {
    font-family: var(--font-heading); font-size: .68rem; font-weight: 700;
    letter-spacing: .22em; text-transform: uppercase;
    color: var(--color-gold); margin-bottom: .875rem; display: block;
}

.section-title {
    font-family: var(--font-heading);
    font-size: clamp(1.875rem, 4vw, 2.75rem);
    font-weight: 700; letter-spacing: .05em; margin-bottom: .875rem;
}

.section-subtitle {
    font-family: var(--font-body); font-size: 1.0625rem;
    color: var(--color-gray); max-width: 640px;
    margin: 0 auto 3rem; line-height: 1.85;
}

/* Legacy .divider — replaced by orn-rule but kept for back-compat */
.divider {
    display: flex; align-items: center; gap: 1rem;
    width: fit-content; margin: 1rem auto 2.5rem;
}
.divider::before, .divider::after {
    content: ''; display: block; height: 1px;
    width: 56px; background: var(--grad-gold); opacity: .7;
}

/* Buttons */
.btn {
    display: inline-flex; align-items: center; gap: .6rem;
    padding: .875rem 2.25rem; font-family: var(--font-heading);
    font-size: .75rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase;
    cursor: pointer; transition: all var(--transition); border: none; text-decoration: none;
}
.btn--primary {
    background: var(--grad-gold); color: var(--color-navy);
    box-shadow: var(--shadow-gold);
    clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(201,168,76,.4); color: var(--color-navy); }

.btn--outline {
    background: transparent; color: var(--color-cream);
    border: 1px solid rgba(248,243,232,.4);
    clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.btn--outline:hover { background: rgba(248,243,232,.1); color: var(--color-cream); border-color: var(--color-gold); }

.btn--secondary {
    background: transparent; color: var(--color-gold-dim);
    border: 1px solid var(--color-gold-dim);
    clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.btn--secondary:hover { background: var(--color-gold-dim); color: var(--color-cream); }

/* =========================================================
   ANIMATIONS
========================================================= */
@keyframes fadeUp   { from { opacity:0; transform:translateY(32px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn   { from { opacity:0; } to { opacity:1; } }
@keyframes shimmerG { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes candleFlicker { 0%,100%{opacity:.55;transform:scale(1)} 33%{opacity:.7;transform:scale(1.03)} 66%{opacity:.5;transform:scale(.98)} }
@keyframes rotateHex { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
@keyframes floatOval { 0%,100%{transform:translateY(-48%)} 50%{transform:translateY(calc(-48% - 14px))} }
@keyframes glow { 0%,100%{opacity:.6} 50%{opacity:1} }

.animate { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.animate.in-view { opacity: 1; transform: translateY(0); }
.animate--delay-1 { transition-delay: .15s; }
.animate--delay-2 { transition-delay: .3s; }
.animate--delay-3 { transition-delay: .45s; }

/* =========================================================
   HEADER & NAVIGATION
========================================================= */
.site-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    background: rgba(12,16,24,.97);
    backdrop-filter: blur(16px);
    box-shadow: 0 1px 0 rgba(201,168,76,.15);
    transition: background var(--transition), box-shadow var(--transition);
    padding: .2rem 0;
}

/* Front page only: start transparent so the header blends into the dark hero */
.home .site-header,
.page-template-front-page .site-header {
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
}

.site-header.scrolled {
    background: rgba(12,16,24,.97) !important;
    backdrop-filter: blur(16px) !important;
    box-shadow: 0 1px 0 rgba(201,168,76,.2), var(--shadow-lg) !important;
}

.header-inner {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1rem 2rem; max-width: var(--max-width); margin: 0 auto;
}

/* Logo */
.site-logo {
    display: flex; align-items: center; text-decoration: none; flex-shrink: 0;
}

.logo-img {
    width: 44px; height: 44px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    transition: opacity var(--transition);
}
.site-logo:hover .logo-img { opacity: .85; }

/* Nav */
.primary-nav { display: flex; align-items: center; gap: .1rem; }

.primary-nav a {
    font-family: var(--font-heading); color: rgba(255,255,255,.75);
    font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
    padding: .5rem .875rem; transition: all var(--transition); position: relative;
}
.primary-nav a::after {
    content: ''; position: absolute; bottom: 4px; left: 50%; right: 50%;
    height: 1px; background: var(--color-gold); transition: all var(--transition);
}
.primary-nav a:hover { color: var(--color-gold-light); }
.primary-nav a:hover::after { left: .875rem; right: .875rem; }
.primary-nav a.active { color: var(--color-gold-light); }

.nav-live { color: #f87171 !important; }

.nav-cta {
    background: var(--grad-gold) !important; color: var(--color-navy) !important;
    margin-left: .5rem; padding: .5rem 1.25rem !important;
    clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
    box-shadow: 0 2px 12px rgba(201,168,76,.3);
}
.nav-cta:hover { box-shadow: 0 4px 20px rgba(201,168,76,.5) !important; }
.nav-cta::after { display: none !important; }

.hamburger {
    display: none; flex-direction: column; gap: 5px;
    cursor: pointer; background: none; border: none; padding: .5rem;
}
.hamburger span {
    display: block; width: 26px; height: 1.5px;
    background: var(--color-white); transition: all var(--transition);
}

@media (max-width: 860px) {
    .hamburger { display: flex; }
    .primary-nav {
        position: fixed; top: 0; right: -100%;
        width: min(320px, 88vw); height: 100vh;
        background: var(--color-navy); flex-direction: column; align-items: flex-start;
        padding: 5rem 2rem 2rem; gap: .25rem; transition: right var(--transition);
        box-shadow: -12px 0 48px rgba(0,0,0,.5);
        border-left: 1px solid rgba(201,168,76,.15);
    }
    .primary-nav.open { right: 0; }
    .primary-nav a { font-size: .8rem; width: 100%; padding: .875rem 1rem; border-bottom: 1px solid rgba(201,168,76,.08); }
}

/* =========================================================
   HERO
========================================================= */
.hero {
    position: relative; min-height: 100vh;
    display: flex; align-items: center; overflow: hidden;
    background: var(--grad-dark);
}

/* Stone-texture overlay */
.hero-bg {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 80% 60% at 50% 20%, rgba(201,168,76,.12) 0%, transparent 70%),
        radial-gradient(ellipse 40% 40% at 20% 80%, rgba(122,22,40,.08) 0%, transparent 60%),
        url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
    pointer-events: none; z-index: 0;
}

/* Candlelight shaft */
.hero-pattern {
    position: absolute; top: -10%; left: 50%; transform: translateX(-50%);
    width: 3px; height: 110%;
    background: linear-gradient(180deg, rgba(201,168,76,.35) 0%, rgba(201,168,76,.05) 60%, transparent 100%);
    z-index: 1; pointer-events: none;
    animation: candleFlicker 6s ease-in-out infinite;
}
.hero-pattern::before, .hero-pattern::after {
    content: ''; position: absolute; top: 0;
    background: linear-gradient(180deg, rgba(201,168,76,.18) 0%, transparent 80%);
}
.hero-pattern::before { left: -60px; width: 60px; transform: skewX(6deg); height: 60%; }
.hero-pattern::after  { right: -60px; width: 60px; transform: skewX(-6deg); height: 60%; }

/* Cross oval medallion (positioned by front-page.php) */
.hero-cross-oval {
    position: absolute; right: 6%; top: 50%; transform: translateY(-48%);
    width: 300px; height: 400px; border-radius: 50%;
    overflow: hidden;
    border: 1px solid rgba(201,168,76,.25);
    box-shadow: 0 0 60px rgba(201,168,76,.08), 0 0 0 8px rgba(201,168,76,.06);
    pointer-events: none; user-select: none;
    animation: floatOval 9s ease-in-out infinite; z-index: 1;
}
.hero-cross {
    width: 100%; height: 100%; object-fit: cover;
    opacity: .55;
    filter: none;
}
@media (max-width: 900px) { .hero-cross-oval { display: none; } }

/* Hex ornaments (injected by JS) */
.hero-hex-1, .hero-hex-2 {
    position: absolute; border: 1px solid rgba(201,168,76,.12);
    border-radius: 2px; pointer-events: none; z-index: 1;
}
.hero-hex-1 { width:320px;height:320px;top:-80px;left:-100px;transform:rotate(15deg);animation:rotateHex 80s linear infinite; }
.hero-hex-2 { width:200px;height:200px;bottom:10%;right:5%;transform:rotate(30deg);animation:rotateHex 60s linear infinite reverse; }

.hero-content {
    position: relative; z-index: 2;
    max-width: var(--max-width); margin: 0 auto;
    padding: 10rem 2rem 6rem; width: 100%;
}

/* Monogram line above title */
.hero-eyebrow {
    font-family: var(--font-heading); font-size: .7rem; font-weight: 600;
    letter-spacing: .35em; text-transform: uppercase;
    color: var(--color-gold); opacity: .8; margin-bottom: 2rem;
    display: flex; align-items: center; gap: 1rem;
    animation: fadeIn 1s ease both;
}
.hero-eyebrow::before, .hero-eyebrow::after {
    content: ''; display: block; width: 48px; height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-gold), transparent); opacity: .6;
}

.hero h1 {
    font-family: var(--font-display);
    font-size: clamp(2.25rem, 6vw, 5.5rem);
    font-weight: 700; letter-spacing: .06em; line-height: 1.1;
    color: var(--color-cream); max-width: none;
    margin-bottom: 1.25rem;
    animation: fadeUp .9s ease both .15s;
}
.hero h1 span {
    display: block;
    background: var(--grad-gold); background-size: 200% auto;
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    animation: shimmerG 4s linear infinite;
}

.hero-desc {
    font-family: var(--font-body); font-size: 1.1rem; font-style: italic;
    color: rgba(248,243,232,.65); max-width: 520px;
    margin-bottom: 2.5rem; line-height: 1.9;
    animation: fadeUp .9s ease both .3s;
}

.hero-actions {
    display: flex; flex-wrap: wrap; gap: 1rem;
    animation: fadeUp .9s ease both .45s;
}

.hero-stats {
    display: flex; gap: 0; flex-wrap: wrap; justify-content: flex-start;
    margin-top: 5rem; padding-top: 3rem;
    border-top: 1px solid rgba(201,168,76,.15);
    animation: fadeUp .9s ease both .6s;
}

.hero-stat {
    padding: 0 3rem; text-align: center;
    border-right: 1px solid rgba(201,168,76,.15);
}
.hero-stat:first-child { padding-left: 0; }
.hero-stat:last-child { border-right: none; }

.hero-stat .number {
    font-family: var(--font-display); font-size: 3rem; font-weight: 700; line-height: 1;
    background: var(--grad-gold); background-size: 200% auto;
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    animation: shimmerG 4s linear infinite 1s;
}
.hero-stat .label {
    font-family: var(--font-heading); font-size: .65rem;
    letter-spacing: .2em; text-transform: uppercase;
    color: rgba(248,243,232,.45); margin-top: .4rem;
}

/* Scroll indicator */
.hero-scroll-hint {
    position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%);
    z-index: 2; display: flex; flex-direction: column; align-items: center; gap: .5rem;
    font-family: var(--font-heading); font-size: .6rem; letter-spacing: .2em;
    text-transform: uppercase; color: rgba(248,243,232,.3);
    animation: fadeIn 1.5s ease both 1.2s;
}
.hero-scroll-line {
    width: 1px; height: 48px;
    background: linear-gradient(180deg, rgba(201,168,76,.5), transparent);
    animation: glow 2s ease-in-out infinite;
}

@media (max-width: 640px) {
    .hero-stat { padding: 0 1.5rem; }
    .hero-stat .number { font-size: 2rem; }
}

/* ── Hero layout: two-column with events panel ── */
.hero-layout {
    position: relative; z-index: 2;
    width: 100%; max-width: var(--max-width);
    margin: 0 auto;
    padding: 10rem 2rem 6rem;
    display: flex; align-items: center;
    gap: 2.5rem;
}
.hero-layout .hero-content {
    flex: 1; min-width: 0;
    max-width: none; margin: 0; padding: 0;
}
.hero--with-panel .hero-cross-oval { display: none; }
.hero--with-panel .hero-stats { flex-wrap: nowrap; }
.hero--with-panel .hero-stat { padding: 0 1.25rem; flex: 1; }
.hero--with-panel .hero-stat .number { font-size: 2rem; }
.hero--with-panel .hero-stat .label { font-size: .58rem; letter-spacing: .12em; }

/* Events panel — matches announce-card dark-section pattern */
.hero-events-panel {
    width: 300px; flex-shrink: 0;
    align-self: center;
    display: flex; flex-direction: column; gap: 0;
}

/* "Events" eyebrow — matches .hero-eyebrow style */
.hep-eyebrow {
    font-family: var(--font-heading);
    font-size: .65rem; font-weight: 700;
    letter-spacing: .3em; text-transform: uppercase;
    color: var(--color-gold); opacity: .85;
    display: flex; align-items: center; gap: .75rem;
    margin-bottom: .875rem;
}
.hep-eyebrow::before, .hep-eyebrow::after {
    content: ''; flex: 1; height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-gold), transparent);
    opacity: .45;
}

/* Cards — announce-card pattern */
.hep-card {
    display: block; text-decoration: none;
    background: rgba(255,255,255,.04);
    border-left: 3px solid rgba(201,168,76,.25);
    padding: .875rem 1rem;
    transition: background var(--transition), border-left-color var(--transition);
    margin-bottom: 1.5px;
}
.hep-card:hover {
    background: rgba(255,255,255,.08);
    border-left-color: var(--color-gold);
}
.hep-card--featured { border-left-color: rgba(201,168,76,.5); }

/* Date badge — announce-tag oblique style */
.hep-tag {
    display: inline-block;
    font-family: var(--font-heading);
    font-size: .6rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--color-navy);
    background: var(--color-gold);
    padding: .18rem .5rem;
    margin-bottom: .5rem;
    clip-path: polygon(4px 0%, 100% 0%, calc(100% - 4px) 100%, 0% 100%);
}

.hep-card-date {
    font-family: var(--font-heading);
    font-size: .62rem; letter-spacing: .1em; text-transform: uppercase;
    color: var(--color-gold-dim);
    margin-bottom: .25rem;
}
.hep-card-title {
    font-family: var(--font-heading);
    font-size: .875rem; font-weight: 700;
    color: var(--color-cream); line-height: 1.4;
}
.hep-card--past .hep-card-date { font-size: .58rem; }
.hep-card--past .hep-card-title {
    font-size: .78rem;
    color: rgba(248,243,232,.72);
}

/* View all */
.hep-all-link {
    display: flex; align-items: center; justify-content: flex-end; gap: .375rem;
    font-family: var(--font-heading);
    font-size: .62rem; letter-spacing: .1em; text-transform: uppercase;
    color: var(--color-gold-dim);
    text-decoration: none;
    padding: .625rem .25rem 0;
    transition: color var(--transition);
}
.hep-all-link:hover { color: var(--color-gold); }

/* Responsive */
@media (max-width: 1100px) {
    .hero-events-panel { width: 268px; }
}
@media (max-width: 900px) {
    .hero-layout { flex-direction: column; gap: 0; }
    .hero-events-panel {
        width: 100%; max-width: 480px;
        margin: 2rem auto 0;
    }
}

/* =========================================================
   SCRIPTURE / QUOTE SECTION
========================================================= */
.quote-section {
    background: var(--color-navy);
    padding: 5rem 0;
    text-align: center;
    position: relative; overflow: hidden;
    border-top: 1px solid rgba(201,168,76,.15);
    border-bottom: 1px solid rgba(201,168,76,.15);
}
.quote-section::before {
    content: '\201C'; position: absolute;
    font-family: var(--font-display); font-size: 20rem;
    color: rgba(201,168,76,.04); top: -3rem; left: 2rem; line-height: 1; pointer-events: none;
}

.quote-text {
    font-family: var(--font-body); font-size: clamp(1.25rem, 3vw, 2rem);
    font-weight: 400; font-style: italic; color: var(--color-cream);
    max-width: 820px; margin: 0 auto 1.25rem; line-height: 1.8;
    position: relative; z-index: 1;
}

.quote-source {
    font-family: var(--font-heading); font-size: .7rem;
    letter-spacing: .2em; text-transform: uppercase;
    color: var(--color-gold); position: relative; z-index: 1;
}

/* =========================================================
   MASS SCHEDULE
========================================================= */
.schedule-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.5px; background: var(--color-gray-light);
}

.schedule-card {
    background: var(--color-white);
    padding: 1.75rem;
    border-top: 3px solid var(--color-gold-dim);
    transition: background var(--transition);
}
.schedule-card:hover { background: var(--color-cream); }

.schedule-card .day {
    font-family: var(--font-heading);
    font-size: .78rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
    color: var(--color-navy);
    margin-bottom: 1rem; padding-bottom: .875rem;
    border-bottom: 1px solid var(--color-cream-dark);
}

.schedule-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: .45rem 0; font-size: .875rem;
}
.schedule-row + .schedule-row {
    border-top: 1px solid var(--color-cream-dark);
}

.schedule-time {
    font-family: var(--font-heading); font-weight: 700;
    color: var(--color-gold-dim); font-size: .78rem;
    letter-spacing: .06em; white-space: nowrap; margin-right: 1rem;
}

.schedule-type {
    font-family: var(--font-body); color: var(--color-gray);
    font-size: .875rem; font-style: italic; text-align: right;
}

.office-hours-box {
    background: var(--color-navy); color: var(--color-cream);
    border: 1px solid rgba(201,168,76,.18);
    padding: 2rem 2.5rem; margin-top: 2.5rem;
    display: flex; align-items: center; gap: 2rem; flex-wrap: wrap;
}
.office-hours-box .icon { font-size: 2rem; flex-shrink: 0; }
.office-hours-box h3 {
    font-family: var(--font-heading); font-size: .78rem;
    letter-spacing: .18em; text-transform: uppercase;
    color: var(--color-gold); margin-bottom: .5rem;
}
.office-hours-box p { font-family: var(--font-body); color: rgba(248,243,232,.7); font-size: .9rem; line-height: 1.7; }

/* Office pill (front-page) */
.office-pill {
    display: inline-flex; align-items: center; gap: .625rem;
    background: rgba(201,168,76,.1); border: 1px solid rgba(201,168,76,.2);
    padding: .5rem 1.25rem;
    font-family: var(--font-heading); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
    color: var(--color-gold-light); clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}

/* =========================================================
   ABOUT
========================================================= */
.about-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 4rem; align-items: center;
}
@media (max-width: 768px) { .about-grid { grid-template-columns: 1fr; gap: 2.5rem; } }

.about-image-wrap { position: relative; }

.about-image-main {
    overflow: hidden; box-shadow: var(--shadow-lg);
    aspect-ratio: 4/3; background: var(--color-gray-light);
    border: 1px solid var(--color-gray-light);
}
.about-image-main img { width: 100%; height: 100%; object-fit: cover; }

.about-badge {
    position: absolute; bottom: -1.5rem; right: -1.5rem;
    background: var(--color-navy); border: 1px solid rgba(201,168,76,.25);
    color: var(--color-cream);
    padding: 1.25rem 1.5rem; box-shadow: var(--shadow-gold);
    font-family: var(--font-heading); text-align: center; min-width: 130px;
    clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.about-badge .number {
    font-family: var(--font-display); font-size: 2.25rem; font-weight: 700;
    background: var(--grad-gold); background-size: 200% auto;
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    animation: shimmerG 4s linear infinite;
    line-height: 1;
}
.about-badge .text { font-family: var(--font-heading); font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; margin-top: .35rem; color: rgba(248,243,232,.6); }

.about-content p {
    font-family: var(--font-body); color: var(--color-gray);
    margin-bottom: 1.25rem; line-height: 1.9;
}

.about-features {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 1rem; margin-top: 1.75rem;
}
.about-feature { display: flex; align-items: flex-start; gap: .75rem; }
.about-feature .icon {
    width: 38px; height: 38px;
    background: rgba(201,168,76,.1);
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; flex-shrink: 0;
}
.about-feature .text { font-family: var(--font-body); font-size: .875rem; color: var(--color-gray); line-height: 1.5; }
.about-feature .text strong { display: block; font-family: var(--font-heading); font-size: .75rem; letter-spacing: .06em; text-transform: uppercase; color: var(--color-navy); margin-bottom: .15rem; }

/* =========================================================
   MINISTRIES
========================================================= */
.ministries-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5px; background: var(--color-gray-light);
}

.ministry-card {
    background: var(--color-white); padding: 2rem 1.75rem;
    text-align: center; border-top: 3px solid transparent;
    transition: all var(--transition); cursor: default;
    display: flex; flex-direction: column;
}
.ministry-card:hover {
    background: var(--color-cream); border-top-color: var(--color-gold);
}

/* Linked ministry card */
a.ministry-card--link {
    text-decoration: none; color: inherit; cursor: pointer;
}
a.ministry-card--link:hover {
    background: var(--color-cream);
    border-top-color: var(--color-gold);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}
a.ministry-card--link:hover h3 { color: var(--color-gold-dim); }
.ministry-card-cta {
    display: block; margin-top: auto; padding-top: 1rem;
    font-family: var(--font-heading); font-size: .58rem; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--color-gold-dim);
    transition: transform var(--transition);
}
a.ministry-card--link:hover .ministry-card-cta { transform: translateX(3px); }

.ministry-icon {
    width: 64px; height: 64px;
    background: var(--color-navy);
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    margin: 0 auto 1.25rem;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.6rem;
}

.ministry-card h3 {
    font-family: var(--font-heading); font-size: .9rem;
    font-weight: 700; letter-spacing: .06em;
    color: var(--color-navy); margin-bottom: .625rem;
}
.ministry-card p { font-family: var(--font-body); font-size: .875rem; color: var(--color-gray); line-height: 1.65; }

/* =========================================================
   ANNOUNCEMENTS
========================================================= */
.announcements {
    background: var(--color-navy-mid);
    padding: 5rem 0;
    border-top: 1px solid rgba(201,168,76,.12);
    border-bottom: 1px solid rgba(201,168,76,.12);
}

.announcements .section-label { color: var(--color-gold-light); }
.announcements .section-title { color: var(--color-cream); }

.announce-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5px; margin-top: 2.5rem; background: rgba(201,168,76,.12);
}

.announce-card {
    background: rgba(255,255,255,.04);
    border-left: 3px solid rgba(201,168,76,.25);
    padding: 1.5rem 1.625rem;
    color: rgba(248,243,232,.85);
    transition: background var(--transition);
}
.announce-card:hover { background: rgba(255,255,255,.08); border-left-color: var(--color-gold); }

.announce-tag {
    display: inline-block;
    background: rgba(201,168,76,.15); color: var(--color-gold-light);
    border: 1px solid rgba(201,168,76,.2);
    font-family: var(--font-heading); font-size: .58rem; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase;
    padding: .18rem .75rem; margin-bottom: .875rem;
    clip-path: polygon(4px 0%, 100% 0%, calc(100% - 4px) 100%, 0% 100%);
}

.announce-card h3 { font-family: var(--font-heading); font-size: .9rem; font-weight: 700; letter-spacing: .04em; color: var(--color-navy); margin-bottom: .5rem; }
.announce-card p { font-family: var(--font-body); font-size: .875rem; color: var(--color-gray); line-height: 1.7; }
.announce-date { font-family: var(--font-heading); font-size: .65rem; letter-spacing: .1em; text-transform: uppercase; color: var(--color-gold-dim); margin-top: .875rem; }

/* On the dark navy announcements section, flip to light colours */
.announcements .announce-card h3 { color: var(--color-cream); }
.announcements .announce-card p  { color: rgba(248,243,232,.72); }

/* =========================================================
   SACRAMENTS
========================================================= */
.sac-section {
    background: var(--color-navy);
    position: relative;
}
.sac-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 50% at 100% 0%, rgba(201,168,76,.05) 0%, transparent 60%),
        radial-gradient(ellipse 40% 40% at 0% 100%, rgba(122,22,40,.06) 0%, transparent 60%);
    pointer-events: none;
}
.sac-section .container { position: relative; }

.sac-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.125rem;
    margin-top: 3rem;
}
@media (max-width: 880px) { .sac-grid { grid-template-columns: repeat(2, 1fr); gap: .875rem; } }
@media (max-width: 420px) { .sac-grid { grid-template-columns: repeat(2, 1fr); gap: .625rem; } }

.sac-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 2rem 1.25rem 1.75rem;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(201,168,76,.12);
    border-top: 2px solid rgba(201,168,76,.45);
    border-radius: var(--radius-md);
    transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.sac-card--link {
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}
.sac-card--link:hover {
    transform: translateY(-5px);
    background: rgba(201,168,76,.07);
    border-color: rgba(201,168,76,.38);
    border-top-color: var(--color-secondary);
    box-shadow: 0 16px 48px rgba(0,0,0,.35), 0 0 0 1px rgba(201,168,76,.15);
}

.sac-numeral {
    font-family: var(--font-heading);
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: .25em;
    text-transform: uppercase;
    color: rgba(201,168,76,.35);
    margin-bottom: .875rem;
    line-height: 1;
}

.sac-icon-wrap {
    width: 58px;
    height: 58px;
    border-radius: 50%;
    background: rgba(201,168,76,.08);
    border: 1px solid rgba(201,168,76,.18);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.125rem;
    font-size: 1.5rem;
    line-height: 1;
    transition: background .25s ease, border-color .25s ease;
    flex-shrink: 0;
}
.sac-card--link:hover .sac-icon-wrap {
    background: rgba(201,168,76,.16);
    border-color: rgba(201,168,76,.45);
}

.sac-name {
    font-family: var(--font-heading);
    font-size: .875rem;
    font-weight: 700;
    letter-spacing: .05em;
    color: #fff;
    margin-bottom: .5rem;
    line-height: 1.3;
}

.sac-desc {
    font-family: var(--font-body);
    font-size: .8rem;
    color: rgba(255,255,255,.45);
    line-height: 1.65;
    font-style: italic;
    flex: 1;
}

.sac-cta {
    margin-top: 1.375rem;
    font-family: var(--font-heading);
    font-size: .63rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--color-secondary);
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    opacity: .85;
    transition: gap .22s ease, opacity .22s ease;
}
.sac-card--link:hover .sac-cta {
    gap: .7rem;
    opacity: 1;
}

/* =========================================================
   PATRON SAINTS
========================================================= */
.saints-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5px; background: var(--color-gray-light);
}

.saint-card {
    background: var(--color-white);
    border-top: 3px solid var(--color-gold-dim);
    overflow: hidden; transition: background var(--transition);
}
.saint-card:hover { background: var(--color-cream); }

.saint-img-wrap {
    aspect-ratio: 2/3; overflow: hidden;
    background: var(--color-navy); position: relative;
}
.saint-img-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; filter: sepia(.15); }
.saint-card:hover .saint-img-wrap img { transform: scale(1.03); }
.saint-img-wrap .saint-name-overlay {
    position: absolute; bottom: 0; left: 0; right: 0;
    padding: 2rem 1.25rem 1.25rem;
    background: linear-gradient(to top, rgba(12,16,24,.9) 0%, transparent 100%);
    font-family: var(--font-heading); font-size: .72rem; letter-spacing: .16em;
    text-transform: uppercase; color: var(--color-gold-light);
}

.saint-body { padding: 1.5rem; }
.saint-body h3 { font-family: var(--font-heading); font-size: 1rem; font-weight: 700; letter-spacing: .05em; color: var(--color-navy); margin-bottom: .625rem; }
.saint-body p { font-family: var(--font-body); font-size: .875rem; color: var(--color-gray); line-height: 1.75; }

/* =========================================================
   CONTACT
========================================================= */
.contact-wrapper {
    display: grid; grid-template-columns: 1fr 1.4fr; gap: 3.5rem;
}
@media (max-width: 900px) { .contact-wrapper { grid-template-columns: 1fr; } }

.contact-info h3 {
    font-family: var(--font-heading); font-size: 1.1rem;
    letter-spacing: .06em; color: var(--color-ink); margin-bottom: 2rem;
}

.contact-item {
    display: flex; gap: 1rem; margin-bottom: 1.5rem;
}

.contact-item-icon {
    width: 44px; height: 44px;
    background: rgba(201,168,76,.1);
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; flex-shrink: 0;
}

.contact-item-text { font-family: var(--font-body); font-size: .875rem; color: var(--color-gray); }
.contact-item-text strong { display: block; font-family: var(--font-heading); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--color-navy); margin-bottom: .3rem; }
.contact-item-text a { color: var(--color-gold-dim); }
.contact-item-text a:hover { color: var(--color-gold); }

/* Also handle the c-icon / c-text variant used in front-page.php */
.c-icon {
    width: 44px; height: 44px; flex-shrink: 0;
    background: rgba(201,168,76,.1);
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
}
.c-text { font-family: var(--font-body); font-size: .875rem; color: var(--color-gray); line-height: 1.7; }
.c-text strong { display: block; font-family: var(--font-heading); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--color-navy); margin-bottom: .3rem; }
.c-text a { color: var(--color-gold-dim); }
.c-text a:hover { color: var(--color-gold); }

.social-links { display: flex; gap: .75rem; margin-top: 2rem; }
.soc-btn {
    width: 42px; height: 42px;
    background: var(--color-navy); color: var(--color-gold-light);
    display: flex; align-items: center; justify-content: center;
    transition: all var(--transition);
    clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.soc-btn:hover { background: var(--grad-gold); color: var(--color-navy); transform: translateY(-2px); }

/* Legacy class names from footer.php */
.social-link { @extend .soc-btn; }

.map-wrapper {
    overflow: hidden; box-shadow: var(--shadow-md);
    border: 1px solid var(--color-gray-light);
}
.map-wrapper iframe { width: 100%; border: none; display: block; }

/* Also handle .map-box class used in static HTML */
.map-box {
    overflow: hidden; border: 1px solid var(--color-gray-light);
    box-shadow: var(--shadow-md); min-height: 400px;
}
.map-box iframe { width: 100%; height: 100%; border: none; display: block; min-height: 400px; }

/* Right column wrapper: form card + map stacked */
.contact-rhs { display: flex; flex-direction: column; gap: 1.5rem; }

/* Contact form card */
.contact-form-wrap {
    background: var(--color-white);
    padding: 2.25rem 2.5rem 2.5rem;
    border-top: 2px solid var(--color-gold);
    box-shadow: var(--shadow-sm);
}

.cf-heading {
    font-family: var(--font-heading); font-size: 1rem; font-weight: 700;
    letter-spacing: .06em; color: var(--color-navy); margin-bottom: 1.75rem;
}

/* Success / error notices */
.cf-notice {
    padding: .875rem 1.1rem;
    font-family: var(--font-body); font-size: .875rem; line-height: 1.6;
    margin-bottom: 1.5rem; border-left: 3px solid;
}
.cf-notice--success { background: #f0faf0; border-color: #2e7d32; color: #2e7d32; }
.cf-notice--error   { background: #fdf4f4; border-color: var(--color-crimson); color: var(--color-crimson); }
.cf-notice--error a { color: inherit; text-decoration: underline; }

/* Two-column row */
.cf-row { display: grid; gap: 1.25rem; margin-bottom: 1.25rem; }
.cf-row--2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 560px) { .cf-row--2 { grid-template-columns: 1fr; } }
.cf-row .cf-field { margin-bottom: 0; }

.cf-field { display: flex; flex-direction: column; gap: .35rem; margin-bottom: 1.25rem; }

/* Labels */
.cf-label {
    font-family: var(--font-heading); font-size: .6rem; font-weight: 700;
    letter-spacing: .18em; text-transform: uppercase; color: var(--color-gray);
}
.cf-label span { color: var(--color-gold-dim); margin-left: 1px; }

/* Inputs — underline-only style */
.cf-input {
    font-family: var(--font-body); font-size: .9375rem; color: var(--color-ink);
    background: transparent; width: 100%; box-sizing: border-box;
    border: none; border-bottom: 1px solid var(--color-gray-light);
    padding: .55rem 0; outline: none;
    transition: border-color var(--transition);
    border-radius: 0;
}
.cf-input:focus { border-bottom-color: var(--color-gold); }
.cf-input::placeholder { color: var(--color-gray-light); }
.cf-textarea { resize: vertical; min-height: 110px; }

/* Submit row */
.cf-submit { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; margin-top: .25rem; }
.cf-note {
    font-family: var(--font-body); font-size: .75rem;
    color: var(--color-gray); font-style: italic;
}

/* =========================================================
   BULLETIN TEASER (on front page)
========================================================= */
.bulletin-wrap {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 4rem; align-items: center;
}
@media (max-width: 768px) { .bulletin-wrap { grid-template-columns: 1fr; } }

.bulletin-preview {
    background: var(--color-navy);
    border: 1px solid rgba(201,168,76,.18);
    padding: 2rem; text-align: center;
    box-shadow: var(--shadow-lg);
}
.bulletin-preview .bul-season-pill {
    display: inline-block; background: rgba(201,168,76,.12); color: var(--color-gold-light);
    border: 1px solid rgba(201,168,76,.2);
    font-family: var(--font-heading); font-size: .62rem; letter-spacing: .14em; text-transform: uppercase;
    padding: .2rem .875rem; margin-bottom: .875rem;
    clip-path: polygon(4px 0%, 100% 0%, calc(100% - 4px) 100%, 0% 100%);
}
.bulletin-preview .bul-title { font-family: var(--font-heading); font-size: 1.125rem; font-weight: 700; letter-spacing: .04em; color: var(--color-cream); margin-bottom: .375rem; }
.bulletin-preview .bul-date { font-family: var(--font-heading); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(248,243,232,.4); }

.bulletin-copy .section-title { color: var(--color-ink); }

/* =========================================================
   GALLERY
========================================================= */
.gallery-strip {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: .5rem;
}
@media (max-width: 640px) { .gallery-strip { grid-template-columns: repeat(2, 1fr); } }

.gallery-item {
    aspect-ratio: 1; background: var(--color-cream-dark);
    overflow: hidden; display: flex; align-items: center; justify-content: center;
    font-size: 2.5rem; cursor: pointer; transition: filter var(--transition), transform var(--transition);
}
.gallery-item:hover { filter: brightness(1.08); transform: scale(1.02); }
.gallery-item.tall { grid-row: span 2; }

.gallery-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 1.5px; margin-top: 2.5rem; background: var(--color-gray-light);
}
@media (max-width: 900px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .gallery-grid { grid-template-columns: 1fr; } }

.gallery-item {
    position: relative; overflow: hidden; cursor: pointer;
    aspect-ratio: 3/2; background: var(--color-cream-dark);
}
.gallery-item img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform .4s ease;
}
.gallery-item:hover img { transform: scale(1.06); }

.gallery-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(12,16,24,.8) 0%, transparent 60%);
    display: flex; flex-direction: column; justify-content: flex-end;
    padding: 1rem; opacity: 0; transition: opacity .3s ease;
}
.gallery-item:hover .gallery-overlay { opacity: 1; }

.gallery-category {
    font-family: var(--font-heading); font-size: .62rem; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--color-gold); margin-bottom: .25rem;
}
.gallery-label { font-family: var(--font-body); font-size: .875rem; color: var(--color-cream); }
.gallery-zoom {
    position: absolute; top: .75rem; right: .75rem;
    width: 32px; height: 32px;
    background: rgba(12,16,24,.5); display: flex; align-items: center; justify-content: center;
    color: var(--color-cream); font-size: 1rem; backdrop-filter: blur(4px);
    clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}
.gallery-note { font-family: var(--font-body); font-size: .8rem; color: var(--color-gray); margin-top: 1.5rem; font-style: italic; }
.gallery-empty-notice { text-align: center; padding: 3rem 1rem; font-family: var(--font-body); color: var(--color-gray); }
.gallery-empty-notice a { color: var(--color-gold); text-decoration: underline; }

/* Video play button — always visible on video items */
.gallery-play-btn {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 52px; height: 52px; border-radius: 50%;
    background: rgba(201,168,76,.85);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-navy); font-size: 1.25rem;
    pointer-events: none;
    transition: background var(--transition), transform var(--transition);
    z-index: 1;
}
.gallery-item--video:hover .gallery-play-btn {
    background: var(--color-gold);
    transform: translate(-50%, -50%) scale(1.1);
}
.gallery-item-placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--color-navy) 0%, #1c2434 100%);
}

/* Lightbox */
.lightbox {
    position: fixed; inset: 0; background: rgba(0,0,0,.92);
    z-index: 9999; display: flex; align-items: center; justify-content: center;
    opacity: 0; visibility: hidden; transition: opacity .3s ease, visibility .3s ease;
}
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox-inner { max-width: 90vw; max-height: 90vh; text-align: center; }
.lightbox-img { max-width: 90vw; max-height: 80vh; display: block; }
.lightbox-video {
    width: min(900px, 90vw); aspect-ratio: 16 / 9;
    border: none; display: block; border-radius: var(--radius-sm);
}
.lightbox-video-el {
    width: min(900px, 90vw); max-height: 80vh;
    display: block; border-radius: var(--radius-sm);
    background: #000;
}
.lightbox-caption { color: rgba(248,243,232,.65); margin-top: .75rem; font-family: var(--font-body); font-size: .9rem; font-style: italic; }
.lightbox-close, .lightbox-prev, .lightbox-next {
    position: absolute; background: rgba(201,168,76,.15);
    border: 1px solid rgba(201,168,76,.2); color: var(--color-cream);
    cursor: pointer; width: 44px; height: 44px; font-size: 1.4rem;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s;
    clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}
.lightbox-close:hover, .lightbox-prev:hover, .lightbox-next:hover { background: rgba(201,168,76,.3); }
.lightbox-close { top: 1.5rem; right: 1.5rem; clip-path: none; border-radius: 50%; }
.lightbox-prev { left: 1.5rem; top: 50%; transform: translateY(-50%); }
.lightbox-next { right: 1.5rem; top: 50%; transform: translateY(-50%); }

/* Gallery category cards (homepage teaser + gallery page) */
.gallery-categories {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-top: 2.5rem;
}
@media (max-width: 900px) { .gallery-categories { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .gallery-categories { grid-template-columns: 1fr; } }

.gallery-cat-card {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: var(--radius-md, 8px);
    aspect-ratio: 4/3;
    text-decoration: none;
}
.gallery-cat-card img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: transform .4s ease;
}
.gallery-cat-card:hover img { transform: scale(1.05); }
.gallery-cat-card:focus-visible { outline: 2px solid var(--color-gold); outline-offset: 3px; }

.gallery-cat-card__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(12,16,24,.82) 0%, rgba(12,16,24,.18) 55%, transparent 100%);
    display: flex; flex-direction: column; justify-content: flex-end;
    padding: 1rem;
}
.gallery-cat-card__name {
    display: block;
    font-family: var(--font-heading); font-size: .68rem; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--color-gold); margin-bottom: .2rem;
}
.gallery-cat-card__count {
    display: block;
    font-family: var(--font-body); font-size: .875rem;
    color: var(--color-cream);
}

/* "View All Photos" CTA below homepage teaser */
.gallery-cta { text-align: center; margin-top: 2rem; }

/* Gallery page breadcrumb */
.gallery-breadcrumb {
    margin-bottom: 1.5rem;
    font-family: var(--font-body); font-size: .875rem;
}
.gallery-breadcrumb a { color: var(--color-gold); }
.gallery-breadcrumb a:hover { text-decoration: underline; }

/* Gallery page category heading */
.gallery-page-heading {
    margin-bottom: 2rem;
}
.gallery-page-heading h1 {
    font-family: var(--font-heading); font-size: clamp(1.5rem, 3vw, 2.25rem);
    color: var(--color-cream); font-weight: 700;
}
.gallery-page-heading .gallery-page-count {
    font-family: var(--font-body); font-size: .875rem;
    color: rgba(248,243,232,.55); margin-top: .25rem;
}

/* Dark section text overrides for gallery teaser */
.gallery-section .section-label { color: var(--color-gold-light); }
.gallery-section .section-title { color: var(--color-cream); }
.gallery-section .divider::before,
.gallery-section .divider::after { background: var(--color-gold); }

/* Gallery dark section: empty-state notice uses gray (low contrast on navy) */
.gallery-section .gallery-empty-notice,
.gallery-section .gallery-empty-notice p { color: rgba(248,243,232,.65); }

/* Announcements dark section: dim-gold date is low contrast on navy */
.announcements .announce-date { color: var(--color-gold); }

/* =========================================================
   HOMILIES PREVIEW
========================================================= */
.homily-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5px;
    background: var(--color-gray-light);
    margin-top: 3rem;
}
@media (max-width: 900px) { .homily-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px)  { .homily-grid { grid-template-columns: 1fr; } }

.homily-card {
    background: var(--color-white);
    display: flex;
    flex-direction: column;
    transition: transform var(--transition), box-shadow var(--transition);
}
.homily-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }

.homily-thumb {
    aspect-ratio: 16 / 9;
    overflow: hidden;
    position: relative;
    background: var(--color-navy);
}
.homily-thumb img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform .5s ease;
}
.homily-card:hover .homily-thumb img { transform: scale(1.04); }

.homily-thumb-fallback {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    background: var(--grad-dark);
}

.homily-body {
    padding: 1.75rem 1.75rem 2rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    border-top: 2px solid var(--color-gold);
}

.homily-date {
    font-family: var(--font-heading);
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--color-gold-dim);
    margin-bottom: .6rem;
}

.homily-title {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.35;
    margin-bottom: .75rem;
}
.homily-title a {
    color: var(--color-navy);
    text-decoration: none;
    transition: color var(--transition);
}
.homily-title a:hover { color: var(--color-gold-dim); }

.homily-excerpt {
    font-family: var(--font-body);
    font-size: .875rem;
    line-height: 1.75;
    color: var(--color-gray);
    flex: 1;
    margin-bottom: 1.25rem;
}

.homily-read {
    font-family: var(--font-heading);
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--color-gold);
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    align-self: flex-start;
    transition: color var(--transition);
}
.homily-read::after { content: '→'; transition: transform var(--transition); }
.homily-read:hover { color: var(--color-gold-dim); }
.homily-read:hover::after { transform: translateX(3px); }

.homily-empty {
    text-align: center;
    padding: 3rem 1rem;
    font-family: var(--font-body);
    color: var(--color-gray);
    font-style: italic;
}

/* =========================================================
   FOOTER
========================================================= */
.site-footer {
    background: var(--color-navy);
    border-top: 1px solid rgba(201,168,76,.15);
    padding: 5rem 0 0;
}

/* Ornamental rule at top */
.footer-grid {
    display: grid; grid-template-columns: 1.8fr 1fr 1fr 1.2fr;
    gap: 3rem; margin-bottom: 3rem;
}
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; } }
@media (max-width: 560px)  { .footer-grid { grid-template-columns: 1fr; } }

.footer-logo .logo-img { width: 52px; height: 52px; }
.footer-brand p {
    font-family: var(--font-body); font-size: .875rem; line-height: 1.85;
    margin-top: 1.25rem; max-width: 280px; color: rgba(248,243,232,.45);
}

.footer-heading {
    font-family: var(--font-heading); color: var(--color-gold);
    font-size: .62rem; font-weight: 700; letter-spacing: .2em;
    text-transform: uppercase; margin-bottom: 1.5rem;
}

.footer-links li + li { margin-top: .75rem; }
.footer-links a {
    font-family: var(--font-body); color: rgba(248,243,232,.45);
    font-size: .875rem; display: flex; align-items: center;
    gap: .5rem; transition: color var(--transition);
}
.footer-links a::before { content: '›'; color: var(--color-gold-dim); font-size: 1rem; }
.footer-links a:hover { color: var(--color-gold-light); }

.footer-contact-item {
    display: flex; gap: .75rem; margin-bottom: 1rem;
    font-family: var(--font-body); font-size: .8125rem;
    color: rgba(248,243,232,.45); line-height: 1.65;
}
.footer-contact-item .icon { flex-shrink: 0; margin-top: .15rem; }
.footer-contact-item a { color: rgba(248,243,232,.45); transition: color var(--transition); }
.footer-contact-item a:hover { color: var(--color-gold-light); }

.footer-bottom {
    border-top: 1px solid rgba(201,168,76,.1); padding: 1.75rem 0;
    display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
    font-family: var(--font-heading); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase;
    color: rgba(248,243,232,.2);
}
.footer-bottom a { color: var(--color-gold-dim); }

/* Social links in footer */
.social-links { display: flex; gap: .75rem; margin-top: 1.25rem; }
.social-link {
    width: 42px; height: 42px;
    background: rgba(201,168,76,.1); color: var(--color-gold-light);
    display: flex; align-items: center; justify-content: center;
    transition: all var(--transition);
    clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.social-link:hover { background: var(--grad-gold); color: var(--color-navy) !important; transform: translateY(-2px); }

/* =========================================================
   SCROLL TO TOP
========================================================= */
.scroll-top {
    position: fixed; bottom: 2rem; right: 2rem;
    width: 46px; height: 46px; background: var(--grad-gold); color: var(--color-navy);
    border: none; cursor: pointer; font-size: 1.1rem;
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-gold); transition: all var(--transition);
    opacity: 0; visibility: hidden; z-index: 999;
    clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
    font-family: var(--font-heading); font-weight: 700;
}
.scroll-top.visible { opacity: 1; visibility: visible; }
.scroll-top:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(201,168,76,.5); }

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width: 640px) {
    .section { padding: 4rem 0; }
    .container { padding: 0 1.25rem; }
    .hero-stat { padding: 0 1.5rem; }
    .about-badge { right: 0; bottom: -1rem; }
    .about-features { grid-template-columns: 1fr; }
    .hero h1 { font-size: 2.25rem; }
}

/* =========================================================
   BEC (BASIC ECCLESIAL COMMUNITIES)
========================================================= */
.bec-group-heading {
    font-family: var(--font-heading);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--color-gold-dim);
    margin: 3rem 0 1.25rem;
    padding-bottom: .5rem;
    border-bottom: 1px solid var(--color-gold-pale);
}

.bec-zones-details {
    margin-top: 3rem;
}
.bec-zones-summary {
    font-family: var(--font-heading);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--color-gold-dim);
    padding-bottom: .5rem;
    border-bottom: 1px solid var(--color-gold-pale);
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    gap: .6rem;
    user-select: none;
}
.bec-zones-summary::-webkit-details-marker { display: none; }
.bec-zones-summary::after {
    content: '▸';
    font-size: .9rem;
    transition: transform .2s ease;
    margin-left: auto;
}
.bec-zones-details[open] .bec-zones-summary::after {
    transform: rotate(90deg);
}
.bec-zones-details .bec-zones-grid {
    margin-top: 1.25rem;
}

.bec-team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: .5rem;
}
.bec-team-card {
    background: var(--color-white);
    border: 1px solid var(--color-gray-light);
    border-top: 3px solid var(--color-gold);
    padding: 1.25rem 1.25rem 1rem;
}
.bec-team-role {
    font-family: var(--font-heading);
    font-size: .58rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--color-gold-dim);
    margin-bottom: .3rem;
}
.bec-team-name {
    font-family: var(--font-heading);
    font-size: .92rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: .4rem;
}
.bec-team-phone {
    font-family: var(--font-body);
    font-size: .8rem;
    color: var(--color-gray);
    display: block;
}
.bec-team-phone:hover { color: var(--color-gold-dim); }

.bec-zones-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}
@media (max-width: 900px) { .bec-zones-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px)  { .bec-zones-grid { grid-template-columns: 1fr; } }

.bec-zone-card {
    background: var(--color-white);
    border: 1px solid var(--color-gray-light);
    overflow: hidden;
}
.bec-zone-name {
    background: var(--color-navy);
    color: var(--color-gold-light);
    font-family: var(--font-heading);
    font-size: .64rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: .75rem 1rem;
}

.bec-list { list-style: none; margin: 0; padding: .25rem 0; }
.bec-item {
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--color-cream-dark);
    font-size: .84rem;
    line-height: 1.65;
}
.bec-item:last-child { border-bottom: none; }

.bec-item-saint {
    font-family: var(--font-heading);
    font-size: .82rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: .15rem;
}
.bec-item-area,
.bec-item-coord,
.bec-item-email {
    font-family: var(--font-body);
    color: var(--color-gray);
    font-size: .78rem;
}
.bec-item-coord a,
.bec-item-email a { color: var(--color-gold-dim); }
.bec-item-coord a:hover,
.bec-item-email a:hover { color: var(--color-gold); }

/* =========================================================
   SACRAMENT REQUEST FORM PAGE
========================================================= */
.sac-req-hero {
    background: var(--grad-dark);
    padding: 5rem 0 3.5rem;
    border-bottom: 2px solid rgba(201,168,76,.2);
}
.sac-req-hero h1 {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    color: var(--color-white);
    letter-spacing: .06em;
    margin: .5rem 0 1.25rem;
}
.sac-req-back {
    font-family: var(--font-heading);
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--color-gold-dim);
}
.sac-req-back:hover { color: var(--color-gold); }

.sac-req-body {
    padding: 3.5rem 2rem 5rem;
    max-width: 740px;
    margin-left: auto;
    margin-right: auto;
}

.sac-req-intro {
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--color-gray);
    line-height: 1.85;
    margin-bottom: 2.5rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--color-cream-dark);
}

.sac-req-notice {
    padding: 1rem 1.25rem;
    font-family: var(--font-body);
    font-size: .9rem;
    line-height: 1.7;
    margin-bottom: 2rem;
    border-left: 3px solid;
}
.sac-req-notice--error   { background: #fdf4f4; border-color: var(--color-crimson); color: var(--color-crimson); }
.sac-req-notice--error a { color: inherit; text-decoration: underline; }
.sac-req-notice--success {
    background: var(--color-cream-dark);
    border-color: var(--color-gold);
    color: var(--color-ink);
    text-align: center;
    padding: 3rem 2rem;
}
.sac-req-success-icon {
    width: 56px; height: 56px;
    background: var(--grad-gold);
    color: var(--color-navy);
    font-size: 1.5rem; font-weight: 700;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 1.25rem;
}
.sac-req-notice--success h2 {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    color: var(--color-navy);
    margin-bottom: .75rem;
}

/* Form fields — extend the existing cf-* system */
.sac-req-form { display: flex; flex-direction: column; gap: 0; }

.sac-req-field {
    display: flex; flex-direction: column; gap: .35rem;
    margin-bottom: 1.5rem;
}
.sac-req-label {
    font-family: var(--font-heading);
    font-size: .6rem; font-weight: 700;
    letter-spacing: .18em; text-transform: uppercase;
    color: var(--color-gray);
}
.sac-req-required { color: var(--color-gold-dim); margin-left: 2px; }

/* Reuse cf-input style */
.sac-req-input {
    font-family: var(--font-body); font-size: .9375rem; color: var(--color-ink);
    background: transparent; width: 100%; box-sizing: border-box;
    border: none; border-bottom: 1px solid var(--color-gray-light);
    padding: .5rem 0; outline: none;
    transition: border-color var(--transition);
}
.sac-req-input:focus  { border-bottom-color: var(--color-gold); }
.sac-req-input::placeholder { color: var(--color-gray-light); }
textarea.sac-req-input { resize: vertical; min-height: 100px; padding-top: .35rem; }
select.sac-req-input  { appearance: none; cursor: pointer; background: transparent; }

.sac-req-submit { margin-top: 1rem; display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.sac-req-note {
    font-family: var(--font-body); font-size: .75rem;
    color: var(--color-gray); font-style: italic;
}

/* =========================================================
   MINISTRY PROFILE PAGE
========================================================= */
.min-profile-body {
    padding: 3.5rem 2rem 5rem;
}

.min-profile-photo {
    margin-bottom: 3.5rem;
    text-align: center;
}
.min-profile-img {
    width: 100%; max-width: 860px;
    height: auto; max-height: 480px;
    object-fit: cover;
    border-top: 3px solid var(--color-gold);
    display: block; margin: 0 auto;
}
.min-profile-photo-caption {
    font-family: var(--font-heading); font-size: .62rem; font-weight: 600;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--color-gray); margin-top: .75rem;
}

.min-profile-heading {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 3vw, 1.75rem);
    font-weight: 700; letter-spacing: .05em;
    color: var(--color-navy);
    margin-bottom: 1.75rem;
    padding-bottom: .75rem;
    border-bottom: 1px solid var(--color-gold-pale);
}

.min-members-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.25rem;
}

.min-member-card {
    display: flex; align-items: flex-start; gap: 1.1rem;
    background: var(--color-white);
    border: 1px solid var(--color-gray-light);
    border-left: 3px solid var(--color-gold);
    padding: 1.25rem 1.25rem 1.25rem 1rem;
}
.min-member-avatar {
    width: 46px; height: 46px; flex-shrink: 0;
    background: var(--color-navy);
    color: var(--color-gold-light);
    font-family: var(--font-heading); font-size: 1.1rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}
.min-member-info { min-width: 0; }
.min-member-name {
    font-family: var(--font-heading); font-size: .9rem;
    font-weight: 700; letter-spacing: .03em;
    color: var(--color-navy); margin-bottom: .2rem;
}
.min-member-desig {
    font-family: var(--font-heading); font-size: .6rem; font-weight: 700;
    letter-spacing: .15em; text-transform: uppercase;
    color: var(--color-gold-dim); margin-bottom: .35rem;
}
.min-member-phone,
.min-member-email {
    font-family: var(--font-body); font-size: .78rem;
    color: var(--color-gray); display: block;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.min-member-phone:hover,
.min-member-email:hover { color: var(--color-gold-dim); }

/* =========================================================
   ENTRY CONTENT — post / CPT block spacing
========================================================= */
.entry-content {
    font-family: var(--font-body);
    font-size: 1.0625rem;
    line-height: 1.9;
    color: var(--color-gray);
}

/* Vertical rhythm: space between every block */
.entry-content > * + * { margin-top: 1.5rem; }

/* Tighter spacing after headings */
.entry-content > h1 + *,
.entry-content > h2 + *,
.entry-content > h3 + *,
.entry-content > h4 + * { margin-top: .875rem; }

/* Headings */
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
    font-family: var(--font-heading);
    color: var(--color-ink);
    line-height: 1.3;
    margin-top: 2.5rem;
}
.entry-content h2 { font-size: 1.5rem; }
.entry-content h3 { font-size: 1.25rem; }
.entry-content h4 { font-size: 1.05rem; letter-spacing: .02em; }

/* Lists */
.entry-content ul,
.entry-content ol {
    padding-left: 1.5rem;
}
.entry-content li + li { margin-top: .375rem; }

/* Images & figures */
.entry-content img {
    max-width: 100%; height: auto;
    border-radius: var(--radius-md);
    display: block;
}
.entry-content figure { margin: 2rem 0; }
.entry-content figcaption {
    font-size: .8125rem; font-style: italic;
    color: var(--color-gray); text-align: center;
    margin-top: .5rem;
}

/* Blockquote */
.entry-content blockquote {
    border-left: 3px solid var(--color-gold);
    padding: .875rem 1.25rem;
    background: rgba(201,168,76,.05);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    font-style: italic;
    color: var(--color-ink);
}
.entry-content blockquote cite {
    display: block;
    font-size: .8125rem;
    font-style: normal;
    color: var(--color-gold-dim);
    margin-top: .5rem;
}

/* Horizontal rule */
.entry-content hr {
    border: none;
    border-top: 1px solid var(--color-gray-light);
    margin: 2.5rem 0;
}

/* Tables */
.entry-content table {
    width: 100%; border-collapse: collapse;
    font-size: .9375rem;
}
.entry-content th,
.entry-content td {
    padding: .625rem .875rem;
    border: 1px solid var(--color-gray-light);
    text-align: left;
}
.entry-content th {
    background: var(--color-navy);
    color: var(--color-gold-light);
    font-family: var(--font-heading);
    font-size: .75rem; letter-spacing: .08em; text-transform: uppercase;
}
.entry-content tr:nth-child(even) td { background: rgba(0,0,0,.025); }

/* Gutenberg block spacing override */
.entry-content .wp-block-image,
.entry-content .wp-block-gallery,
.entry-content .wp-block-video,
.entry-content .wp-block-embed,
.entry-content .wp-block-table,
.entry-content .wp-block-group,
.entry-content .wp-block-cover { margin-top: 2rem; margin-bottom: 2rem; }

.entry-content .wp-block-separator { margin: 2.5rem 0; }

.entry-content .wp-block-buttons { margin-top: 2rem; gap: .75rem; }

/* ── Highlights Section ──────────────────────────────── */

.spp-highlights {
    border-top: 4px solid var(--color-gold);
}

/* ── Part 1: Permanent Highlight ── */
.spp-hl-wrap {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: 3rem;
    align-items: center;
    margin-bottom: 4rem;
}
.spp-hl-image {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    aspect-ratio: 16 / 9;
}
.spp-hl-img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
}
.spp-hl-label {
    color: var(--color-gold);
}
.spp-hl-title {
    font-family: var(--font-display);
    font-size: clamp(1.4rem, 3vw, 2.25rem);
    color: var(--color-cream);
    line-height: 1.25;
    margin: .5rem 0 1rem;
}
.spp-hl-excerpt {
    font-family: var(--font-body);
    color: var(--color-gray);
    font-size: 1rem;
    line-height: 1.7;
    margin-bottom: 1.25rem;
}
.spp-hl-date {
    display: inline-block;
    font-family: var(--font-heading);
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: 1.5rem;
}
.spp-hl-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.spp-hl-actions {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
}
.spp-hl-wrap--no-image {
    grid-template-columns: 1fr;
    max-width: 680px;
    margin-left: auto;
    margin-right: auto;
}
@media (max-width: 768px) {
    .spp-hl-wrap {
        grid-template-columns: 1fr;
        gap: 1.5rem;
        margin-bottom: 2.5rem;
    }
}

/* ── Part 2: Events Carousel ── */
.spp-carousel-header {
    display: flex;
    align-items: baseline;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}
.spp-carousel {
    position: relative;
    padding: 0 2rem;
}
.spp-carousel-track {
    display: flex;
    gap: 1rem;
    overflow-x: scroll;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: .5rem;
    align-items: stretch;
}
.spp-carousel-track::-webkit-scrollbar { display: none; }

.spp-carousel-card {
    flex-shrink: 0;
    width: 260px;
    scroll-snap-align: start;
    background: var(--color-navy-soft);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    text-decoration: none;
    color: inherit;
    transition: transform var(--transition), box-shadow var(--transition);
    display: flex;
    flex-direction: column;
}
.spp-carousel-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    color: inherit;
}
.spp-carousel-thumb {
    position: relative;
    height: 180px;
    overflow: hidden;
    background: var(--color-navy-mid);
    flex-shrink: 0;
}
.spp-carousel-thumb img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: transform var(--transition);
}
.spp-carousel-card:hover .spp-carousel-thumb img { transform: scale(1.04); }
.spp-carousel-thumb-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; opacity: .2; color: var(--color-cream);
}
.spp-carousel-date {
    position: absolute;
    bottom: .5rem; left: .5rem;
    font-family: var(--font-heading);
    font-size: .6rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    background: var(--color-gold);
    color: var(--color-navy);
    padding: .2rem .45rem;
    border-radius: var(--radius-sm);
}
.spp-carousel-body {
    padding: .875rem 1rem 1rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: .35rem;
}
.spp-carousel-title {
    font-family: var(--font-heading);
    font-size: .875rem;
    color: var(--color-cream);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.4;
}
.spp-carousel-excerpt {
    font-family: var(--font-body);
    font-size: .76rem;
    color: var(--color-gray);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.spp-carousel-more {
    flex-shrink: 0;
    scroll-snap-align: start;
    align-self: center;
    white-space: nowrap;
    margin-left: .5rem;
}
.spp-carousel-prev,
.spp-carousel-next {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    background: var(--color-navy-soft);
    border: 1px solid var(--color-gold-dim);
    color: var(--color-gold);
    width: 2.25rem; height: 2.25rem;
    border-radius: var(--radius-full);
    font-size: 1.25rem; line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background var(--transition), color var(--transition);
    z-index: 1;
}
.spp-carousel-prev:hover,
.spp-carousel-next:hover {
    background: var(--color-gold-dim);
    color: var(--color-cream);
}
.spp-carousel-prev { left: 0; }
.spp-carousel-next { right: 0; }
@media (max-width: 768px) {
    .spp-carousel        { padding: 0; }
    .spp-carousel-prev,
    .spp-carousel-next   { display: none; }
    .spp-carousel-card   { width: 78vw; }
}
@media (max-width: 560px) {
    .spp-carousel-excerpt { display: none; }
}

