:root{ --brand:#1f2a44; --accent:#0e7c86; --ink:#1a1f2c; --muted:#5b6472; --line:#e4e7ec; --bg:#f5f6f8; --card:#fff; --ok:#15803d; --okl:#dcfce7; --warn:#b45309; --warnl:#fef3c7; --red:#b91c1c; --redl:#fee2e2; }
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:system-ui,-apple-system,"Segoe UI",sans-serif;background:var(--bg);color:var(--ink);line-height:1.5}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
.muted{color:var(--muted);font-size:.86rem}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:9px;font-weight:600;font-size:.88rem;border:none;cursor:pointer;text-decoration:none}
.btn-brand{background:var(--brand);color:#fff}.btn-brand:hover{filter:brightness(1.12);text-decoration:none}
.btn-ghost{background:#fff;border:1.5px solid var(--line);color:var(--muted)}.btn-ghost:hover{border-color:var(--brand);color:var(--brand);text-decoration:none}
.btn-sm{padding:6px 11px;font-size:.8rem}
/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand),#0a1326);padding:20px}
.login-card{background:#fff;border-radius:18px;padding:36px;max-width:380px;width:100%;box-shadow:0 20px 50px rgba(0,0,0,.3);text-align:center}
.login-logo{max-height:64px;margin-bottom:10px}
.login-brand{font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--accent);font-weight:700}
.login-card h1{font-size:1.4rem;color:var(--brand);margin:6px 0 2px}
.login-card form{text-align:left;margin-top:18px}
.login-card label{display:block;font-size:.82rem;font-weight:600;margin:10px 0 5px}
.login-card input{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:9px}
.login-foot{margin-top:18px;font-size:.74rem;color:var(--muted)}
/* topbar / nav */
.topbar{background:var(--brand);color:#fff;display:flex;align-items:center;gap:13px;padding:11px 18px}
.tb-logo{width:38px;height:38px;border-radius:8px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;overflow:hidden}
.tb-logo img{max-width:100%;max-height:100%}.tb-logo span{font-weight:700}
.tb-titles{flex:1;min-width:0}.tb-org{font-weight:700;font-size:1.02rem}.tb-sub{font-size:.68rem;opacity:.7;text-transform:uppercase;letter-spacing:1px}
.tb-user{display:flex;align-items:center;gap:10px}.tb-name{font-size:.84rem}
.rol-pill{font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:20px;background:rgba(255,255,255,.16)}
.rol-admin{background:#fef3c7;color:#92400e}.rol-recepcion{background:#dbeafe;color:#1e40af}.rol-resolutor{background:#dcfce7;color:#166534}
.nav{background:#fff;border-bottom:1px solid var(--line);display:flex;gap:2px;padding:0 14px;overflow-x:auto;position:sticky;top:0;z-index:10}
.nav-item{padding:13px 14px;font-size:.86rem;font-weight:600;color:var(--muted);border-bottom:2.5px solid transparent;white-space:nowrap}
.nav-item:hover{color:var(--brand);text-decoration:none}.nav-item.active{color:var(--accent);border-bottom-color:var(--accent)}
/* layout */
.main{max-width:1000px;margin:0 auto;padding:22px 16px 50px}
.vh{margin-bottom:16px}.vh h2{font-size:1.4rem;color:var(--brand)}
.card{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:18px;box-shadow:0 1px 3px rgba(16,24,40,.05);margin-bottom:16px}
.card-h{font-weight:700;color:var(--brand);margin-bottom:12px;font-size:.96rem}
.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:18px}
.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px}
.sv{font-size:1.8rem;font-weight:800;color:var(--brand);line-height:1}.sl{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:5px}
/* tabla */
.tbl{width:100%;border-collapse:collapse;font-size:.86rem}
.tbl th{background:var(--brand);color:#fff;text-align:left;padding:10px 12px;font-size:.72rem;text-transform:uppercase;letter-spacing:.4px}
.tbl td{padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:#fafbfc}
.empty{text-align:center;color:var(--muted);padding:30px}
/* estados / plazos */
.estado{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.72rem;font-weight:700}
.est-recibido{background:#e0e7ff;color:#3730a3}.est-asignado{background:#dbeafe;color:#1e40af}.est-en_resolucion{background:#fef3c7;color:#92400e}
.est-respondido{background:#cffafe;color:#0e7490}.est-cerrado{background:var(--okl);color:var(--ok)}.est-archivado{background:#f1f5f9;color:#64748b}.est-aclaracion{background:#fef3c7;color:#92400e}
.dr{font-weight:700;font-size:.8rem;padding:2px 8px;border-radius:6px}
.dr-ok{background:var(--okl);color:var(--ok)}.dr-warn{background:var(--warnl);color:var(--warn)}.dr-venc{background:var(--redl);color:var(--red)}
/* formularios */
.form label{display:block;font-weight:600;font-size:.82rem;margin:12px 0 5px}
.form input[type=text],.form input[type=email],.form input[type=password],.form input[type=date],.form input:not([type]),.form select,.form textarea{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:9px;font-size:.9rem;font-family:inherit}
.form input[type=file]{font-size:.84rem}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.chk{display:flex;align-items:center;gap:8px;font-weight:500;font-size:.86rem;margin:8px 0}
.chk input{width:auto}
.chkgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:4px;margin-top:4px}
.hint{font-size:.76rem;color:var(--muted);margin-top:3px}
.kv{padding:6px 0;font-size:.9rem;border-bottom:1px solid #f1f3f5}.kv:last-child{border:none}
.inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.alert{padding:11px 14px;border-radius:9px;font-size:.86rem;margin-bottom:14px}.alert.err{background:var(--redl);color:var(--red)}.alert.ok{background:var(--okl);color:var(--ok)}
.foot{text-align:center;padding:18px;font-size:.74rem;color:var(--muted);background:#fff;border-top:1px solid var(--line)}
@media(max-width:600px){.grid2{grid-template-columns:1fr}.tbl{font-size:.78rem}.tbl th,.tbl td{padding:7px}}
.nav-badge{display:inline-block;background:#dc2626;color:#fff;font-size:.7rem;font-weight:700;line-height:1;border-radius:10px;padding:3px 7px;margin-left:2px;vertical-align:middle}
/* — Módulos de cumplimiento — */
.cards-cumpl{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.ccard{display:block;background:var(--card);border:1.5px solid var(--line);border-radius:13px;padding:16px;text-decoration:none;color:var(--ink);transition:border-color .15s}
.ccard:hover{border-color:var(--accent);text-decoration:none}
.ccard-t{font-weight:700;color:var(--brand);font-size:.96rem;margin-bottom:5px}
.ccard-d{font-size:.8rem;color:var(--muted);line-height:1.45;margin-bottom:9px}
.ccard-s{font-size:.74rem;font-weight:700;padding:3px 9px;border-radius:12px;display:inline-block;background:var(--bg);color:var(--muted)}
.ccard-s.ok{background:var(--okl);color:var(--ok)}
.ccard-s.pend{background:var(--warnl);color:var(--warn)}
.multa-res{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:8px}
.mr-box{border:1.5px solid var(--line);border-radius:11px;padding:13px;text-align:center}
.mr-box.mr-est{border-color:var(--accent);background:#fffaf2}
.mr-l{font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700}
.mr-v{font-size:1.3rem;font-weight:800;color:var(--brand);margin-top:4px}
.mr-est .mr-v{color:#b45309}
.riesgo-row{display:grid;grid-template-columns:2fr 64px 64px 2fr;gap:7px;margin-bottom:7px}
.riesgo-row input,.riesgo-row select{padding:8px 10px;font-size:.84rem}
@media(max-width:640px){.riesgo-row{grid-template-columns:1fr 64px 64px;}.riesgo-row input:last-child{grid-column:1/-1}}
