/* Mega Life Chapel — "The Royal Citadel". Midnight + royal gold, regal serif display. */
:root{
  --ink:#0b0a1f;        /* midnight */
  --ink-2:#14112e;      /* deep royal */
  --ink-3:#1d1840;
  --gold:#d4af37;
  --gold-2:#f0d27a;
  --gold-soft:#bda04a;
  --ivory:#f7f4ec;
  --ivory-2:#ece6d6;
  --purple:#4a2c8f;
  --muted:#a39fc2;
  --line:rgba(212,175,55,.22);
  --maxw:1180px;
  --r:18px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Sora',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--ink);color:var(--ivory);font-family:var(--sans);
  font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.skip{position:absolute;left:-999px}
.skip:focus{left:12px;top:12px;background:var(--gold);color:var(--ink);padding:8px 14px;border-radius:8px;z-index:99}

h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;margin:0 0 .4em}
h1{font-size:clamp(2.6rem,7vw,5.4rem);letter-spacing:-.02em}
h2{font-size:clamp(2rem,4.5vw,3.2rem);letter-spacing:-.015em}
h3{font-size:1.5rem}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);margin-bottom:1rem;display:inline-block}
.lead{font-size:1.18rem;color:#d8d4ea;max-width:60ch}
.gold{color:var(--gold-2)}
.serif{font-family:var(--serif)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:500;
  font-size:.95rem;padding:.85em 1.7em;border-radius:100px;transition:.25s;cursor:pointer;border:1px solid transparent}
.btn-gold{background:linear-gradient(120deg,var(--gold),var(--gold-2));color:#1a1405;
  box-shadow:0 8px 30px -8px rgba(212,175,55,.6)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 40px -10px rgba(212,175,55,.7)}
.btn-ghost{border-color:var(--line);color:var(--ivory)}
.btn-ghost:hover{border-color:var(--gold);background:rgba(212,175,55,.08)}

/* top service bar */
.topbar{position:fixed;top:0;left:0;right:0;z-index:48;background:#100d28;border-bottom:1px solid var(--line)}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;height:38px;font-size:.78rem;gap:1rem}
.tb-svc{color:var(--gold-2);font-weight:500;letter-spacing:.03em}
.tb-loc{color:#bdb9d6;transition:.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-loc:hover{color:var(--gold-2)}

/* nav */
.nav{position:fixed;top:38px;left:0;right:0;z-index:50;transition:.3s;
  background:linear-gradient(to bottom,rgba(11,10,31,.92),rgba(11,10,31,.35));backdrop-filter:blur(6px)}
.nav.scrolled{top:0;background:rgba(11,10,31,.95);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
@media(max-width:680px){.topbar{display:none}.nav{top:0}}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-logo{width:44px;height:44px;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text b{font-family:var(--serif);font-weight:600;font-size:1.15rem;letter-spacing:.01em}
.brand-text i{font-style:normal;font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-soft);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:1.9rem}
.nav-links a{font-size:.92rem;font-weight:400;color:#cfcbe6;transition:.2s;position:relative}
.nav-links a:not(.btn):hover{color:var(--gold-2)}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--gold);transition:.25s}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-give{padding:.6em 1.4em}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:2px;background:var(--gold);transition:.3s}

/* hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;
  background:linear-gradient(100deg,rgba(11,10,31,.96) 0%,rgba(20,17,46,.86) 44%,rgba(11,10,31,.55) 100%),
    url('/media/chapel/site/hero.jpg');
  background-size:cover;background-position:center 30%}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(40% 50% at 80% 30%,rgba(212,175,55,.18),transparent 70%),
  radial-gradient(30% 40% at 12% 80%,rgba(74,44,143,.4),transparent 70%);pointer-events:none}
.hero::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E")}
.hero-inner{position:relative;z-index:2;padding:120px 0 80px}
.hero h1{margin-bottom:.3em}
.hero .lead{margin:0 0 2.2rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-verse{margin-top:3rem;padding-left:1.2rem;border-left:2px solid var(--gold);
  font-family:var(--serif);font-style:italic;font-size:1.15rem;color:#d9d4ef;max-width:46ch}
.crest-watermark{position:absolute;right:-4%;top:50%;transform:translateY(-50%);font-size:38rem;
  line-height:1;color:rgba(212,175,55,.05);z-index:1;pointer-events:none;font-family:var(--serif)}

/* sections */
section{position:relative}
.band{padding:clamp(70px,10vw,130px) 0}
.band-soft{background:linear-gradient(var(--ink),var(--ink-2))}
.center{text-align:center}
.center .lead{margin-inline:auto}
.divider{width:60px;height:2px;background:linear-gradient(90deg,var(--gold),transparent);margin:0 0 1.4rem}
.center .divider{margin-inline:auto;background:linear-gradient(90deg,transparent,var(--gold),transparent)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* pillars (mission/vision/objectives) */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.pillar{background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);border-radius:var(--r);padding:2rem;transition:.3s}
.pillar:hover{transform:translateY(-4px);border-color:var(--gold);background:rgba(212,175,55,.05)}
.pillar h3{color:var(--gold-2)}
.pillar .num{font-family:var(--serif);font-size:2.4rem;color:var(--gold-soft);opacity:.5;line-height:1}

/* cards grid (pastors, sermons, events) */
.grid{display:grid;gap:1.5rem;margin-top:3rem}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.3s}
.card:hover{transform:translateY(-5px);border-color:var(--gold-soft);box-shadow:0 24px 50px -20px rgba(0,0,0,.6)}
.pcard .ph{aspect-ratio:3/4;overflow:hidden;background:var(--ink-3)}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.pcard:hover .ph img{transform:scale(1.05)}
.pcard .body{padding:1.2rem 1.3rem 1.5rem}
.pcard h3{font-size:1.25rem;margin-bottom:.1em}
.pcard .role{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}

/* compact pastor team (circular avatars) */
.pteam{display:flex;flex-wrap:wrap;justify-content:center;gap:2.6rem 2.2rem;margin-top:3rem}
.pmember{width:158px;text-align:center}
.pmember .avatar{width:142px;height:142px;border-radius:50%;margin:0 auto 1rem;padding:5px;
  background:linear-gradient(150deg,var(--gold-soft),transparent 60%);transition:.35s}
.pmember:hover .avatar{transform:translateY(-5px);background:linear-gradient(150deg,var(--gold-2),var(--gold-soft))}
.pmember .avatar span{display:block;width:100%;height:100%;border-radius:50%;overflow:hidden;
  border:1px solid var(--ink);background:var(--ink-3)}
.pmember .avatar img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.pmember h3{font-size:1.02rem;margin:0 0 .15em}
.pmember .role{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.pmember .pbio{font-size:.84rem;color:var(--muted);margin-top:.5rem}
@media(max-width:560px){.pteam{gap:2rem 1.4rem}.pmember{width:132px}.pmember .avatar{width:118px;height:118px}}

.scard .thumb{aspect-ratio:16/9;background:var(--ink-3);position:relative;overflow:hidden}
.scard .thumb img{width:100%;height:100%;object-fit:cover}
.scard .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:2.4rem;color:#fff;background:rgba(11,10,31,.25);transition:.3s}
.scard:hover .play{background:rgba(11,10,31,.1)}
.scard .body{padding:1.2rem 1.3rem 1.4rem}
.scard .meta{font-size:.78rem;color:var(--gold);letter-spacing:.08em;text-transform:uppercase}
.scard h3{font-size:1.15rem;margin:.3em 0}

.ecard{display:flex;gap:1.3rem;align-items:center;background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--r);padding:1.3rem 1.5rem;transition:.3s}
.ecard:hover{border-color:var(--gold-soft);transform:translateX(4px)}
.ecard .date{flex:0 0 78px;text-align:center;font-family:var(--serif)}
.ecard .date .d{font-size:2rem;color:var(--gold-2);line-height:1}
.ecard .date .m{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.ecard h3{font-size:1.2rem;margin:0}
.ecard .loc{font-size:.9rem;color:var(--muted)}

/* departments chips */
.dept-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2.5rem}
.dept{border:1px solid var(--line);border-radius:14px;padding:1.4rem 1.5rem;background:rgba(255,255,255,.02);transition:.3s}
.dept:hover{border-color:var(--gold);background:rgba(212,175,55,.05)}
.dept h4{font-family:var(--serif);font-size:1.2rem;color:var(--gold-2);margin:0 0 .2em}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem;margin-top:3rem}
.gallery a{position:relative;display:block;aspect-ratio:4/3;overflow:hidden;border-radius:12px;
  border:1px solid var(--line)}
.gallery a img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(11,10,31,.55));opacity:0;transition:.3s}
.gallery a:hover img{transform:scale(1.07)}
.gallery a:hover::after{opacity:1}
.gallery .cap{position:absolute;left:12px;bottom:10px;z-index:2;font-size:.78rem;color:var(--gold-2);
  opacity:0;transform:translateY(6px);transition:.3s}
.gallery a:hover .cap{opacity:1;transform:none}
.gallery.feature a:first-child{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}.gallery.feature a:first-child{grid-column:span 2;grid-row:auto;aspect-ratio:4/3}}

/* department editorial rows */
.dept-row{padding:2.2rem 0;border-bottom:1px solid var(--line)}
.dept-row:first-child{padding-top:0}
.dept-row-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.9rem}
.dept-row-head h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:0;color:var(--gold-2)}
.dept-mail{font-size:.85rem;color:var(--gold-soft);border:1px solid var(--line);padding:.4em 1em;border-radius:100px;transition:.2s}
.dept-mail:hover{border-color:var(--gold);color:var(--gold-2)}
.dept-body{color:#d4d0e8;font-size:1.04rem;max-width:70ch;margin:0}

/* split / about */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center}
.split .art{aspect-ratio:4/5;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);position:relative}
.split .art img{width:100%;height:100%;object-fit:cover}
.frame-gold{position:relative}
.frame-gold::after{content:"";position:absolute;inset:14px;border:1px solid rgba(212,175,55,.5);border-radius:10px;pointer-events:none}

/* social icons */
.sicon{width:15px;height:15px;fill:currentColor;flex:0 0 auto;vertical-align:-2px;margin-right:.5em}
.stile-name{display:inline-flex;align-items:center}
.foot-social a{display:flex;align-items:center}

/* streamlined Partner With Us CTA */
.give-cta{background:linear-gradient(105deg,#241d52,var(--ink-2));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.give-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;
  padding:clamp(2.5rem,6vw,4rem) 0;flex-wrap:wrap}
.give-cta-inner h2{margin:.2rem 0 0;font-size:clamp(1.8rem,3.5vw,2.6rem)}
.give-cta-inner .gtext{max-width:48ch;color:#cfcbe6;margin:.6rem 0 0;font-size:1.02rem}

/* forms */
.form{max-width:560px;margin:2.5rem auto 0;display:grid;gap:1rem}
.form input,.form textarea,.form select{width:100%;padding:.95em 1.1em;background:rgba(255,255,255,.04);
  border:1px solid var(--line);border-radius:12px;color:var(--ivory);font-family:var(--sans);font-size:1rem}
.form textarea{min-height:140px;resize:vertical}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--gold)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.note{font-size:.85rem;color:var(--muted)}
.flash{padding:.9em 1.2em;border-radius:12px;background:rgba(212,175,55,.12);border:1px solid var(--gold);margin-top:1rem}

/* embeds */
.embed{aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.embed iframe{width:100%;height:100%;border:0}
.embed.audio{aspect-ratio:auto;height:200px}

/* watch & connect */
.watch-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:2.5rem;margin-top:3rem;align-items:start}
.connect h3{color:var(--gold-2);font-size:1.5rem}
.connect .note{margin:.3rem 0 1.2rem}
.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-top:1.5rem}
.stile{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.85em 1.1em;
  border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.025);transition:.25s}
.stile:hover{border-color:var(--gold);background:rgba(212,175,55,.07);transform:translateY(-2px)}
.stile-name{font-size:.9rem;color:#e6e2f4}
.stile-go{color:var(--gold);font-size:.85rem}
@media(max-width:900px){.watch-grid{grid-template-columns:1fr}}
@media(max-width:560px){.social-grid{grid-template-columns:1fr}}

/* verse-of-the-day popup */
.verse-pop{position:fixed;right:20px;bottom:20px;z-index:60;max-width:340px;
  background:linear-gradient(155deg,var(--ink-3),var(--ink-2));border:1px solid var(--gold-soft);
  border-radius:16px;padding:1.5rem 1.6rem;box-shadow:0 30px 70px -20px rgba(0,0,0,.8);
  transform:translateY(140%);opacity:0;transition:.55s cubic-bezier(.2,.8,.2,1)}
.verse-pop.show{transform:none;opacity:1}
.verse-x{position:absolute;top:8px;right:12px;background:none;border:0;color:var(--muted);
  font-size:1.4rem;cursor:pointer;line-height:1;transition:.2s}
.verse-x:hover{color:var(--gold-2)}
.verse-eyebrow{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.verse-text{font-family:var(--serif);font-style:italic;font-size:1.12rem;line-height:1.45;
  color:#ece8f8;margin:.6rem 0 .5rem}
.verse-ref{font-size:.85rem;color:var(--gold-2);font-weight:500}
@media(max-width:560px){.verse-pop{right:12px;left:12px;bottom:12px;max-width:none}}

/* This Sunday — weekly flyer banner */
.flyer-band{background:radial-gradient(70% 110% at 50% 0%,#241d52,var(--ink-2))}
.flyer-wrap{display:grid;grid-template-columns:auto 1fr;gap:3rem;align-items:center;
  margin-top:3rem;max-width:900px;margin-inline:auto}
.flyer-frame{display:block;border-radius:16px;overflow:hidden;border:1px solid var(--gold-soft);
  padding:8px;background:linear-gradient(160deg,rgba(212,175,55,.28),rgba(255,255,255,.02));
  box-shadow:0 30px 70px -30px rgba(0,0,0,.7);transition:.3s;max-width:330px}
.flyer-frame:hover{transform:translateY(-4px);border-color:var(--gold)}
.flyer-frame img{width:100%;border-radius:10px;display:block}
.flyer-info h3{font-size:clamp(1.5rem,3vw,2rem);color:var(--gold-2);margin:.4rem 0 1.3rem}
.flyer-meta{list-style:none;padding:0;margin:0 0 1.7rem;display:grid;gap:1rem}
.flyer-meta li{display:grid;gap:.2rem}
.flyer-meta span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.flyer-meta b{font-weight:400;color:#e6e2f4;font-size:1.05rem}
.flyer-cta{display:flex;gap:.8rem;flex-wrap:wrap}
@media(max-width:760px){.flyer-wrap{grid-template-columns:1fr;justify-items:center;text-align:center}
  .flyer-frame{max-width:300px}.flyer-meta{justify-items:center}.flyer-cta{justify-content:center}}

/* seamless gallery carousel (auto-scrolling marquee, contained, size-aware) */
.carousel{overflow:hidden;padding:.5rem 0;
  -webkit-mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.carousel-track{display:flex;gap:1rem;width:max-content;animation:cscroll 55s linear infinite}
.carousel:hover .carousel-track{animation-play-state:paused}
@keyframes cscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.gcard{position:relative;flex:0 0 auto;width:clamp(210px,24vw,290px);aspect-ratio:4/3;
  border-radius:14px;overflow:hidden;border:1px solid var(--line);text-decoration:none}
.gcard img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gcard:hover img{transform:scale(1.07)}
.gcard::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(11,10,31,.7))}
.gcap{position:absolute;left:13px;bottom:11px;z-index:2;font-size:.8rem;color:var(--gold-2);
  letter-spacing:.02em;text-shadow:0 1px 5px rgba(0,0,0,.7)}
@media(prefers-reduced-motion:reduce){.carousel-track{animation:none;overflow-x:auto}}

/* page hero (inner pages) */
.phero{padding:160px 0 60px;background:radial-gradient(90% 100% at 50% -10%,#241d52,var(--ink));text-align:center}
.prose{max-width:70ch;margin:0 auto;color:#d8d4ea}
.prose p{margin:0 0 1.1em}

/* footer */
.foot{background:linear-gradient(var(--ink-2),var(--ink));border-top:1px solid var(--line);padding:80px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2.5rem;align-items:start}
.foot-social{display:grid;grid-template-columns:1fr 1fr;gap:0 1.4rem}
.foot-logo{width:96px;height:96px;object-fit:contain;margin-bottom:1.1rem}
.foot-brand p{color:var(--muted);font-size:.92rem;max-width:32ch;margin:.2rem 0}
.foot-addr{color:var(--gold-soft)!important;margin-top:.6rem!important}
.foot-col h4{font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:.2rem 0 1.1rem}
.foot-col a{display:block;color:#bdb9d6;font-size:.92rem;padding:.36rem 0;transition:.2s}
.foot-col a:hover{color:var(--gold-2);padding-left:4px}
.foot-base{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  margin-top:3.5rem;padding-top:1.6rem;border-top:1px solid var(--line);color:var(--muted);font-size:.82rem}

/* responsive */
@media(max-width:900px){
  .pillars,.dept-grid,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:2rem}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{position:fixed;inset:76px 0 auto 0;flex-direction:column;gap:0;background:rgba(11,10,31,.98);
    backdrop-filter:blur(16px);border-bottom:1px solid var(--line);padding:1rem 22px 1.6rem;
    transform:translateY(-130%);transition:.35s;align-items:stretch}
  body.menu-open .nav-links{transform:none}
  .nav-links a{padding:.9rem 0;border-bottom:1px solid rgba(255,255,255,.05)}
  .nav-give{margin-top:.8rem;text-align:center;justify-content:center}
  .nav-toggle{display:flex}
  .pillars,.dept-grid,.grid.cols-3,.grid.cols-4,.foot-grid{grid-template-columns:1fr}
  .crest-watermark{font-size:20rem;opacity:.5}
  .form .row{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
