/*
Theme Name: Prophetic Life International Church
Theme URI: https://yourchurch.com
Author: Your Church
Description: Official WordPress theme for Prophetic Life International Church (PLIC). Includes all 11 ministries, live services, testimonials, prayer requests, giving, and contact pages.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: plic
Tags: church, religious, ministry, custom-logo, custom-menu, featured-images, full-width-template
*/

/* =====================================================
   GRACEFIRE DESIGN SYSTEM
   Palette: Deep Brown · Warm Gold · Cream · Sage
   Fonts: Playfair Display (display) + Inter (body)
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --gold:          #D4A017;
  --gold-lt:       #F0C840;
  --gold-dk:       #A87810;
  --gold-bg:       #FBF5E0;
  --deep:          #12102A;
  --brown:         #3A2A6E;
  --brown-lt:      #5A4870;
  --cream:         #FAF8FF;
  --cream-dk:      #F0EBF8;
  --sage:          #6B8F71;
  --sage-lt:       #A0C4A6;
  --white:         #FFFDF7;
  --muted:         #7A6E90;
  --border:        #DDD0EE;

  --purple:        #6B3FA0;
  --purple-lt:    #9B6DD0;
  --purple-bg:    #F3EEF9;
  --blue:         #1A5FAA;
  --blue-lt:      #4A8FD4;
  --magenta:      #C4338A;
  --font-display:  'Playfair Display', Georgia, serif;
  --font-body:     'Inter', sans-serif;

  --space-xs:  0.375rem;
  --space-sm:  0.75rem;
  --space-md:  1.25rem;
  --space-lg:  2rem;
  --space-xl:  3.5rem;
  --space-2xl: 5rem;

  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   20px;
  --radius-xl:   28px;
  --radius-full: 9999px;

  --shadow-sm:   0 2px 8px rgba(28,18,9,.07);
  --shadow-md:   0 6px 24px rgba(28,18,9,.10);
  --shadow-lg:   0 16px 48px rgba(28,18,9,.13);
  --shadow-gold: 0 8px 32px rgba(201,150,42,.22);

  --ease: cubic-bezier(.4,0,.2,1);
  --dur:  220ms;
}

/* ─── Reset ─────────────────────────────────────── */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--font-body);
  color: var(--deep);
  background: var(--cream);
  line-height: 1.7;
}
img { max-width: 100%; height: auto; display: block; }
a  { color: var(--gold); text-decoration: none; transition: color var(--dur) var(--ease); }
a:hover { color: var(--gold-dk); }

/* ─── Typography ─────────────────────────────────── */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.2;
  color: var(--deep);
}
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.5rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); }
h4 { font-size: 1.15rem; }
p  { margin-bottom: var(--space-md); }
p:last-child { margin-bottom: 0; }
blockquote {
  border-left: 3px solid var(--gold);
  padding-left: var(--space-md);
  font-family: var(--font-display);
  font-style: italic;
  color: var(--brown-lt);
}

/* ─── Layout ─────────────────────────────────────── */
.container        { width: min(1160px, 100% - 2.5rem); margin-inline: auto; }
.container--narrow{ width: min(760px, 100% - 2.5rem); margin-inline: auto; }
.container--wide  { width: min(1380px, 100% - 2.5rem); margin-inline: auto; }

/* ─── Eyebrow ─────────────────────────────────────── */
.eyebrow {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--space-sm);
}
.eyebrow::before,.eyebrow::after {
  content: '';
  display: block;
  width: 22px;
  height: 1px;
  background: var(--gold);
  opacity: .6;
}

/* ─── Buttons ─────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .9rem;
  padding: .75rem 1.75rem;
  border-radius: var(--radius-full);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--dur) var(--ease);
  text-decoration: none;
  letter-spacing: .02em;
}
.btn--primary {
  background: var(--gold);
  color: var(--deep);
  box-shadow: var(--shadow-gold);
}
.btn--primary:hover {
  background: var(--gold-lt);
  color: var(--deep);
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(201,150,42,.32);
}
.btn--secondary {
  background: transparent;
  color: var(--gold);
  border-color: var(--gold);
}
.btn--secondary:hover { background: var(--gold); color: var(--deep); }
.btn--ghost {
  background: var(--cream-dk);
  color: var(--brown-lt);
  border-color: var(--border);
}
.btn--ghost:hover { background: var(--border); color: var(--brown); }
.btn--white { background: #fff; color: var(--deep); }
.btn--white:hover { background: var(--cream); color: var(--deep); }
.btn--outline-white {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,.4);
}
.btn--outline-white:hover { background: rgba(255,255,255,.1); color: #fff; }

/* ─── Cross Divider ───────────────────────────────── */
.cross-divider {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}
.cross-divider__line { flex: 1; height: 1px; background: var(--border); }
.cross-divider__icon {
  width: 18px; height: 18px;
  position: relative;
  flex-shrink: 0;
}
.cross-divider__icon::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 3px; height: 18px;
  background: var(--gold);
  border-radius: 2px;
}
.cross-divider__icon::after {
  content: '';
  position: absolute;
  top: 5px; left: 50%;
  transform: translateX(-50%);
  width: 14px; height: 3px;
  background: var(--gold);
  border-radius: 2px;
}

/* ─── Section ─────────────────────────────────────── */
.section { padding: var(--space-2xl) 0; }
.section--tinted { background: var(--cream-dk); }
.section--dark {
  background: var(--deep);
  color: rgba(255,255,255,.85);
}
.section--dark h1,.section--dark h2,.section--dark h3 { color: #fff; }

.section-header { margin-bottom: var(--space-xl); }
.section-header--center { text-align: center; }
.section-header--center .section-sub { margin-inline: auto; }
.section-title { margin-bottom: .5rem; }
.section-sub { font-size: 1rem; color: var(--muted); max-width: 540px; line-height: 1.75; }

/* ─── Cards ───────────────────────────────────────── */
.card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
  transition: all var(--dur) var(--ease);
}
.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}
.card--gold-top { border-top: 3px solid var(--gold); }

/* ─── Header ──────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(253,248,240,.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  padding: .85rem 0;
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-lg);
}
.site-logo {
  display: flex;
  align-items: center;
  gap: 0;
  text-decoration: none;
}
.site-logo__cross {
  width: 32px; height: 32px;
  position: relative;
  flex-shrink: 0;
}
.site-logo__cross::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 5px; height: 32px;
  background: var(--gold);
  border-radius: 3px;
}
.site-logo__cross::after {
  content: '';
  position: absolute;
  top: 9px; left: 50%;
  transform: translateX(-50%);
  width: 22px; height: 5px;
  background: var(--gold);
  border-radius: 3px;
}
.site-logo__text {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.3rem;
  color: var(--deep);
}
.site-logo__text span { color: var(--gold); }

.site-nav { display: flex; gap: .15rem; align-items: center; }
.site-nav a {
  font-size: .85rem;
  font-weight: 500;
  color: var(--brown-lt);
  padding: .4rem .9rem;
  border-radius: var(--radius-full);
  transition: all var(--dur) var(--ease);
}
.site-nav a:hover,.site-nav a.current-menu-item,.site-nav a.current-page-ancestor {
  background: var(--gold-bg);
  color: var(--brown);
}
.site-header__actions { display: flex; align-items: center; gap: var(--space-sm); }

/* Mobile nav */
.menu-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}
.menu-toggle span {
  display: block;
  width: 22px; height: 2px;
  background: var(--deep);
  border-radius: 2px;
  transition: all var(--dur) var(--ease);
}
.mobile-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 5rem var(--space-lg) var(--space-lg);
  transform: translateY(-100%);
  transition: transform 300ms var(--ease);
  z-index: 90;
  box-shadow: var(--shadow-lg);
}
.mobile-nav.is-open { transform: translateY(0); }
.mobile-nav ul { list-style: none; display: flex; flex-direction: column; gap: .25rem; }
.mobile-nav a {
  display: block;
  padding: .75rem 1rem;
  font-size: 1rem;
  font-weight: 500;
  color: var(--deep);
  border-radius: var(--radius-md);
}
.mobile-nav a:hover { background: var(--gold-bg); color: var(--brown); }

/* ─── Hero ─────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 600px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--deep);
}
.hero__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #1C1209 0%, #3a200a 40%, #5a3015 70%, #1C1209 100%);
  z-index: 0;
}
.hero__pattern {
  position: absolute; inset: 0; z-index: 1;
  opacity: .07;
  background-image:
    radial-gradient(circle at 20% 50%, #C9962A 1px, transparent 1px),
    radial-gradient(circle at 80% 20%, #C9962A 1px, transparent 1px),
    radial-gradient(circle at 60% 80%, #C9962A 1px, transparent 1px);
  background-size: 60px 60px, 80px 80px, 100px 100px;
}
.hero__glow {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 600px; height: 600px;
  background: radial-gradient(ellipse, rgba(201,150,42,.12) 0%, transparent 70%);
  z-index: 1;
}
.hero__inner {
  position: relative;
  z-index: 2;
  padding: 100px 0;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-xl);
  align-items: center;
}
.hero__content { max-width: 580px; }
.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold-lt);
  margin-bottom: var(--space-md);
}
.hero__eyebrow::before,.hero__eyebrow::after {
  content: ''; display: block;
  width: 24px; height: 1px;
  background: var(--gold-lt); opacity: .6;
}
.hero__title {
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.15;
  margin-bottom: var(--space-md);
}
.hero__title em { color: var(--gold-lt); font-style: italic; }
.hero__subtitle {
  font-size: 1.05rem;
  color: rgba(255,255,255,.7);
  max-width: 460px;
  line-height: 1.8;
  margin-bottom: var(--space-lg);
}
.hero__actions { display: flex; gap: var(--space-md); flex-wrap: wrap; }

/* Service badge */
.hero__service-badge {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(201,150,42,.35);
  border-radius: var(--radius-lg);
  padding: 22px 28px;
  backdrop-filter: blur(10px);
  flex-shrink: 0;
}
.hero__badge-label {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold-lt);
  margin-bottom: 12px;
}
.hero__badge-times { display: flex; flex-direction: column; gap: 8px; }
.hero__badge-time {
  font-size: .85rem;
  color: rgba(255,255,255,.85);
  display: flex;
  align-items: center;
  gap: 10px;
}
.hero__badge-dot {
  width: 7px; height: 7px;
  background: var(--gold);
  border-radius: 50%;
  flex-shrink: 0;
}

/* ─── Service Times ───────────────────────────────── */
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}
.service-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-top: 3px solid var(--gold);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: all var(--dur) var(--ease);
}
.service-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.service-day {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
}
.service-time {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--deep);
  line-height: 1;
  margin-bottom: 6px;
}
.service-name {
  font-size: .85rem;
  font-weight: 500;
  color: var(--brown-lt);
  margin-bottom: var(--space-md);
}
.tags { display: flex; gap: 6px; flex-wrap: wrap; }
.tag {
  font-size: .7rem;
  font-weight: 600;
  color: var(--brown-lt);
  background: var(--cream-dk);
  border: 1px solid var(--border);
  padding: .2rem .65rem;
  border-radius: var(--radius-full);
}
.tag--gold { color: var(--brown); background: var(--gold-bg); border-color: rgba(201,150,42,.3); }

/* Location card */
.location-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg) var(--space-xl);
  display: flex;
  gap: var(--space-lg);
  align-items: flex-start;
}
.location-icon {
  width: 52px; height: 52px;
  background: var(--gold-bg);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
}
.location-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 4px;
}
.location-name {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--deep);
  margin-bottom: 4px;
}
.location-addr { font-size: .88rem; color: var(--muted); }

/* ─── Sermons ──────────────────────────────────────── */
.sermon-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-md); }
.sermon-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--dur) var(--ease);
}
.sermon-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: rgba(201,150,42,.4); }
.sermon-thumb {
  height: 160px;
  background: var(--deep);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.sermon-thumb__bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg,#1C1209,#5a3015);
  opacity: .9;
}
.play-btn {
  width: 50px; height: 50px;
  border-radius: 50%;
  background: rgba(201,150,42,.9);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  transition: transform var(--dur) var(--ease);
}
.sermon-card:hover .play-btn { transform: scale(1.12); }
.play-icon {
  width: 0; height: 0;
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  border-left: 16px solid #fff;
  margin-left: 3px;
}
.sermon-body { padding: var(--space-md); }
.sermon-series {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 5px;
}
.sermon-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--deep);
  line-height: 1.35;
  margin-bottom: 8px;
}
.sermon-meta { font-size: .78rem; color: var(--muted); }

/* ─── Events ──────────────────────────────────────── */
.event-item {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  transition: all var(--dur) var(--ease);
}
.event-item:hover { border-color: var(--gold); background: var(--gold-bg); }
.event-date { width: 56px; text-align: center; flex-shrink: 0; }
.event-month { font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); }
.event-day { font-family: var(--font-display); font-size: 2rem; font-weight: 700; color: var(--deep); line-height: 1; }
.event-name { font-weight: 600; font-size: .95rem; color: var(--deep); margin-bottom: 3px; }
.event-detail { font-size: .8rem; color: var(--muted); }
.event-badge {
  font-size: .7rem;
  font-weight: 700;
  padding: .3rem .8rem;
  border-radius: var(--radius-full);
  background: rgba(107,143,113,.12);
  color: var(--sage);
  border: 1px solid rgba(107,143,113,.28);
  flex-shrink: 0;
}

/* ─── Ministries ──────────────────────────────────── */
.ministry-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--space-md); }
.ministry-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-align: center;
  transition: all var(--dur) var(--ease);
}
.ministry-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.ministry-icon {
  width: 56px; height: 56px;
  background: var(--gold-bg);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin: 0 auto var(--space-md);
}
.ministry-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--deep);
  margin-bottom: 6px;
}
.ministry-desc { font-size: .84rem; color: var(--muted); line-height: 1.65; }

/* ─── Prayer & Give ───────────────────────────────── */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); }
.panel {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
}
.panel-title { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; color: var(--deep); margin-bottom: .4rem; }
.panel-sub { font-size: .9rem; color: var(--muted); line-height: 1.7; margin-bottom: var(--space-lg); }
.form-group { margin-bottom: var(--space-sm); }
.form-input,.form-textarea,.form-select {
  width: 100%;
  padding: .7rem 1rem;
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--deep);
  background: var(--cream);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color var(--dur) var(--ease);
}
.form-input:focus,.form-textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(201,150,42,.12); }
.form-textarea { resize: vertical; min-height: 100px; }
.btn-submit {
  width: 100%;
  background: var(--gold);
  color: var(--deep);
  font-family: var(--font-body);
  font-size: .9rem;
  font-weight: 600;
  padding: .8rem;
  border-radius: var(--radius-full);
  border: none;
  cursor: pointer;
  transition: all var(--dur) var(--ease);
  margin-top: var(--space-sm);
}
.btn-submit:hover { background: var(--gold-lt); transform: translateY(-2px); }

/* Give amounts */
.give-amounts { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; margin-bottom: var(--space-md); }
.give-btn {
  padding: .65rem .4rem;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--cream);
  font-size: .88rem;
  font-weight: 600;
  color: var(--brown-lt);
  cursor: pointer;
  transition: all var(--dur) var(--ease);
  font-family: var(--font-body);
  white-space: nowrap;
  text-align: center;
  overflow: hidden;
}
.give-btn:hover,.give-btn.selected {
  border-color: var(--gold);
  background: var(--gold-bg);
  color: var(--brown);
}
.give-verse {
  font-family: var(--font-display);
  font-style: italic;
  font-size: .84rem;
  color: var(--brown-lt);
  text-align: center;
  line-height: 1.75;
  border-top: 1px solid var(--border);
  padding-top: var(--space-md);
  margin-top: var(--space-md);
}

/* ─── CTA Banner ──────────────────────────────────── */
.cta-banner {
  background: var(--deep);
  padding: var(--space-2xl) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-banner__glow {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 80% at 50% 50%,rgba(201,150,42,.12) 0%,transparent 70%);
}
.cta-banner__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: .75rem;
  position: relative;
}
.cta-banner__title em { color: var(--gold-lt); font-style: italic; }
.cta-banner__sub { font-size: 1.05rem; color: rgba(255,255,255,.65); max-width: 460px; margin: 0 auto var(--space-lg); line-height: 1.7; position: relative; }
.cta-banner__actions { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; position: relative; }

/* ─── Footer ──────────────────────────────────────── */
.site-footer {
  background: var(--deep);
  color: rgba(255,255,255,.6);
  padding: 0;
  width: 100%;
}
.site-footer .container {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 52px !important;
  padding-right: 52px !important;
}
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; width: 100%; margin-bottom: var(--space-xl); padding-top: 52px; }
.footer-logo-text { font-family: var(--font-display); font-size: 1.2rem; color: #fff; margin-bottom: .5rem; }
.footer-logo-text span { color: var(--gold-lt); }
.footer-tagline { font-size: .82rem; line-height: 1.7; max-width: 240px; }
.footer-col-title { font-size: .78rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #fff; margin-bottom: var(--space-md); }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.footer-links a { font-size: .82rem; color: rgba(255,255,255,.55); transition: color var(--dur) var(--ease); }
.footer-links a:hover { color: var(--gold-lt); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding: var(--space-md) 52px; display: flex; justify-content: space-between; align-items: center; font-size: .78rem; flex-wrap: wrap; gap: var(--space-sm); width: 100%; }

/* ─── Blog / Archive ──────────────────────────────── */
.post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-lg); }
.post-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--dur) var(--ease);
}
.post-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.post-card__thumb { height: 180px; overflow: hidden; }
.post-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease); }
.post-card:hover .post-card__thumb img { transform: scale(1.04); }
.post-card__body { padding: var(--space-md); }
.post-card__category { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--gold); margin-bottom: 5px; }
.post-card__title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; color: var(--deep); margin-bottom: var(--space-sm); line-height: 1.3; }
.post-card__excerpt { font-size: .84rem; color: var(--muted); line-height: 1.65; }

/* ─── WP Compat ───────────────────────────────────── */
.wp-block-image img { border-radius: var(--radius-md); }
.entry-content a { text-decoration: underline; text-underline-offset: 3px; }
.entry-content ul,.entry-content ol { padding-left: 1.5rem; margin-bottom: var(--space-md); }
.entry-content li { margin-bottom: .4rem; }
.entry-content h2,.entry-content h3 { margin-top: var(--space-xl); margin-bottom: var(--space-sm); }
.screen-reader-text { position: absolute; width: 1px; height: 1px; clip: rect(0,0,0,0); overflow: hidden; }

/* Pagination */
.nav-links { display: flex; gap: var(--space-sm); justify-content: center; flex-wrap: wrap; }
.nav-links a,.nav-links span { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; padding: 0 .75rem; border: 1.5px solid var(--border); border-radius: var(--radius-md); font-size: .85rem; font-weight: 500; color: var(--deep); background: var(--white); transition: all var(--dur) var(--ease); }
.nav-links a:hover { border-color: var(--gold); color: var(--gold); }
.nav-links .current { background: var(--gold); border-color: var(--gold); color: var(--deep); }

/* ─── Animations ──────────────────────────────────── */
@keyframes fadeUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
.fade-up   { animation: fadeUp .5s var(--ease) both; }
.fade-up-1 { animation-delay: .1s; }
.fade-up-2 { animation-delay: .2s; }
.fade-up-3 { animation-delay: .3s; }
.fade-up-4 { animation-delay: .45s; }

/* ─── Responsive ──────────────────────────────────── */
@media (max-width: 1024px) {
  .hero__inner   { grid-template-columns: 1fr; }
  .hero__service-badge { display: none; }
  .two-col       { grid-template-columns: 1fr; }
  .footer-grid   { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .site-nav { display: none; }
  .menu-toggle { display: flex; }
  .footer-grid { grid-template-columns: 1fr; }
  .services-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .hero__actions { flex-direction: column; }
  .cta-banner__actions { flex-direction: column; align-items: center; }
}

/* ─── Accessibility ───────────────────────────────── */
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius: 2px; }
.skip-link { position: absolute; top: -100%; left: var(--space-md); background: var(--gold); color: var(--deep); padding: .5rem 1rem; border-radius: 0 0 var(--radius-md) var(--radius-md); font-weight: 600; z-index: 9999; transition: top .2s; }
.skip-link:focus { top: 0; }

@media print { .site-header,.site-footer,.btn,.cta-banner { display: none !important; } }

/* ─── Layout Overrides: Prayer/Give full-bleed & Footer full-width ─── */
.prayer-give-section,
.pg-section {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  gap: 0 !important;
}
.prayer-give-section .container,
.pg-section .container {
  max-width: 100% !important;
  padding: 0 !important;
}
.pg-prayer, .prayer-panel-left {
  background: #fff;
  border-right: 1px solid #DDD0EE;
  padding: 56px 52px !important;
}
.pg-give, .give-panel-right {
  background: #221E42;
  padding: 56px 52px !important;
}
/* Amount buttons — never wrap */
.give-btn, .amt, .give-amounts button {
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  font-size: 0.85rem !important;
  padding: 0.6rem 0.3rem !important;
}
/* Footer truly full width */
.site-footer,
.site-footer > *:not(.container) {
  max-width: 100% !important;
  width: 100% !important;
}
.site-footer .footer-grid {
  grid-template-columns: 2fr 1fr 1fr 1fr !important;
  width: 100% !important;
  gap: 40px !important;
}
.site-footer .footer-bottom {
  width: 100% !important;
  padding-left: 52px !important;
  padding-right: 52px !important;
  justify-content: space-between !important;
}
@media (max-width: 900px) {
  .prayer-give-section, .pg-section { grid-template-columns: 1fr !important; }
  .pg-prayer, .prayer-panel-left,
  .pg-give, .give-panel-right { padding: 36px 24px !important; }
  .site-footer .footer-grid { grid-template-columns: 1fr 1fr !important; }
  .site-footer .footer-bottom { padding-left: 24px !important; padding-right: 24px !important; flex-direction: column !important; align-items: center !important; text-align: center !important; }
}
@media (max-width: 560px) {
  .site-footer .footer-grid { grid-template-columns: 1fr !important; }
}

/* ─── Form field labels, errors, validation ─── */
.field-group { display:flex; flex-direction:column; margin-bottom:.75rem; }
.field-label { font-size:.82rem; font-weight:600; color:var(--brown); margin-bottom:.35rem; }
.surrender-label { color:rgba(255,255,255,.75) !important; }
.field-req { color:var(--purple); }
.field-error { font-size:.78rem; color:#dc2626; margin-top:.3rem; display:none; }
.surrender-error { color:#f87171 !important; }
.field-checkbox { display:flex; align-items:center; gap:.5rem; font-size:.82rem; color:var(--brown-lt); margin-bottom:.75rem; cursor:pointer; }
.field-checkbox input { accent-color:var(--purple); }
.form-input.input-error { border-color:#dc2626 !important; }
.surrender-input.input-error { border-color:#f87171 !important; }
.surrender-input { background:rgba(255,255,255,.07) !important; border-color:rgba(155,109,208,.3) !important; color:#fff !important; }
.surrender-input::placeholder { color:rgba(255,255,255,.35) !important; }

/* ═══════════════════════════════════════════════════════════
   PRAYER & SURRENDER — AGREED FULL-BLEED LAYOUT
   These rules are authoritative. Nothing else overrides them.
   ═══════════════════════════════════════════════════════════ */
div.plic-pg-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 0 !important;
  box-sizing: border-box !important;
}
div.plic-pg-left {
  background: #ffffff !important;
  border-right: 1px solid #DDD0EE !important;
  padding: 60px 56px !important;
  box-sizing: border-box !important;
}
div.plic-pg-right {
  background: #221E42 !important;
  padding: 60px 56px !important;
  box-sizing: border-box !important;
}
/* Field labels */
div.plic-pg-left  .field-label { color: #12102A !important; }
div.plic-pg-right .field-label { color: rgba(255,255,255,.78) !important; }
/* Panel title */
div.plic-pg-left  .panel-title,
div.plic-pg-left  h3.panel-title { color: #12102A !important; font-size: 1.45rem !important; }
div.plic-pg-right .panel-title,
div.plic-pg-right h3.panel-title { color: #ffffff !important; font-size: 1.45rem !important; }
/* Sub text */
div.plic-pg-left  .panel-sub { color: #7A6E90 !important; }
div.plic-pg-right .panel-sub { color: rgba(255,255,255,.5) !important; }
/* Form inputs — right panel */
div.plic-pg-right .form-input,
div.plic-pg-right .surrender-input {
  background: rgba(255,255,255,.07) !important;
  border-color: rgba(155,109,208,.32) !important;
  color: #ffffff !important;
}
div.plic-pg-right .form-input::placeholder,
div.plic-pg-right .surrender-input::placeholder { color: rgba(255,255,255,.35) !important; }
div.plic-pg-right select.form-input option,
div.plic-pg-right select.surrender-input option { background: #221E42 !important; color: #fff !important; }
/* Error text */
div.plic-pg-right .field-error,
div.plic-pg-right .surrender-error { color: #f87171 !important; }
/* Verse / scripture */
div.plic-pg-right .give-verse {
  color: rgba(255,255,255,.28) !important;
  border-color: rgba(155,109,208,.15) !important;
}
/* Responsive */
@media (max-width: 860px) {
  div.plic-pg-grid {
    grid-template-columns: 1fr !important;
  }
  div.plic-pg-left,
  div.plic-pg-right {
    padding: 40px 24px !important;
    border-right: none !important;
  }
}

/* ── Hide site title / tagline text next to logo ── */
.site-logo .site-logo__text,
.site-logo .custom-logo-link + *,
.site-header .site-title,
.site-header .site-description,
.site-header p.site-title,
.site-header p.site-description,
.wp-site-blocks .site-title,
.site-branding__text,
h1.site-title,
p.site-title {
  display: none !important;
}
/* Ensure the logo link itself only shows the image */
.site-logo,
a.site-logo,
a.custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — COMPREHENSIVE FIXES
   Covers all breakpoints. These rules are last in the file
   so they override everything above them.
   ═══════════════════════════════════════════════════════════════ */

/* ── Base mobile resets ───────────────────────────────────────── */
html { overflow-x: hidden !important; }
body { overflow-x: hidden !important; min-width: 0 !important; }
img  { max-width: 100% !important; height: auto !important; }
* { -webkit-text-size-adjust: 100%; }

/* ── Tablet: 768px – 1024px ──────────────────────────────────── */
@media (max-width: 1024px) {
  .container, .container--wide { width: calc(100% - 2rem) !important; }
  .site-nav { gap: .08rem; }
  .site-nav a { font-size: .78rem; padding: .35rem .55rem; }
  .hero__inner, .two-col { grid-template-columns: 1fr !important; }
  .hero__content { text-align: center; }
  .hero__actions { justify-content: center; }
  .hero__service-card { display: none !important; }
  .vision-grid, .vm-grid { grid-template-columns: 1fr !important; }
  .ministry-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .sermon-grid  { grid-template-columns: repeat(2, 1fr) !important; }
  .stats-band   { grid-template-columns: repeat(2, 1fr) !important; }
  .footer-grid  { grid-template-columns: 1fr 1fr !important; gap: 32px !important; }
  /* Prayer / Surrender side by side stays until 860px */
}

/* ── Mobile: max 860px — prayer/surrender stacks ─────────────── */
@media (max-width: 860px) {
  div.plic-pg-grid,
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
    display: block !important;
  }
  div[style*="background:#221E42"][style*="padding:60px 56px"],
  div[style*="background:#ffffff"][style*="padding:60px 56px"] {
    padding: 40px 24px !important;
  }
}

/* ── Mobile: max 768px ────────────────────────────────────────── */
@media (max-width: 768px) {
  /* Nav */
  .site-header__inner { padding: 0 1rem; position: relative; }
  .site-nav { display: none !important; }
  .site-header__actions .btn--primary { display: none !important; }
  .menu-toggle { display: flex !important; }
  .mobile-nav.is-open { display: block !important; }
  .mobile-nav {
    position: fixed !important; top: 64px !important; left: 0 !important; right: 0 !important;
    background: rgba(250,248,255,.98) !important; z-index: 98 !important;
    padding: 1.5rem 1.5rem 2rem !important;
    box-shadow: 0 8px 32px rgba(18,16,42,.12) !important;
    border-top: 3px solid #6B3FA0 !important;
    display: none;
  }
  .mobile-nav ul, .mobile-nav > * {
    display: flex !important; flex-direction: column !important; gap: .25rem !important; list-style: none !important;
  }
  .mobile-nav a {
    display: block !important; padding: .75rem 1rem !important;
    font-size: 1rem !important; font-weight: 600 !important;
    color: #12102A !important; border-radius: 10px !important; text-decoration: none !important;
  }
  .mobile-nav a:hover { background: #EDE8F5 !important; color: #6B3FA0 !important; }

  /* Hero */
  .hero { min-height: auto !important; }
  .hero__inner { padding: 56px 20px 52px !important; }
  .hero__title { font-size: clamp(1.8rem, 7vw, 2.8rem) !important; }
  .hero__subtitle { font-size: .9rem !important; }
  .hero__actions { flex-wrap: wrap !important; gap: .6rem !important; justify-content: center !important; }
  .hero__actions .btn { font-size: .82rem !important; padding: .65rem 1.2rem !important; }

  /* Sections */
  .section { padding: 52px 20px !important; }
  .section-title { font-size: clamp(1.4rem, 5.5vw, 2rem) !important; }

  /* Grids → single column */
  .ministry-grid  { grid-template-columns: 1fr !important; }
  .sermon-grid    { grid-template-columns: 1fr !important; }
  .stats-band     { grid-template-columns: 1fr 1fr !important; }
  .footer-grid    { grid-template-columns: 1fr !important; gap: 28px !important; }

  /* Give amount buttons */
  .give-amounts,
  div[id*="amts"] {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  .give-btn, .amt {
    font-size: .78rem !important;
    padding: .55rem .25rem !important;
    white-space: nowrap !important;
  }

  /* Footer */
  .footer-body, .footer-bottom { padding-left: 20px !important; padding-right: 20px !important; }
  .footer-bottom { flex-direction: column !important; text-align: center !important; gap: 10px !important; }

  /* Prayer / Surrender forms */
  div[style*="padding:60px 56px"] { padding: 36px 20px !important; }
  .field-group { margin-bottom: .6rem !important; }

  /* CTA band */
  .cta-banner { padding: 56px 20px !important; }
  .cta-banner__actions { flex-direction: column !important; align-items: center !important; gap: .6rem !important; }
  .cta-banner__actions .btn { width: 100% !important; max-width: 320px !important; justify-content: center !important; }

  /* Event rows */
  .event-card, .ev-row { flex-wrap: wrap !important; }

  /* Page hero */
  .page-hero { padding: 52px 20px 44px !important; }
  .page-hero h1, .ph-h1 { font-size: clamp(1.4rem, 6vw, 2.2rem) !important; }

  /* Two-col contact layout */
  .two-col { grid-template-columns: 1fr !important; }
  .frm-row { grid-template-columns: 1fr !important; }

  /* Carousel cards */
  .sermon-carousel__track .sermon-card { width: 85vw !important; flex: 0 0 85vw !important; }

  /* Live services grid */
  .live-grid, [style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }
}

/* ── Small mobile: max 480px ──────────────────────────────────── */
@media (max-width: 480px) {
  .stats-band { grid-template-columns: 1fr 1fr !important; }
  .section { padding: 40px 16px !important; }
  .hero__title { font-size: clamp(1.5rem, 8vw, 2.2rem) !important; }
  .site-header { height: 58px !important; }
  .section-title { font-size: clamp(1.2rem, 6vw, 1.7rem) !important; }
  .btn--primary, .btn--secondary { font-size: .78rem !important; padding: .6rem 1.1rem !important; }
}
