/* ============================================================
   post.css — article page styles
   All layers defined in base.css
   ============================================================ */

@layer components {

  /* ── Post header ── */
  .post-header {
    padding-block: var(--space-xl) var(--space-l);
    border-block-end: 1px solid var(--rule);
    margin-block-end: var(--space-l);
  }

  .post-eyebrow {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    flex-wrap: wrap;
    font-family: var(--sans);
    font-size: var(--step--1);
    color: var(--ink-4);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-block-end: var(--space-s);
  }

  .post-eyebrow-sep {
    color: var(--rule-strong);
    user-select: none;
    aria-hidden: true;
  }

  .post-title {
    font-family: var(--serif);
    font-size: var(--step-4);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: var(--ink);
    margin-block-end: var(--space-xs);
  }

  .post-subtitle {
    font-family: var(--serif);
    font-style: italic;
    font-size: var(--step-1);
    color: var(--ink-3);
    line-height: 1.5;
  }

  /* ── Audio player ──
        SC 1.2.1 Audio-only: transcript or text alternative required.
        The player links to both audio and the post text (which IS the alternative).
        SC 1.4.2 Audio Control: auto-play is never used. ── */
  .audio-player {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    flex-wrap: wrap;
    padding: var(--space-xs) var(--space-s);
    border: 1px solid var(--rule-strong);
    border-radius: var(--radius-lg);
    background: var(--paper-2);
    margin-block: var(--space-m);
    container-type: inline-size;
  }

  .audio-player__label {
    font-family: var(--sans);
    font-size: var(--step--1);
    color: var(--ink-3);
    white-space: nowrap;
    flex-shrink: 0;
  }

  .audio-player__controls {
    display: flex;
    align-items: center;
    gap: var(--space-2xs);
    flex: 1;
    min-inline-size: 0;
  }

  .audio-player__btn {
    inline-size: 44px;
    block-size: 44px;
    border-radius: 50%;
    border: 1px solid var(--rule-strong);
    background: var(--paper);
    color: var(--ink);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background var(--transition);

    &:hover {
      background: var(--paper-3);
    }
  }

  .audio-player__progress {
    flex: 1;
    min-inline-size: 60px;
    block-size: 4px;
    appearance: none;
    background: var(--paper-3);
    border-radius: 2px;
    cursor: pointer;
    accent-color: var(--ink);

    &::-webkit-slider-thumb { inline-size: 16px; block-size: 16px; }
    &::-moz-range-thumb     { inline-size: 16px; block-size: 16px; }
  }

  .audio-player__time {
    font-family: var(--mono);
    font-size: var(--step--1);
    color: var(--ink-4);
    white-space: nowrap;
    flex-shrink: 0;
    min-inline-size: 4ch;
    text-align: end;
  }

  /* Container query: collapse label on narrow containers */
  @container (max-width: 28rem) {
    .audio-player__label { display: none; }
  }

  /* ── Prose ── */
  .prose {
    font-family: var(--serif);
    font-size: var(--step-0);
    line-height: 1.85;
    color: var(--ink-2);

    & > * + * {
      margin-block-start: 1.4em;
    }

    & h2 {
      font-family: var(--serif);
      font-size: var(--step-2);
      font-weight: 500;
      letter-spacing: -0.015em;
      color: var(--ink);
      line-height: 1.3;
      margin-block-start: 2.5em;
      margin-block-end: 0.5em;
    }

    & h3 {
      font-family: var(--serif);
      font-size: var(--step-1);
      font-weight: 500;
      color: var(--ink);
      line-height: 1.4;
      margin-block-start: 2em;
      margin-block-end: 0.4em;
    }

    & strong {
      font-weight: 500;
      color: var(--ink);
    }

    & a {
      color: var(--ink);
      text-decoration-color: var(--ink-3);

      &:hover {
        text-decoration-color: var(--ink);
      }
    }

    /* Inline code */
    & code {
      font-family: var(--mono);
      font-size: 0.875em;
      background: var(--paper-2);
      border: 1px solid var(--paper-3);
      padding-block: 0.1em;
      padding-inline: 0.35em;
      border-radius: var(--radius);
      color: var(--ink);
    }

    /* Code blocks */
    & pre {
      background: var(--paper-2);
      border: 1px solid var(--paper-3);
      border-radius: var(--radius-lg);
      padding: var(--space-s) var(--space-m);
      overflow-x: auto;
      margin-block: 1.8em;
      position: relative;
      /* SC 1.4.10 Reflow — horizontal scroll is allowed for code blocks
           per WCAG exception for content requiring two-dimensional layout */
      tab-size: 2;

      & code {
        font-family: var(--mono);
        font-size: var(--step--1);
        line-height: 1.75;
        background: none;
        border: none;
        padding: 0;
        color: var(--ink-2);
        white-space: pre;
      }
    }

    /* Language label — shown when no copy button present */
    & pre[data-lang]:not(:has(.code-copy-btn))::after {
      content: attr(data-lang);
      position: absolute;
      inset-block-start: var(--space-xs);
      inset-inline-end: var(--space-s);
      font-family: var(--sans);
      font-size: var(--step--1);
      color: var(--ink-4);
      letter-spacing: 0.04em;
      text-transform: uppercase;
    }

    /* Blockquote */
    & blockquote {
      border-inline-start: 3px solid var(--ink);
      padding-block: var(--space-3xs);
      padding-inline: var(--space-m);
      margin-block: 1.8em;
      font-style: italic;
      color: var(--ink-3);

      & p { margin: 0; }
    }

    /* Lists */
    & ul, & ol {
      padding-inline-start: 1.5em;
    }

    & li {
      margin-block-end: 0.4em;

      &::marker {
        color: var(--ink-4);
      }
    }

    /* HR */
    & hr {
      border: none;
      border-block-start: 1px solid var(--rule);
      margin-block: 2.5em;
    }

    /* Figures */
    & figure {
      margin-block: 2em;
    }

    & figcaption {
      font-family: var(--sans);
      font-size: var(--step--1);
      color: var(--ink-4);
      text-align: center;
      margin-block-start: var(--space-2xs);
    }

    /* Tables — SC 1.3.1 requires header cells */
    & table {
      width: 100%;
      border-collapse: collapse;
      font-size: var(--step--1);
      overflow-x: auto;
      display: block;
    }

    & th {
      font-weight: 500;
      color: var(--ink);
      text-align: start;
      padding: var(--space-2xs) var(--space-xs);
      border-block-end: 2px solid var(--rule-strong);
    }

    & td {
      padding: var(--space-2xs) var(--space-xs);
      border-block-end: 1px solid var(--rule);
      color: var(--ink-2);
    }
  }

  /* ── Copy button (injected by code-copy component) ── */
  .code-copy-btn {
    position: absolute;
    inset-block-start: var(--space-xs);
    inset-inline-end: var(--space-xs);
    font-family: var(--sans);
    font-size: var(--step--1);
    color: var(--ink-4);
    background: none;
    border: 1px solid var(--paper-3);
    border-radius: var(--radius);
    padding-block: 2px;
    padding-inline: var(--space-2xs);
    cursor: pointer;
    min-block-size: 24px;
    transition: color var(--transition), background var(--transition);

    &:hover {
      color: var(--ink-2);
      background: var(--paper-3);
    }

    &[data-copied="true"] {
      color: var(--ink-3);
    }
  }

  /* ── Post footer ── */
  .post-footer {
    border-block-start: 1px solid var(--rule);
    margin-block-start: var(--space-xl);
    padding-block-start: var(--space-l);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-m);
    flex-wrap: wrap;
  }

  /* ── Post navigation ── */
  .post-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-s);
    border-block-start: 1px solid var(--rule);
    margin-block-start: var(--space-l);
    padding-block-start: var(--space-l);

    @media (max-width: 30rem) {
      grid-template-columns: 1fr;
    }
  }

  .post-nav-link {
    display: flex;
    flex-direction: column;
    gap: var(--space-3xs);
    text-decoration: none;
    padding: var(--space-xs);
    border-radius: var(--radius-lg);
    transition: background var(--transition);

    &:hover {
      background: var(--paper-2);
    }

    &--next {
      text-align: end;
    }
  }

  .post-nav-label {
    font-family: var(--sans);
    font-size: var(--step--1);
    color: var(--ink-4);
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }

  .post-nav-title {
    font-family: var(--serif);
    font-size: var(--step-0);
    color: var(--ink-2);
    line-height: 1.4;
    transition: color var(--transition);
  }

  .post-nav-link:hover .post-nav-title {
    color: var(--ink);
  }
}
