:root{
--cream:#f7f3ed;--charcoal:#2b2b2b;--sage:#8fa99b;--brick:#b46a55;
--accent: var(--brick);
--accent2: var(--sage);
}
/* Seasonal overrides */
body.season-christmas{ --accent:#b46a55; --accent2:#2f6b4f; }
body.season-newyear{ --accent:#2b2b2b; --accent2:#8fa99b; }
body.season-easter{ --accent:#8fa99b; --accent2:#b46a55; }

body{
margin:0;
font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
background:var(--cream);
color:var(--charcoal);
font-size:18px;
line-height:1.6;
}
.nav{
display:flex;justify-content:space-between;align-items:center;
padding:1rem 2rem;border-bottom:2px solid var(--accent2);
background:#fff;position:relative;
}
.brand{display:flex;align-items:center;gap:.75rem;font-weight:600;}
.brand img{height:54px;}
.nav ul{list-style:none;display:flex;gap:1.2rem;margin:0;padding:0;flex-wrap:wrap;}
.nav a{text-decoration:none;color:var(--charcoal);}
.menu-toggle{display:none;font-size:1.9rem;background:none;border:none;color:var(--charcoal);cursor:pointer;}
.banner{background:var(--accent);color:#fff;padding:1rem;text-align:center;font-weight:600;}
.hero{text-align:center;padding:4rem 1rem;}
.verse{font-style:italic;max-width:900px;margin:2rem auto;color:#444;}
.subtitle{font-size:1.2rem;margin-top:1rem;}
.btn{background:var(--accent);padding:.9rem 2rem;border-radius:4px;color:#fff;text-decoration:none;font-weight:600;display:inline-block;margin-top:1rem;}
.section{max-width:1000px;margin:auto;padding:3.5rem 1.5rem;text-align:center;}
.card{background:#fff;border:1px solid #e7e0d8;border-left:6px solid var(--accent2);border-radius:10px;padding:1.25rem;max-width:820px;margin:1.25rem auto;text-align:left;}
label{display:block;margin:.75rem 0 .25rem;font-weight:600;}
input, textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;font-family:inherit;}
textarea{min-height:160px;}
.small{font-size:.95rem;color:#555;}
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem;}
.gallery img{width:100%;border-radius:6px;}
footer{text-align:center;padding:2rem;border-top:1px solid #ddd;background:#fff;font-size:.95rem;}
footer .times{margin-top:.5rem;font-weight:600;}

/* Seasonal decorations */
.header-lights{
  position:absolute;
  top:-6px;
  left:0;
  right:0;
  height:18px;
  pointer-events:none;
  background-repeat:repeat-x;
  background-size:120px 18px;
  /* a subtle "string of bulbs" using a repeating radial gradient */
  background-image:
    radial-gradient(circle at 10px 12px, rgba(255, 206, 84, .95) 0 4px, transparent 5px),
    radial-gradient(circle at 30px 12px, rgba(84, 255, 177, .85) 0 4px, transparent 5px),
    radial-gradient(circle at 50px 12px, rgba(255, 120, 145, .85) 0 4px, transparent 5px),
    radial-gradient(circle at 70px 12px, rgba(120, 190, 255, .85) 0 4px, transparent 5px),
    linear-gradient(to right, rgba(60,60,60,.55), rgba(60,60,60,.55));
  background-position:0 0, 0 0, 0 0, 0 0, 0 8px;
  background-size:120px 18px, 120px 18px, 120px 18px, 120px 18px, 120px 2px;
  opacity:.9;
}

#snow-canvas{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  z-index:999;
  pointer-events:none;
}

@media(max-width:820px){
.menu-toggle{display:block;}
.nav ul{display:none;flex-direction:column;position:absolute;top:76px;left:0;width:100%;background:#fff;border-top:1px solid #ddd;z-index:1000;}
.nav ul.show{display:flex;}
.nav ul li{padding:1rem;border-bottom:1px solid #eee;text-align:center;}
}


.pastor-block{display:flex;justify-content:center;margin:20px 0;}
.pastor-block img{max-width:100%;height:auto;}
.pastor-text{text-align:center;}


/* --- Professional polish --- */
:root{
  --bg: #f7f5f0;
  --text: #1f2937;
  --muted: #4b5563;
  --card: #ffffff;
  --border: rgba(0,0,0,.08);
  --shadow: 0 10px 25px rgba(0,0,0,.08);
  --radius: 16px;
  --accent: #1f6f5b; /* deep green */
  --accent-2: #b07a5b; /* warm bronze */
}

html, body{
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.55;
}

.section{
  max-width: 980px;
  margin: 0 auto;
  padding: 48px 20px;
}

h1, h2{
  letter-spacing: .2px;
}

h1{
  font-size: clamp(28px, 4vw, 44px);
  margin-bottom: 10px;
}

p{
  color: var(--muted);
  font-size: 18px;
}

.nav{
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(247,245,240,.9);
  border-bottom: 1px solid var(--border);
}

.nav .brand .brand-text{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  font-weight: 700;
  letter-spacing: .3px;
  line-height: 1.1;
}

.nav .brand .brand-line1,
.nav .brand .brand-line2{
  display: block;
}

@media (min-width: 721px){
  .nav .brand .brand-text{
    flex-direction: row;
    align-items: baseline;
    text-align: left;
    gap: 8px;
  }
  .nav .brand .brand-line1,
  .nav .brand .brand-line2{
    display: inline;
  }
}

#nav-menu a{
  color: var(--text);
  font-weight: 600;
  text-decoration: none;
}

#nav-menu a:hover{
  color: var(--accent);
}

.card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px 22px;
  /* Center all section bodies/cards on desktop */
  max-width: 860px;
  margin: 18px auto;
}

.card h2{
  margin-top: 0;
  color: var(--text);
}

button, .btn, a.button{
  background: var(--accent-2);
  border: 0;
  border-radius: 14px;
  padding: 14px 18px;
  font-weight: 700;
  color: white !important;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}

button:hover, .btn:hover, a.button:hover{
  filter: brightness(0.95);
}

input, textarea, select{
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
  font-size: 16px;
}

footer{
  border-top: 1px solid var(--border);
  padding: 30px 18px;
  text-align: center;
  color: var(--muted);
  background: rgba(255,255,255,.55);
}

.gallery{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

.gallery img{
  width: 100%;
  height: auto;
  border-radius: 14px;
  border: 1px solid var(--border);
  box-shadow: 0 8px 18px rgba(0,0,0,.07);
}

/* Mobile menu visibility */
.menu-toggle{
  color: #111 !important;
  background: transparent;
  border: 1px solid rgba(0,0,0,.18);
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 22px;
  line-height: 1;
}
.menu-toggle:focus{outline: 2px solid rgba(0,0,0,.25); outline-offset: 2px;}

@media (max-width: 768px){
  #nav-menu{
    max-height: calc(100vh - 80px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* iOS menu safe area */
@media (max-width: 768px){
  #nav-menu{
    padding-bottom: 110px; /* keeps last items above Safari URL bar */
  }
}

.nav .brand img{
  height: 48px;
  width: auto;
  max-width: 48px;
  object-fit: contain;
}

/* Pastors page layout */
.pastor-hero{
  display:flex;
  justify-content:center;
  margin: 18px 0 10px;
}
.pastor-hero img{
  width: min(520px, 92vw);
  height: auto;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 10px 25px rgba(0,0,0,.10);
}
.pastor-copy{
  text-align:center;
  max-width: 800px;
  margin: 0 auto;
}
/* First Time labels */
.label{
  font-weight: 700;
  color: #1f2937;
}

/* Fix bold body text */
.card, .card p, .card li{
  font-weight: 400 !important;
}
.label{
  font-weight: 700 !important;
}

/* iOS menu safe area v2 */
@media (max-width: 768px){
  #nav-menu{
    padding-bottom: calc(260px + env(safe-area-inset-bottom)) !important;
    max-height: calc(100vh - 70px) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  #nav-menu li:last-child{
    margin-bottom: 180px;
  }
}

/* Center site title on mobile */
@media (max-width: 768px){
  .site-title, .header-title, header h1{
    text-align: center !important;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}


/* --- Mobile header: truly center the site title between logo and hamburger --- */
@media (max-width: 768px){
  header, .site-header {
    position: sticky;
    top: 0;
    z-index: 999;
  }

  /* Common wrappers (covers most simple static layouts) */
  header .header-inner,
  header .header-content,
  header .container,
  .site-header .header-inner,
  .site-header .header-content,
  .site-header .container{
    display: grid !important;
    grid-template-columns: 64px 1fr 64px !important;
    align-items: center !important;
    column-gap: 8px !important;
  }

  /* Logo area on left */
  header .logo,
  header .site-logo,
  .site-header .logo,
  .site-header .site-logo{
    justify-self: start !important;
  }

  /* Title centered */
  header h1,
  header .site-title,
  header .header-title,
  .site-header h1,
  .site-header .site-title,
  .site-header .header-title{
    justify-self: center !important;
    text-align: center !important;
    margin: 0 !important;
    width: 100% !important;
  }

  /* Hamburger/menu button on right */
  header .menu-toggle,
  header .nav-toggle,
  header .hamburger,
  .site-header .menu-toggle,
  .site-header .nav-toggle,
  .site-header .hamburger{
    justify-self: end !important;
  }
}


/* --- Gallery layout: centered thumbnails, not oversized --- */
.gallery{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  justify-items: center;
  align-items: start;
  margin-top: 16px;
}
.gallery img{
  width: 100%;
  height: auto;
  max-width: 420px;
  border-radius: 10px;
  display: block;
}

/* --- Full-site polish pass --- */

/* Keep the header title visually centered on mobile */
@media (max-width: 640px){
  .brand{ flex: 1; justify-content: center; }
  .brand-text{ width: 100%; text-align: center; }
}

/* Page titles */
.page-title{
  margin: 6px 0 18px;
  text-align: center;
}

/* Pastors page layout */
.pastor-grid{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.pastor-hero{ width: 100%; display: flex; justify-content: center; }
.pastor-hero img{ width: 100%; max-width: 560px; height: auto; display: block; }
.pastor-copy{ max-width: 720px; text-align: center; }

/* Slightly smoother typography */
body{
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Better focus visibility */
a:focus-visible, button:focus-visible{
  outline: 3px solid rgba(0,0,0,0.35);
  outline-offset: 3px;
}

/* --- Full-site polish overrides (Dec 2025) --- */
:root{
  --font-body: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  --font-heading: ui-serif, Georgia, "Times New Roman", Times, serif;
}

body{
  font-family: var(--font-body);
  letter-spacing: 0.1px;
}

h1,h2,h3,h4,h5,h6,
.section-title,
.hero-title{
  font-family: var(--font-heading);
}

/* Gallery thumbnails: keep consistent sizing on mobile */
.gallery-grid img{
  width: 100%;
  height: 240px;
  object-fit: cover;
}

@media (max-width: 480px){
  .gallery-grid{ grid-template-columns: 1fr; }
  .gallery-grid img{ height: 210px; }
}

/* Mobile menu: ensure last item isn't hidden behind iOS URL bar */
@media (max-width: 768px){
  .nav-links{ padding-bottom: 110px; }
}

/* Header title centering on mobile */
.header-container .brand-text{ text-align: center; }
.header-container .brand-line1,
.header-container .brand-line2{ display:block; }

/* Prevent any accidental duplicate brand text inside the nav (helps if a page template is stale) */
.site-header nav .brand-text,
.site-header nav .brand-line1,
.site-header nav .brand-line2{
  display: none !important;
}

/* Force a clean 3-column header on small screens so the title truly centers */
@media (max-width: 520px){
  .header-inner{
    grid-template-columns: 56px 1fr 56px;
  }
  .brand{ justify-self: start; }
  .nav-toggle{ justify-self: end; }
  .brand-text{ justify-self: center; max-width: 260px; }
  .brand-line1, .brand-line2{ width: 100%; text-align: center; }
}

.announcement-card{background:#fff;border-radius:14px;padding:1.25rem 1.5rem;margin-top:1.25rem;box-shadow:0 6px 18px rgba(0,0,0,.08)}
.badge{display:inline-block;background:#f1f5f9;color:#334155;font-size:.75rem;font-weight:600;padding:.25rem .6rem;border-radius:999px;margin-bottom:.5rem}
.announcement-card.emmaus{border-left:5px solid #64748b}

.announcement-card h3{margin-top:0;margin-bottom:.5rem;font-weight:700}

.announcement-card .date{margin:0 0 .75rem 0; font-weight:600; opacity:.8}

.announcement-note{text-align:center;color:#6b7280;margin-bottom:1rem}
