/* ============================================================
   Diedrich Jewelers — JM Care Plan Page Styles
   Scope: .djw-careplan
   File: diedrich-careplan.css
   Upload to FTP and call via global header script tag
   ============================================================ */

/* --- Variables --- */
.djw-careplan {
  --djw-bg: #FCFAF8;
  --djw-alt: #F8F4EF;
  --djw-gold: #BDA078;
  --djw-dark-bg: #7D7C7C;
  --djw-dark-text: #383333;
  --djw-light-text: #FCFAF8;
  --djw-font-heading: 'Alga', 'Cormorant Garamond', Georgia, serif;
  --djw-font-body: 'Gotham', 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  --djw-radius: 2px;
  --djw-transition: all 0.3s ease;
  --djw-max-width: 1140px;
  --djw-section-pad: 90px 24px;
  font-family: var(--djw-font-body) !important;
  color: var(--djw-dark-text) !important;
  background-color: var(--djw-bg) !important;
}

/* --- Reset within scope --- */
.djw-careplan *,
.djw-careplan *::before,
.djw-careplan *::after {
  box-sizing: border-box !important;
}

.djw-careplan p,
.djw-careplan h1,
.djw-careplan h2,
.djw-careplan h3,
.djw-careplan ul,
.djw-careplan li,
.djw-careplan details,
.djw-careplan summary {
  margin: 0 !important;
  padding: 0 !important;
}

/* --- Container --- */
.djw-careplan .djw-cp-container {
  max-width: var(--djw-max-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  width: 100% !important;
}

/* --- Typography --- */
.djw-careplan h1,
.djw-careplan h2,
.djw-careplan h3 {
  font-family: var(--djw-font-heading) !important;
  color: var(--djw-dark-text) !important;
  font-weight: 400 !important;
  line-height: 1.15 !important;
  letter-spacing: 0.01em !important;
}

.djw-careplan h1 {
  font-size: clamp(2.8rem, 6vw, 5rem) !important;
  margin-bottom: 20px !important;
}

.djw-careplan h2 {
  font-size: clamp(2rem, 4vw, 3rem) !important;
  margin-bottom: 20px !important;
}

.djw-careplan h3 {
  font-size: 1.25rem !important;
  margin-bottom: 10px !important;
}

.djw-careplan p {
  font-family: var(--djw-font-body) !important;
  font-size: 0.975rem !important;
  line-height: 1.75 !important;
  color: var(--djw-dark-text) !important;
  margin-bottom: 16px !important;
}

.djw-careplan p:last-child {
  margin-bottom: 0 !important;
}

.djw-careplan .djw-cp-center {
  text-align: center !important;
}

.djw-careplan .djw-cp-light-text,
.djw-careplan .djw-cp-light-text p,
.djw-careplan .djw-cp-light-text h2 {
  color: var(--djw-light-text) !important;
}

/* --- Eyebrow --- */
.djw-careplan .djw-cp-eyebrow {
  font-family: var(--djw-font-body) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--djw-gold) !important;
  margin-bottom: 14px !important;
  display: block !important;
}

.djw-careplan .djw-cp-eyebrow-light {
  color: var(--djw-gold) !important;
}

/* --- Buttons --- */
.djw-careplan .djw-cp-btn {
  display: inline-block !important;
  background-color: var(--djw-gold) !important;
  color: var(--djw-light-text) !important;
  font-family: var(--djw-font-body) !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  padding: 14px 32px !important;
  border: 2px solid var(--djw-gold) !important;
  border-radius: var(--djw-radius) !important;
  transition: var(--djw-transition) !important;
  cursor: pointer !important;
  margin-top: 24px !important;
}

.djw-careplan .djw-cp-btn:hover {
  background-color: transparent !important;
  color: var(--djw-gold) !important;
}

.djw-careplan .djw-cp-btn-outline {
  background-color: transparent !important;
  color: var(--djw-light-text) !important;
  border-color: var(--djw-light-text) !important;
}

.djw-careplan .djw-cp-btn-outline:hover {
  background-color: var(--djw-light-text) !important;
  color: var(--djw-dark-text) !important;
}

.djw-careplan .djw-cp-btn-light {
  background-color: var(--djw-light-text) !important;
  color: var(--djw-dark-text) !important;
  border-color: var(--djw-light-text) !important;
}

.djw-careplan .djw-cp-btn-light:hover {
  background-color: transparent !important;
  color: var(--djw-light-text) !important;
}

/* --- Sections --- */
.djw-careplan section {
  padding: var(--djw-section-pad) !important;
}

.djw-careplan .djw-cp-light {
  background-color: var(--djw-bg) !important;
}

.djw-careplan .djw-cp-alt {
  background-color: var(--djw-alt) !important;
}

.djw-careplan .djw-cp-dark {
  background-color: var(--djw-dark-bg) !important;
}

/* --- Hero --- */
.djw-careplan .djw-cp-hero {
  background-color: var(--djw-dark-text) !important;
  text-align: center !important;
  padding: 120px 24px !important;
  position: relative !important;
  overflow: hidden !important;
}

.djw-careplan .djw-cp-hero::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: radial-gradient(ellipse at 60% 50%, rgba(189, 160, 120, 0.12) 0%, transparent 70%) !important;
  pointer-events: none !important;
}

.djw-careplan .djw-cp-hero h1 {
  color: var(--djw-light-text) !important;
  margin-bottom: 20px !important;
}

.djw-careplan .djw-cp-hero .djw-cp-hero-sub {
  color: rgba(252, 250, 248, 0.75) !important;
  max-width: 620px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  font-size: 1.05rem !important;
  margin-bottom: 0 !important;
}

/* --- Included Banner --- */
.djw-careplan .djw-cp-included-banner {
  background-color: var(--djw-gold) !important;
  padding: 22px 24px !important;
}

.djw-careplan .djw-cp-included-inner {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  justify-content: center !important;
}

.djw-careplan .djw-cp-included-icon {
  font-size: 1.2rem !important;
  color: var(--djw-light-text) !important;
  font-weight: 700 !important;
  flex-shrink: 0 !important;
}

.djw-careplan .djw-cp-included-inner p {
  color: var(--djw-light-text) !important;
  font-weight: 700 !important;
  font-size: 0.9rem !important;
  letter-spacing: 0.02em !important;
  text-align: center !important;
  margin-bottom: 0 !important;
}

/* --- Two Column Layout --- */
.djw-careplan .djw-cp-two-col {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 80px !important;
  align-items: center !important;
}

.djw-careplan .djw-cp-col-text p {
  margin-bottom: 16px !important;
}

/* --- Visual Card --- */
.djw-careplan .djw-cp-visual-card {
  background-color: var(--djw-dark-text) !important;
  padding: 48px 40px !important;
  border-radius: var(--djw-radius) !important;
}

.djw-careplan .djw-cp-vc-item {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  padding: 24px 0 !important;
}

.djw-careplan .djw-cp-vc-num {
  font-family: var(--djw-font-heading) !important;
  font-size: 3rem !important;
  color: var(--djw-gold) !important;
  line-height: 1 !important;
}

.djw-careplan .djw-cp-vc-label {
  font-size: 0.8rem !important;
  color: rgba(252, 250, 248, 0.7) !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
}

.djw-careplan .djw-cp-vc-divider {
  height: 1px !important;
  background-color: rgba(252, 250, 248, 0.1) !important;
}

/* --- Section Intro --- */
.djw-careplan .djw-cp-section-intro {
  max-width: 700px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
  margin-bottom: 56px !important;
  font-size: 1rem !important;
}

/* --- Coverage Grid --- */
.djw-careplan .djw-cp-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  margin-bottom: 40px !important;
}

.djw-careplan .djw-cp-card {
  background-color: var(--djw-bg) !important;
  padding: 36px 28px !important;
  border-radius: var(--djw-radius) !important;
  border: 1px solid rgba(189, 160, 120, 0.2) !important;
  transition: var(--djw-transition) !important;
}

.djw-careplan .djw-cp-card:hover {
  border-color: var(--djw-gold) !important;
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 40px rgba(56, 51, 51, 0.08) !important;
}

.djw-careplan .djw-cp-card-icon {
  width: 44px !important;
  height: 44px !important;
  margin-bottom: 20px !important;
}

.djw-careplan .djw-cp-card-icon svg {
  width: 100% !important;
  height: 100% !important;
}

.djw-careplan .djw-cp-card h3 {
  margin-bottom: 10px !important;
  font-size: 1.1rem !important;
}

.djw-careplan .djw-cp-card p {
  font-size: 0.9rem !important;
  line-height: 1.65 !important;
  margin-bottom: 0 !important;
}

/* --- Disclaimer --- */
.djw-careplan .djw-cp-disclaimer {
  font-size: 0.78rem !important;
  color: rgba(56, 51, 51, 0.55) !important;
  text-align: center !important;
  max-width: 680px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 0 !important;
  font-style: italic !important;
}

/* --- Plan Cards --- */
.djw-careplan .djw-cp-plans {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 28px !important;
  max-width: 880px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 48px !important;
}

.djw-careplan .djw-cp-plan-card {
  background-color: rgba(252, 250, 248, 0.06) !important;
  border: 1px solid rgba(252, 250, 248, 0.15) !important;
  padding: 44px 36px !important;
  border-radius: var(--djw-radius) !important;
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
}

.djw-careplan .djw-cp-plan-featured {
  background-color: rgba(189, 160, 120, 0.12) !important;
  border-color: var(--djw-gold) !important;
}

.djw-careplan .djw-cp-plan-badge {
  position: absolute !important;
  top: -14px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  background-color: var(--djw-gold) !important;
  color: var(--djw-light-text) !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  padding: 5px 16px !important;
  white-space: nowrap !important;
  margin-bottom: 0 !important;
}

.djw-careplan .djw-cp-plan-label {
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--djw-gold) !important;
  margin-bottom: 8px !important;
}

.djw-careplan .djw-cp-plan-title {
  font-family: var(--djw-font-heading) !important;
  font-size: 2rem !important;
  color: var(--djw-light-text) !important;
  margin-bottom: 16px !important;
}

.djw-careplan .djw-cp-plan-desc {
  color: rgba(252, 250, 248, 0.75) !important;
  font-size: 0.9rem !important;
  line-height: 1.7 !important;
  margin-bottom: 24px !important;
}

.djw-careplan .djw-cp-plan-list {
  list-style: none !important;
  padding: 0 !important;
  margin-bottom: 0 !important;
  flex-grow: 1 !important;
}

.djw-careplan .djw-cp-plan-list li {
  font-size: 0.88rem !important;
  color: rgba(252, 250, 248, 0.85) !important;
  padding: 10px 0 !important;
  border-bottom: 1px solid rgba(252, 250, 248, 0.08) !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 0 !important;
}

.djw-careplan .djw-cp-plan-list li::before {
  content: '—' !important;
  color: var(--djw-gold) !important;
  font-size: 0.75rem !important;
  flex-shrink: 0 !important;
}

/* --- Steps --- */
.djw-careplan .djw-cp-steps {
  display: flex !important;
  align-items: flex-start !important;
  gap: 24px !important;
  margin-top: 56px !important;
}

.djw-careplan .djw-cp-step {
  flex: 1 !important;
  text-align: center !important;
}

.djw-careplan .djw-cp-step-num {
  font-family: var(--djw-font-heading) !important;
  font-size: 3.5rem !important;
  color: var(--djw-gold) !important;
  line-height: 1 !important;
  margin-bottom: 16px !important;
  display: block !important;
}

.djw-careplan .djw-cp-step h3 {
  margin-bottom: 12px !important;
}

.djw-careplan .djw-cp-step p {
  font-size: 0.9rem !important;
  margin-bottom: 0 !important;
}

.djw-careplan .djw-cp-step-arrow {
  font-size: 1.5rem !important;
  color: var(--djw-gold) !important;
  margin-top: 60px !important;
  flex-shrink: 0 !important;
}

/* --- FAQ --- */
.djw-careplan .djw-cp-faq-wrap {
  max-width: 800px !important;
}

.djw-careplan .djw-cp-faqs {
  margin-top: 48px !important;
  border-top: 1px solid rgba(56, 51, 51, 0.15) !important;
}

.djw-careplan .djw-cp-faq {
  border-bottom: 1px solid rgba(56, 51, 51, 0.15) !important;
  padding: 0 !important;
}

.djw-careplan .djw-cp-faq summary {
  font-family: var(--djw-font-body) !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  color: var(--djw-dark-text) !important;
  padding: 22px 40px 22px 0 !important;
  cursor: pointer !important;
  list-style: none !important;
  position: relative !important;
  display: block !important;
}

.djw-careplan .djw-cp-faq summary::-webkit-details-marker {
  display: none !important;
}

.djw-careplan .djw-cp-faq summary::after {
  content: '+' !important;
  position: absolute !important;
  right: 0 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 1.4rem !important;
  color: var(--djw-gold) !important;
  font-weight: 300 !important;
  transition: var(--djw-transition) !important;
}

.djw-careplan .djw-cp-faq[open] summary::after {
  content: '−' !important;
}

.djw-careplan .djw-cp-faq p {
  padding: 0 40px 22px 0 !important;
  font-size: 0.9rem !important;
  color: rgba(56, 51, 51, 0.75) !important;
  margin-bottom: 0 !important;
}

/* --- CTA Banner --- */
.djw-careplan .djw-cp-cta-banner {
  background-color: var(--djw-dark-text) !important;
  padding: 80px 24px !important;
}

.djw-careplan .djw-cp-cta-inner {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 40px !important;
}

.djw-careplan .djw-cp-cta-inner h2 {
  color: var(--djw-light-text) !important;
  margin-bottom: 12px !important;
}

.djw-careplan .djw-cp-cta-inner p {
  color: rgba(252, 250, 248, 0.75) !important;
  max-width: 520px !important;
  margin-bottom: 0 !important;
}

.djw-careplan .djw-cp-cta-inner .djw-cp-btn-light {
  flex-shrink: 0 !important;
  margin-top: 0 !important;
}

/* --- Credit Footer --- */
.djw-careplan .djw-cp-credit {
  background-color: var(--djw-alt) !important;
  padding: 28px 24px !important;
  border-top: 1px solid rgba(189, 160, 120, 0.2) !important;
}

.djw-careplan .djw-cp-credit-inner {
  text-align: center !important;
}

.djw-careplan .djw-cp-credit p {
  font-size: 0.78rem !important;
  color: rgba(56, 51, 51, 0.55) !important;
  font-style: italic !important;
  margin-bottom: 0 !important;
}

.djw-careplan .djw-cp-credit a {
  color: var(--djw-gold) !important;
  text-decoration: underline !important;
  transition: var(--djw-transition) !important;
}

.djw-careplan .djw-cp-credit a:hover {
  color: var(--djw-dark-text) !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1023px) {
  .djw-careplan .djw-cp-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .djw-careplan .djw-cp-two-col {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
}

@media (max-width: 767px) {
  .djw-careplan {
    --djw-section-pad: 60px 20px;
  }

  .djw-careplan .djw-cp-grid {
    grid-template-columns: 1fr !important;
  }

  .djw-careplan .djw-cp-plans {
    grid-template-columns: 1fr !important;
  }

  .djw-careplan .djw-cp-steps {
    flex-direction: column !important;
    align-items: center !important;
  }

  .djw-careplan .djw-cp-step-arrow {
    transform: rotate(90deg) !important;
    margin-top: 0 !important;
  }

  .djw-careplan .djw-cp-cta-inner {
    flex-direction: column !important;
    text-align: center !important;
    align-items: center !important;
  }

  .djw-careplan .djw-cp-cta-inner p {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .djw-careplan .djw-cp-hero {
    padding: 80px 20px !important;
  }

  .djw-careplan .djw-cp-included-inner {
    flex-direction: column !important;
    text-align: center !important;
  }

  .djw-careplan .djw-cp-visual-card {
    padding: 36px 24px !important;
  }
}

@media (max-width: 479px) {
  .djw-careplan .djw-cp-faq summary {
    padding-right: 28px !important;
    font-size: 0.88rem !important;
  }

  .djw-careplan .djw-cp-plan-card {
    padding: 36px 24px !important;
  }
}

/* ============================================================
   SPARKLE REWARDS PAGE — Additional Styles
   Scope: .djw-sparkle (used alongside .djw-careplan)
   ============================================================ */

/* --- Hero override for Sparkle --- */
.djw-sparkle .djw-sr-hero {
  position: relative !important;
  overflow: hidden !important;
}

.djw-sparkle .djw-sr-hero::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: radial-gradient(ellipse at 30% 60%, rgba(189, 160, 120, 0.14) 0%, transparent 65%) !important;
  pointer-events: none !important;
}

.djw-sparkle .djw-sr-hero-inner {
  position: relative !important;
  z-index: 1 !important;
}

.djw-sparkle .djw-sr-hero-badge {
  position: absolute !important;
  top: 36px !important;
  right: 48px !important;
  z-index: 2 !important;
  border: 1px solid var(--djw-gold) !important;
  padding: 8px 20px !important;
  border-radius: 40px !important;
}

.djw-sparkle .djw-sr-badge-text {
  font-family: var(--djw-font-body) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--djw-gold) !important;
}

/* --- Intro Grid --- */
.djw-sparkle .djw-sr-intro-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 80px !important;
  align-items: center !important;
}

/* --- Stat Stack --- */
.djw-sparkle .djw-sr-stat-stack {
  background-color: var(--djw-dark-text) !important;
  padding: 48px 40px !important;
  border-radius: var(--djw-radius) !important;
}

.djw-sparkle .djw-sr-stat {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  padding: 24px 0 !important;
}

.djw-sparkle .djw-sr-stat-num {
  font-family: var(--djw-font-heading) !important;
  font-size: 2.8rem !important;
  color: var(--djw-gold) !important;
  line-height: 1 !important;
}

.djw-sparkle .djw-sr-stat-label {
  font-size: 0.78rem !important;
  color: rgba(252, 250, 248, 0.7) !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
}

.djw-sparkle .djw-sr-stat-divider {
  height: 1px !important;
  background-color: rgba(252, 250, 248, 0.1) !important;
}

/* --- Benefits grid override (3 col) --- */
.djw-sparkle .djw-sr-benefits-grid {
  grid-template-columns: repeat(3, 1fr) !important;
}

/* --- Dark Two Col --- */
.djw-sparkle .djw-sr-two-col-dark {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 64px !important;
  margin-top: 56px !important;
}

.djw-sparkle .djw-sr-dark-col-title {
  font-family: var(--djw-font-heading) !important;
  font-size: 1.4rem !important;
  color: var(--djw-light-text) !important;
  margin-bottom: 20px !important;
  font-weight: 400 !important;
  letter-spacing: 0.05em !important;
}

.djw-sparkle .djw-sr-dark-col-body {
  color: rgba(252, 250, 248, 0.95) !important;
  font-size: 0.9rem !important;
  line-height: 1.75 !important;
  margin-bottom: 16px !important;
}

.djw-sparkle .djw-sr-dark-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.djw-sparkle .djw-sr-dark-list li {
  font-size: 0.88rem !important;
  color: rgba(252, 250, 248, 0.95) !important;
  padding: 10px 0 !important;
  border-bottom: 1px solid rgba(252, 250, 248, 0.08) !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  margin-bottom: 0 !important;
  line-height: 1.6 !important;
}

.djw-sparkle .djw-sr-dark-list li::before {
  content: '—' !important;
  color: var(--djw-gold) !important;
  font-size: 0.75rem !important;
  flex-shrink: 0 !important;
  margin-top: 2px !important;
}

/* --- Birthday Section --- */
.djw-sparkle .djw-sr-birthday-wrap {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 80px !important;
  align-items: center !important;
}

.djw-sparkle .djw-sr-birthday-card {
  background-color: var(--djw-dark-text) !important;
  border-radius: var(--djw-radius) !important;
  overflow: hidden !important;
  position: relative !important;
}

.djw-sparkle .djw-sr-birthday-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  background-color: var(--djw-gold) !important;
}

.djw-sparkle .djw-sr-birthday-card-inner {
  padding: 48px 40px !important;
  text-align: center !important;
}

.djw-sparkle .djw-sr-bday-icon {
  display: block !important;
  font-size: 1.8rem !important;
  color: var(--djw-gold) !important;
  margin-bottom: 16px !important;
}

.djw-sparkle .djw-sr-bday-amount {
  font-family: var(--djw-font-heading) !important;
  font-size: 3.5rem !important;
  color: var(--djw-light-text) !important;
  line-height: 1 !important;
  margin-bottom: 8px !important;
}

.djw-sparkle .djw-sr-bday-req {
  font-size: 0.78rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  color: var(--djw-gold) !important;
  margin-bottom: 28px !important;
}

.djw-sparkle .djw-sr-bday-divider {
  height: 1px !important;
  background-color: rgba(252, 250, 248, 0.1) !important;
  margin-bottom: 24px !important;
}

.djw-sparkle .djw-sr-bday-terms {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  text-align: left !important;
}

.djw-sparkle .djw-sr-bday-terms li {
  font-size: 0.82rem !important;
  color: rgba(252, 250, 248, 0.65) !important;
  padding: 8px 0 !important;
  border-bottom: 1px solid rgba(252, 250, 248, 0.07) !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  line-height: 1.55 !important;
  margin-bottom: 0 !important;
}

.djw-sparkle .djw-sr-bday-terms li::before {
  content: '—' !important;
  color: var(--djw-gold) !important;
  font-size: 0.75rem !important;
  flex-shrink: 0 !important;
  margin-top: 2px !important;
}

/* --- Fine Print Section --- */
.djw-sparkle .djw-sr-fine-print-intro {
  max-width: 800px !important;
  margin: 32px auto 0 !important;
  padding: 28px 32px !important;
  background-color: var(--djw-alt) !important;
  border-left: 3px solid var(--djw-gold) !important;
  border-radius: var(--djw-radius) !important;
}

.djw-sparkle .djw-sr-fine-print-intro p {
  font-size: 0.88rem !important;
  color: rgba(56, 51, 51, 0.75) !important;
  font-style: italic !important;
  margin-bottom: 0 !important;
}

/* --- Steps override for sparkle --- */
.djw-sparkle .djw-sr-steps {
  max-width: 900px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ============================================================
   SPARKLE RESPONSIVE
   ============================================================ */

@media (max-width: 1023px) {
  .djw-sparkle .djw-sr-intro-grid {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }

  .djw-sparkle .djw-sr-birthday-wrap {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }

  .djw-sparkle .djw-sr-two-col-dark {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }

  .djw-sparkle .djw-sr-benefits-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 767px) {
  .djw-sparkle .djw-sr-hero-badge {
    display: none !important;
  }

  .djw-sparkle .djw-sr-benefits-grid {
    grid-template-columns: 1fr !important;
  }

  .djw-sparkle .djw-sr-stat-stack {
    padding: 36px 24px !important;
  }

  .djw-sparkle .djw-sr-birthday-card-inner {
    padding: 36px 24px !important;
  }

  .djw-sparkle .djw-sr-fine-print-intro {
    padding: 24px 20px !important;
  }
}

