/* ============================================================
   VECTOR EMPRESARIAL — Aviso legal · página austera
============================================================ */

:root{
  --teal:#1B6B93;
  --teal-700:#155471;
  --teal-50:#EAF2F7;
  --ink:#0F172A;
  --ink-2:#475569;
  --ink-3:#64748B;
  --line:#E5E9EE;
  --line-2:#EEF1F4;
  --bg:#FFFFFF;
  --bg-alt:#F8FAFC;
  --bg-dark-2:#091A2C;
  --r-sm:.5rem;
  --r:.75rem;
  --r-lg:1rem;
  --maxw:1400px;
  --maxw-read:760px;
  --gutter:40px;
  --ease: cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Inter",ui-sans-serif,system-ui,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
::selection{background:var(--teal);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);position:relative}
.wrap-read{max-width:var(--maxw-read);margin:0 auto;padding:0 var(--gutter);position:relative}
.mono{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace}

.eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--teal);display:inline-flex;align-items:center;gap:10px;margin:0}
.eyebrow .bullet{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}
.eyebrow.muted{color:var(--ink-3)}

h1{font-size:clamp(40px,4.4vw,60px);line-height:1.04;letter-spacing:-.035em;font-weight:800;color:var(--ink);margin:0;text-wrap:balance}
h2{font-size:24px;line-height:1.2;letter-spacing:-.015em;font-weight:700;color:var(--ink);margin:0}
h3{font-size:16px;line-height:1.3;letter-spacing:-.005em;font-weight:700;color:var(--ink);margin:0}
p{margin:0;color:var(--ink-2);text-wrap:pretty}

/* Header */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;transition:border-color .25s ease, background .25s ease}
header.site.scrolled{border-color:var(--line);background:rgba(255,255,255,.94)}
.scroll-bar{position:absolute;left:0;right:0;bottom:-1px;height:2px;background:transparent}
.scroll-bar-fill{height:100%;background:var(--teal);width:0%;transition:width .12s linear}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.01em;font-size:16px;color:var(--ink)}
.logo-mark{width:30px;height:30px;border-radius:8px;background:var(--teal);display:grid;place-items:center;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18), 0 4px 12px -4px rgba(27,107,147,.45)}
.logo-mark svg{width:14px;height:14px}
nav.primary{display:flex;align-items:center;gap:4px}
nav.primary a{padding:9px 14px;border-radius:8px;font-size:14.5px;color:var(--ink);font-weight:500;transition:background .15s ease, color .15s ease}
nav.primary a:hover{background:var(--bg-alt);color:var(--teal)}
.btn{position:relative;display:inline-flex;align-items:center;gap:.55em;padding:14px 22px;border-radius:var(--r);font-weight:600;font-size:15px;transition:transform .25s var(--ease), background .25s var(--ease);white-space:nowrap}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 6px 20px -10px rgba(27,107,147,.55)}
.btn-primary:hover{background:var(--teal-700)}
.btn .arrow{transition:transform .3s var(--ease);display:inline-block}
.btn:hover .arrow{transform:translateX(4px)}

/* Hero */
.hero{padding:80px 0 56px;background:var(--bg-alt);border-bottom:1px solid var(--line)}
.hero-inner{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.hero-inner h1{margin-top:8px;max-width:18ch}
.hero-inner p.sub{font-size:17px;color:var(--ink-2);max-width:60ch;line-height:1.6}
.hero-meta{
  margin-top:16px;font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11.5px;
  color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--line);border-radius:6px;padding:5px 10px;
}
.hero-meta b{color:var(--ink);font-weight:600}

/* Body — two cols: ToC sticky left + reading column */
.legal-body{padding:64px 0 96px}
.legal-grid{display:grid;grid-template-columns:240px 1fr;gap:64px;align-items:flex-start}

.toc{position:sticky;top:104px}
.toc h4{
  font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-3);
  font-weight:600;margin:0 0 14px;
}
.toc ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;counter-reset:toc}
.toc ol li{counter-increment:toc}
.toc a{
  display:grid;grid-template-columns:24px 1fr;gap:10px;align-items:flex-start;
  padding:8px 10px;border-radius:8px;font-size:13.5px;color:var(--ink-2);line-height:1.4;
  transition:background .2s var(--ease), color .2s var(--ease);
  border-left:2px solid transparent;
}
.toc a::before{content:counter(toc, decimal-leading-zero);font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;color:var(--ink-3);font-weight:500}
.toc a:hover{background:var(--bg-alt);color:var(--ink)}
.toc a.active{background:var(--bg-alt);color:var(--ink);font-weight:600;border-left-color:var(--teal)}

/* Reading column */
.legal-reader{max-width:680px}
.legal-section{
  margin-bottom:64px;padding-bottom:64px;border-bottom:1px solid var(--line-2);scroll-margin-top:104px;
}
.legal-section:last-child{border-bottom:0;padding-bottom:0;margin-bottom:0}
.legal-section .section-num{
  font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;
  color:var(--teal);letter-spacing:.12em;font-weight:600;text-transform:uppercase;margin-bottom:14px;
}
.legal-section h2{margin-bottom:24px}
.legal-section h3{margin:32px 0 12px;font-size:15px;letter-spacing:.02em;text-transform:uppercase;color:var(--ink-3);font-weight:600;letter-spacing:.08em}
.legal-section p{font-size:15px;line-height:1.75;color:var(--ink-2);margin-bottom:14px}
.legal-section p b{color:var(--ink);font-weight:600}
.legal-section ul{list-style:none;padding:0;margin:14px 0 18px;display:flex;flex-direction:column;gap:10px}
.legal-section ul li{
  position:relative;padding-left:22px;font-size:15px;line-height:1.65;color:var(--ink-2);
}
.legal-section ul li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:2px;background:var(--teal)}
.legal-section ul li b{color:var(--ink);font-weight:600}

.legal-meta-box{
  background:var(--bg-alt);border:1px solid var(--line);border-left:3px solid var(--teal);
  border-radius:0 8px 8px 0;padding:18px 22px;margin:18px 0 24px;
}
.legal-meta-box dl{display:grid;grid-template-columns:160px 1fr;gap:8px 18px;margin:0;font-size:14px}
.legal-meta-box dt{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase;padding-top:2px}
.legal-meta-box dd{margin:0;color:var(--ink);font-weight:500}

.placeholder-flag{
  display:inline-flex;align-items:center;gap:8px;font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#a86c0a;
  background:#FFF8EB;border:1px solid #FCD9A1;padding:6px 11px;border-radius:6px;margin-bottom:22px;
}
.placeholder-flag::before{content:"●";color:#F59E0B}

/* Cookie table */
.cookie-table{
  border:1px solid var(--line);border-radius:8px;overflow:hidden;margin:16px 0 18px;font-size:13.5px;
}
.cookie-table .row{
  display:grid;grid-template-columns:1.2fr 1fr 2fr .8fr;
  padding:12px 14px;border-bottom:1px solid var(--line-2);gap:14px;
}
.cookie-table .row:last-child{border-bottom:0}
.cookie-table .row.head{
  background:var(--bg-alt);font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;
  font-size:10.5px;color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase;font-weight:600;
}
.cookie-table .row b{color:var(--ink);font-weight:600}
.cookie-table .row .cat{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--teal);text-transform:uppercase}

/* Footer */
footer.site{background:var(--bg-dark-2);color:#fff;padding:80px 0 32px;position:relative}
footer.site::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg, transparent, rgba(255,255,255,.15), transparent)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:48px}
.footer-logo{margin-bottom:14px;font-size:18px;color:#fff;display:flex;align-items:center;gap:10px}
footer.site h5{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:600;margin:0 0 18px}
footer.site ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
footer.site a{color:rgba(255,255,255,.82);font-size:14.5px;transition:color .15s ease}
footer.site a:hover{color:#fff}
footer.site .brand{font-weight:700;font-size:18px;color:#fff}
footer.site .tag{color:rgba(255,255,255,.65);font-size:14.5px;margin:8px 0 6px;font-style:italic;font-family:"Lora",Georgia,serif}
footer.site .loc{color:rgba(255,255,255,.5);font-size:13px}
.copy{margin-top:64px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);font-size:12.5px;color:rgba(255,255,255,.5);display:flex;justify-content:space-between;align-items:center}

@media (max-width:1080px){
  .legal-grid{grid-template-columns:1fr;gap:32px}
  .toc{position:static}
  .legal-meta-box dl{grid-template-columns:1fr}
  .cookie-table .row{grid-template-columns:1fr;gap:6px}
  .cookie-table .row.head{display:none}
}
@media (max-width:980px){
  :root{--gutter:28px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  nav.primary{display:none}
}

/* ============================================================
   TWEAKS · 3 control axes
     [data-tone]   = notarial (default) | legible | compacto
     [data-layout] = indice (default)   | lineal  | cards
     [data-accent] = sutil (default)    | marcado | monocromo
   These reshape the *feel* of the page, not single pixels.
============================================================ */

/* ---- Tone: legible (Lora serif body, generous line-height) ---- */
body[data-tone="legible"] .hero-inner p.sub{
  font-family:"Lora",Georgia,serif;font-style:italic;font-size:19px;line-height:1.55;
}
body[data-tone="legible"] .legal-section p{
  font-family:"Lora",Georgia,serif;font-size:17px;line-height:1.85;color:var(--ink-2);
}
body[data-tone="legible"] .legal-section ul li{
  font-family:"Lora",Georgia,serif;font-size:16.5px;line-height:1.75;
}
body[data-tone="legible"] .legal-section h2{
  font-family:"Lora",Georgia,serif;font-weight:500;font-style:italic;letter-spacing:-.01em;font-size:30px;
}
body[data-tone="legible"] .legal-meta-box dd{font-family:"Inter",sans-serif}

/* ---- Tone: compacto (denser, smaller, manual de derecho feel) ---- */
body[data-tone="compacto"] h1{font-size:clamp(32px,3.4vw,46px)}
body[data-tone="compacto"] .hero{padding:56px 0 36px}
body[data-tone="compacto"] .hero-inner p.sub{font-size:15px;line-height:1.55}
body[data-tone="compacto"] .legal-body{padding:48px 0 72px}
body[data-tone="compacto"] .legal-section{margin-bottom:40px;padding-bottom:40px}
body[data-tone="compacto"] .legal-section h2{font-size:19px;margin-bottom:16px;letter-spacing:-.005em}
body[data-tone="compacto"] .legal-section h3{margin:22px 0 8px;font-size:11px;letter-spacing:.14em}
body[data-tone="compacto"] .legal-section p{font-size:13.5px;line-height:1.6;margin-bottom:10px}
body[data-tone="compacto"] .legal-section ul{margin:10px 0 14px;gap:7px}
body[data-tone="compacto"] .legal-section ul li{font-size:13.5px;line-height:1.55;padding-left:18px}
body[data-tone="compacto"] .legal-section ul li::before{top:9px}
body[data-tone="compacto"] .section-num{font-size:10px;margin-bottom:10px}
body[data-tone="compacto"] .legal-meta-box{padding:14px 18px;margin:14px 0 18px}
body[data-tone="compacto"] .legal-meta-box dl{gap:6px 14px;font-size:12.5px}
body[data-tone="compacto"] .cookie-table{font-size:12px}
body[data-tone="compacto"] .cookie-table .row{padding:9px 11px}

/* ---- Layout: lineal (sin ToC, columna única estrecha) ---- */
body[data-layout="lineal"] .toc{display:none}
body[data-layout="lineal"] .legal-grid{grid-template-columns:1fr;gap:0}
body[data-layout="lineal"] .legal-reader{max-width:640px;margin:0 auto}

/* ---- Layout: cards (cada sección es una ficha bordeada) ---- */
body[data-layout="cards"] .toc{display:none}
body[data-layout="cards"] .legal-grid{grid-template-columns:1fr;gap:0}
body[data-layout="cards"] .legal-reader{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:28px}
body[data-layout="cards"] .legal-section{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:40px 44px;margin:0;
  box-shadow:0 18px 40px -32px rgba(15,23,42,.18), 0 2px 6px -3px rgba(15,23,42,.05);
}
body[data-layout="cards"] .legal-section:not(:last-child){border-bottom:1px solid var(--line)}
body[data-layout="cards"].legal-body{background:var(--bg-alt)}
body[data-layout="cards"] .legal-body{background:var(--bg-alt)}

/* ---- Accent: marcado (acentos teal con presencia) ---- */
body[data-accent="marcado"] .legal-section{
  border-top:3px solid var(--teal);padding-top:36px;
}
body[data-accent="marcado"] .legal-section:first-child{border-top:3px solid var(--teal)}
body[data-accent="marcado"] .section-num{
  display:inline-block;background:var(--teal);color:#fff;padding:5px 10px;border-radius:5px;
  letter-spacing:.14em;
}
body[data-accent="marcado"] .legal-section h2{
  position:relative;padding-bottom:18px;margin-bottom:32px;
}
body[data-accent="marcado"] .legal-section h2::after{
  content:"";position:absolute;left:0;bottom:0;width:56px;height:3px;background:var(--teal);
}
body[data-accent="marcado"] .legal-section h3{color:var(--teal)}
body[data-accent="marcado"] .toc a.active{background:var(--teal-50);border-left-width:3px;color:var(--teal)}
body[data-accent="marcado"] .toc a.active::before{color:var(--teal);font-weight:600}
body[data-accent="marcado"] .hero{background:linear-gradient(180deg, var(--bg-alt) 0%, var(--bg-alt) 80%, #fff 100%)}
body[data-accent="marcado"] .hero-meta{border-color:var(--teal);color:var(--teal)}

/* ---- Accent: monocromo (negro puro · austeridad máxima) ---- */
body[data-accent="monocromo"]{
  --teal:#0F172A;
  --teal-700:#000;
  --teal-50:#F1F5F9;
  --orange-50:#F3F4F6;
}
body[data-accent="monocromo"] .placeholder-flag{
  background:#F3F4F6;border-color:#D1D5DB;color:#374151;
}
body[data-accent="monocromo"] .placeholder-flag::before{color:#6B7280}
body[data-accent="monocromo"] .cookie-table .row .cat{color:var(--ink)}
body[data-accent="monocromo"] .toc a.active{border-left-color:var(--ink)}
body[data-accent="monocromo"] .legal-meta-box{border-left-color:var(--ink)}
body[data-accent="monocromo"] .scroll-bar-fill{background:var(--ink)}

/* When `cards` + `marcado` combine, the border-top stays inside the card */
body[data-layout="cards"][data-accent="marcado"] .legal-section{border-top:3px solid var(--teal);padding-top:32px}

