/*
 * ═══════════════════════════════════════════════════════════════════════════
 *  LA ÚLTIMA PISTA — lup-legal.css
 *  Componentes exclusivos de la página legal.html.
 *  Requiere: lup.css
 * ═══════════════════════════════════════════════════════════════════════════
 */

/* ══════════════════════════════════════════════════════
   TIPOGRAFÍA ESPECÍFICA DE DOCUMENTO LEGAL
   (sobreescribe algunos valores de lup.css para contexto documento)
══════════════════════════════════════════════════════ */
.legal-body h2{
  font-size:clamp(2rem,4vw,4rem);color:var(--l-ink);
  line-height:1.06;letter-spacing:-.01em;
}
.legal-body h3{
  font-family:var(--mono);font-size:.62rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin:2.25rem 0 .75rem;
}
.legal-body p{
  line-height:1.9;font-size:.88rem;
  color:var(--l-muted);margin-bottom:.85rem;
}
.legal-body strong{font-weight:500;color:var(--l-ink)}
.legal-body a{color:var(--gold-dk);transition:color .2s}
.legal-body a:hover{color:var(--gold)}

/* ══════════════════════════════════════════════════════
   PAGE HEADER (variante legal — sin breadcrumb tags)
══════════════════════════════════════════════════════ */
.page-header{
  background:var(--d-bg);
  padding:clamp(8rem,14vw,13rem) 0 clamp(4rem,7vw,6rem);
  position:relative;overflow:hidden;
}
.page-header::before{
  content:'';position:absolute;top:-20%;right:0;
  width:50vw;height:80vh;max-width:700px;
  background:radial-gradient(ellipse,rgba(200,168,72,.06) 0%,transparent 65%);
  border-radius:50%;pointer-events:none;
}
.page-header h1{font-size:clamp(3rem,7vw,7.5rem);color:var(--d-paper);margin-bottom:1rem}
.page-header h1 em{color:var(--gold);font-style:italic}
.page-header__breadcrumb{
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--d-muted);margin-bottom:2rem;
  display:flex;align-items:center;gap:.5rem;
}
.page-header__breadcrumb a{color:var(--d-muted);transition:color .2s}
.page-header__breadcrumb a:hover{color:var(--d-cream)}
.page-header__breadcrumb span{color:var(--gold)}
.page-header__breadcrumb::before{content:'›';color:var(--d-faint)}
.page-header__meta{font-size:.72rem;color:var(--d-muted);margin-top:1rem}

/* ══════════════════════════════════════════════════════
   TOC — TABLA DE CONTENIDOS
══════════════════════════════════════════════════════ */
.legal-toc-wrap{
  background:var(--l-warm);
  border-bottom:1px solid var(--l-brd);
  padding:1.5rem 0;
}
.legal-toc{display:flex;gap:.5rem;flex-wrap:wrap}
.legal-toc__item{
  font-size:.62rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--l-muted);padding:.5rem .9rem;
  background:var(--l-card);border:1px solid var(--l-brd2);border-radius:var(--r2);
  transition:all .18s;
}
.legal-toc__item:hover{border-color:var(--l-brd);color:var(--l-ink)}

/* ══════════════════════════════════════════════════════
   SECCIONES LEGALES
══════════════════════════════════════════════════════ */
.legal-body{max-width:800px}
.legal-section{
  scroll-margin-top:6rem;
  padding-top:clamp(3rem,6vw,6rem);
  border-top:1px solid var(--l-brd2);
  margin-top:clamp(3rem,6vw,6rem);
}
.legal-section:first-of-type{border-top:none;margin-top:0}
.legal-section h2{
  padding-bottom:.75rem;
  border-bottom:1px solid var(--l-brd);
  margin-bottom:2rem;
}
.legal-section h2 span{
  font-size:.6rem;font-weight:500;letter-spacing:.2em;
  text-transform:uppercase;color:var(--l-faint);
  display:block;font-family:var(--mono);margin-bottom:.35rem;
}

/* ══════════════════════════════════════════════════════
   NOTA BOX
══════════════════════════════════════════════════════ */
.note-box{
  background:var(--gold-bg);
  border:1px solid rgba(200,168,72,.2);
  border-radius:var(--r2);
  padding:1rem 1.25rem;margin:1.25rem 0;
}
.note-box p{font-size:.82rem;color:var(--l-mid);margin:0;line-height:1.75}
.note-box strong{color:var(--gold-dk)}

/* ══════════════════════════════════════════════════════
   TABLA DE DATOS (privacidad, etc.)
══════════════════════════════════════════════════════ */
.table-wrap{
  overflow-x:auto;margin:1.25rem 0;
  border:1px solid var(--l-brd);border-radius:var(--r2);
}
.legal-table{width:100%;border-collapse:collapse;font-size:.8rem}
.legal-table th{
  font-size:.58rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-dk);background:var(--l-warm);
  padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--l-brd);
}
.legal-table td{
  padding:.75rem 1rem;border-bottom:1px solid var(--l-brd2);
  color:var(--l-muted);vertical-align:top;line-height:1.65;
}
.legal-table td:first-child{color:var(--l-ink);font-weight:400}
.legal-table tr:last-child td{border-bottom:none}
.legal-table tr:hover td{background:rgba(180,150,100,.04)}
.legal-table code{
  font-family:var(--mono);font-size:.8em;
  background:var(--l-warm);padding:.15em .4em;
  border-radius:var(--r);color:var(--l-mid);
}

/* ══════════════════════════════════════════════════════
   DATA BLOCK (RGPD row layout)
══════════════════════════════════════════════════════ */
.data-block{
  background:var(--l-warm);
  border:1px solid var(--l-brd);border-left:2px solid var(--gold);
  overflow:hidden;margin:1.25rem 0;border-radius:0 var(--r2) var(--r2) 0;
}
.data-row{
  display:grid;grid-template-columns:180px 1fr;
  gap:1rem;padding:.75rem 1.1rem;border-bottom:1px solid var(--l-brd2);
}
.data-row:last-child{border-bottom:none}
.data-row span:first-child{font-size:.62rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--l-faint)}
.data-row span:last-child{font-size:.85rem;color:var(--l-mid)}

/* ══════════════════════════════════════════════════════
   RESPONSIVE — LEGAL
══════════════════════════════════════════════════════ */
@media(max-width:640px){
  .data-row{grid-template-columns:1fr;gap:.2rem}
  .legal-table{font-size:.75rem}
  .legal-table th,.legal-table td{padding:.6rem .75rem}
}
