/* ============================================================
   SOLUA — For Couples
   Extends styles.css + parents.css. Reuses the proven layout
   components (par-hero, help-grid, age-band, timeline, par-quote)
   with a couple-specific identity: warm terracotta (Pentecost /
   the love that binds) as the lead accent, and a Scripture band
   unique to this page.
   ============================================================ */

/* lead accent for couples — terracotta over the parents' sage */
:root { --clay-deep: #9C5746; }

/* ---------- hero: re-tint the glows toward the warm clay ---------- */
.cpl-hero .hero-glow {
  background: radial-gradient(circle, rgba(184,107,90,0.46) 0%, rgba(184,107,90,0.10) 44%, transparent 68%);
}
.cpl-hero .hero-glow.two {
  background: radial-gradient(circle, rgba(212,183,133,0.26) 0%, transparent 66%);
}
.cpl-hero .hero-trust .stars { color: var(--color-christmas); }

/* floating "for two" card — warm clay icon tile */
.cpl-hero .ph-card .ph-ico { background: rgba(184,107,90,0.22); color: #E69A86; }

/* the two intertwined rings mark, used in the eyebrow + closing */
.rings { display: inline-flex; }
.rings svg { width: 17px; height: 17px; }

/* ---------- editorial sacrament statement (reuses .first-teacher) ---------- */
.sacrament .ft-eyebrow { color: var(--clay); }
.sacrament p.lead b { color: var(--clay-deep); }

/* ---------- help cards: warm the icon tiles ---------- */
.cpl-help .help .h-ico { background: rgba(184,107,90,0.12); color: var(--clay); }

/* ---------- "shared prayer" feature — two phones beginning together ---------- */
.shared { background: var(--color-surface-1); }
.shared .wrap {
  display: grid; grid-template-columns: 1fr 0.92fr; gap: 64px; align-items: center;
}
.shared .section-head { margin-bottom: 0; }
.shared-points { list-style: none; padding: 0; margin: 30px 0 0; display: flex; flex-direction: column; gap: 20px; }
.shared-points li { display: flex; gap: 15px; }
.shared-points .ico {
  width: 40px; height: 40px; border-radius: 12px; flex-shrink: 0;
  display: grid; place-items: center; background: var(--color-cream); color: var(--clay);
}
.shared-points .ico svg { width: 20px; height: 20px; }
.shared-points h4 { margin: 1px 0 4px; font-size: 17px; font-weight: 600; }
.shared-points p { margin: 0; font-size: 15px; line-height: 1.5; color: var(--color-text-secondary); text-wrap: pretty; }

/* the paired-phones visual */
.pair {
  position: relative; display: grid; place-items: center;
  padding: 14px 0;
}
.pair-phone {
  width: 218px; aspect-ratio: 9 / 18.6; border-radius: 32px;
  background: #0c0b0a; padding: 8px;
  box-shadow: 0 30px 60px rgba(31,29,27,0.26), 0 0 0 1px rgba(31,29,27,0.06);
}
.pair-phone.back {
  position: absolute; top: -22px; left: calc(50% - 150px);
  transform: rotate(-7deg); opacity: .82; width: 196px;
  filter: saturate(0.92);
}
.pair-phone.front { transform: rotate(4deg); z-index: 2; }
.pair-screen {
  width: 100%; height: 100%; border-radius: 25px; overflow: hidden;
  background: var(--color-cream); display: flex; flex-direction: column;
  padding: 22px 18px; position: relative;
}
.pair-screen .ps-top { display: flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 600; color: var(--clay); letter-spacing: 0.08em; text-transform: uppercase; }
.pair-screen .ps-top .live { width: 7px; height: 7px; border-radius: 50%; background: var(--clay); box-shadow: 0 0 0 0 rgba(184,107,90,.5); animation: pulse-clay 2.2s infinite; }
@keyframes pulse-clay { 0%{ box-shadow:0 0 0 0 rgba(184,107,90,.5);} 70%{ box-shadow:0 0 0 8px rgba(184,107,90,0);} 100%{ box-shadow:0 0 0 0 rgba(184,107,90,0);} }
.pair-screen h5 { margin: 16px 0 5px; font-size: 19px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.12; }
.pair-screen .ps-meta { font-size: 12px; color: var(--color-text-secondary); margin: 0 0 18px; }
.pair-screen .ps-art {
  margin-top: auto; height: 124px; border-radius: 16px; overflow: hidden; position: relative;
}
.pair-screen .ps-art img { width: 100%; height: 100%; object-fit: cover; }
.pair-screen .ps-who {
  position: absolute; left: 10px; bottom: 10px; right: 10px; z-index: 2;
  display: flex; align-items: center; gap: 7px; color: var(--color-cream); font-size: 11px; font-weight: 600;
}
.pair-screen .ps-who .av { display: flex; }
.pair-screen .ps-who .av span { width: 22px; height: 22px; border-radius: 50%; margin-left: -7px; border: 2px solid rgba(0,0,0,0.3); }
.pair-screen .ps-who .av span:first-child { margin-left: 0; }
.pair-screen .ps-scrim { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.55)); }

/* ---------- seasons of marriage band — re-uses .ages / .age-row ---------- */
/* (no overrides needed; segment colors set inline per row) */

/* ---------- Scripture band (unique to couples) — dark, centered ---------- */
.verse { background: var(--hero-ink); color: var(--color-cream); position: relative; overflow: hidden; text-align: center; }
.verse .hero-glow { top: -30%; left: 50%; transform: translateX(-50%); right: auto; width: 760px; height: 760px;
  background: radial-gradient(circle, rgba(184,107,90,0.30) 0%, transparent 64%); }
.verse .wrap { position: relative; z-index: 2; max-width: 900px; }
.verse .v-cross {
  width: 50px; height: 50px; border-radius: 15px; margin: 0 auto 30px;
  display: grid; place-items: center; background: rgba(184,107,90,0.18); color: #E69A86;
}
.verse .v-cross svg { width: 24px; height: 24px; }
.verse blockquote {
  margin: 0; font-weight: 300; font-style: italic;
  font-size: clamp(28px, 4vw, 48px); line-height: 1.26; letter-spacing: -0.02em;
  color: var(--color-cream); text-wrap: balance;
}
.verse cite {
  display: block; margin-top: 26px; font-style: normal; font-weight: 600;
  font-size: 14px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(250,247,242,0.6);
}

/* ---------- couple quote: warm the stars + larger photo (reuses .par-quote) ---------- */
.cpl-quote .pq-who .stars { color: var(--color-christmas); }
.cpl-quote .wrap { gap: 56px; }
.cpl-quote .pq-photo { width: 240px; height: 280px; }
@media (max-width: 560px) {
  .cpl-quote .pq-photo { width: 100%; height: 280px; }
}

/* ---------- closing accent ---------- */
.cpl-closing .closing-badge { background: var(--clay); }

/* ---------- responsive ---------- */
@media (max-width: 980px) {
  .shared .wrap { grid-template-columns: 1fr; gap: 44px; }
  .pair { order: -1; }
}
@media (max-width: 560px) {
  .pair-phone.front { width: 200px; }
  .pair-phone.back { display: none; }
}
