/* ═══════════════ FÁBRICA NOTARIAL v2 · ESTILOS ═══════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0A0E17; --panel:#111827; --panel2:#0D1219; --campo:#151F2E;
  --texto:#E2DDD4; --muted:#7A8BA0; --muted2:#5A6B80;
  --oro:#C9963F; --oro-osc:#9A7030;
  --verde:#34D399; --rojo:#F87171; --ambar:#FBBF24;
  --borde:rgba(255,255,255,0.07); --borde-oro:rgba(201,150,63,0.25);
}
body{font-family:system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;background:var(--bg);color:var(--texto);height:100vh;overflow:hidden}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#1E2C42;border-radius:4px}
.oculto{display:none !important}

/* ═══ PORTADA ═══ */
#portada{position:fixed;inset:0;background:radial-gradient(ellipse at top,#101828,#070A12);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}
.portada-box{background:var(--panel);border:1px solid var(--borde-oro);border-radius:18px;padding:42px 38px;max-width:460px;width:100%;text-align:center;box-shadow:0 24px 64px rgba(0,0,0,.55)}
.portada-logo{font-size:44px;margin-bottom:10px}
.portada-box h1{color:var(--oro);font-size:26px;margin-bottom:6px}
.portada-sub{color:var(--muted);font-size:13px;margin-bottom:24px}
.portada-status{margin-top:16px}
.pill{display:inline-block;padding:6px 14px;border:1px solid var(--borde);border-radius:999px;font-size:12px;color:var(--muted)}
.pill.ok{border-color:rgba(52,211,153,.4);color:var(--verde)}
.pill.error{border-color:rgba(248,113,113,.4);color:var(--rojo)}
.portada-nota{margin-top:18px;font-size:11px;color:var(--muted2);line-height:1.6}

/* ═══ BOTONES ═══ */
.btn-oro{background:linear-gradient(135deg,var(--oro),var(--oro-osc));color:#07090F;border:none;border-radius:10px;padding:12px 22px;font-size:14px;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s}
.btn-oro:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(201,150,63,.3)}
.btn-oro:disabled{opacity:.5;cursor:wait;transform:none}
.btn-gris{background:transparent;color:var(--muted);border:1px solid var(--borde);border-radius:10px;padding:11px 18px;font-size:13px;cursor:pointer;transition:border-color .15s,color .15s}
.btn-gris:hover{border-color:var(--borde-oro);color:var(--texto)}

/* ═══ LAYOUT ═══ */
.app{display:flex;height:100vh;overflow:hidden}
.main{flex:1;display:flex;flex-direction:column;min-width:0}

/* ═══ SIDEBAR ═══ */
#sidebar{width:250px;min-width:250px;background:var(--panel2);border-right:1px solid var(--borde);display:flex;flex-direction:column;position:relative;transition:width .25s ease,min-width .25s ease}
#sidebar.colapsado{width:64px;min-width:64px}
.sb-header{padding:16px 14px;display:flex;align-items:center;gap:11px;border-bottom:1px solid var(--borde)}
.sb-ico{width:38px;height:38px;background:linear-gradient(145deg,var(--oro),#7A5C20);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sb-txt{overflow:hidden;white-space:nowrap;transition:opacity .2s}
.sb-title{font-size:14px;font-weight:700;color:var(--oro)}
.sb-sub{font-size:10px;color:#3A4F66;margin-top:2px}
#sidebar.colapsado .sb-txt{opacity:0;width:0}
#btn-toggle{position:absolute;top:74px;right:-13px;width:26px;height:26px;background:#1A2536;border:1px solid var(--borde-oro);border-radius:50%;color:var(--oro);font-size:11px;cursor:pointer;z-index:50;display:flex;align-items:center;justify-content:center;transition:transform .25s;line-height:1}
#btn-toggle:hover{background:#243550}
#sidebar.colapsado #btn-toggle{transform:rotate(180deg)}
.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px}
.sb-sec{font-size:9px;color:#2E4060;letter-spacing:1.5px;text-transform:uppercase;padding:12px 10px 4px;white-space:nowrap;transition:opacity .2s}
#sidebar.colapsado .sb-sec{opacity:0}
.ni{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:9px;cursor:pointer;margin-bottom:2px;border:1px solid transparent;white-space:nowrap;overflow:hidden;position:relative;transition:background .15s}
.ni:hover{background:rgba(255,255,255,.05)}
.ni.active{background:rgba(201,150,63,.1);border-color:rgba(201,150,63,.2)}
.ni-ico{font-size:15px;width:20px;text-align:center;flex-shrink:0}
.ni-lbl{font-size:13px;color:var(--muted);transition:opacity .2s}
.ni.active .ni-lbl{color:#D4C8A8;font-weight:600}
#sidebar.colapsado .ni-lbl{opacity:0;width:0}
.nb{margin-left:auto;background:rgba(201,150,63,.15);color:var(--oro);font-size:10px;padding:2px 7px;border-radius:10px;font-weight:700;flex-shrink:0;transition:opacity .2s}
#sidebar.colapsado .nb{opacity:0}
#sidebar.colapsado .ni::after{content:attr(data-tip);position:absolute;left:54px;top:50%;transform:translateY(-50%);background:#1A2536;border:1px solid var(--borde-oro);color:#C8BDA0;font-size:12px;padding:5px 11px;border-radius:7px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s;z-index:100}
#sidebar.colapsado .ni:hover::after{opacity:1}
.sb-user{padding:12px 14px;border-top:1px solid var(--borde);display:flex;align-items:center;gap:10px;overflow:hidden}
.sb-avatar{width:32px;height:32px;background:var(--campo);border:1px solid var(--borde-oro);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.sb-uinfo{overflow:hidden;transition:opacity .2s}
.sb-uname{font-size:12px;color:#8A9BB0;font-weight:600;white-space:nowrap}
.sb-urole{font-size:10px;color:#3A4F66;white-space:nowrap}
#sidebar.colapsado .sb-uinfo{opacity:0}
.sb-dot{width:8px;height:8px;border-radius:50%;background:var(--ambar);margin-left:auto;flex-shrink:0}
.sb-dot.on{background:var(--verde)}
#sidebar.colapsado .sb-dot{opacity:0}

/* ═══ TOPBAR ═══ */
.topbar{padding:14px 22px;border-bottom:1px solid var(--borde);background:rgba(17,24,39,.5);display:flex;align-items:center;justify-content:space-between}
.bc{font-weight:700;font-size:15px}
.top-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted2)}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted2);display:inline-block}
.status-dot.on{background:var(--verde)}
.status-dot.off{background:var(--rojo)}

/* ═══ VISTAS ═══ */
.view{display:none;padding:20px;overflow-y:auto;flex:1}
.view.active{display:block}
.card{background:var(--panel);border:1px solid var(--borde);border-radius:14px;padding:20px;margin-bottom:16px;max-width:1000px}
.card-title{font-size:13px;font-weight:700;color:var(--oro);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}
.lbl{display:block;font-size:11px;color:#4A5B70;text-transform:uppercase;letter-spacing:.5px;margin:12px 0 6px}
.inp{width:100%;background:var(--campo);border:1px solid rgba(201,150,63,.18);border-radius:9px;padding:11px 14px;color:var(--texto);font-size:13px;outline:none;transition:border-color .2s}
.inp:focus{border-color:rgba(201,150,63,.5)}
.area{resize:vertical;min-height:200px;font-family:'Courier New',monospace;font-size:12.5px;line-height:1.55}
select.inp{cursor:pointer}
.fila{display:flex;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}
.run-info{font-size:12px;color:var(--muted2)}
.nota{font-size:11.5px;color:var(--muted2);line-height:1.6;margin-top:12px}
.err-box{margin-top:14px;padding:12px 15px;border-radius:10px;border:1px solid rgba(248,113,113,.4);background:rgba(248,113,113,.1);color:#FECACA;font-size:13px;line-height:1.6;white-space:pre-wrap}
.cfg-msg{margin-top:12px;font-size:13px}

/* ═══ LOADING ═══ */
.spinner{width:34px;height:34px;border:3px solid #1E2C42;border-top-color:var(--oro);border-radius:50%;animation:girar .8s linear infinite;margin:6px auto 14px}
@keyframes girar{to{transform:rotate(360deg)}}
.load-msg{text-align:center;font-size:13px;color:var(--muted)}

/* ═══ RESULTADOS ═══ */
.semaforo{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:11px;font-weight:800;font-size:15px;margin-bottom:16px}
.semaforo.FAIL{background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.4);color:var(--rojo)}
.semaforo.WARN{background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.35);color:var(--ambar)}
.semaforo.OK{background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.35);color:var(--verde)}
.dato-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.dato{background:var(--campo);border:1px solid var(--borde);border-radius:9px;padding:10px 13px}
.dato .k{font-size:10px;color:#4A5B70;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.dato .v{font-size:13px;color:var(--texto);line-height:1.45;word-break:break-word}
.dato.malo{border-color:rgba(248,113,113,.45)}
.dato.malo .v{color:var(--rojo);font-weight:600}
.sub-sec{font-size:12px;font-weight:700;color:#8A9BB0;margin:18px 0 8px;text-transform:uppercase;letter-spacing:.6px}
.qa-item{border:1px solid var(--borde);border-left-width:4px;border-radius:9px;padding:12px 15px;margin-bottom:9px;background:var(--campo)}
.qa-item.FAIL{border-left-color:var(--rojo)}
.qa-item.WARN{border-left-color:var(--ambar)}
.qa-head{display:flex;align-items:center;gap:9px;margin-bottom:5px;flex-wrap:wrap}
.qa-id{font-size:11px;font-weight:800;font-family:'Courier New',monospace}
.qa-sev{font-size:10px;font-weight:800;padding:2px 9px;border-radius:9px}
.qa-sev.FAIL{background:rgba(248,113,113,.16);color:var(--rojo)}
.qa-sev.WARN{background:rgba(251,191,36,.14);color:var(--ambar)}
.qa-msg{font-size:13px;line-height:1.55}
.qa-accion{font-size:12px;color:var(--muted);margin-top:5px;line-height:1.5}
.qa-fuente{font-size:10.5px;color:#3A4F66;margin-top:5px;font-style:italic}
.qa-vacio{padding:14px;text-align:center;color:var(--verde);font-size:13px}

/* ═══ CASOS ═══ */
.caso-item{border:1px solid var(--borde);border-radius:10px;padding:13px 16px;margin-bottom:9px;background:var(--campo);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.caso-info{flex:1;min-width:200px}
.caso-id{font-weight:700;font-size:13px;color:var(--oro)}
.caso-meta{font-size:11px;color:var(--muted2);margin-top:3px}
.caso-sem{font-size:11px;font-weight:800;padding:3px 10px;border-radius:9px}
.caso-sem.FAIL{background:rgba(248,113,113,.14);color:var(--rojo)}
.caso-sem.WARN{background:rgba(251,191,36,.12);color:var(--ambar)}
.caso-sem.OK{background:rgba(52,211,153,.12);color:var(--verde)}
.btn-mini{background:transparent;border:1px solid var(--borde);color:var(--muted);border-radius:8px;padding:6px 12px;font-size:12px;cursor:pointer}
.btn-mini:hover{border-color:var(--borde-oro);color:var(--texto)}

/* ═══ REGLAS ═══ */
.regla-item{display:flex;gap:12px;align-items:flex-start;border-bottom:1px solid var(--borde);padding:10px 4px;font-size:12.5px}
.regla-id{font-family:'Courier New',monospace;font-weight:800;color:var(--oro);min-width:92px}
.regla-txt{color:var(--muted);line-height:1.5}

@media (max-width:760px){
  #sidebar{position:fixed;height:100vh;z-index:60}
  .card{padding:14px}
}
