/* =====================================================================
   Summer Smiles Ortho Event — promo-page component styles.
   Loaded AFTER styles.css. Every colour derives from the shared brand
   variables in styles.css :root (no scattered hex); translucent tints use
   color-mix() so they still track the palette. Buttons, .container,
   .section(+modifiers), .section-head/.eyebrow, and .cta-band are reused
   from the shared stylesheet for cohesion with the rest of the site.
   ===================================================================== */

/* Derived, palette-tracking tints for use on dark surfaces */
.promo {
  --on-dark-soft: color-mix(in srgb, var(--white) 82%, transparent);
  --on-dark-mute: color-mix(in srgb, var(--white) 68%, transparent);
  --on-dark-line: color-mix(in srgb, var(--white) 16%, transparent);
  --on-dark-fill: color-mix(in srgb, var(--white) 8%, transparent);
  --teal-glow:    color-mix(in srgb, var(--teal) 16%, transparent);
}

/* ── Slim promo topbar (sits above the shared header) ── */
.promo-topbar {
  background: var(--slate-deep); color: var(--white);
  text-align: center; padding: 0.55rem 1rem; font-size: 0.85rem; font-weight: 600;
}
.promo-topbar strong { color: var(--teal); font-weight: 800; }
.promo-topbar .sep { color: color-mix(in srgb, var(--white) 35%, transparent); margin: 0 0.45rem; }

/* ── Hero ── */
.promo-hero {
  position: relative; overflow: hidden; text-align: center;
  background: linear-gradient(135deg, var(--slate-deep), var(--slate) 70%, var(--slate-deep));
  padding: clamp(3.5rem, 7vw, 5.5rem) var(--gutter) clamp(3rem, 6vw, 4.5rem);
}
.promo-hero::before, .promo-hero::after {
  content: ""; position: absolute; border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle, var(--teal-glow) 0%, transparent 70%);
}
.promo-hero::before { width: 600px; height: 600px; top: -200px; right: -100px; }
.promo-hero::after  { width: 400px; height: 400px; bottom: -150px; left: -50px; }
.promo-hero__inner { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; }
.promo-label {
  display: inline-block; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; padding: 6px 16px; border-radius: 999px; margin-bottom: 1rem;
  background: var(--teal-glow); color: var(--teal);
}
.promo-hero h1 {
  color: var(--white); font-size: clamp(2rem, 5vw, 3.25rem); font-weight: 800;
  line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 0.5rem;
}
.promo-hero h1 em { color: var(--teal); font-style: normal; }
.promo-hero .sub {
  color: var(--on-dark-soft); font-size: 1.05rem; max-width: 560px;
  margin: 1rem auto 2rem; line-height: 1.6;
}
.promo-actions { display: flex; align-items: center; justify-content: center; gap: 0.9rem; flex-wrap: wrap; }

/* Countdown */
.countdown {
  display: flex; align-items: flex-start; justify-content: center; gap: 0.5rem;
  margin: 2.5rem auto 0; max-width: 520px; flex-wrap: wrap;
}
.cd-block {
  background: var(--on-dark-fill); border: 1px solid var(--on-dark-line);
  border-radius: 8px; padding: 0.75rem 1.05rem; text-align: center; min-width: 72px;
}
.cd-num { font-size: 1.75rem; font-weight: 800; color: var(--white); line-height: 1; font-variant-numeric: tabular-nums; }
.cd-label { font-size: 0.58rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--on-dark-mute); margin-top: 0.35rem; }
.cd-sep { font-size: 1.75rem; font-weight: 300; color: var(--on-dark-line); line-height: 1; margin-top: 0.5rem; }
.promo-ends { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-dark-mute); text-align: center; margin-top: 1rem; }
.promo-ended-msg { color: var(--on-dark-soft); font-size: 0.95rem; font-weight: 600; }

/* ── Trust strip ── */
.trust { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 1.2rem var(--gutter); }
.trust-inner { max-width: 1080px; margin: 0 auto; display: flex; align-items: center; justify-content: center; gap: 0.9rem 2.5rem; flex-wrap: wrap; }
.trust-item { display: flex; align-items: center; gap: 0.5rem; font-size: 0.82rem; font-weight: 600; color: var(--slate); letter-spacing: 0.01em; }
.trust-item .ico { width: 18px; height: 18px; color: var(--teal-deep); }

/* ── Pricing cards ── */
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.25rem; }
.price-card {
  background: var(--white); border: 1.5px solid var(--border); border-radius: 14px; overflow: hidden;
  display: flex; flex-direction: column; transition: transform .2s, box-shadow .2s, border-color .2s;
}
.price-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--teal); }
.price-card.featured { border-color: var(--teal); box-shadow: 0 8px 30px color-mix(in srgb, var(--teal) 28%, transparent); transform: translateY(-4px); }
.card-header { background: var(--slate-deep); padding: 1.4rem 1.5rem 1.1rem; position: relative; }
.card-badge {
  position: absolute; top: 14px; right: 14px; background: var(--teal); color: var(--slate-deep);
  font-size: 0.6rem; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 999px;
}
.card-icon { color: var(--teal); margin-bottom: 0.6rem; }
.card-icon .ico { width: 26px; height: 26px; }
.card-name { font-size: 1.05rem; font-weight: 700; color: var(--white); margin-bottom: 0.25rem; }
.card-tagline { font-size: 0.74rem; color: color-mix(in srgb, var(--white) 72%, transparent); font-weight: 500; }
.card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; gap: 1rem; }
.card-discount { display: flex; align-items: baseline; gap: 0.5rem; flex-wrap: wrap; }
.discount-amount { font-size: 2.25rem; font-weight: 900; color: var(--teal-deep); line-height: 1; letter-spacing: -0.02em; }
.discount-label { font-size: 0.8rem; font-weight: 600; color: var(--slate); }
.card-details { display: flex; flex-direction: column; gap: 0.55rem; }
.card-detail { display: flex; align-items: flex-start; gap: 0.5rem; font-size: 0.83rem; color: var(--slate); font-weight: 500; line-height: 1.45; }
.card-detail strong { color: var(--slate-deep); font-weight: 700; }
.detail-check { width: 16px; height: 16px; border-radius: 50%; background: var(--teal-tint); color: var(--teal-deep); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.detail-check .ico { width: 10px; height: 10px; stroke-width: 2.5; }
.card-cta { margin-top: auto; padding-top: 0.5rem; }
.card-cta a {
  display: block; text-align: center; font-size: 0.78rem; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase; text-decoration: none;
  color: var(--slate-deep); border: 1.5px solid var(--teal-deep); border-radius: 6px;
  padding: 0.8rem; transition: background .15s, color .15s, border-color .15s;
}
.card-cta a:hover { background: var(--teal-deep); color: var(--white); }
.price-card.featured .card-cta a { background: var(--teal-deep); color: var(--white); border-color: var(--teal-deep); }
.price-card.featured .card-cta a:hover { background: var(--slate-deep); border-color: var(--slate-deep); }

/* Case-planning contact card */
.price-card--contact { background: var(--teal-tint); border-color: var(--teal-deep); }
.price-card--contact .card-body { background: var(--teal-tint); }
.price-card--contact .contact-blurb { font-size: 0.88rem; color: var(--slate); line-height: 1.6; font-weight: 500; }
.price-card--contact .card-cta a { background: var(--slate-deep); color: var(--white); border-color: var(--slate-deep); }
.price-card--contact .card-cta a:hover { background: var(--ink); border-color: var(--ink); }

/* ── How to participate (on .section--slate) ── */
.steps-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.5rem; max-width: 1000px; margin: 0 auto; position: relative; }
.steps-row::before { content: ""; position: absolute; top: 28px; left: calc(12.5% + 28px); right: calc(12.5% + 28px); height: 2px; background: color-mix(in srgb, var(--teal) 30%, transparent); pointer-events: none; }
.step-card { text-align: center; position: relative; z-index: 1; }
.step-num { width: 56px; height: 56px; border-radius: 50%; background: var(--teal-deep); color: var(--white); font-size: 1.25rem; font-weight: 800; display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem; box-shadow: 0 4px 16px color-mix(in srgb, var(--teal) 40%, transparent); }
.step-title { font-size: 0.95rem; font-weight: 700; color: var(--white); margin-bottom: 0.5rem; }
.step-desc { font-size: 0.82rem; color: var(--on-dark-soft); font-weight: 400; line-height: 1.6; }
.step-desc strong { color: var(--teal); font-weight: 700; }
@media (max-width: 720px) { .steps-row::before { display: none; } }

/* ── Promotion details / terms ── */
.terms-inner { max-width: 860px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; }
.terms-col h3 { font-size: 0.82rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal-deep); margin-bottom: 1rem; }
.terms-list { display: flex; flex-direction: column; gap: 0.65rem; list-style: none; margin: 0; padding: 0; }
.terms-item { display: flex; align-items: flex-start; gap: 0.65rem; font-size: 0.85rem; color: var(--slate); font-weight: 500; line-height: 1.5; }
.terms-item::before { content: ""; flex-shrink: 0; width: 6px; height: 6px; border-radius: 50%; background: var(--teal); margin-top: 0.5em; }
@media (max-width: 640px) { .terms-inner { grid-template-columns: 1fr; gap: 1.75rem; } }

/* CTA-band fine print (reuses the shared .cta-band surface) */
.cta-band .cta-note { margin-top: 1.1rem; font-size: 0.8rem; letter-spacing: 0.04em; color: var(--teal-tint); }
