/* ============================================================
   CésarAguilar.Coach — Estilos comunes para páginas legales
   (Aviso legal · Privacidad · Cookies)
   Mantiene el branding exacto del index: paleta coral, navegación
   y footer idénticos, tipografía Manrope, mismo sistema visual.
   ============================================================ */

:root {
  --coral: #FF533D; --coral-deep: #E23512;
  --coral-soft: rgba(255,83,61,0.08);
  --coral-line: rgba(255,83,61,0.24);
  --bg-dark: #0C0E12; --bg-deep: #06070A; --bg-gray: #F5F6F8;
  --text-dark: #0C0E12;
  --text-secondary: #5B6470;
  --text-light: #FFFFFF;
  --text-light-dim: rgba(255,255,255,0.78);
  --text-muted: rgba(255,255,255,0.48);
  --border: #E5E7EB;
  --border-dark: rgba(255,255,255,0.08);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: 'Manrope', system-ui, -apple-system, sans-serif;
  color: var(--text-dark);
  background: #fff;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

.container { max-width: 1120px; margin: 0 auto; padding: 0 24px; }
.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 24px; }

/* ============ NAV (idéntico al index) ============ */
.nav {
  background: #fff;
  border-bottom: 1px solid var(--border);
  padding: 16px 0;
  position: sticky; top: 0; z-index: 100;
}
.nav-inner {
  max-width: 1120px; margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
}
.brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: inherit; }
.iso {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--bg-dark); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 16px;
  position: relative;
  font-family: 'Manrope', sans-serif;
}
.iso::after {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--coral); position: absolute; top: 6px; right: 6px;
}
.brand-text { font-size: 17px; font-weight: 700; letter-spacing: -0.01em; }
.brand-text .dot { color: var(--coral); }
.brand-text .coach-underline {
  text-decoration: underline;
  text-decoration-color: var(--coral);
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}
.back-link {
  color: var(--text-secondary); text-decoration: none;
  font-size: 14px; font-weight: 500;
  transition: color 0.15s;
}
.back-link:hover { color: var(--coral); }

/* ============ HEADER ============ */
.legal-header {
  padding: 80px 0 56px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #FAFAFB 0%, #fff 100%);
}
.eyebrow {
  font-size: 11.5px; text-transform: uppercase;
  letter-spacing: 0.18em; color: var(--coral);
  font-weight: 700; margin-bottom: 14px;
}
h1 {
  font-size: clamp(34px, 4.5vw, 52px);
  font-weight: 800; letter-spacing: -0.03em;
  line-height: 1.05; margin-bottom: 14px;
}
h1 .dot { color: var(--coral); }
.legal-header .meta { color: var(--text-secondary); font-size: 14px; }

/* ============ CONTENT ============ */
.legal-content { padding: 56px 0 96px; }
.legal-content h2 {
  font-size: 22px; font-weight: 800;
  letter-spacing: -0.02em;
  margin: 40px 0 14px;
  color: var(--text-dark);
}
.legal-content h2:first-child { margin-top: 0; }
.legal-content h3 {
  font-size: 17px; font-weight: 700;
  margin: 26px 0 10px;
  color: var(--text-dark);
}
.legal-content p {
  font-size: 15.5px; color: #2D3340; margin-bottom: 14px;
}
.legal-content ul, .legal-content ol {
  margin: 0 0 18px 24px; padding: 0;
}
.legal-content li {
  font-size: 15.5px; color: #2D3340; margin-bottom: 8px;
}
.legal-content strong { font-weight: 700; color: var(--text-dark); }
.legal-content a {
  color: var(--coral); text-decoration: underline;
  text-underline-offset: 2px;
}
.legal-content a:hover { color: var(--coral-deep); }

/* Tablas legales */
.legal-table {
  width: 100%; border-collapse: collapse;
  margin: 18px 0; font-size: 14.5px;
  border: 1px solid var(--border);
  border-radius: 8px; overflow: hidden;
}
.legal-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.legal-table tr:last-child td { border-bottom: 0; }
.legal-table td:first-child {
  font-weight: 700; color: var(--text-dark);
  width: 32%; background: var(--bg-gray);
}
.legal-table th {
  padding: 12px 14px; text-align: left;
  background: var(--bg-dark); color: #fff;
  font-size: 12.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.legal-table.cookies-table td:first-child {
  background: transparent; width: auto; font-weight: 600;
}
.legal-table.cookies-table tr:nth-child(even) td { background: var(--bg-gray); }

/* Callout coral */
.callout {
  background: var(--coral-soft);
  border-left: 3px solid var(--coral);
  padding: 18px 22px;
  border-radius: 6px;
  margin: 26px 0; font-size: 14.5px;
}
.callout p { margin: 0; color: var(--text-dark); }

/* Tarjetas de derechos (privacidad) */
.rights-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 14px; margin: 18px 0;
}
@media (min-width: 640px) {
  .rights-grid { grid-template-columns: 1fr 1fr; }
}
.right-card {
  background: var(--bg-gray);
  border-radius: 10px; padding: 16px 18px;
  border: 1px solid var(--border);
}
.right-card h4 {
  font-size: 14.5px; font-weight: 800;
  margin-bottom: 6px; color: var(--coral);
}
.right-card p {
  font-size: 13.5px; margin: 0;
  color: #2D3340; line-height: 1.5;
}

/* ============ FOOTER (idéntico al index) ============ */
footer {
  background: var(--bg-deep);
  color: var(--text-light-dim);
  padding: 64px 0 32px;
  border-top: 1px solid var(--border-dark);
}
.footer-grid {
  display: grid; gap: 40px;
  grid-template-columns: 1fr;
  margin-bottom: 48px;
}
@media (min-width: 780px) {
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; }
}
.foot-brand .brand { margin-bottom: 16px; }
.foot-brand .brand-text { color: #fff; }
.foot-brand p {
  color: var(--text-light-dim);
  font-size: 14px; max-width: 320px;
  line-height: 1.6;
}
.foot-col h4 {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-muted); margin-bottom: 16px;
}
.foot-col ul { list-style: none; }
.foot-col li { margin-bottom: 10px; }
.foot-col a {
  color: var(--text-light-dim);
  font-size: 14px; font-weight: 500;
  text-decoration: none; transition: color 0.15s;
}
.foot-col a:hover { color: var(--coral); }
.foot-legal {
  border-top: 1px solid var(--border-dark);
  padding-top: 24px;
  display: flex; flex-wrap: wrap;
  gap: 16px 24px;
  justify-content: space-between; align-items: flex-start;
  font-size: 12px; color: var(--text-muted);
}
.foot-legal a { color: var(--text-muted); text-decoration: none; }
.foot-legal a:hover { color: var(--coral); }
.foot-legal .legal-info { max-width: 700px; line-height: 1.6; }
.foot-legal strong { color: var(--text-light-dim); font-weight: 700; }
@media (max-width: 760px) {
  .foot-legal { flex-direction: column; gap: 12px; }
}
