/* ============================================================
   Steps of Jesus - main.css
   - Main layout + content styles used across site
   - Theme tokens + nav live in nav.css
   - Episodes archive layout is scoped to body.soj-page-episodes
   ============================================================ */

/* ---------- Global reset ---------- */
* { box-sizing: border-box; }

html, body { height: 100%; }

body{
  margin: 0;
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg);
  color: var(--text-main);
  min-height: 100vh;
}

a{ color: inherit; text-decoration: none; }

/* ---------- Shared shell ---------- */
.soj-shell{
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 12px; /* better than margin hacks on mobile */
}

/* ============================================================
   HERO (index.php)
   ============================================================ */

.soj-hero{
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 2.5rem;
  margin-top: 2.5rem;
  align-items: center;
  color: var(--ink);
}

.soj-kicker{
  font-size: 0.75rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.3rem 0.9rem 0.3rem 0.3rem;
  border-radius: 999px;
  background: var(--card);
  border: 1px solid var(--border-subtle);
  box-shadow: 0 2px 6px rgba(0,0,0,0.25);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.soj-kicker-pill{
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(34,197,94,0.16);
  color: #16a34a;
  font-size: 0.8rem;
}

.soj-hero h1{
  margin: 0.8rem 0 0.4rem;
  font-size: clamp(1.8rem, 5vw, 2.4rem);
  letter-spacing: 0.03em;
  color: var(--ink);
}

.soj-hero h1 span{
  background: linear-gradient(120deg, var(--accent), #facc15);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.soj-hero-sub{
  margin: 0.5rem 0 1.5rem;
  color: var(--muted);
  font-size: 0.98rem;
  max-width: 32rem;
}

/* CTA Buttons */
.soj-hero-cta{
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1.1rem;
}

.soj-btn-primary{
  border: none;
  outline: none;
  padding: 0.7rem 1.4rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), var(--accent-strong));
  color: #fff;
  font-size: 0.92rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 12px 30px rgba(0,0,0,0.5);
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.soj-btn-primary span.icon{ font-size: 1.1rem; }

.soj-btn-ghost{
  padding: 0.65rem 1.3rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.3);
  background: rgba(0,0,0,0.2);
  color: var(--text-main);
  font-size: 0.9rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.soj-btn-ghost span.icon{ font-size: 1rem; }

.soj-platforms{
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  font-size: 0.75rem;
  color: var(--text-muted);
  align-items: center;
}

.badge-pill{
  border-radius: 999px;
  padding: 0.25rem 0.75rem;
  border: 1px solid rgba(255,255,255,0.20);
  background: var(--bg-softer);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  cursor: pointer;
  color: var(--text-main);
}

.badge-pill span.icon{ font-size: 0.95rem; }

.badge-pill:hover{
  border-color: rgba(255,255,255,0.35);
  background: var(--card-bg);
}

/* ============================================================
   HERO PLAYER CARD (shared: index.php + episodes.php)
   ============================================================ */

.soj-hero-card{
  background: var(--card-bg);
  border-radius: 1.5rem;
  padding: 1.5rem 1.3rem;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  overflow: hidden;
}

.soj-hero-card::before{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, var(--accent-soft), transparent 60%);
  opacity: 0.7;
  pointer-events: none;
}

.soj-hero-card-main{
  position: relative;
  z-index: 1;
}

.soj-pill{
  font-size: 0.7rem;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  background: rgba(15,23,42,0.7);
  border: 1px solid rgba(255,255,255,0.18);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.soj-pill span.dot{
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--success);
  box-shadow: 0 0 8px var(--success);
}

.soj-ep-title{
  margin: 0.7rem 0 0.15rem;
  font-size: 1.05rem;
  font-weight: 600;
}

.soj-ep-meta{
  font-size: 0.78rem;
  color: var(--text-muted);
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.soj-chip{
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
  background: rgba(15,23,42,0.8);
  border: 1px solid rgba(255,255,255,0.18);
  font-size: 0.72rem;
}

.soj-wave{
  margin-top: 1rem;
  height: 14px;
  border-radius: 999px;
  background: rgba(148,163,184,0.18);
  overflow: hidden;
  position: relative;
}

.soj-wave-fill{
  position: absolute;
  inset: 0;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--accent-strong));
  transition: width 0.15s linear;
}

/* PLAYER (shared) */
.soj-player-shell{
  position: relative;
  z-index: 1;
  padding: 0.9rem 0.9rem 0.85rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(255,255,255,0.16);
  background:
    radial-gradient(circle at top left, rgba(255,122,60,0.16), transparent 55%),
    var(--card-bg);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.soj-player-top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.soj-player-btn{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: none;
  background: #f9fafb;
  color: #000;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,0.6);
  flex: 0 0 auto;
}

.soj-player-label{
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.soj-player-label span:first-child{
  font-size: 0.75rem;
  color: var(--text-muted);
}

.soj-player-label span:last-child{
  font-size: 0.9rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.soj-player-pills{
  display: flex;
  align-items: center;
  gap: 0.4rem;
  flex: 0 0 auto;
}

.soj-resume-pill{
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: var(--card);
  color: var(--ink);
  padding: 0.35rem 0.85rem;
  font-size: 0.8rem;
  border-radius: 999px;
  border: 1px solid var(--border-subtle);
  box-shadow: 0 2px 6px rgba(0,0,0,0.28);
}

.soj-startover-pill{
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.8rem;
  font-size: 0.78rem;
  border-radius: 999px;
  cursor: pointer;
  background: transparent;
  color: var(--muted);
  border: 1px solid rgba(148,163,184,0.6);
  box-shadow: 0 1px 3px rgba(15,23,42,0.07);
}

.soj-startover-pill .icon{
  font-size: 0.9rem;
  opacity: 0.8;
}

.soj-startover-pill:hover{
  background: rgba(148,163,184,0.06);
}

.soj-timeline-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.soj-timeline-center{
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  min-width: 0;
}

.soj-skip-btn{
  padding: 0.3rem 0.8rem;
  border-radius: 999px;
  font-size: 0.8rem;
  cursor: pointer;
  white-space: nowrap;
  background: var(--bg-soft);
  color: var(--ink);
  border: 1px solid var(--border-subtle);
  box-shadow: 0 2px 6px rgba(0,0,0,0.22);
  font-weight: 500;
}

.soj-skip-btn:hover{
  background: var(--bg-softer);
  box-shadow: 0 3px 10px rgba(0,0,0,0.3);
}

audio{ width: 100%; }

/* Scripture + label chip styling */
#current-ep-short-label,
#current-ep-scripture{
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.75rem;
  font-size: 0.75rem;
  border-radius: 999px;
  background: var(--card);
  color: var(--ink);
  border: 1px solid var(--border-subtle);
  box-shadow: 0 2px 6px rgba(0,0,0,0.24);
}

/* ============================================================
   SECTIONS (shared)
   ============================================================ */

.soj-section{ margin-top: 3rem; }

.soj-section-header{
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  margin-bottom: 1.1rem;
}

.soj-section h2{
  margin: 0;
  font-size: 1.35rem;
}

.soj-section-sub{
  font-size: 0.85rem;
  color: var(--text-muted);
  max-width: 26rem;
}

/* ============================================================
   EPISODE LIST (home + archive uses same container id)
   ============================================================ */

.soj-episode-list{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 1rem;
}

.soj-episode-card{
  border-radius: 1.1rem;
  padding: 0.95rem 0.95rem 0.9rem;
  background: var(--card-bg);
  border: 1px solid var(--border-subtle);
  box-shadow: 0 10px 30px rgba(0,0,0,0.45);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.soj-episode-card:hover{
  border-color: var(--accent-soft);
  transform: translateY(-1px);
  transition: transform 140ms ease-out, box-shadow 140ms ease-out, border-color 140ms ease-out;
}

.soj-episode-card::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(249,115,22,0.10);
  opacity: 0;
  transition: opacity 140ms ease-out;
  pointer-events: none;
}

.soj-episode-card:hover::after{ opacity: 1; }

.soj-ep-row-top{
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

.soj-ep-badge{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  background: var(--accent-soft);
  color: var(--accent-strong);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 600;
}

.soj-ep-text{
  flex: 1;
  min-width: 0;
}

.soj-ep-text h3{
  margin: 0;
  font-size: 0.98rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.soj-ep-text .meta-line{
  margin-top: 0.15rem;
  font-size: 0.75rem;
  color: var(--text-muted);
  display: flex;
  gap: 0.45rem;
  align-items: center;
  flex-wrap: wrap;
}

.soj-ep-play-cta{
  font-size: 0.75rem;
  padding: 0.3rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.35);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}

.soj-ep-desc{
  font-size: 0.78rem;
  color: var(--text-muted);
}

.soj-ep-tags{
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.15rem;
}

.soj-ep-tag{
  font-size: 0.7rem;
  padding: 0.16rem 0.5rem;
  border-radius: 999px;
  background: rgba(15,23,42,0.75);
  border: 1px solid rgba(255,255,255,0.08);
}

/* ============================================================
   ABOUT & CONTACT
   ============================================================ */

.soj-about-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 2rem;
  margin-top: 1.5rem;
}

.soj-about-card,
.soj-contact-card{
  background: var(--card-bg);
  border-radius: 1.1rem;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-soft);
  padding: 1.1rem 1rem 1.1rem;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.soj-about-card h3,
.soj-contact-card h3{
  margin-top: 0;
  margin-bottom: 0.35rem;
  font-size: 1.05rem;
  color: var(--text-main);
}

.soj-contact-form{
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: 0.4rem;
}

.soj-field{
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  font-size: 0.8rem;
}

.soj-field label{ color: var(--text-muted); }

.soj-field input,
.soj-field textarea{
  border-radius: 0.7rem;
  border: 1px solid rgba(148,163,184,0.5);
  padding: 0.5rem 0.7rem;
  font: inherit;
  background: rgba(15,23,42,0.8);
  color: var(--text-main);
  resize: vertical;
  min-height: 2.3rem;
}

.soj-field textarea{ min-height: 90px; }

.soj-field input::placeholder,
.soj-field textarea::placeholder{
  color: rgba(148,163,184,0.85);
  font-size: 0.8rem;
}

.soj-contact-note{
  font-size: 0.78rem;
  color: var(--text-muted);
  margin-top: 0.35rem;
}

.soj-btn-small{
  align-self: flex-start;
  border-radius: 999px;
  border: none;
  padding: 0.5rem 1.2rem;
  font-size: 0.85rem;
  font-weight: 600;
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  margin-top: 0.3rem;
}

/* ============================================================
   FOOTER
   ============================================================ */

footer.soj-footer{
  margin-top: 3rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border-subtle);
  font-size: 0.78rem;
  color: var(--text-muted);
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: space-between;
}

.soj-footer-links{
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.soj-footer-links a{
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 3px;
}

/* ============================================================
   Admin / Upload (unchanged, kept)
   ============================================================ */

.soj-admin-layout{
  margin-top: 2.5rem;
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 2rem;
  align-items: flex-start;
}

.soj-admin-card{
  background: var(--card-bg);
  border-radius: 1.2rem;
  padding: 1.2rem 1.2rem 1.3rem;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-soft);
}

.soj-admin-card h2{
  margin-top: 0;
  margin-bottom: 0.25rem;
}

.soj-admin-side{
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.soj-admin-info-card{
  background: var(--card-bg);
  border-radius: 1.1rem;
  padding: 1rem 1rem 1.1rem;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-soft);
  font-size: 0.85rem;
}

.soj-admin-info-card h3{
  margin-top: 0;
  margin-bottom: 0.4rem;
  font-size: 1rem;
}

.soj-admin-info-card ol{
  padding-left: 1.1rem;
  margin: 0 0 0.4rem;
  font-size: 0.85rem;
}

.soj-admin-info-card li + li{ margin-top: 0.15rem; }

.soj-alert{
  border-radius: 0.9rem;
  padding: 0.8rem 0.95rem;
  margin-bottom: 1rem;
  font-size: 0.85rem;
}

.soj-alert ul{
  margin: 0.35rem 0 0;
  padding-left: 1.1rem;
}

.soj-alert-error{
  background: rgba(239,68,68,0.18);
  border: 1px solid rgba(239,68,68,0.7);
  color: #fecaca;
}

.soj-alert-success{
  background: rgba(34,197,94,0.18);
  border: 1px solid rgba(34,197,94,0.7);
  color: #bbf7d0;
}

.soj-snippet{
  width: 100%;
  min-height: 140px;
  border-radius: 0.8rem;
  border: 1px solid rgba(148,163,184,0.8);
  background: rgba(15,23,42,0.95);
  color: #e5e7eb;
  padding: 0.75rem;
  font-family: Consolas, "Fira Code", monospace;
  font-size: 0.8rem;
  resize: vertical;
}

.soj-snippet-note{
  font-size: 0.78rem;
  color: var(--text-muted);
  margin-top: 0.3rem;
}

.soj-admin-divider{
  border: none;
  border-top: 1px solid var(--border-subtle);
  margin: 1.5rem 0 1.3rem;
}

.soj-field-row{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.soj-admin-file-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.soj-admin-file-list li{
  padding: 0.45rem 0.55rem;
  border-radius: 0.7rem;
  background: rgba(15,23,42,0.75);
  border: 1px solid rgba(148,163,184,0.35);
}

.soj-admin-file-list .file-name{
  font-size: 0.82rem;
  font-weight: 500;
}

.soj-admin-file-list .file-meta{
  font-size: 0.75rem;
  color: var(--text-muted);
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
}

@media (max-width: 900px){
  .soj-admin-layout{ grid-template-columns: minmax(0, 1fr); }
  .soj-field-row{ grid-template-columns: minmax(0, 1fr); }
}

/* ============================================================
   Walk With Jesus Split Section (index.php)
   ============================================================ */

.soj-walk-split{
  display: flex;
  align-items: center;
  gap: 2.5rem;
  margin: 3rem 0;
  padding: 2rem;
  border-radius: 20px;
  background: var(--card);
  box-shadow: 0 4px 14px rgba(0,0,0,0.07);
  overflow: hidden;
}

.soj-walk-text{
  flex: 1;
  max-width: 540px;
}

.soj-walk-text h2{
  margin: 0 0 0.75rem;
  font-size: 2rem;
  font-weight: 700;
}

.soj-walk-text p{
  margin: 0.5rem 0;
  line-height: 1.65;
}

.soj-walk-kicker{
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  opacity: 0.8;
  margin-bottom: 0.5rem;
}

.soj-walk-verse{
  margin-top: 1rem;
  font-style: italic;
  opacity: 0.95;
}

.soj-walk-verse span{
  font-style: normal;
  font-weight: 600;
  margin-left: 0.35rem;
}

.soj-walk-image-wrap{
  flex: 1;
  display: flex;
  justify-content: center;
}

.soj-walk-image{
  width: 100%;
  height: auto;
  border-radius: 18px;
  object-fit: contain;
  box-shadow: 0 4px 14px rgba(0,0,0,0.15);
}

@media (max-width: 820px){
  .soj-walk-split{
    flex-direction: column-reverse;
    padding: 1.5rem;
  }
  .soj-walk-image{
    width: 100%;
    max-height: 380px;
    object-fit: contain;
  }
  .soj-walk-text h2{ font-size: 1.6rem; }
}

/* ============================================================
   Responsive (shared)
   ============================================================ */

@media (max-width: 900px){
  .soj-hero{ grid-template-columns: minmax(0, 1fr); }
  .soj-hero-card{ order: -1; }
  .soj-about-grid{ grid-template-columns: minmax(0, 1fr); }
}

@media (max-width: 800px){
  .soj-episode-list{ grid-template-columns: minmax(0, 1fr); }
}

/* Make player controls behave on small screens */
@media (max-width: 520px){
  .soj-player-top{
    flex-wrap: wrap;
    justify-content: flex-start;
  }
  .soj-player-pills{
    width: 100%;
    justify-content: flex-start;
  }
}

/* ============================================================
   EPISODES ARCHIVE LAYOUT (episodes.php only)
   Requires: <body class="soj-page-episodes">
   ============================================================ */

body.soj-page-episodes .soj-main{
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 1.1rem 0.75rem 2.25rem; /* FIXED: no giant 5rem top padding */
}

body.soj-page-episodes .soj-main .soj-section{
  margin-top: 1.5rem; /* override shared 3rem */
}

body.soj-page-episodes .soj-archive-header h1{
  font-size: clamp(2.1rem, 3vw, 2.6rem);
  margin: 0 0 0.5rem;
}

body.soj-page-episodes .soj-archive-header p{
  margin: 0;
  opacity: 0.85;
  max-width: 42rem;
}

/* Player + filters layout */
body.soj-page-episodes .soj-archive-top{
  display: grid;
  gap: 1.1rem;
  align-items: start;
  margin-top: 1.25rem;
}

/* Desktop 2-col */
@media (min-width: 980px){
  body.soj-page-episodes .soj-archive-top{
    grid-template-columns: minmax(0, 460px) minmax(0, 1fr);
  }
  body.soj-page-episodes .soj-archive-top #listen{
    position: sticky;
    top: 92px; /* adjust if your sticky header height differs */
  }
}

/* Filters spacing */
body.soj-page-episodes .soj-archive-filters .soj-section-sub{
  max-width: 44rem;
}

body.soj-page-episodes .soj-filters-row{
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 0.9rem;
  margin-top: 0.75rem;
}

@media (max-width: 740px){
  body.soj-page-episodes .soj-filters-row{
    grid-template-columns: 1fr;
  }
}

/* Archive list can be denser without changing home page */
body.soj-page-episodes #episodes .soj-section-sub{
  max-width: 46rem;
}
