/* =====================================================
   responsive.css — All media queries
   ===================================================== */

/* =====================================================
   GOOGLE CALENDAR helper styles (calendar.js output)
   ===================================================== */
.gcal-loading,
.gcal-notice {
  padding: 1.5rem;
  color: var(--text-light);
  font-size: .95rem;
  font-style: italic;
  text-align: center;
}
.gcal-notice a { color: var(--gold); text-decoration: underline; }
.gcal-notice code {
  background: var(--light-gray);
  padding: .1em .4em;
  border-radius: 3px;
  font-size: .85em;
  font-style: normal;
}

/* Clickable event items (when linked to Google Calendar) */
a.event-item--link {
  text-decoration: none;
  color: inherit;
  display: grid;
  cursor: pointer;
}
a.event-item--link:hover { background: var(--off-white); margin: 0 -1rem; padding-left: 1rem; padding-right: 1rem; }
a.event-item--link:hover .event-info h3 { color: var(--gold); }

.event-gcal-hint {
  display: inline-block;
  margin-top: .35rem;
  font-size: .75rem;
  font-weight: 600;
  color: var(--gold);
  opacity: 0;
  transition: opacity .2s ease;
}
a.event-item--link:hover .event-gcal-hint { opacity: 1; }

/* =====================================================
   1024px — Tablet landscape
   ===================================================== */
@media (max-width: 1024px) {
  .leadership-grid { grid-template-columns: repeat(3, 1fr); }
  .leader-card--primary { grid-column: span 1; }
  .leader-card--primary .leader-img { height: 200px; }
}

/* =====================================================
   900px — Tablet portrait
   ===================================================== */
@media (max-width: 900px) {
  .featured-grid { grid-template-columns: 1fr; }
  .featured-side { flex-direction: row; }
  .featured-card--small { flex: 1; }

  .intro-grid { grid-template-columns: 1fr; gap: 2.5rem; }

  .sermons-grid { grid-template-columns: 1fr; }

  .ministries-grid { grid-template-columns: repeat(2, 1fr); }

  .contact-grid { grid-template-columns: 1fr; gap: 2.5rem; }

  .footer-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .footer-links { grid-template-columns: repeat(3, 1fr); }

  .two-col { grid-template-columns: 1fr; gap: 2rem; }
  .two-col--reverse { direction: ltr; }

  .highlight-cards { grid-template-columns: 1fr 1fr; }

  .giving-features { grid-template-columns: 1fr; }

  .sermon-full-item { grid-template-columns: 64px 1fr auto; gap: 1rem; }
}

/* =====================================================
   768px — Mobile (large phones / small tablets)
   ===================================================== */
@media (max-width: 768px) {
  /* --- Container / global --- */
  .container { padding: 0 1.25rem; }

  .section-title { font-size: 1.8rem; }

  /* --- Topbar --- */
  .topbar-inner > span:not(.topbar-social) { display: none; }
  .topbar-inner { padding: 0 1.25rem; }

  /* --- Header / Nav --- */
  .main-nav { display: none; }
  .nav-toggle { display: flex; }
  .main-nav.open {
    display: flex;
    position: absolute;
    top: 72px;
    left: 0;
    right: 0;
    background: var(--navy-dark);
    flex-direction: column;
    padding: 1rem 0 1.5rem;
    z-index: 999;
    box-shadow: 0 8px 24px rgba(0,0,0,.4);
  }
  .main-nav.open ul { flex-direction: column; gap: 0; }
  .main-nav.open a { display: block; padding: .85rem 1.5rem; font-size: 1rem; border-radius: 0; }
  .site-header { position: sticky; }

  /* --- Logo — prevent overflow on narrow screens --- */
  .logo-name { font-size: .95rem; }
  .logo-location { display: none; }

  /* --- Hero --- */
  .hero { min-height: auto; }
  .hero::after { display: none; }
  .hero-content { padding: 4rem 1.25rem 7rem; }
  .hero-service-bar { position: static; flex-wrap: wrap; }
  .hero-service-bar .service-divider { display: none; }
  .service-info { padding: .9rem 1rem; flex: 1 1 50%; min-width: 0; }

  /* --- Featured / cards --- */
  .featured-side { flex-direction: column; }
  .featured-card-body { padding: 1.25rem; }
  .featured-card--large h2 { font-size: 1.4rem; }

  /* --- Sections padding --- */
  .intro-section,
  .sermons-section,
  .ministries-section,
  .events-section,
  .leadership-section,
  .contact-section,
  .featured-section { padding: 3.5rem 0; }
  .content-section { padding: 3.5rem 0; }

  /* --- Sermons --- */
  .sermon-item { gap: .875rem; }
  .sermon-item-info h4 { font-size: .85rem; }

  /* --- Ministries --- */
  .ministries-grid { grid-template-columns: 1fr; }

  /* --- Events --- */
  .event-item { grid-template-columns: 72px 1fr; gap: 1rem; }
  .event-item:hover { margin: 0; padding-left: 0; padding-right: 0; }
  .event-info h3 { font-size: 1.1rem; }

  /* --- Leadership --- */
  .leadership-grid { grid-template-columns: repeat(2, 1fr); }

  /* --- Highlight cards --- */
  .highlight-cards { grid-template-columns: 1fr; }

  /* --- Contact form --- */
  .contact-form-wrap { padding: 1.75rem 1.25rem; }

  /* --- Footer --- */
  .footer-inner { padding-top: 3rem; padding-bottom: 2rem; }
  .footer-links { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
  .footer-bottom .container { flex-direction: column; align-items: flex-start; gap: .5rem; }

  /* --- Page hero (sub-pages) --- */
  .page-hero { padding: 3.5rem 0 3rem; }
  .page-hero::after { font-size: 8rem; }
  .page-hero h1 { font-size: clamp(1.7rem, 6vw, 2.4rem); }

  /* --- Content image placeholder (ministry pages) --- */
  .content-img-placeholder { height: 240px; }

  /* --- Sermon full list (sermons page) --- */
  .sermon-full-item { grid-template-columns: 60px 1fr; gap: .875rem; }
  .sermon-full-item > a { display: none; }
  .sermon-full-item h3 { font-size: .95rem; }
}

/* =====================================================
   480px — Small phones (iPhone SE, Galaxy A, etc.)
   ===================================================== */
@media (max-width: 480px) {
  /* --- Global spacing --- */
  .container { padding: 0 1rem; }
  .section-title { font-size: 1.6rem; }

  /* --- Buttons stacking in hero --- */
  .hero-cta { flex-direction: column; align-items: flex-start; gap: .75rem; }
  .hero-cta .btn { width: 100%; text-align: center; }
  .hero-content { padding: 3rem 1rem 1.5rem; }

  /* --- Hero service bar — full-width stacked --- */
  .hero-service-bar { flex-direction: column; }
  .service-info { flex: 1 1 100%; padding: .75rem 1.25rem; }

  /* --- Intro cards --- */
  .intro-cards { grid-template-columns: 1fr; }
  .intro-main h2 { font-size: 1.7rem; }

  /* --- Sermons --- */
  .sermon-card-body { padding: 1.25rem 1rem; }
  .sermon-card-body h3 { font-size: 1.1rem; }
  .sermon-item { gap: .75rem; }

  /* --- Ministries --- */
  .ministry-card { padding: 1.5rem; }

  /* --- Events --- */
  .event-item { grid-template-columns: 60px 1fr; gap: .875rem; }
  .event-date-block { padding: .6rem .35rem; }
  .event-day { font-size: 1.6rem; }

  /* --- Leadership --- */
  .leadership-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .leader-img { height: 140px; }
  .leader-info { padding: .75rem; }
  .leader-info h3 { font-size: .9rem; }

  /* --- Highlight / giving cards --- */
  .highlight-card { padding: 1.5rem; }
  .highlight-cards { gap: 1rem; }
  .giving-features { gap: 1rem; }

  /* --- Footer --- */
  .footer-links { grid-template-columns: 1fr 1fr; gap: 1.5rem; }

  /* --- Contact form --- */
  .contact-form-wrap { padding: 1.5rem 1rem; border-radius: 8px; }
  .form-group input,
  .form-group textarea { font-size: .9rem; padding: .7rem .875rem; }

  /* --- Page hero --- */
  .page-hero { padding: 2.5rem 0 2rem; }
  .breadcrumb { font-size: .72rem; }
  .ministry-page-icon { width: 58px; height: 58px; margin-bottom: 1rem; }
  .ministry-page-icon svg { width: 30px; height: 30px; }

  /* --- Content image --- */
  .content-img-placeholder { height: 200px; }

  /* --- Two-col gap --- */
  .two-col { gap: 1.5rem; }
  .content-text h2 { font-size: 1.7rem; }

  /* --- Sermon full list --- */
  .sermon-full-item { grid-template-columns: 52px 1fr; gap: .75rem; padding: 1.25rem 0; }
  .sermon-full-item h3 { font-size: .9rem; }
  .sermon-full-date .day { font-size: 1.2rem; }
}
