/* Estilos compartidos para los validadores nuevos · paleta antesdelafirma */
* { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --bg: #fafafa; --card: #fff; --ink: #0a0a0a; --ink-2: #404040; --ink-3: #737373; --ink-4: #a3a3a3;
  --line: #e5e7eb; --line-2: #d4d4d8;
  --green: #14b8a6; --green-dk: #0f766e; --green-50: #f0fdfa;
  --amber: #f59e0b; --amber-50: #fffbeb;
  --red: #ef4444; --red-50: #fef2f2; --red-100: #fee2e2;
  --blue: #3b82f6; --blue-50: #eff6ff;
  --purple: #8b5cf6; --purple-50: #f5f3ff;
  --mono: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
}
html, body { background: var(--bg); color: var(--ink); font-family: Inter, system-ui, sans-serif; line-height: 1.5; -webkit-font-smoothing: antialiased; }
.container { max-width: 980px; margin: 0 auto; padding: 0 24px; }
.topbar { border-bottom: 1px solid var(--line); background: rgba(255,255,255,0.9); backdrop-filter: blur(10px); position: sticky; top: 0; z-index: 100; }
.topbar-inner { display: flex; align-items: center; justify-content: space-between; padding: 14px 24px; max-width: 1200px; margin: 0 auto; }
.topbar a { color: var(--ink-3); text-decoration: none; font-size: 13px; }
.topbar a:hover { color: var(--ink); }
.topbar .logo { font-weight: 700; color: var(--ink); }
.topbar nav { display: flex; gap: 24px; }

.hero { padding: 56px 0 28px; }
.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size: 12px; font-weight:600; padding:6px 12px; border-radius: 100px; margin-bottom: 18px; letter-spacing: 0.04em; text-transform: uppercase; }
h1 { font-size: 40px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.15; margin-bottom: 16px; }
h1 em { font-style: normal; color: var(--green-dk); }
.lead { font-size: 17px; color: var(--ink-2); max-width: 720px; line-height: 1.6; }
.lead strong { color: var(--ink); font-weight: 600; }

.form-card { background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 28px; margin-top: 36px; }
.form-card h2 { font-size: 18px; font-weight: 600; margin-bottom: 6px; }
.form-card .sub { font-size: 13px; color: var(--ink-3); margin-bottom: 16px; }
textarea { width: 100%; min-height: 280px; padding: 14px; border: 1px solid var(--line-2); border-radius: 10px; font-family: var(--mono); font-size: 12px; line-height: 1.5; background: #fafafa; color: var(--ink); resize: vertical; }
textarea:focus { outline: 2px solid var(--green); outline-offset: -1px; }
.btn-validar { margin-top: 14px; padding: 14px 28px; background: var(--ink); color: white; border: none; border-radius: 10px; font-size: 15px; font-weight: 600; cursor: pointer; font-family: inherit; }
.btn-validar:hover { opacity: 0.9; }
.btn-validar:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-ejemplo { margin-top: 10px; margin-left: 10px; padding: 10px 16px; background: transparent; border: 1px solid var(--line-2); border-radius: 8px; font-size: 13px; color: var(--ink-2); cursor: pointer; font-family: inherit; }
.btn-ejemplo:hover { background: #fafafa; color: var(--ink); }

.privacidad { margin-top: 14px; padding: 12px 16px; background: var(--green-50); border: 1px solid #99f6e4; border-radius: 10px; font-size: 12px; color: #115e59; line-height: 1.5; }

.resultado { display: none; margin-top: 36px; }
.veredicto-card { padding: 28px; border-radius: 16px; margin-bottom: 24px; }
.veredicto-card.limpio { background: var(--green-50); border: 1px solid #99f6e4; }
.veredicto-card.revisar { background: var(--blue-50); border: 1px solid #bfdbfe; }
.veredicto-card.negociable { background: var(--amber-50); border: 1px solid #fcd34d; }
.veredicto-card.problematico { background: var(--red-50); border: 1px solid #fca5a5; }
.veredicto-card.no_firmar, .veredicto-card.no_comprar, .veredicto-card.usura { background: var(--red-100); border: 2px solid var(--red); }
.veredicto-card h2 { font-size: 26px; font-weight: 700; letter-spacing: -0.015em; margin-bottom: 4px; }
.veredicto-card .score { font-family: var(--mono); font-size: 36px; font-weight: 700; }
.veredicto-card.limpio h2, .veredicto-card.limpio .score { color: var(--green-dk); }
.veredicto-card.revisar h2, .veredicto-card.revisar .score { color: var(--blue); }
.veredicto-card.negociable h2, .veredicto-card.negociable .score { color: #92400e; }
.veredicto-card.problematico h2, .veredicto-card.problematico .score,
.veredicto-card.no_firmar h2, .veredicto-card.no_firmar .score,
.veredicto-card.no_comprar h2, .veredicto-card.no_comprar .score,
.veredicto-card.usura h2, .veredicto-card.usura .score { color: #991b1b; }
.veredicto-row { display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
.veredicto-stats { display: flex; gap: 14px; flex-wrap: wrap; font-size: 12px; }
.stat-chip { padding: 4px 10px; border-radius: 100px; background: white; border: 1px solid var(--line); font-weight: 600; }
.stat-chip.critical { color: var(--red); border-color: #fca5a5; }
.stat-chip.warning { color: #92400e; border-color: #fcd34d; }
.stat-chip.info { color: var(--blue); border-color: #bfdbfe; }

.alerta { background: var(--card); border: 1px solid var(--line); border-left: 4px solid var(--ink-3); border-radius: 10px; padding: 18px 22px; margin-bottom: 14px; }
.alerta.critical { border-left-color: var(--red); }
.alerta.warning { border-left-color: var(--amber); }
.alerta.info { border-left-color: var(--blue); }
.alerta-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
.alerta-nivel { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 3px 8px; border-radius: 4px; }
.alerta.critical .alerta-nivel { background: var(--red-50); color: var(--red); }
.alerta.warning .alerta-nivel { background: var(--amber-50); color: #92400e; }
.alerta.info .alerta-nivel { background: var(--blue-50); color: var(--blue); }
.alerta-titulo { font-size: 15px; font-weight: 600; color: var(--ink); }
.alerta-codigo { font-family: var(--mono); font-size: 10px; color: var(--ink-4); margin-left: auto; }
.alerta-desc { font-size: 13px; color: var(--ink-2); line-height: 1.6; margin-bottom: 10px; }
.alerta-rec { background: #fafafa; padding: 10px 12px; border-radius: 8px; font-size: 13px; line-height: 1.6; }
.alerta-rec strong { color: var(--green-dk); }
.alerta-legal { margin-top: 6px; font-size: 11px; color: var(--ink-4); font-family: var(--mono); }

.datos-card { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 22px; margin-top: 24px; }
.datos-card h3 { font-size: 14px; font-weight: 600; margin-bottom: 14px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ink-3); }
.datos-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.dato { background: #fafafa; padding: 10px 12px; border-radius: 8px; }
.dato .label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ink-3); font-weight: 600; }
.dato .value { font-family: var(--mono); font-size: 14px; font-weight: 600; color: var(--ink); margin-top: 2px; word-break: break-word; }
.dato .value.no-data { color: var(--ink-4); font-style: italic; }

.footer-note { margin: 80px 0 40px; padding-top: 32px; border-top: 1px solid var(--line); font-size: 12px; color: var(--ink-3); line-height: 1.7; }
.footer-note a { color: var(--ink-2); }

@media (max-width: 640px) {
  h1 { font-size: 28px; }
  .datos-grid { grid-template-columns: 1fr; }
  .topbar nav a:not(:first-child):not(:last-child) { display: none; }
}
