/* ================================================================
   Maturity Tool — Partner offer page

   Page-specific styles. Brand tokens come from @contentious/ui
   (content-maturity theme: fire primary, lichen surfaces).
   ================================================================ */

@layer utilities {

  /* ── Smooth anchor scrolling ─────────────────────────────────── */

  @media (prefers-reduced-motion: no-preference) {
    html {
      scroll-behavior: smooth;
    }
  }

  /* ── Scroll reveal ───────────────────────────────────────────── */

  @media (prefers-reduced-motion: no-preference) {
    .js .reveal {
      opacity: 0;
      transform: translateY(1.25rem);
      transition:
        opacity 700ms cubic-bezier(0.16, 1, 0.3, 1),
        transform 700ms cubic-bezier(0.16, 1, 0.3, 1);
    }

    .js .reveal.is-in {
      opacity: 1;
      transform: translateY(0);
    }
  }

  /* ── Hero ────────────────────────────────────────────────────── */

  .c-hero-section {
    padding-top: 5rem;
    padding-bottom: 5rem;
    position: relative;
    background-color: var(--lichen-150);
  }

  .c-hero-section::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: linear-gradient(90deg,
        transparent,
        color-mix(in srgb, var(--gloaming-900) 10%, transparent),
        transparent);
  }

  .hero-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    align-items: center;
  }

  @media (min-width: 56rem) {
    .hero-grid {
      grid-template-columns: 1.1fr 1fr;
      gap: 3rem;
    }
  }

  .hero-image-wrap {
    display: flex;
    justify-content: center;
  }

  .hero-image {
    max-width: 100%;
    height: auto;
    display: block;
  }

  @media (min-width: 56rem) {
    .hero-image {
      max-width: 36rem;
    }
  }

  .type-accent-label {
    font-size: var(--font-size-sm);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fire-600);
    font-weight: var(--font-weight-medium);
    margin-bottom: 1.5rem;
  }

  .c-hero__heading {
    max-width: 28ch;
    margin-bottom: 1.5rem;
  }

  .c-hero__heading span {
    display: block;
  }

  .c-hero__intro {
    max-width: 48ch;
    color: var(--muted-foreground);
    margin-bottom: 2rem;
  }

  .hero-cta-group {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
  }

  /* ── Section tint ────────────────────────────────────────────── */

  .section-alt {
    background-color: var(--lichen-200);
  }

  /* ── Quote section ───────────────────────────────────────────── */

  .section-quote {
    padding-top: 7rem;
    padding-bottom: 7rem;
    color: var(--limestone-200);
    background-color: var(--gloaming-550);
  }

  .section-quote .c-section-header__title {
    color: var(--limestone-100);
    margin-bottom: 0.75rem;
  }

  .quote-eyebrow {
    color: var(--sorbet-500);
    margin-bottom: 3rem;
  }

  .quote-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4rem;
    align-items: start;
  }

  @media (min-width: 56rem) {
    .quote-grid {
      grid-template-columns: 1fr 1fr;
      gap: 6rem;
    }
  }

  .pull-quote {
    margin: 0;
    position: relative;
    padding-top: 4rem;
  }

  .pull-quote::before {
    content: "\201C";
    font-family: var(--font-heading-display);
    font-size: 8rem;
    line-height: 0.5;
    color: var(--fire-400);
    position: absolute;
    top: 2rem;
    left: 0;
    opacity: 0.6;
  }

  .pull-quote__text {
    font-size: calc(2em * var(--text-multiplier));
    line-height: 1.4;
    color: var(--limestone-200);
    font-weight: var(--font-weight-normal);
    font-style: italic;
    margin: 0;
  }

  .quote-body {
    display: flex;
    flex-direction: column;
    gap: 1.75rem;
  }

  @media (min-width: 56rem) {
    .quote-body {
      padding-top: 4rem;
    }
  }

  .quote-body p {
    font-size: calc(1.2em * var(--text-multiplier));
    line-height: var(--line-height-relaxed);
    color: var(--limestone-300);
    margin: 0;
  }

  .quote-body p.quote-body__coda {
    font-weight: var(--font-weight-medium);
    color: var(--limestone-100);
  }

  /* ── Feature grid ────────────────────────────────────────────── */

  .feature-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  @media (min-width: 48rem) {
    .feature-grid {
      grid-template-columns: repeat(2, 1fr);
      gap: 1.5rem;
    }
  }

  @media (min-width: 56rem) {
    .feature-grid--three {
      grid-template-columns: repeat(3, 1fr);
    }
  }

  /* ── Benefits groups ─────────────────────────────────────────── */

  .benefits-group+.benefits-group {
    margin-top: 3.5rem;
  }

  .benefits-group__label {
    font-family: var(--font-heading-display);
    font-size: calc(1.25em * var(--text-multiplier));
    font-weight: var(--font-weight-normal);
    line-height: var(--heading-line-height);
    color: var(--foreground);
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
  }

  .benefits-group__label::before {
    content: "";
    display: inline-block;
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background-color: var(--fire-500);
    transform: translateY(-0.15em);
  }

  /* ── Two-column layout ───────────────────────────────────────── */

  .two-col {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  @media (min-width: 56rem) {
    .two-col {
      grid-template-columns: repeat(2, 1fr);
      gap: 2rem;
    }
  }

  /* ── Included / scope cards ──────────────────────────────────── */

  .c-card.included-card,
  .c-card.scope-card {
    padding: 2rem;
    border-radius: 0.75rem;
  }

  .included-card__header,
  .scope-card__title {
    margin-bottom: 1.5rem;
  }

  .included-card__eyebrow {
    font-size: var(--font-size-sm);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fire-600);
    margin-bottom: 0.5rem;
    font-weight: var(--font-weight-medium);
  }

  .included-card__title,
  .scope-card__title {
    font-size: var(--font-size-h3);
    line-height: var(--heading-line-height);
    font-weight: var(--font-weight-normal);
    color: var(--foreground);
  }

  .included-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }

  .included-list li {
    position: relative;
    padding-left: 1.75rem;
    line-height: var(--body-line-height);
    font-size: calc(1em * var(--text-multiplier));
    color: var(--foreground);
  }

  .included-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 50%;
    background-color: var(--fire-500);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--fire-500) 18%, transparent);
  }

  .scope-card .included-list li::before {
    background-color: var(--gloaming-400);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--gloaming-400) 18%, transparent);
  }

  /* ── Pricing grid ────────────────────────────────────────────── */

  .pricing-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    align-items: stretch;
  }

  @media (min-width: 56rem) {
    .pricing-grid {
      grid-template-columns: repeat(3, 1fr);
    }
  }

  .c-card.pricing-card {
    padding: 2rem;
    border-radius: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }

  .c-card.pricing-card--featured {
    border: 2px solid var(--fire-500);
    box-shadow:
      0 4px 20px 0 color-mix(in srgb, var(--fire-500) 20%, transparent),
      0 1px 4px 0 color-mix(in srgb, var(--gloaming-900) 6%, transparent);
    transform: translateY(-4px);
  }

  @media (max-width: 56rem) {
    .c-card.pricing-card--featured {
      transform: none;
    }
  }

  .pricing-card__eyebrow {
    font-size: var(--font-size-sm);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fire-600);
    margin-bottom: 0.5rem;
    font-weight: var(--font-weight-medium);
  }

  .pricing-card--featured .pricing-card__eyebrow {
    color: var(--fire-700);
  }

  .pricing-card__title {
    font-size: var(--font-size-h3);
    font-weight: var(--font-weight-normal);
    line-height: var(--heading-line-height);
    color: var(--foreground);
    margin-bottom: 0.75rem;
  }

  .pricing-card__description {
    font-size: calc(0.95em * var(--text-multiplier));
    line-height: var(--body-line-height);
    color: var(--muted-foreground);
  }

  .pricing-card__figures {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.25rem;
    background-color: var(--lichen-300);
    border-radius: 0.5rem;
  }

  .pricing-card--featured .pricing-card__figures {
    background-color: color-mix(in srgb, var(--fire-500) 10%, var(--lichen-200));
  }

  .pricing-card__figure {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
  }

  .pricing-card__amount {
    font-family: var(--font-heading-display);
    font-size: calc(1.8em * var(--text-multiplier));
    line-height: 1.1;
    color: var(--foreground);
  }

  .pricing-card__period {
    font-size: var(--font-size-sm);
    color: var(--muted-foreground);
  }

  .pricing-card__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
  }

  .pricing-card__list li {
    position: relative;
    padding-left: 1.5rem;
    font-size: calc(0.95em * var(--text-multiplier));
    line-height: var(--body-line-height);
  }

  .pricing-card__list li::before {
    content: "→";
    position: absolute;
    left: 0;
    color: var(--fire-500);
    font-weight: var(--font-weight-medium);
  }

  /* ── Timeline ────────────────────────────────────────────────── */

  .timeline {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    position: relative;
  }

  @media (min-width: 56rem) {
    .timeline {
      grid-template-columns: repeat(3, 1fr);
      gap: 2rem;
    }
  }

  .timeline__step {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.75rem;
    background-color: var(--card);
    border-radius: 0.75rem;
    border: 1px solid var(--border);
    position: relative;
  }

  .timeline__marker {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background-color: var(--fire-500);
    color: var(--fire-100, var(--limestone-100));
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading-display);
    font-size: 1.25rem;
    line-height: 1;
  }

  .timeline__week {
    font-size: var(--font-size-sm);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fire-600);
    font-weight: var(--font-weight-medium);
    margin-bottom: 0.25rem;
  }

  .timeline__title {
    font-size: calc(1.2em * var(--text-multiplier));
    line-height: var(--heading-line-height);
    color: var(--foreground);
    margin-bottom: 0.5rem;
    font-weight: var(--font-weight-normal);
  }

  .timeline__detail {
    font-size: calc(0.95em * var(--text-multiplier));
    line-height: var(--body-line-height);
    color: var(--muted-foreground);
  }

  /* ── CTA section ─────────────────────────────────────────────── */

  .section-cta {
    background-color: var(--fire-600);
    color: var(--limestone-100);
  }

  .cta-inner {
    text-align: center;
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .cta-title {
    font-size: var(--font-size-h2);
    line-height: var(--heading-line-height);
    margin-bottom: 1rem;
    color: var(--limestone-100);
    font-weight: var(--font-weight-normal);
  }

  .cta-subtitle {
    font-size: calc(1.15em * var(--text-multiplier));
    line-height: var(--body-line-height);
    color: var(--limestone-300);
    max-width: 36rem;
    margin: 0 auto 2rem;
  }

  .cta-actions {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    flex-wrap: wrap;
  }

  .section-cta .btn-primary {
    background-color: var(--limestone-100);
    color: var(--fire-700);
  }

  .section-cta .btn-primary:hover {
    background-color: var(--limestone-200);
  }

  /* ── Footer ──────────────────────────────────────────────────── */

  .site-footer {
    background-color: var(--gloaming-600);
    color: var(--limestone-700);
    padding: 2.5rem 0;
  }

  .site-footer__inner {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .site-footer p {
    color: var(--limestone-700);
  }

  /* ── Code samples ────────────────────────────────────────────── */

  code {
    font-family: var(--font-mono);
    font-size: 0.9em;
    padding: 0.15em 0.4em;
    background-color: color-mix(in srgb, var(--fire-500) 10%, transparent);
    color: var(--fire-700);
    border-radius: 0.25rem;
  }

  .section-cta code {
    background-color: color-mix(in srgb, var(--limestone-100) 15%, transparent);
    color: var(--limestone-100);
  }
}