
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --gold:#C9A84C;--gold-light:#E2C26A;--gold-dark:#8B6914;
  --crimson:#7A0000;--dark:#0a0a0a;--dark2:#0f0505;--dark3:#140808;
  --text:#F0E6CC;--muted:#9A8060;--subtle:#6B5A40;
}
html{scroll-behavior:smooth;}
body{font-family:'Lato',sans-serif;background:var(--dark);color:var(--text);overflow-x:hidden;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:#0a0a0a;}
::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px;}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:100;height:90px;display:flex;align-items:center;padding:0 48px;justify-content:space-between;transition:all 0.5s ease;border-bottom:1px solid rgba(201,168,76,0.08);}
header.scrolled{background:rgba(8,0,0,0.92)!important;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom-color:rgba(201,168,76,0.25);box-shadow:0 4px 30px rgba(0,0,0,0.5);}
.logo-wrap{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0;}
#logoCanvas{width:68px;height:68px;filter:drop-shadow(0 0 8px rgba(201,168,76,0.4));transition:transform 0.3s;}
.logo-wrap:hover #logoCanvas{transform:scale(1.05);}
.logo-text p:first-child{font-family:'Cinzel',serif;font-size:13px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold-light);line-height:1.3;}
.logo-text p:last-child{font-family:'Cinzel',serif;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);line-height:1.3;}
nav{display:flex;align-items:center;gap:28px;}
.nav-link{font-family:'Cinzel',serif;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text);text-decoration:none;transition:color 0.3s;position:relative;}
.nav-link::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform 0.3s;}
.nav-link:hover,.nav-link.active{color:var(--gold-light);}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1);}
.actions{display:flex;gap:12px;}
.btn-give{padding:9px 20px;background:transparent;color:var(--gold-light);font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--gold);border-radius:2px;text-decoration:none;transition:all 0.3s;}
.btn-give:hover{background:var(--gold);color:var(--dark);}
.hamburger{display:none;width:40px;height:40px;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text);font-size:22px;}
.gold-line{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(201,168,76,0.6),transparent);opacity:0;transition:opacity 0.5s;}
header.scrolled .gold-line{opacity:1;}

/* MOBILE DRAWER */
.backdrop{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.7);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity 0.3s;}
.backdrop.open{opacity:1;pointer-events:auto;}
.drawer{position:fixed;top:0;right:0;bottom:0;z-index:201;width:min(320px,85vw);background:rgba(8,0,0,0.98);border-left:1px solid rgba(201,168,76,0.2);display:flex;flex-direction:column;transform:translateX(100%);transition:transform 0.35s ease;}
.drawer.open{transform:translateX(0);}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(201,168,76,0.15);}
.drawer-header span{font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold);}
.close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text);font-size:18px;}
.drawer-nav{flex:1;overflow-y:auto;padding:8px 0;}
.drawer-link{display:block;padding:14px 24px;font-family:'Cinzel',serif;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text);text-decoration:none;border-bottom:1px solid rgba(201,168,76,0.08);transition:all 0.2s;}
.drawer-link:hover,.drawer-link.active{color:var(--gold-light);padding-left:32px;}
.drawer-footer{padding:20px 24px;border-top:1px solid rgba(201,168,76,0.15);}
.drawer-give{display:block;text-align:center;padding:12px;background:var(--crimson);color:var(--gold-light);font-family:'Cinzel',serif;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--gold);border-radius:2px;text-decoration:none;}

/* PAGE HERO */
.page-hero{padding:160px 48px 72px;text-align:center;background:linear-gradient(180deg,rgba(122,0,0,0.12) 0%,transparent 100%);position:relative;}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(201,168,76,0.05),transparent);pointer-events:none;}
.page-hero-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.35em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:flex;align-items:center;justify-content:center;gap:12px;}
.page-hero-label::before,.page-hero-label::after{content:'';flex:1;max-width:60px;height:1px;}
.page-hero-label::before{background:linear-gradient(to right,transparent,var(--gold));}
.page-hero-label::after{background:linear-gradient(to left,transparent,var(--gold));}
.page-hero h1{font-family:'Cinzel',serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:600;color:var(--gold-light);letter-spacing:0.06em;margin-bottom:16px;}
.page-hero p{font-family:'Cormorant Garamond',serif;font-size:clamp(1rem,2vw,1.25rem);color:var(--muted);max-width:580px;margin:0 auto;}

/* FILTER PILLS */
.filters-wrap{padding:0 48px 48px;display:flex;justify-content:center;}
.filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;}
.filter-btn{font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;padding:8px 18px;border-radius:2px;background:transparent;color:var(--muted);border:1px solid rgba(201,168,76,0.18);cursor:pointer;transition:all 0.25s;}
.filter-btn:hover{color:var(--text);border-color:rgba(201,168,76,0.4);}
.filter-btn.active{background:rgba(201,168,76,0.12);color:var(--gold-light);border-color:rgba(201,168,76,0.5);}

/* GRID */
.ministries-section{padding:0 48px 80px;}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;list-style:none;}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.grid{grid-template-columns:1fr;}}

/* CARD */
.card{background:var(--dark2);border:1px solid rgba(201,168,76,0.15);border-radius:4px;overflow:hidden;cursor:pointer;transition:border-color 0.3s,box-shadow 0.3s,transform 0.3s;display:flex;flex-direction:column;animation:cardIn 0.45s ease both;}
@keyframes cardIn{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);}}
.card:hover{border-color:rgba(201,168,76,0.42);box-shadow:0 14px 42px rgba(0,0,0,0.55);transform:translateY(-4px);}
.card:focus-visible{outline:none;box-shadow:0 0 0 2px var(--dark),0 0 0 4px var(--gold);}

/* Card image area */
.card-img{position:relative;aspect-ratio:16/9;overflow:hidden;flex-shrink:0;}
/* Gradient fallback */
.card-img-bg{position:absolute;inset:0;transition:transform 0.55s ease;}
/* Actual photo */
.card-img-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 0.55s ease;}
.card:hover .card-img-bg,
.card:hover .card-img-photo{transform:scale(1.07);}
.card-img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.08) 30%,rgba(0,0,0,0.65) 100%);pointer-events:none;}
.card-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.card-icon svg{width:52px;height:52px;opacity:0.5;transition:opacity 0.3s,transform 0.3s;}
/* Hide icon when a real photo is present */
.card-img.has-photo .card-icon{display:none;}
.card:hover .card-icon svg{opacity:0.75;transform:scale(1.08);}
.card-badge{position:absolute;bottom:12px;left:14px;font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:0.22em;text-transform:uppercase;padding:3px 10px;border-radius:2px;border:1px solid;z-index:1;}

/* Card body */
.card-body{padding:22px 22px 26px;display:flex;flex-direction:column;gap:10px;flex:1;}
.card-name{font-family:'Cinzel',serif;font-size:1.05rem;font-weight:600;letter-spacing:0.05em;color:var(--gold-light);line-height:1.3;transition:color 0.25s;}
.card:hover .card-name{color:var(--gold);}
.card-desc{font-family:'Lato',sans-serif;font-size:0.875rem;color:var(--muted);line-height:1.7;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.card-meta{display:flex;align-items:center;gap:8px;font-family:'Cinzel',serif;font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:var(--subtle);}
.card-meta svg{flex-shrink:0;opacity:0.6;}
.card-cta{display:inline-flex;align-items:center;gap:6px;margin-top:6px;font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);transition:gap 0.25s,color 0.25s;}
.card:hover .card-cta{gap:11px;color:var(--gold-light);}

/* MODAL */
dialog{padding:0;border:none;background:transparent;max-width:min(820px,96vw);max-height:92vh;border-radius:6px;overflow:hidden;}
dialog::backdrop{background:rgba(0,0,0,0.82);backdrop-filter:blur(6px);}
.modal-inner{background:var(--dark2);border:1px solid rgba(201,168,76,0.22);border-radius:6px;overflow-y:auto;max-height:92vh;display:flex;flex-direction:column;}

/* Modal hero */
.modal-hero{position:relative;aspect-ratio:21/8;overflow:hidden;flex-shrink:0;}
/* Gradient fallback */
.modal-hero-bg{position:absolute;inset:0;}
/* Actual photo */
.modal-hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.modal-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.25),rgba(8,0,0,0.86));}
.modal-hero-content{position:absolute;bottom:0;left:0;right:0;padding:28px 36px;z-index:1;}
.modal-badge{display:inline-block;font-family:'Cinzel',serif;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;padding:4px 12px;border-radius:2px;border:1px solid;margin-bottom:12px;}
.modal-title{font-family:'Cinzel',serif;font-size:clamp(1.5rem,4vw,2.25rem);font-weight:600;color:var(--gold-light);letter-spacing:0.05em;line-height:1.2;}
.modal-tagline{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.1rem;color:var(--muted);margin-top:6px;}
.modal-close{position:absolute;top:16px;right:16px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.6);border:1px solid rgba(201,168,76,0.25);border-radius:50%;color:var(--text);font-size:18px;cursor:pointer;transition:all 0.2s;z-index:2;}
.modal-close:hover{background:rgba(201,168,76,0.15);color:var(--gold-light);}

/* Modal body */
.modal-body{padding:32px 36px;display:flex;flex-direction:column;gap:28px;}
.modal-desc{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--muted);line-height:1.85;}
.section-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.section-label::after{content:'';flex:1;height:1px;background:linear-gradient(to right,rgba(201,168,76,0.4),transparent);}
.modal-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:540px){.modal-info-grid{grid-template-columns:1fr;}}
.info-card{background:rgba(201,168,76,0.04);border:1px solid rgba(201,168,76,0.12);border-radius:3px;padding:16px 18px;display:flex;flex-direction:column;gap:6px;}
.info-card-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:0.25em;text-transform:uppercase;color:var(--gold);}
.info-card-value{font-size:0.9rem;color:var(--text);line-height:1.6;white-space:pre-line;}
.modal-leader-row{display:flex;align-items:center;gap:18px;padding:18px 20px;background:rgba(201,168,76,0.04);border:1px solid rgba(201,168,76,0.12);border-radius:3px;}
/* Leader photo or initial avatar */
.leader-avatar{width:60px;height:60px;border-radius:50%;border:2px solid rgba(201,168,76,0.35);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Cinzel',serif;font-size:20px;color:var(--gold-light);background:linear-gradient(135deg,var(--dark3),rgba(201,168,76,0.2));overflow:hidden;}
.leader-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.leader-name{font-family:'Cinzel',serif;font-size:14px;letter-spacing:0.08em;color:var(--gold-light);}
.leader-role{font-size:12px;color:var(--muted);margin-top:3px;}
.modal-events-list{display:flex;flex-direction:column;gap:10px;}
.event-item{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;background:rgba(201,168,76,0.04);border:1px solid rgba(201,168,76,0.1);border-radius:3px;}
.event-date-box{flex-shrink:0;width:44px;text-align:center;background:rgba(122,0,0,0.3);border:1px solid rgba(122,0,0,0.5);border-radius:3px;padding:6px 4px;}
.event-date-mo{font-family:'Cinzel',serif;font-size:8px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gold);}
.event-date-day{font-family:'Cinzel',serif;font-size:1.4rem;font-weight:700;color:var(--gold-light);line-height:1;}
.event-title{font-family:'Cinzel',serif;font-size:12px;letter-spacing:0.06em;color:var(--text);}
.event-time{font-size:12px;color:var(--muted);margin-top:3px;}
.modal-cta{display:flex;gap:12px;flex-wrap:wrap;padding-top:4px;}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:var(--crimson);color:var(--gold-light);font-family:'Cinzel',serif;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--gold);border-radius:2px;cursor:pointer;transition:all 0.3s;}
.btn-primary:hover{background:var(--gold);color:var(--crimson);}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:transparent;color:var(--gold-light);font-family:'Cinzel',serif;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;border:1px solid rgba(201,168,76,0.35);border-radius:2px;cursor:pointer;transition:all 0.3s;}
.btn-secondary:hover{background:rgba(201,168,76,0.1);}

/* FOOTER */
footer{background:var(--dark2);border-top:1px solid rgba(201,168,76,0.15);padding:40px 48px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;}
.footer-brand{font-family:'Cinzel',serif;font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gold-light);}
.footer-info{font-size:12px;color:var(--muted);text-align:center;line-height:1.8;}
.footer-info a{color:var(--muted);text-decoration:none;}
.footer-info a:hover{color:var(--gold-light);}
.footer-copy{font-size:11px;color:var(--subtle);}

@media(max-width:768px){
  header{padding:0 20px;height:70px;}
  header nav{display:none;}
  .hamburger{display:flex;}
  .page-hero{padding:120px 24px 56px;}
  .filters-wrap{padding:0 24px 36px;}
  .ministries-section{padding:0 24px 60px;}
  footer{flex-direction:column;text-align:center;padding:32px 24px;}
  .modal-hero-content{padding:20px 22px;}
  .modal-body{padding:22px 22px;}
}
