/**
 * Component: Related Pages hub grid.
 *
 * Reusable anywhere — About Us hub, sub-page footers, etc.
 * Mirrors the .about-hub-card pattern with vimta- prefix.
 *
 * CSS layer: components (declared in tokens.css).
 * Breakpoints: 64em (tablet ≤1024px) · 48em (mobile ≤768px).
 *
 * @package Vimta
 */

@layer components {

/* ════════════════════════════════════════════════════════════════════════════
   §1  SECTION SHELL
   ════════════════════════════════════════════════════════════════════════════ */

  .vimta-related-pages {
    background-color: var(--secondary-ultra-light);
  }

  .vimta-related-pages--white {
    background-color: var(--white);
  }

/* ════════════════════════════════════════════════════════════════════════════
   §2  CARD GRID
   ════════════════════════════════════════════════════════════════════════════ */

  .vimta-related-pages__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--grid-gap);
    list-style: none;
    margin: 0;
    padding: 0;
    margin-block-start: var(--container-gap);
  }

/* ════════════════════════════════════════════════════════════════════════════
   §3  INDIVIDUAL CARD
   ════════════════════════════════════════════════════════════════════════════ */

  /* <li> invisible — all styling on the inner <a> */
  .vimta-related-pages__card {
    display: contents;
  }

  .vimta-related-pages__inner {
    display: flex;
    flex-direction: column;
    gap: var(--card-gap);
    padding: var(--card-padding-compact);
    background: var(--white);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    border: 1px solid var(--border-subtle);
    text-decoration: none;
    color: inherit;
    transition:
      box-shadow var(--duration-fast) var(--ease-out),
      transform var(--duration-fast) var(--ease-out),
      border-color var(--duration-fast) var(--ease-out);
  }

  .vimta-related-pages__inner:hover,
  .vimta-related-pages__inner:focus-visible {
    box-shadow: var(--card-shadow-hover);
    transform: translateY(-2px);
    border-color: var(--border-accent);
  }

  .vimta-related-pages__inner:focus-visible {
    outline: var(--focus-ring);
    outline-offset: var(--focus-ring-offset);
  }

/* ════════════════════════════════════════════════════════════════════════════
   §4  ICON BOX
   ════════════════════════════════════════════════════════════════════════════ */

  .vimta-related-pages__icon-box {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 2.75rem;
    block-size: 2.75rem;
    border-radius: var(--radius-s);
    flex-shrink: 0;
    color: var(--primary);
  }

  /* accent-a (0-indexed 0, 2, 4…) — primary ultra-light */
  .vimta-related-pages__card--accent-a .vimta-related-pages__icon-box {
    background-color: var(--primary-ultra-light);
  }

  /* accent-b (0-indexed 1, 3, 5…) — blush tint */
  .vimta-related-pages__card--accent-b .vimta-related-pages__icon-box {
    background-color: color-mix(in oklch, var(--secondary) 40%, var(--white));
  }

/* ════════════════════════════════════════════════════════════════════════════
   §5  CARD BODY
   ════════════════════════════════════════════════════════════════════════════ */

  .vimta-related-pages__body {
    display: flex;
    flex-direction: column;
    gap: var(--stack-gap);
    flex: 1 1 auto;
  }

  .vimta-related-pages__title {
    font-size: var(--heading-xs);
    font-weight: var(--weight-bold);
    line-height: var(--leading-snug);
    color: var(--text-main);
    margin: 0;
    transition: color var(--duration-fast) var(--ease-out);
  }

  .vimta-related-pages__inner:hover .vimta-related-pages__title,
  .vimta-related-pages__inner:focus-visible .vimta-related-pages__title {
    color: var(--primary);
  }

  .vimta-related-pages__desc {
    font-size: var(--text-s);
    line-height: var(--leading-normal);
    color: var(--text-muted);
    margin: 0;
    flex: 1 1 auto;
  }

  /* Arrow — pushed to end of column */
  .vimta-related-pages__arrow {
    display: flex;
    align-items: center;
    color: var(--primary);
    opacity: 0;
    transform: translateX(-4px);
    transition:
      opacity var(--duration-fast) var(--ease-out),
      transform var(--duration-fast) var(--ease-out);
    margin-block-start: auto;
  }

  .vimta-related-pages__inner:hover .vimta-related-pages__arrow,
  .vimta-related-pages__inner:focus-visible .vimta-related-pages__arrow {
    opacity: 1;
    transform: translateX(0);
  }

/* ════════════════════════════════════════════════════════════════════════════
   §6  RESPONSIVE
   ════════════════════════════════════════════════════════════════════════════ */

  @media (max-width: 64em) {
    .vimta-related-pages__grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @media (max-width: 48em) {
    .vimta-related-pages__grid {
      grid-template-columns: 1fr;
    }

    .vimta-related-pages__arrow {
      opacity: 1;
      transform: none;
    }
  }

} /* end @layer components */
