/* ==========================================================================
   36-legal.css — Legal pages (privacidad, terminos, cookies)

   Pages render via the kit's `_hero_simple` for the title/subline and
   `_legal_article` for the body. The body is a Markdown source rendered
   to HTML by Redcarpet (see `legal_markdown_helper.rb`); section headings
   become <h3 id="…"> and <h4>, callouts become <blockquote>, and "Lo que
   no hacemos"-style asides use the same <blockquote> with no extra class.

   Replaces the legacy `16-legal.css` from before the kit migration.
   ========================================================================== */

/* ---- Section wrapper ---- */
.lp-legal {
  padding-block: var(--space-11);
  background-color: var(--color-bg);
}

.lp-legal .container--narrow {
  max-width: var(--container-narrow);
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

/* ---- Table of contents ---- */
.lp-legal__toc {
  background-color: var(--color-gray-50);
  border-radius: var(--radius-xl);
  padding: var(--space-7);
  margin-bottom: var(--space-10);
}

.lp-legal__toc-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-5);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

.lp-legal__toc-list {
  list-style: decimal inside;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.lp-legal__toc-list li::marker {
  color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
}

.lp-legal__toc-list a {
  font-size: var(--font-size-sm);
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.lp-legal__toc-list a:hover,
.lp-legal__toc-list a:focus-visible {
  color: var(--color-terracotta);
  text-decoration: underline;
}

/* ---- Article body — typography for Markdown-rendered prose ---- */
.lp-legal__body {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  max-width: 70ch;
}

.lp-legal__body > h3 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin-top: var(--space-11);
  margin-bottom: var(--space-6);
  scroll-margin-top: var(--space-12);
}

.lp-legal__body > h3:first-child {
  margin-top: 0;
}

.lp-legal__body > h4 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin-top: var(--space-8);
  margin-bottom: var(--space-5);
}

.lp-legal__body p {
  margin: 0 0 var(--space-5);
}

.lp-legal__body strong {
  color: var(--color-text);
  font-weight: var(--font-weight-semibold);
}

.lp-legal__body em {
  color: var(--color-text-tertiary);
  font-style: italic;
}

/* The leading "Última actualización" line of each section is wrapped by
   Redcarpet in <em>; keep it visually distinct from in-prose emphasis. */
.lp-legal__body > p:first-child em {
  display: inline-block;
  font-size: var(--font-size-sm);
  font-style: normal;
  color: var(--color-text-tertiary);
  letter-spacing: var(--letter-spacing-wide);
}

/* ---- Lists ---- */
.lp-legal__body ul,
.lp-legal__body ol {
  margin: 0 0 var(--space-5);
  padding-left: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.lp-legal__body li {
  line-height: var(--line-height-relaxed);
}

.lp-legal__body li > p {
  margin: 0;
}

.lp-legal__body li::marker {
  color: var(--color-primary);
}

/* ---- Links ---- */
.lp-legal__body a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 0.15em;
  transition: color var(--transition-fast);
}

.lp-legal__body a:hover,
.lp-legal__body a:focus-visible {
  color: var(--color-terracotta);
}

/* ---- Tables ---- */
.lp-legal__body table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
  margin: 0 0 var(--space-7);
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.lp-legal__body thead {
  background-color: var(--color-gray-50);
}

.lp-legal__body th,
.lp-legal__body td {
  text-align: left;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  line-height: var(--line-height-normal);
  vertical-align: top;
}

.lp-legal__body th {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  white-space: nowrap;
}

.lp-legal__body td {
  color: var(--color-text-secondary);
}

/* ---- Blockquote: highlighted aside (e.g. "Lo que no hacemos") ---- */
.lp-legal__body blockquote {
  background-color: var(--color-gray-50);
  border-left: 3px solid var(--color-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: var(--space-7);
  margin: var(--space-7) 0;
  color: var(--color-text-secondary);
}

.lp-legal__body blockquote > *:first-child {
  margin-top: 0;
}

.lp-legal__body blockquote > *:last-child {
  margin-bottom: 0;
}

.lp-legal__body blockquote ul,
.lp-legal__body blockquote ol {
  margin-bottom: 0;
}

/* ---- Inline code (used for cookie names and similar identifiers) ---- */
.lp-legal__body code {
  font-family: var(--font-family-mono, ui-monospace, SFMono-Regular, monospace);
  font-size: 0.9em;
  background-color: var(--color-gray-50);
  padding: 0.1em 0.35em;
  border-radius: var(--radius-sm);
  color: var(--color-text);
}

/* ---- Responsive ---- */
@media (min-width: 1024px) {
  /* Sidebar TOC layout on desktop */
  .lp-legal .container--narrow {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--space-10);
    align-items: start;
    max-width: var(--container-default);
  }

  .lp-legal__toc {
    position: sticky;
    top: var(--space-9);
    margin-bottom: 0;
  }

  .lp-legal__toc-list {
    max-height: calc(100vh - var(--space-12) * 2);
    overflow-y: auto;
  }

  .lp-legal__body {
    max-width: 70ch;
  }
}

@media (max-width: 600px) {
  .lp-legal {
    padding-block: var(--space-9);
  }

  .lp-legal__toc {
    padding: var(--space-5);
  }

  .lp-legal__body th,
  .lp-legal__body td {
    padding: var(--space-3) var(--space-4);
    font-size: var(--font-size-xs);
  }

  .lp-legal__body > h3 {
    font-size: var(--font-size-xl);
  }
}
