/* =====================================================================
   VAG Church theme styles
   Identity derived from the church seal: royal blue + gold + cream.
   Display: Fraunces (serif) · Body: Mulish (sans)
   ===================================================================== */

:root {
	--blue-900:#022A5C;
	--blue:#023777;
	--blue-600:#0A4C9C;
	--blue-400:#2E6BB8;
	--gold:#F4A81E;
	--gold-600:#E0951A;
	--gold-200:#F6D58C;
	--cream:#F7EFD9;
	--cream-200:#FBF6EC;
	--ink:#1E2230;
	--muted:#5A6172;
	--line:rgba(2,55,119,.12);
	--white:#ffffff;

	--font-display:'Fraunces',Georgia,'Times New Roman',serif;
	--font-body:'Mulish',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

	--radius:16px;
	--radius-sm:10px;
	--shadow:0 18px 40px -24px rgba(2,42,92,.45);
	--shadow-sm:0 8px 20px -14px rgba(2,42,92,.5);
	--maxw:1140px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
	margin:0;
	font-family:var(--font-body);
	color:var(--ink);
	background:var(--white);
	line-height:1.65;
	font-size:17px;
	-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue-600);text-decoration:none}
a:hover{color:var(--gold-600)}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--blue);line-height:1.15;font-weight:600;margin:0 0 .5em}
p{margin:0 0 1rem}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:760px;margin-left:auto;margin-right:auto}
.section{padding:84px 0}
.section--cream{background:var(--cream)}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--gold);color:var(--blue-900);padding:10px 16px;z-index:1000}
.skip-link:focus{left:8px;top:8px}

/* ---------- Buttons ---------- */
.btn{
	display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
	font-family:var(--font-body);font-weight:700;font-size:.95rem;letter-spacing:.01em;
	padding:.85rem 1.6rem;border-radius:999px;border:2px solid transparent;cursor:pointer;
	transition:transform .15s ease,background .2s ease,color .2s ease,border-color .2s ease;
	text-align:center;line-height:1;
}
.btn:hover{transform:translateY(-2px)}
.btn--gold{background:var(--gold);color:var(--blue-900)}
.btn--gold:hover{background:var(--gold-600);color:var(--blue-900)}
.btn--blue{background:var(--blue);color:#fff}
.btn--blue:hover{background:var(--blue-600);color:#fff}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--ghost:hover{background:#fff;color:var(--blue);border-color:#fff}
.btn--ghost-blue{background:transparent;color:var(--blue);border-color:var(--line)}
.btn--ghost-blue:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn--sm{padding:.6rem 1.15rem;font-size:.85rem}
.btn--block{display:flex;width:100%}

/* ---------- Eyebrow + section heads ---------- */
.eyebrow{
	display:inline-flex;align-items:center;gap:.55rem;
	font-family:var(--font-body);font-weight:700;text-transform:uppercase;
	letter-spacing:.16em;font-size:.74rem;color:var(--gold-600);margin-bottom:.9rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}
.eyebrow--light{color:var(--gold-200)}
.eyebrow--light::before{background:var(--gold-200)}
.section-head{margin-bottom:48px}
.section-head--center{text-align:center}
.section-head--center .eyebrow::after{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}
.section-title{font-size:clamp(1.9rem,3.4vw,2.7rem);margin:0}
.section-title--light{color:#fff}
.section__cta{text-align:center;margin-top:42px}
.section__cta--left{text-align:left}

.vag-icon{width:1.25em;height:1.25em;flex:none}

/* ---------- Topbar ---------- */
.topbar{background:var(--blue-900);color:#dfe8f5;font-size:.84rem}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;min-height:42px;gap:1rem}
.topbar__contact{display:flex;gap:1.4rem;flex-wrap:wrap}
.topbar__contact a{color:#dfe8f5;display:inline-flex;align-items:center;gap:.4rem}
.topbar__contact a:hover{color:var(--gold-200)}
.topbar__contact .vag-icon{width:1rem;height:1rem}
.topbar__tag{color:var(--gold-200);font-weight:600;letter-spacing:.04em}

/* ---------- Header ---------- */
.site-header{background:#fff;position:sticky;top:0;z-index:100;box-shadow:0 1px 0 var(--line)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;min-height:84px;gap:1rem}
.brand__link{display:flex;align-items:center;gap:.85rem}
.brand__logo,.custom-logo{width:60px;height:60px;border-radius:50%;object-fit:cover;box-shadow:var(--shadow-sm)}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__name{font-family:var(--font-display);font-weight:700;font-size:1.35rem;color:var(--blue)}
.brand__sub{font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--gold-600);font-weight:700}

.primary-nav .nav-menu{list-style:none;display:flex;gap:.4rem;margin:0;padding:0;align-items:center}
.primary-nav a{
	display:block;padding:.6rem .95rem;border-radius:999px;color:var(--blue);font-weight:600;font-size:.96rem;
	transition:background .18s ease,color .18s ease;
}
.primary-nav a:hover,.primary-nav .current-menu-item>a{background:var(--cream);color:var(--blue)}
.primary-nav .menu-item-has-children{position:relative}
.primary-nav .sub-menu{
	list-style:none;margin:0;padding:.4rem;position:absolute;top:100%;left:0;min-width:200px;
	background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);
	opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s ease;z-index:50;
}
.primary-nav .menu-item-has-children:hover .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}

.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:0;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span{width:24px;height:2px;background:var(--blue);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
	position:relative;overflow:hidden;text-align:center;color:#fff;
	background:
		linear-gradient(180deg,rgba(2,42,92,.86),rgba(2,42,92,.94)),
		var(--hero-bg,radial-gradient(circle at 50% 0%,#0A4C9C,#022A5C));
	background-size:cover;background-position:center;
	padding:72px 0 0;
}
.hero__rays{
	position:absolute;inset:-30% -10% auto;height:120%;
	background:
		conic-gradient(from 180deg at 50% 0%,
			transparent 0deg,rgba(244,168,30,.10) 12deg,transparent 24deg,
			rgba(244,168,30,.10) 36deg,transparent 48deg,rgba(244,168,30,.08) 60deg,
			transparent 72deg,rgba(244,168,30,.10) 84deg,transparent 96deg);
	pointer-events:none;mix-blend-mode:screen;
}
.hero__inner{position:relative;z-index:2;padding-bottom:64px}
.hero__seal img{
	width:150px;height:150px;border-radius:50%;margin:0 auto 1.4rem;
	box-shadow:0 0 0 6px rgba(255,255,255,.12),0 24px 50px -20px rgba(0,0,0,.6);
}
.hero__eyebrow{color:var(--gold-200);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700;margin-bottom:.6rem}
.hero__title{color:#fff;font-size:clamp(2.6rem,6vw,4.4rem);margin:0 0 .3em;letter-spacing:-.01em}
.hero__verse{max-width:640px;margin:0 auto 2rem;font-family:var(--font-display);font-style:italic;font-size:clamp(1.05rem,2vw,1.35rem);color:#eaf1fb}
.hero__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero__strip{position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.12);background:rgba(2,30,66,.5)}
.hero__strip-inner{display:flex;justify-content:center;gap:2.4rem;flex-wrap:wrap;padding:18px 24px;font-weight:600;font-size:.92rem;color:#eaf1fb}
.hero__strip span{display:inline-flex;align-items:center;gap:.5rem}
.hero__strip .vag-icon{color:var(--gold-200)}

/* ---------- Welcome ---------- */
.welcome__grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:56px;align-items:center}
.welcome__frame{
	position:relative;border-radius:var(--radius);overflow:hidden;background:var(--cream);
	border:1px solid var(--line);box-shadow:var(--shadow);
}
.welcome__frame::before{content:"";position:absolute;inset:0;border:2px solid var(--gold);border-radius:var(--radius);margin:10px;pointer-events:none;opacity:.5}
.welcome__frame img{width:100%;aspect-ratio:1/1;object-fit:contain;padding:24px;background:radial-gradient(circle at 50% 40%,#fff,var(--cream))}
.welcome__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.welcome__stats div{background:var(--blue);color:#fff;border-radius:12px;padding:16px 10px;text-align:center}
.welcome__stats strong{display:block;font-family:var(--font-display);font-size:1.5rem;color:var(--gold-200)}
.welcome__stats span{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;opacity:.85}
.welcome__text p{color:var(--muted);font-size:1.05rem}
.welcome__text .btn{margin-top:.6rem}

/* ---------- Ministries ---------- */
.ministry-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px}
.ministry-card{
	background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 24px;text-align:center;
	transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden;
}
.ministry-card::after{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-200))}
.ministry-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.ministry-card__icon{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:var(--cream);color:var(--blue);margin-bottom:14px}
.ministry-card__icon .vag-icon{width:1.7rem;height:1.7rem}
.ministry-card__title{font-size:1.2rem;margin-bottom:.35rem}
.ministry-card__day{color:var(--gold-600);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;margin:0 0 .35rem}
.ministry-card__time{color:var(--muted);font-size:.95rem;margin:0}

/* ---------- Event cards ---------- */
.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px}
.event-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.event-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.event-card__media{position:relative;display:block;aspect-ratio:16/10;background:var(--cream);overflow:hidden}
.event-card__media img{width:100%;height:100%;object-fit:cover}
.event-card__placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--gold-600)}
.event-card__placeholder .vag-icon{width:2.4rem;height:2.4rem}
.event-card__date{position:absolute;top:12px;left:12px;background:var(--blue);color:#fff;border-radius:10px;padding:8px 12px;text-align:center;line-height:1;box-shadow:var(--shadow-sm)}
.event-card__date strong{display:block;font-family:var(--font-display);font-size:1.4rem;color:var(--gold-200)}
.event-card__date em{font-style:normal;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}
.event-card__body{padding:22px;display:flex;flex-direction:column;gap:.5rem;flex:1}
.event-card__title{font-size:1.25rem;margin:0}
.event-card__title a{color:var(--blue)}
.event-card__title a:hover{color:var(--gold-600)}
.event-card__meta{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}
.event-card__meta li{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.92rem}
.event-card__meta .vag-icon{color:var(--gold-600);width:1rem;height:1rem}
.event-card__excerpt{color:var(--muted);font-size:.95rem;margin:0}
.link-arrow{font-weight:700;color:var(--blue-600);margin-top:auto}
.link-arrow span{transition:transform .2s;display:inline-block}
.link-arrow:hover span{transform:translateX(4px)}

/* ---------- Visit CTA ---------- */
.visit-cta{background:linear-gradient(135deg,var(--blue),var(--blue-900));color:#fff;padding:64px 0}
.visit-cta__inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.visit-cta p{color:#dfe8f5;max-width:520px;margin:0}
.visit-cta .section-title{margin-bottom:.4rem}

/* ---------- Page hero ---------- */
.page-hero{padding:72px 0 56px;color:#fff;background:linear-gradient(135deg,var(--blue-600),var(--blue-900));position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-60px;top:-60px;width:260px;height:260px;border-radius:50%;border:2px solid rgba(244,168,30,.25)}
.page-hero__title{color:#fff;font-size:clamp(2.1rem,4.5vw,3.2rem);margin:0}
.page-hero__lead{color:#dfe8f5;max-width:640px;margin:.8rem 0 0;font-size:1.08rem}
.back-link{display:inline-block;color:var(--gold-200);font-weight:600;margin-bottom:1rem}
.back-link:hover{color:#fff}

/* ---------- Pastor + beliefs ---------- */
.pastor-card{max-width:760px;margin:0 auto;background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:36px;text-align:center}
.pastor-card h3{font-size:1.7rem;margin-bottom:.2rem}
.pastor-card__role{color:var(--gold-600);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;margin-bottom:1rem}
.pastor-card p{color:var(--muted);margin:0}
.beliefs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px}
.belief{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;text-align:center}
.belief__icon{display:inline-flex;width:54px;height:54px;border-radius:50%;background:var(--blue);color:var(--gold-200);align-items:center;justify-content:center;margin-bottom:12px}
.belief h4{font-size:1.1rem;margin-bottom:.4rem}
.belief p{color:var(--muted);font-size:.93rem;margin:0}

/* ---------- Service list ---------- */
.service-list{display:flex;flex-direction:column;gap:16px;max-width:920px;margin:0 auto}
.service-row{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 28px;transition:box-shadow .2s,transform .2s}
.service-row:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.service-row__icon{display:inline-flex;width:58px;height:58px;border-radius:50%;background:var(--cream);color:var(--blue);align-items:center;justify-content:center}
.service-row__icon .vag-icon{width:1.7rem;height:1.7rem}
.service-row__title{font-size:1.3rem;margin:0 0 .25rem}
.service-row__desc{color:var(--muted);margin:0;font-size:.96rem}
.service-row__when{text-align:right;min-width:200px}
.service-row__day{color:var(--gold-600);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;margin:0 0 .25rem}
.service-row__time{color:var(--blue);font-weight:700;margin:0;display:inline-flex;align-items:center;gap:.45rem;justify-content:flex-end}
.service-row__time .vag-icon{color:var(--gold-600);width:1rem;height:1rem}

/* ---------- Gallery ---------- */
.gallery-filter{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end;background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;margin-bottom:38px}
.gallery-filter__field{display:flex;flex-direction:column;gap:.35rem;min-width:160px;flex:1}
.gallery-filter__field label{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--blue)}
.gallery-filter select{padding:.65rem .8rem;border:1px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:.95rem;color:var(--ink)}
.gallery-filter__actions{display:flex;gap:.6rem;align-items:flex-end}

.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:26px}
.album{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s}
.album:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.album__cover{display:block;position:relative;width:100%;border:0;padding:0;cursor:pointer;aspect-ratio:4/3;background:var(--cream);overflow:hidden}
.album__cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.album__cover:hover img{transform:scale(1.05)}
.album__count{position:absolute;bottom:10px;right:10px;background:rgba(2,42,92,.85);color:#fff;font-size:.76rem;font-weight:700;padding:5px 10px;border-radius:999px}
.album__placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--gold-600)}
.album__placeholder .vag-icon{width:2.4rem;height:2.4rem}
.album__meta{padding:18px 20px}
.album__tag{display:inline-block;background:var(--cream);color:var(--blue);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border-radius:999px;margin-bottom:.5rem}
.album__title{font-size:1.18rem;margin:0 0 .2rem}
.album__date{color:var(--muted);font-size:.88rem;margin:0}
.album__data{display:none}

.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.photo-grid__item{border:0;padding:0;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:4/3;background:var(--cream)}
.photo-grid__item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.photo-grid__item:hover img{transform:scale(1.06)}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;background:rgba(2,18,42,.94);display:none;align-items:center;justify-content:center;z-index:1000;padding:24px}
.lightbox.is-open{display:flex}
.lightbox__figure{margin:0;max-width:min(1000px,92vw);max-height:86vh;text-align:center}
.lightbox__img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px;box-shadow:0 30px 60px -20px rgba(0,0,0,.7)}
.lightbox__cap{color:#cdd8ea;margin-top:.7rem;font-size:.92rem}
.lightbox__close{position:absolute;top:18px;right:22px;background:transparent;border:0;color:#fff;font-size:2.4rem;line-height:1;cursor:pointer}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:0;color:#fff;width:54px;height:54px;border-radius:50%;font-size:2rem;cursor:pointer;transition:background .2s}
.lightbox__nav:hover{background:var(--gold);color:var(--blue-900)}
.lightbox__prev{left:18px}
.lightbox__next{right:18px}
.lightbox__counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#cdd8ea;font-size:.85rem;font-weight:600}

/* ---------- Magazine ---------- */
.magazine-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:28px}
.magazine{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.magazine:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.magazine__cover{position:relative;aspect-ratio:3/4;background:linear-gradient(135deg,var(--blue-600),var(--blue-900));display:flex;align-items:center;justify-content:center;overflow:hidden}
.magazine__cover img{width:100%;height:100%;object-fit:cover}
.magazine__pdfmark{color:var(--gold-200);font-family:var(--font-display);font-weight:700;font-size:2rem;letter-spacing:.1em}
.magazine__body{padding:20px;display:flex;flex-direction:column;gap:.4rem;flex:1}
.magazine__title{font-size:1.15rem;margin:0}
.magazine__date{color:var(--gold-600);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin:0}
.magazine__excerpt{color:var(--muted);font-size:.92rem;margin:0}
.magazine__actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:auto;padding-top:.6rem}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:54px;align-items:start}
.contact-list{list-style:none;margin:1.4rem 0 0;padding:0;display:flex;flex-direction:column;gap:24px}
.contact-list li{display:flex;gap:16px}
.contact-list__icon{flex:none;width:50px;height:50px;border-radius:50%;background:var(--cream);color:var(--blue);display:inline-flex;align-items:center;justify-content:center}
.contact-list strong{display:block;color:var(--blue);margin-bottom:.15rem}
.contact-list p{margin:0;color:var(--muted)}
.contact-form-wrap{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:34px}
.contact-form{display:flex;flex-direction:column;gap:18px}
.form-row{display:flex;flex-direction:column;gap:.4rem}
.form-row--split{flex-direction:row;gap:18px}
.form-row--split>div{flex:1;display:flex;flex-direction:column;gap:.4rem}
.contact-form label{font-weight:700;font-size:.85rem;color:var(--blue)}
.contact-form input,.contact-form textarea{
	padding:.8rem .9rem;border:1px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:1rem;color:var(--ink);
}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--blue-400);box-shadow:0 0 0 3px rgba(46,107,184,.18)}
.vag-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{padding:14px 18px;border-radius:12px;margin-bottom:18px;font-weight:600}
.form-note--ok{background:#e7f6ec;color:#1c6b3a;border:1px solid #b9e3c8}
.form-note--err{background:#fdeceb;color:#a3271f;border:1px solid #f3c2bd}
.map-section{line-height:0}
.map-section iframe{display:block}

/* ---------- Single event ---------- */
.single-event{display:grid;grid-template-columns:1.6fr .8fr;gap:48px;align-items:start}
.single-event__media{border-radius:var(--radius);overflow:hidden;margin-bottom:26px;box-shadow:var(--shadow)}
.info-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:28px;position:sticky;top:110px}
.info-card h3{margin-bottom:1rem}
.info-card ul{list-style:none;margin:0 0 1.4rem;padding:0;display:flex;flex-direction:column;gap:.8rem}
.info-card li{display:flex;align-items:center;gap:.6rem;color:var(--ink)}
.info-card .vag-icon{color:var(--gold-600)}

/* ---------- Prose ---------- */
.prose{font-size:1.06rem;color:#2c313f}
.prose h2{font-size:1.7rem;margin-top:1.6em}
.prose h3{font-size:1.35rem;margin-top:1.4em}
.prose img{border-radius:var(--radius);margin:1.4em 0}
.prose ul,.prose ol{padding-left:1.3em}
.prose blockquote{border-left:4px solid var(--gold);background:var(--cream);padding:1rem 1.4rem;border-radius:0 12px 12px 0;font-family:var(--font-display);font-style:italic;color:var(--blue)}
.page-feature{border-radius:var(--radius);overflow:hidden;margin-bottom:2rem;box-shadow:var(--shadow)}
.post-list{display:flex;flex-direction:column;gap:34px}
.post-item{border-bottom:1px solid var(--line);padding-bottom:30px}
.post-item__meta{color:var(--gold-600);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em}

/* ---------- Pagination ---------- */
.pagination{display:flex;justify-content:center;margin-top:46px}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;margin:0 4px;border-radius:10px;border:1px solid var(--line);color:var(--blue);font-weight:700;text-decoration:none}
.pagination .page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue)}
.pagination .page-numbers:hover:not(.current){background:var(--cream)}
.nav-links{display:flex;flex-wrap:wrap;justify-content:center}

/* ---------- Empty state ---------- */
.empty-state{text-align:center;padding:60px 20px;color:var(--muted);background:var(--cream);border:1px dashed var(--line);border-radius:var(--radius)}
.empty-state .vag-icon{width:2.6rem;height:2.6rem;color:var(--gold-600);margin-bottom:.6rem}
.empty-state p{max-width:460px;margin:0 auto}

/* ---------- Footer ---------- */
.site-footer{background:var(--blue-900);color:#cdd8ea}
.site-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding:62px 0 44px}
.footer__logo{width:68px;height:68px;border-radius:50%;margin-bottom:1rem}
.footer__name{font-family:var(--font-display);font-size:1.3rem;color:#fff;margin:0 0 .3rem}
.footer__tag{font-size:.92rem;margin:0;color:#a9bbd6}
.footer-widget__title,.footer-col h4{color:#fff;font-size:1.05rem;margin-bottom:1rem}
.footer-col a{color:#cdd8ea}
.footer-col a:hover{color:var(--gold-200)}
.footer__address{font-style:normal;margin-bottom:.8rem;line-height:1.6}
.footer-menu,.footer__times{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.footer__times li{display:flex;justify-content:space-between;gap:1rem;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:.45rem}
.footer__times span{color:var(--gold-200);font-weight:600}
.footer__social{display:flex;gap:.6rem;margin-top:1.2rem}
.footer__social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff;text-transform:uppercase}
.footer__social a:hover{background:var(--gold);color:var(--blue-900)}
.site-footer__bar{border-top:1px solid rgba(255,255,255,.1);padding:18px 0;font-size:.86rem;color:#90a4c4;text-align:center}
.site-footer__bar p{margin:0}
.footer__admin{margin-left:14px;padding-left:14px;border-left:1px solid rgba(255,255,255,.2);color:#90a4c4}
.footer__admin:hover{color:var(--gold-200)}

/* ---------- Responsive ---------- */
@media (max-width:980px){
	.welcome__grid,.contact-grid,.single-event{grid-template-columns:1fr}
	.single-event__side{order:-1}
	.info-card{position:static}
	.site-footer__grid{grid-template-columns:1fr 1fr;gap:32px}
	.service-row{grid-template-columns:auto 1fr;gap:18px}
	.service-row__when{grid-column:1 / -1;text-align:left;min-width:0}
	.service-row__time{justify-content:flex-start}
}
@media (max-width:760px){
	.section{padding:60px 0}
	.nav-toggle{display:flex}
	.primary-nav{
		position:fixed;inset:0 0 0 auto;width:min(300px,82vw);background:#fff;
		transform:translateX(100%);transition:transform .28s ease;z-index:200;
		padding:90px 24px 24px;box-shadow:-20px 0 50px -30px rgba(0,0,0,.5);overflow-y:auto;
	}
	.primary-nav.is-open{transform:translateX(0)}
	.primary-nav .nav-menu{flex-direction:column;align-items:stretch;gap:.25rem}
	.primary-nav a{padding:.85rem 1rem}
	.primary-nav .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding-left:1rem}
	body.nav-open{overflow:hidden}
	.nav-backdrop{position:fixed;inset:0;background:rgba(2,18,42,.5);z-index:150;opacity:0;visibility:hidden;transition:.25s}
	.nav-backdrop.is-open{opacity:1;visibility:visible}
	.topbar__tag{display:none}
	.visit-cta__inner{flex-direction:column;align-items:flex-start}
	.form-row--split{flex-direction:column}
	.welcome__stats{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:480px){
	.site-footer__grid{grid-template-columns:1fr}
	.hero__strip-inner{gap:1rem}
	.welcome__stats strong{font-size:1.25rem}
}

/* ---------- Accessibility ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--gold);outline-offset:2px}
@media (prefers-reduced-motion:reduce){
	*{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}
