/* ===========================================================
   DatoFino — Plantilla de REPORTE de datos
   Hereda el lenguaje "Curioso": verde-noche, serif de título,
   acento naranjo, mono JetBrains, semáforo como dato.
   Pensada para lectura larga y para ser citada por motores de IA.
   Sistema de componentes reutilizable (miles de páginas).
   =========================================================== */

/* Fuentes de marca self-hosteadas (AUD-20 H1). Antes venían de una hoja
   remota de Google Fonts, pero la CSP estricta (style-src/font-src 'self',
   AUD-01) bloqueaba ese origen → la marca caía a fallbacks. Ahora son woff2
   (subset latin) en /assets/fonts/: cumplen la CSP sin tocarla, sin cadena
   de requests ni 3er origen. font-display:swap = texto visible al toque.
   Spectral es estática (un archivo por peso); Figtree y JetBrains Mono son
   VARIABLES → un solo woff2 cubre todo el eje wght (font-weight:rango). */
@font-face{font-family:'Spectral';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/spectral-400.woff2') format('woff2');}
@font-face{font-family:'Spectral';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/spectral-500.woff2') format('woff2');}
@font-face{font-family:'Spectral';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/spectral-600.woff2') format('woff2');}
@font-face{font-family:'Spectral';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/spectral-400i.woff2') format('woff2');}
@font-face{font-family:'Spectral';font-style:italic;font-weight:500;font-display:swap;src:url('/assets/fonts/spectral-500i.woff2') format('woff2');}
@font-face{font-family:'Figtree';font-style:normal;font-weight:100 900;font-display:swap;src:url('/assets/fonts/figtree.woff2') format('woff2');}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:100 800;font-display:swap;src:url('/assets/fonts/jetbrains-mono.woff2') format('woff2');}

:root{
  --bg:#060d09;
  --bg-2:#0a140e;
  --card:rgba(236,244,237,.025);
  --ink:#ECF4ED;
  --read:rgba(236,244,237,.82);   /* cuerpo legible para lectura larga */
  --muted:rgba(236,244,237,.58);
  --muted-2:rgba(236,244,237,.52); /* AUD-21: .36 daba ~3:1; .52 ≈ 5:1 (AA) */
  --line:rgba(236,244,237,.13);
  --line-2:rgba(236,244,237,.07);

  --accent:#F64A00;
  --accent-deep:#D33D00;
  --green:#46D07F;
  --amar:#F4C34D;
  --rojo:#FF7A5E;

  --readw:780px;     /* ancho de texto */
  --wide:1080px;     /* ancho de tablas / panorama */
  --pad:clamp(20px,4vw,40px);
  --ease:cubic-bezier(.22,.7,.2,1);

  --f-disp:'Spectral', Georgia, serif;
  --f-body:'Figtree', system-ui, sans-serif;
  --f-mono:'JetBrains Mono', ui-monospace, monospace;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--read);
  font-family:var(--f-body); font-size:17px; line-height:1.62;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  min-height:100svh; overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--accent); color:#fff; }
b,strong{ font-weight:700; color:var(--ink); }

/* Foco visible por teclado (AUD-21, WCAG 2.4.7). */
:focus-visible{ outline:3px solid var(--accent); outline-offset:2px; }
.df-btn:focus-visible{ outline-color:var(--ink); }

/* Saltar al contenido (AUD-21, WCAG 2.4.1): visible solo al enfocar con teclado. */
.skip-link{ position:fixed; left:12px; top:-60px; z-index:100; background:var(--accent-deep,#D33D00); color:#fff; padding:10px 16px; border-radius:8px; font-family:var(--f-body); font-weight:600; transition:top .15s var(--ease); }
.skip-link:focus{ top:12px; }

/* progreso de lectura */
.scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:0%; z-index:300;
  background:linear-gradient(90deg, var(--green), var(--accent));
  transition:width .08s linear;
}

/* ===========================================================
   1 · HEADER (barra simple, sticky)
   =========================================================== */
.site-head{
  position:sticky; top:0; z-index:120;
  background:rgba(6,13,9,.78); backdrop-filter:blur(14px) saturate(1.2); -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line-2);
}
.site-head-inner{
  max-width:var(--wide); margin-inline:auto; padding:14px var(--pad);
  display:flex; align-items:center; gap:22px;
}
.brand{ display:inline-flex; align-items:center; gap:9px; }
.brand img{ width:26px; height:26px; }
.brand .name{ font-family:var(--f-disp); font-weight:500; font-size:1.24rem; letter-spacing:-.01em; }
.brand .name b{ font-weight:600; }
.head-nav{ margin-left:auto; display:flex; align-items:center; gap:24px; }
.head-nav a{ font-size:.92rem; color:var(--muted); transition:color .16s; }
.head-nav a:hover{ color:var(--ink); }
.head-cta{
  font-family:var(--f-body); font-weight:600; font-size:.88rem;
  padding:9px 18px; border-radius:999px; border:1px solid rgba(246,74,0,.4);
  background:rgba(246,74,0,.12); color:var(--ink);
  transition:background .16s, transform .16s;
}
.head-cta:hover{ background:rgba(246,74,0,.22); transform:translateY(-1px); }
@media(max-width:680px){ .head-nav a:not(.head-cta){ display:none; } }

/* ===========================================================
   contenedor de documento
   =========================================================== */
.doc{ max-width:var(--wide); margin-inline:auto; padding:0 var(--pad); }
.doc-col{ max-width:var(--readw); }   /* columna de lectura alineada izq. */

/* ===========================================================
   2 · ENCABEZADO DE PÁGINA (H1 + bajada + frescura)
   =========================================================== */
.page-head{ position:relative; isolation:isolate; overflow:hidden; border-bottom:1px solid var(--line-2); }
.page-head #radar{ position:absolute; inset:0; width:100%; height:100%; z-index:0; opacity:.55; transition:opacity .6s var(--ease); }
.page-head.no-radar #radar{ opacity:0; }
.page-head .veil{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(6,13,9,.4) 0%, rgba(6,13,9,.2) 30%, rgba(6,13,9,.72) 78%, var(--bg) 100%);
}
.page-head-inner{
  position:relative; z-index:2;
  max-width:var(--wide); margin-inline:auto; padding:clamp(40px,7vw,86px) var(--pad) clamp(30px,5vw,54px);
}
.crumbs{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); display:flex; gap:.6em; flex-wrap:wrap; margin-bottom:1.4rem; }
.crumbs a:hover{ color:var(--accent); }
.crumbs .sep{ color:var(--line); }
.page-head h1{
  font-family:var(--f-disp); font-weight:500; letter-spacing:-.015em; line-height:1.08;
  font-size:clamp(2rem,5vw,3.5rem); margin:0; max-width:18ch; text-wrap:balance; color:var(--ink);
}
/* Título sin tell de "dos fuentes/dos colores" a media frase — ver curioso.css. */
.page-head h1 em{ font-style:normal; color:inherit; }
.page-sub{
  font-size:clamp(1.05rem,1.6vw,1.28rem); color:var(--muted); line-height:1.5;
  max-width:56ch; margin:1.4rem 0 0; text-wrap:pretty;
}
.freshness{
  margin-top:1.8rem; display:inline-flex; align-items:center; gap:.7em; flex-wrap:wrap;
  font-family:var(--f-mono); font-size:.76rem; color:var(--muted-2); letter-spacing:.02em;
}
.freshness .live{ width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 9px 1px var(--green); animation:pulse 2.4s var(--ease) infinite; }
.freshness b{ color:var(--muted); font-weight:500; }
.freshness .sep{ color:var(--line); }
@keyframes pulse{ 0%,100%{ opacity:.5; } 50%{ opacity:1; } }
@media(prefers-reduced-motion:reduce){ .freshness .live{ animation:none; } }

/* ===========================================================
   3 · PANORAMA (tarjeta destacada de indicadores)
   =========================================================== */
.panorama{
  position:relative; z-index:2; margin:clamp(-30px,-4vw,-46px) auto 0; max-width:var(--wide);
  padding:0 var(--pad);
}
.panorama-card{
  display:grid; grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line); border-radius:18px; overflow:hidden;
  background:linear-gradient(180deg, rgba(10,18,13,.92), rgba(10,18,13,.82));
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  box-shadow:0 40px 90px -50px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.05);
}
.pan-stat{ padding:clamp(1.3rem,2.6vw,2rem); border-right:1px solid var(--line-2); }
.pan-stat:last-child{ border-right:none; }
.pan-stat .n{
  font-family:var(--f-disp); font-weight:500; font-size:clamp(2rem,4.4vw,3rem); line-height:.95; letter-spacing:-.03em; color:var(--ink);
}
.pan-stat .n .u{ font-size:.42em; color:var(--accent); margin-left:.12em; vertical-align:.22em; font-weight:600; }
.pan-stat.hot .n{ color:var(--accent); }
.pan-stat .l{ font-family:var(--f-mono); font-size:.74rem; color:var(--muted); margin-top:.7rem; line-height:1.45; }
@media(max-width:780px){
  .panorama-card{ grid-template-columns:repeat(2,1fr); }
  .pan-stat:nth-child(2){ border-right:none; }
  .pan-stat:nth-child(1),.pan-stat:nth-child(2){ border-bottom:1px solid var(--line-2); }
}
@media(max-width:430px){
  .panorama-card{ grid-template-columns:1fr; }
  .pan-stat{ border-right:none; border-bottom:1px solid var(--line-2); }
  .pan-stat:last-child{ border-bottom:none; }
}

/* ===========================================================
   4 · BLOQUE H2 ANSWER-FIRST (componente central)
   =========================================================== */
.qblock{ border-top:1px solid var(--line-2); }
.qblock-inner{ max-width:var(--wide); margin-inline:auto; padding:clamp(48px,7vw,86px) var(--pad); }
.qblock .qnum{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); display:block; margin-bottom:1rem; }
.qblock h2{
  font-family:var(--f-disp); font-weight:500; letter-spacing:-.015em; line-height:1.1;
  font-size:clamp(1.55rem,3.2vw,2.4rem); margin:0; max-width:22ch; text-wrap:balance; color:var(--ink);
}
.qblock h2 em{ font-style:normal; color:inherit; }
/* primera frase = respuesta directa, destacada */
.answer{
  font-family:var(--f-disp); font-weight:400; font-style:normal;
  font-size:clamp(1.18rem,2vw,1.5rem); line-height:1.4; color:var(--ink);
  max-width:var(--readw); margin:1.5rem 0 0; text-wrap:pretty;
  padding-left:1.1rem; border-left:2px solid var(--accent);
}
.answer b{ color:var(--accent); font-weight:600; }
.context{ font-size:1.02rem; color:var(--read); line-height:1.62; max-width:var(--readw); margin:1.2rem 0 0; text-wrap:pretty; }
.context + .context{ margin-top:1rem; }
.context a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; text-decoration-color:rgba(246,74,0,.4); }
.context a:hover{ text-decoration-color:var(--accent); }
.aside-note{ font-family:var(--f-mono); font-size:.78rem; color:var(--muted-2); line-height:1.55; max-width:var(--readw); margin:1.3rem 0 0; }
.aside-note::before{ content:"// "; color:var(--accent); }

/* ===========================================================
   SEMÁFORO · componente de dato (no decoración)
   =========================================================== */
.sem{ display:inline-flex; align-items:center; gap:.5em; white-space:nowrap; font-variant-numeric:tabular-nums; }
.sem .dot{ width:9px; height:9px; border-radius:50%; flex:none; }
.sem.v .dot{ background:var(--green); box-shadow:0 0 8px 1px rgba(70,208,127,.7); }
.sem.a .dot{ background:var(--amar); box-shadow:0 0 7px 0 rgba(244,195,77,.5); }
.sem.r .dot{ background:var(--rojo); box-shadow:0 0 7px 0 rgba(255,122,94,.5); }
.sem .lab{ font-family:var(--f-mono); font-size:.86em; color:var(--read); }

/* leyenda del semáforo */
.sem-legend{
  display:flex; flex-wrap:wrap; gap:clamp(.8rem,2vw,1.6rem); margin-top:1.3rem;
  font-family:var(--f-mono); font-size:.74rem; color:var(--muted); letter-spacing:.01em;
}
.sem-legend .li{ display:inline-flex; align-items:center; gap:.5em; }
.sem-legend .dot{ width:9px; height:9px; border-radius:50%; }
.sem-legend .v .dot{ background:var(--green); box-shadow:0 0 8px 1px rgba(70,208,127,.7); }
.sem-legend .a .dot{ background:var(--amar); }
.sem-legend .r .dot{ background:var(--rojo); }

/* ===========================================================
   TABLA DE DATOS (componente · móvil con scroll)
   =========================================================== */
.table-wrap{ margin-top:1.8rem; border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--card); }
.table-scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
table.data{ width:100%; border-collapse:collapse; min-width:560px; }
table.data caption{ text-align:left; font-family:var(--f-mono); font-size:.72rem; color:var(--muted-2); padding:.9rem 1.1rem; letter-spacing:.04em; border-bottom:1px solid var(--line-2); }
table.data thead th{
  font-family:var(--f-mono); font-size:.7rem; font-weight:500; letter-spacing:.08em; text-transform:uppercase;
  color:var(--muted-2); text-align:left; padding:.85rem 1.1rem; border-bottom:1px solid var(--line);
  white-space:nowrap; background:rgba(0,0,0,.18);
}
table.data thead th.num{ text-align:right; }
table.data tbody td{ padding:.95rem 1.1rem; border-bottom:1px solid var(--line-2); vertical-align:middle; font-size:.96rem; }
table.data tbody tr:last-child td{ border-bottom:none; }
table.data tbody tr{ transition:background .14s; }
table.data tbody tr:hover{ background:rgba(246,74,0,.05); }
table.data td.num{ text-align:right; font-variant-numeric:tabular-nums; font-family:var(--f-mono); font-size:.9rem; color:var(--read); }
table.data td.money{ text-align:right; font-variant-numeric:tabular-nums; font-family:var(--f-mono); font-size:.9rem; color:var(--ink); }
table.data .rubro-link{ font-weight:600; color:var(--ink); display:inline-flex; align-items:center; gap:.4em; }
table.data .rubro-link .arr{ color:var(--muted-2); transition:transform .14s, color .14s; font-family:var(--f-mono); }
table.data tr:hover .rubro-link{ color:var(--accent); }
table.data tr:hover .rubro-link .arr{ color:var(--accent); transform:translateX(2px); }
.table-hint{ font-family:var(--f-mono); font-size:.7rem; color:var(--muted-2); margin:.7rem 0 0; }
@media(max-width:600px){ .table-hint::after{ content:" — desliza la tabla →"; } }

/* ===========================================================
   5 · TARJETAS DE NICHO (puerta abierta)
   =========================================================== */
.niche-grid{ margin-top:1.8rem; display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.niche{
  border:1px solid var(--line); border-radius:16px; padding:clamp(1.3rem,2.4vw,1.7rem);
  background:var(--card); position:relative; overflow:hidden;
  transition:border-color .16s, transform .16s, background .16s;
}
.niche.open{ background:linear-gradient(160deg, rgba(70,208,127,.08), transparent 65%); border-color:rgba(70,208,127,.28); }
.niche:hover{ transform:translateY(-3px); border-color:var(--muted-2); }
.niche .ntop{ display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.niche .nrubro{ font-family:var(--f-disp); font-weight:500; font-size:1.18rem; letter-spacing:-.01em; color:var(--ink); line-height:1.15; }
.niche .nbig{ font-family:var(--f-disp); font-weight:500; font-size:clamp(2.4rem,5vw,3rem); line-height:1; letter-spacing:-.03em; color:var(--green); margin-top:1rem; }
.niche .nbig .u{ font-size:.34em; color:var(--muted); font-family:var(--f-mono); font-weight:400; margin-left:.4em; letter-spacing:.04em; }
.niche.amber .nbig{ color:var(--amar); }
.niche .nl{ font-family:var(--f-mono); font-size:.72rem; color:var(--muted); margin-top:.6rem; line-height:1.45; }
@media(max-width:820px){ .niche-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .niche-grid{ grid-template-columns:1fr; } }

/* lista de medianas (mini-listado) */
.median-list{ margin-top:1.6rem; border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--card); max-width:var(--readw); }
.median-row{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.85rem 1.2rem; border-bottom:1px solid var(--line-2); }
.median-row:last-child{ border-bottom:none; }
.median-row.general{ background:rgba(246,74,0,.06); }
.median-row .ml{ color:var(--read); font-size:.96rem; }
.median-row.general .ml{ color:var(--ink); font-weight:600; }
.median-row .mv{ font-family:var(--f-mono); font-variant-numeric:tabular-nums; font-size:.92rem; color:var(--ink); white-space:nowrap; }
.median-row.general .mv{ color:var(--accent); font-weight:700; }

/* ===========================================================
   FAQ · acordeón
   =========================================================== */
.faq{ margin-top:1.8rem; max-width:var(--readw); border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line-2); }
.faq-q{
  width:100%; text-align:left; background:none; border:none; cursor:pointer; color:var(--ink);
  font-family:var(--f-disp); font-weight:500; font-size:clamp(1.08rem,1.8vw,1.3rem); letter-spacing:-.01em;
  padding:1.2rem 2.4rem 1.2rem 0; position:relative; line-height:1.3;
}
.faq-q .ic{ position:absolute; right:0; top:1.4rem; width:16px; height:16px; flex:none; transition:transform .25s var(--ease); }
.faq-q .ic::before,.faq-q .ic::after{ content:""; position:absolute; background:var(--accent); border-radius:2px; }
.faq-q .ic::before{ top:7px; left:0; width:16px; height:2px; }
.faq-q .ic::after{ left:7px; top:0; width:2px; height:16px; transition:transform .25s var(--ease); }
.faq-item.open .faq-q .ic::after{ transform:scaleY(0); }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .3s var(--ease); }
.faq-a-inner{ padding:0 0 1.3rem; color:var(--read); font-size:1rem; line-height:1.6; max-width:60ch; }

/* ===========================================================
   12 · CTA (banda destacada, sobria)
   =========================================================== */
.cta-band{ border-top:1px solid var(--line-2); background:var(--bg-2); position:relative; overflow:hidden; }
.cta-band::before{
  content:""; position:absolute; right:-8%; top:-40%; width:min(640px,80vw); height:min(640px,80vw); border-radius:50%;
  background:radial-gradient(circle, rgba(246,74,0,.14), transparent 64%); pointer-events:none;
}
.cta-inner{ position:relative; max-width:var(--wide); margin-inline:auto; padding:clamp(44px,6vw,72px) var(--pad);
  display:grid; grid-template-columns:1.5fr auto; gap:clamp(1.6rem,4vw,3rem); align-items:center; }
.cta-text h2{ font-family:var(--f-disp); font-weight:500; font-size:clamp(1.5rem,3vw,2.2rem); letter-spacing:-.015em; line-height:1.18; margin:0; max-width:24ch; color:var(--ink); }
.cta-text h2 em{ font-style:normal; color:inherit; }
.cta-text .micro{ font-family:var(--f-mono); font-size:.78rem; color:var(--muted-2); margin-top:1rem; }
.cta-text .micro b{ color:var(--muted); font-weight:500; }
.df-btn{
  display:inline-flex; align-items:center; gap:.55em; justify-content:center;
  font-family:var(--f-body); font-weight:600; font-size:1.02rem; line-height:1;
  padding:16px 30px; border-radius:999px; border:1px solid transparent;
  background:var(--accent-deep); color:#fff; cursor:pointer; white-space:nowrap; /* AUD-21: #D33D00 da blanco a 4,7:1 (AA); el #F64A00 daba 3,6:1 */
  box-shadow:0 14px 34px -12px rgba(246,74,0,.7), inset 0 1px 0 rgba(255,255,255,.2);
  transition:transform .16s var(--ease), background .16s, box-shadow .16s;
}
.df-btn svg{ width:1.15em; height:1.15em; }
.df-btn:hover{ transform:translateY(-2px); background:#B83400; box-shadow:0 18px 40px -12px rgba(246,74,0,.8); }
@media(max-width:720px){ .cta-inner{ grid-template-columns:1fr; } }

/* ===========================================================
   13 · FOOTER
   =========================================================== */
.colophon{ border-top:1px solid var(--line-2); background:rgba(0,0,0,.34); }
.colophon-inner{ max-width:var(--wide); margin-inline:auto; padding:2.6rem var(--pad); }
.colophon-top{ display:flex; flex-wrap:wrap; gap:1.4rem 2rem; align-items:center; justify-content:space-between; }
.colophon .c-brand{ display:flex; align-items:center; gap:.6rem; color:var(--ink); font-family:var(--f-disp); font-weight:500; font-size:1.15rem; letter-spacing:-.01em; }
.colophon .c-brand img{ width:24px; height:24px; }
.c-links{ display:flex; flex-wrap:wrap; gap:1.4rem; font-family:var(--f-mono); font-size:.78rem; }
.c-links a{ color:var(--muted-2); transition:color .16s; }
.c-links a:hover{ color:var(--accent); }
.colophon-meta{
  margin-top:1.8rem; padding-top:1.4rem; border-top:1px solid var(--line-2);
  display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; align-items:center;
  font-family:var(--f-mono); font-size:.74rem; color:var(--muted-2); line-height:1.5;
}
.colophon-meta b{ color:var(--muted); font-weight:500; }
.colophon-meta .sep{ color:var(--line); }
.source-tag{ display:inline-flex; align-items:center; gap:.5em; }
.source-tag .dot{ width:6px; height:6px; border-radius:50%; background:var(--green); }

/* ===========================================================
   REVEAL
   =========================================================== */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1 !important; transform:none !important; } }

/* ===========================================================
   TWEAKS PANEL (idéntico a Curioso)
   =========================================================== */
.tweaks{
  position:fixed; right:18px; bottom:18px; z-index:200; width:296px; max-width:calc(100vw - 36px);
  background:#0c150f; border:1px solid var(--line); border-radius:18px;
  box-shadow:0 30px 70px -24px rgba(0,0,0,.7); overflow:hidden; color:var(--ink);
  transform:translateY(20px) scale(.97); opacity:0; pointer-events:none;
  transition:transform .3s var(--ease), opacity .3s var(--ease);
}
.tweaks.open{ transform:none; opacity:1; pointer-events:auto; }
.tweaks-head{ display:flex; align-items:center; justify-content:space-between; padding:13px 16px; border-bottom:1px solid var(--line-2); }
.tweaks-head .t{ font-family:var(--f-mono); font-size:.82rem; font-weight:700; display:inline-flex; align-items:center; gap:.5em; }
.tweaks-head .t .live{ width:8px; height:8px; border-radius:50%; background:var(--green); }
.tweaks-close{ border:none; background:transparent; font-size:1.4rem; line-height:1; cursor:pointer; color:var(--muted); }
.tweaks-body{ padding:6px 16px 8px; max-height:62vh; overflow:auto; }
.tw-row{ padding:12px 0; border-bottom:1px solid var(--line-2); }
.tw-row:last-child{ border-bottom:none; }
.tw-label{ font-size:.82rem; font-weight:600; margin-bottom:9px; display:flex; justify-content:space-between; align-items:center; }
.tw-label .v{ font-family:var(--f-mono); font-size:.72rem; color:var(--muted); }
.tw-toggle{ width:44px; height:25px; border-radius:999px; border:none; background:var(--line); position:relative; cursor:pointer; transition:background .2s; }
.tw-toggle[aria-checked="true"]{ background:var(--accent); }
.tw-toggle::after{ content:""; position:absolute; top:3px; left:3px; width:19px; height:19px; border-radius:50%; background:#fff; transition:transform .2s var(--ease); }
.tw-toggle[aria-checked="true"]::after{ transform:translateX(19px); }
.tw-swatches{ display:flex; gap:8px; }
.tw-swatch{ width:30px; height:30px; border-radius:9px; border:2px solid transparent; cursor:pointer; transition:transform .12s; }
.tw-swatch:hover{ transform:scale(1.08); }
.tw-swatch[aria-checked="true"]{ border-color:#fff; box-shadow:0 0 0 2px #0c150f inset; }
.tw-seg{ display:flex; gap:6px; }
.tw-seg button{ flex:1; font-family:var(--f-body); font-size:.82rem; font-weight:600; padding:8px 4px; border-radius:9px; border:1px solid var(--line); background:transparent; cursor:pointer; color:var(--muted); transition:all .15s; }
.tw-seg button[aria-checked="true"]{ background:var(--accent); border-color:var(--accent); color:#fff; }
.tw-text{ width:100%; font-family:var(--f-body); font-size:.86rem; padding:9px 11px; border-radius:9px; border:1px solid var(--line); background:rgba(0,0,0,.3); color:var(--ink); }
.tw-text:focus{ outline:none; border-color:var(--accent); }
input[type=range]{ width:100%; accent-color:var(--accent); }
.tweaks-foot{ padding:11px 16px; border-top:1px solid var(--line-2); font-family:var(--f-mono); font-size:.7rem; color:var(--muted-2); }

/* ===========================================================
   VARIANTE COMPACTA
   =========================================================== */
.compact .page-head h1{ max-width:20ch; }
.compact-stat-row{ margin-top:1.8rem; display:grid; grid-template-columns:repeat(3,1fr); gap:14px; max-width:var(--readw); }
@media(max-width:560px){ .compact-stat-row{ grid-template-columns:1fr; } }
