section .wrap {display: flex; flex-direction: column; align-items: center; max-width: 720px; }

.legal-hero { padding: 64px 0 48px; }
.legal-eyebrow { font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); margin-bottom: 12px; }
.legal-h1 { font-size: clamp(28px,4vw,42px); font-weight: 900; line-height: 1.08; letter-spacing: -.03em; color: var(--navy); margin-bottom: 14px; }
.legal-meta { font-size: 12px; color: var(--gray-txt); }
.legal-body { padding-bottom: 80px;}
.legal-body .wrap {max-width: 860px;}
.legal-body h2 { font-size: 17px; font-weight: 800; color: var(--navy); letter-spacing: -.02em; margin-top: 44px; margin-bottom: 14px; padding-top: 44px; border-top: 1px solid var(--gray-line); }
.legal-body h2:first-child { margin-top: 0; padding-top: 0; border-top: none; }
.legal-body p { font-size: 14px; color: var(--gray-txt); line-height: 1.8; margin-bottom: 14px; }
.legal-body p:last-child { margin-bottom: 0; }
.legal-body ul { margin: 12px 0 14px 0; display: flex; flex-direction: column; gap: 8px; padding-left: 0; list-style: none; }
.legal-body ul li { font-size: 14px; color: var(--gray-txt); line-height: 1.7; display: flex; align-items: flex-start; gap: 10px; }
.legal-body ul li::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--accent); flex-shrink: 0; margin-top: 8px; }
.legal-body a { color: var(--accent); text-decoration: none; }
.legal-body a:hover { text-decoration: underline; }
.legal-body strong { font-weight: 700; color: var(--navy); }
.review-flag { background: var(--review-bg); border: 1px solid var(--review-border); border-radius: 10px; padding: 14px 18px; margin: 16px 0; display: flex; align-items: flex-start; gap: 10px; }
.review-flag-icon { font-size: 14px; flex-shrink: 0; margin-top: 1px; }
.review-flag-txt { font-size: 12px; color: var(--review-txt); line-height: 1.6; font-style: italic; }
.review-flag-txt strong { font-weight: 700; font-style: normal; }
.legal-index { background: var(--gray-bg); border-radius: 14px; padding: 24px 28px; margin-bottom: 44px; }
.legal-index-title { font-size: 11px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase; color: var(--gray-txt); margin-bottom: 14px; }
.legal-index ol { list-style: none; display: flex; flex-direction: column; gap: 8px; counter-reset: idx; padding: 0; }
.legal-index ol li { counter-increment: idx; display: flex; align-items: center; gap: 8px; }
.legal-index ol li::before { content: counter(idx, decimal-leading-zero); font-size: 10px; font-weight: 700; color: var(--accent); min-width: 22px; }
.legal-index ol li a { font-size: 13px; font-weight: 600; color: var(--navy); text-decoration: none; transition: color .18s; }
.legal-index ol li a:hover { color: var(--accent); }

/* TABLA DE COOKIES */
.cookies-table-wrap { overflow-x: auto; margin: 20px 0; border-radius: 12px; border: 1.5px solid var(--gray-line); }
.cookies-table { width: 100%; border-collapse: collapse; min-width: 500px; }
.cookies-table thead tr { background: var(--navy); }
.cookies-table thead th { padding: 12px 16px; font-size: 11px; font-weight: 700; color: rgba(255,255,255,.70); text-align: left; letter-spacing: .04em; text-transform: uppercase; }
.cookies-table tbody tr:nth-child(even) td { background: var(--gray-bg); }
.cookies-table td { padding: 12px 16px; font-size: 13px; color: var(--gray-txt); border-top: 1px solid var(--gray-line); line-height: 1.5; vertical-align: top; }
.cookies-table td:first-child { font-weight: 600; color: var(--navy); }
.badge-esencial { background: rgba(22,163,74,.10); color: rgba(22,163,74,.80); font-size: 9px; font-weight: 700; padding: 2px 8px; border-radius: 100px; white-space: nowrap; }
.badge-analisis  { background: rgba(37,99,235,.10); color: rgba(37,99,235,.75); font-size: 9px; font-weight: 700; padding: 2px 8px; border-radius: 100px; white-space: nowrap; }
.badge-marketing { background: rgba(217,119,6,.12); color: rgba(180,83,9,.90); font-size: 9px; font-weight: 700; padding: 2px 8px; border-radius: 100px; white-space: nowrap; }

.footer { background: var(--navy); padding: 56px 0 0; }
.footer-top { display: flex; justify-content: space-between; gap: 48px; flex-wrap: wrap; padding-bottom: 40px; }
.footer-logo { font-size: 18px; font-weight: 800; color: #fff; letter-spacing: -.03em; }
.footer-logo span { font-weight: 300; color: var(--accent); }
.footer-tagline { font-size: 10px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase; color: rgba(255,255,255,.25); margin: 4px 0 12px; }
.footer-brand-desc { font-size: 12px; color: rgba(255,255,255,.28); line-height: 1.7; max-width: 200px; }
.footer-col-wrap { display: flex; gap: 44px; flex-wrap: wrap; }
.footer-col { display: flex; flex-direction: column; gap: 10px; }
.footer-col-title { font-size: 10px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase; color: rgba(255,255,255,.22); margin-bottom: 4px; }
.footer-col a { font-size: 13px; color: rgba(255,255,255,.42); text-decoration: none; transition: color .18s; }
.footer-col a:hover { color: rgba(255,255,255,.80); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.07); padding: 20px 0 28px; }
.footer-disclaimer { font-size: 11px; color: rgba(255,255,255,.20); line-height: 1.7; max-width: 580px; margin-bottom: 14px; }
.footer-copy { font-size: 11px; color: rgba(255,255,255,.20); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 6px; }
@media (max-width: 720px) {
  .footer-top { flex-direction: column; gap: 32px; }
  .footer-col-wrap { gap: 28px; }
}
@media (max-width: 740px){
  .nav-links, .nav-btns { display: none;}
  .hamburger { display: block; }
}