:root {
  --bg: #071410;
  --bg-soft: #0d1f19;
  --panel: rgba(255,255,255,0.06);
  --panel-2: rgba(255,255,255,0.08);
  --line: rgba(255,255,255,0.12);
  --text: #eef8f4;
  --muted: #a7c2b8;
  --brand: #58d39d;
  --brand-2: #b7f3d6;
  --accent: #f1d28a;
  --danger: #ff9689;
  --shadow: 0 20px 60px rgba(0,0,0,.28);
  --radius: 24px;
  --radius-sm: 18px;
  --max: 1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 10% 10%, rgba(88,211,157,.12), transparent 26%),
    radial-gradient(circle at 90% 0%, rgba(241,210,138,.08), transparent 22%),
    linear-gradient(180deg,#071410 0%, #0a1814 45%, #08120f 100%);
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
.container{width:min(calc(100% - 2rem),var(--max));margin:0 auto}
.topbar{
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  backdrop-filter:blur(10px);
}
.topbar-inner{
  min-height:44px; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  color:#d8ebe3; font-size:.92rem;
}
.topbar small{color:var(--muted)}
.site-header{position:sticky;top:0;z-index:30;background:rgba(7,20,16,.72);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.07)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:78px}
.brand{display:flex;align-items:center;gap:.9rem}
.brand img{width:52px;height:52px;border-radius:16px;box-shadow:var(--shadow)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{font-size:1rem}
.brand-text span{font-size:.82rem;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:1rem}
.nav-links a:not(.button){color:#dcece6;font-size:.95rem}
.menu-toggle{display:none;width:46px;height:46px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:#fff}
.button{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  min-height:48px;padding:.9rem 1.25rem;border-radius:999px;border:1px solid transparent;
  font-weight:800;background:linear-gradient(135deg,var(--brand),#35b57a);color:#07130f;
  box-shadow:0 12px 28px rgba(88,211,157,.22);
}
.button:hover{transform:translateY(-1px)}
.button-outline{background:transparent;border-color:rgba(255,255,255,.16);box-shadow:none;color:var(--text)}
.button-ghost{background:rgba(255,255,255,.04);color:var(--text);border-color:rgba(255,255,255,.08);box-shadow:none}
.button-sm{min-height:40px;padding:.7rem 1rem;font-size:.92rem}
.hero{padding:4.5rem 0 3.5rem;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
.eyebrow{display:inline-block;margin-bottom:1rem;padding:.45rem .72rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);font-size:.74rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-2)}
.hero h1,.section-head h2,.page-hero h1{margin:0;letter-spacing:-.045em;line-height:1.03}
.hero h1{font-size:clamp(2.6rem,5vw,5rem);max-width:11ch}
.hero p,.section-head p,.card p,.info-item p,.footer-copy p,.large-card p,.timeline p,.page-hero p,.mini-card p{line-height:1.75;color:var(--muted)}
.actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.5rem}
.check-list{list-style:none;padding:0;margin:1.6rem 0 0;display:grid;gap:.85rem}
.check-list li{display:flex;gap:.75rem;align-items:flex-start;color:#dcece6}
.check-list li::before{content:"";width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--accent));box-shadow:0 0 0 6px rgba(88,211,157,.08);margin-top:.45rem;flex:0 0 auto}
.hero-card,.card,.large-card,.mini-card,.contact-card,.visit-card,.timeline,.embed-card,.quote-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(14px)
}
.hero-card{padding:1.4rem}
.hero-map{
  aspect-ratio:1/1.06;border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    radial-gradient(circle at 30% 40%, rgba(88,211,157,.18), transparent 22%),
    linear-gradient(180deg,#143428,#0f241d 100%);
  position:relative;
}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);background-size:28px 28px;mask-image:linear-gradient(180deg,black,transparent)}
.map-pin{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:92px;height:92px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle, rgba(88,211,157,.26), rgba(88,211,157,.03));border:1px solid rgba(255,255,255,.08)}
.map-pin::before{content:"";width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--brand));box-shadow:0 0 0 10px rgba(255,255,255,.06)}
.map-caption{position:absolute;left:1rem;right:1rem;bottom:1rem;padding:1rem 1rem;border-radius:18px;background:rgba(6,14,11,.58);border:1px solid rgba(255,255,255,.08)}
.map-caption strong{display:block;font-size:1rem}
.map-caption span{display:block;color:var(--muted);margin-top:.3rem}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-top:1rem}
.stat{padding:1rem;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07)}
.stat strong{display:block;font-size:1.3rem}
.stat span{display:block;margin-top:.35rem;color:var(--muted);font-size:.9rem}
.section{padding:4.4rem 0}
.section.alt{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01))}
.section-head{max-width:780px;margin-bottom:1.8rem}
.section-head.center{text-align:center;margin-left:auto;margin-right:auto}
.grid-3,.grid-4,.grid-2{display:grid;gap:1rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{padding:1.35rem}
.card h3,.large-card h3,.mini-card h3,.contact-card h3,.visit-card h3,.embed-card h3{margin:.9rem 0 .4rem;font-size:1.2rem}
.icon-badge{width:50px;height:50px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg, rgba(88,211,157,.22), rgba(241,210,138,.14));font-size:1.3rem;border:1px solid rgba(255,255,255,.08)}
.schedule{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}
.schedule .card{min-height:180px}
.day{display:inline-flex;padding:.45rem .7rem;border-radius:999px;background:rgba(255,255,255,.06);font-size:.76rem;font-weight:800;color:#e3f6ef}
.time{display:block;margin-top:1rem;font-size:2rem;font-weight:900;letter-spacing:-.04em}
.highlight{border-color:rgba(88,211,157,.34);background:linear-gradient(180deg, rgba(88,211,157,.12), rgba(255,255,255,.04))}
.large-card{padding:1.4rem}
.large-card ul{padding-left:1.1rem;color:#dcece6;line-height:1.8}
.media-grid{display:grid;grid-template-columns:1fr .95fr;gap:1rem;align-items:start}
.embed-card iframe{width:100%;aspect-ratio:16/9;border:0;border-radius:18px;background:#000}
.embed-card{padding:1rem}
.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.mini-card{padding:1.2rem}
.quote-card{padding:1.4rem;display:flex;flex-direction:column;gap:.8rem}
.quote-card blockquote{margin:0;font-size:1.05rem;line-height:1.7;color:#dff1ea}
.quote-card cite{color:var(--muted);font-style:normal}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.visit-card{padding:1.35rem}
.visit-list{display:grid;gap:.9rem}
.visit-item{display:flex;gap:.9rem;align-items:flex-start;padding:.9rem;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.visit-item strong{display:block;margin-bottom:.18rem}
.page-hero{padding:3.2rem 0 1.5rem}
.breadcrumbs{display:flex;gap:.5rem;flex-wrap:wrap;color:var(--muted);font-size:.92rem;margin-bottom:1rem}
.breadcrumbs a{color:#d8ebe3}
.timeline{padding:1.3rem}
.timeline + .timeline{margin-top:1rem}
.timeline strong{display:block;font-size:1.08rem;margin-bottom:.4rem}
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:1rem}
.contact-card{padding:1.3rem}
.info-stack{display:grid;gap:.85rem;margin-top:1rem}
.info-item{padding:.95rem;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.info-item strong{display:block;margin-bottom:.25rem}
.form-grid{display:grid;gap:1rem}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
label span{display:block;font-size:.92rem;margin-bottom:.45rem;color:#dcece6}
input,textarea{
  width:100%;border-radius:16px;border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.04);color:var(--text);padding:1rem 1rem;
}
textarea{min-height:150px;resize:vertical}
.output{margin-top:1rem;padding:1rem;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);white-space:pre-wrap;color:#d8ebe3}
.footer{padding:1.4rem 0 2.2rem;border-top:1px solid rgba(255,255,255,.07)}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .9fr;gap:1rem;align-items:start}
.footer-copy{display:flex;gap:.9rem;align-items:flex-start}
.footer-copy img{width:52px;height:52px;border-radius:16px}
.footer-links,.social-links{display:grid;gap:.65rem}
.footer a{color:#dcece6}
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}
@media (max-width: 1050px){
  .hero-grid,.media-grid,.contact-grid,.visit-grid,.grid-3,.grid-4,.grid-2,.schedule,.footer-grid{grid-template-columns:1fr 1fr}
  .schedule{grid-template-columns:repeat(2,1fr)}
  .hero h1{max-width:none}
}
@media (max-width: 760px){
  .topbar{display:none}
  .menu-toggle{display:grid;place-items:center}
  .nav-links{
    position:absolute;top:88px;left:1rem;right:1rem;display:none;flex-direction:column;align-items:stretch;padding:1rem;
    background:rgba(8,18,15,.96);border:1px solid rgba(255,255,255,.08);border-radius:22px;box-shadow:var(--shadow)
  }
  .nav-links.open{display:flex}
  .hero{padding-top:3rem}
  .hero-grid,.media-grid,.contact-grid,.visit-grid,.footer-grid,.grid-3,.grid-4,.grid-2,.schedule,.form-row,.hero-stats,.mini-grid{grid-template-columns:1fr}
  .brand-text strong{font-size:.92rem}
  .button{width:100%}
}


.gallery{
padding:60px;
text-align:center;
}

.gallery-grid{
display:flex;
justify-content:center;
margin-top:20px;
}

.map{
padding:60px;
}

.prayer{
padding:60px;
text-align:center;
}


/* ===== PWA splash ===== */
.app-splash{
  position:fixed; inset:0; z-index:9999;
  display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(circle at 20% 20%, rgba(88,211,157,.14), transparent 24%),
    radial-gradient(circle at 80% 0%, rgba(241,210,138,.09), transparent 20%),
    linear-gradient(180deg,#071410 0%, #0a1814 60%, #08120f 100%);
  transition:opacity .45s ease, visibility .45s ease;
}
.app-splash.is-hidden{opacity:0; visibility:hidden; pointer-events:none}
.app-splash-card{
  text-align:center; padding:2rem 2.2rem; border-radius:30px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  box-shadow:0 20px 60px rgba(0,0,0,.3); backdrop-filter:blur(12px)
}
.app-splash-card img{
  width:108px; height:108px; object-fit:cover; border-radius:28px;
  margin:0 auto 1rem; box-shadow:0 14px 40px rgba(0,0,0,.25)
}
.app-splash-card strong{display:block; font-size:1.15rem}
.app-splash-card span{display:block; margin-top:.35rem; color:var(--muted); font-size:.95rem}

/* ===== map ===== */
.map-frame{
  overflow:hidden; border-radius:var(--radius); border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow); margin-top:1rem;
}
.map-frame iframe{display:block; width:100%; height:380px; border:0}

/* ===== instagram gallery ===== */
.instagram-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:1.2rem;
  margin-top:1.4rem;
}
.instagram-gallery > div{
  min-height:520px;
  border-radius:var(--radius-sm);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  box-shadow:var(--shadow);
  padding:.65rem;
}
.instagram-gallery .placeholder{
  display:flex; align-items:center; justify-content:center; text-align:center;
  padding:2rem; color:var(--muted); min-height:520px;
}
.note{
  color:var(--muted);
  font-size:.94rem;
  line-height:1.7;
}

/* prayer block */
.prayer-direct{
  display:grid;
  gap:1rem;
}
.prayer-direct .helper{
  color:var(--muted); font-size:.92rem;
}

@media (max-width: 720px){
  .app-splash-card{width:min(calc(100% - 2rem), 360px)}
  .instagram-gallery > div{min-height:460px}
}
