/* ─────────────────────────────────────────────────────────────────
   IELTS Speaking — lesson page touches.

   The index page reuses Reading's flat .rd-lessons-grid styles
   directly; this file only carries Speaking-specific lesson-page
   accents and two custom block types (sp-compare, sp-drill-cta)
   plus the practice-page "coming soon" stub.

   Lesson page — group-tinted accent + Speaking-only blocks.
   Reuses .rd-lesson-* styles from the Reading lesson page;
   what we add here is the group-tint and two new blocks.
   ───────────────────────────────────────────────────────────── */

.sp-lesson-page.sp-lesson-foundations { --cat-color: #4A6B7A; }
.sp-lesson-page.sp-lesson-part-1      { --cat-color: #7A8B4A; }
.sp-lesson-page.sp-lesson-part-2      { --cat-color: #B57A2E; }
.sp-lesson-page.sp-lesson-part-3      { --cat-color: #7A4A5B; }

/* Recolour the lesson eyebrow + back link with the group accent. */
.sp-lesson-page .rd-lesson-eyebrow {
  color: var(--cat-color, #B57A2E);
}
.sp-lesson-page .rd-lesson-back {
  color: var(--cat-color, #B57A2E);
}

/* ── compare block (Band X vs Band Y, side-by-side) ──────────── */
.sp-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 1.4rem 0;
}
@media (max-width: 720px) {
  .sp-compare { grid-template-columns: 1fr; }
}
.sp-compare-col {
  position: relative;
  padding: 1.15rem 1.25rem 1.05rem;
  border: 1px solid rgba(31,24,18,.12);
  border-radius: 12px;
  background: rgba(255,255,255,.55);
  box-shadow: 0 1px 0 rgba(0,0,0,.05);
}
.sp-compare-low  { border-left: 3px solid #A85B47; }
.sp-compare-high { border-left: 3px solid #4F7A4A; }
.sp-compare-label {
  display: inline-block;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .25rem .55rem;
  border-radius: 6px;
  margin-bottom: .65rem;
}
.sp-compare-low  .sp-compare-label { background: rgba(168,91,71,.12); color: #8A4533; }
.sp-compare-high .sp-compare-label { background: rgba(79,122,74,.14); color: #2F5A2C; }
.sp-compare-body p { margin: 0 0 .55rem; }
.sp-compare-body p:last-child { margin-bottom: 0; }
.sp-compare-body strong { color: var(--paper-ink, #1F1812); }

/* ── drillCta block — bottom-of-lesson handoff to drill engine ── */
.sp-drill-cta {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 1.2rem;
  padding: 1.3rem 1.4rem;
  margin: 1.8rem 0 .4rem;
  background: linear-gradient(180deg,
      color-mix(in srgb, var(--cat-color, #B57A2E) 10%, transparent),
      color-mix(in srgb, var(--cat-color, #B57A2E)  4%, transparent));
  border: 1px solid color-mix(in srgb, var(--cat-color, #B57A2E) 35%, transparent);
  border-radius: 14px;
  box-shadow: 0 1px 0 rgba(0,0,0,.05);
}
@media (max-width: 560px) {
  .sp-drill-cta { grid-template-columns: 1fr; }
}
.sp-drill-cta-text { display: flex; flex-direction: column; gap: .25rem; }
.sp-drill-cta-eyebrow {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--cat-color, #B57A2E);
}
.sp-drill-cta-title {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 1.15rem;
  font-weight: 500;
  letter-spacing: -.005em;
  line-height: 1.25;
  margin: 0;
  color: var(--paper-ink, #1F1812);
}
.sp-drill-cta-sub {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: .88rem;
  line-height: 1.45;
  color: var(--paper-ink-soft, #4A3F33);
  margin: 0;
}
.sp-drill-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .7rem 1.1rem;
  background: var(--cat-color, #B57A2E);
  color: #FFFDF4;
  border-radius: 10px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: .92rem;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: transform .15s, filter .15s, box-shadow .15s;
  box-shadow: 0 6px 14px -6px color-mix(in srgb, var(--cat-color, #B57A2E) 60%, transparent);
}
.sp-drill-cta-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
  box-shadow: 0 10px 18px -6px color-mix(in srgb, var(--cat-color, #B57A2E) 70%, transparent);
}

/* ── Practice "coming soon" stub ─────────────────────────────── */
.sp-coming {
  margin: 2rem 0;
  padding: 1.6rem 1.8rem;
  background: var(--paper, #F5EBD3);
  border: 1px solid rgba(31,24,18,.10);
  border-radius: 14px;
  box-shadow: 0 1px 0 rgba(0,0,0,.08);
}
.sp-coming-lead {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 1.15rem;
  line-height: 1.45;
  color: var(--paper-ink, #1F1812);
  margin: 0 0 .8rem;
}
.sp-coming-meta {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: .9rem;
  color: var(--paper-ink-soft, #4A3F33);
  margin: 0;
}
