

:root{--bg:#0b0f1a;--bg2:#111827;--bg3:#1a2235;--surface:#1f2d47;
  --border:#253352;--accent:#3b82f6;--accent2:#60a5fa;
  --gold:#f59e0b;--red:#ef4444;--green:#10b981;--teal:#06b6d4;--purple:#8b5cf6;
  --text:#f1f5f9;--text2:#94a3b8;--text3:#475569;
  --font:'Sora',sans-serif;--mono:'JetBrains Mono',monospace;--r:10px}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:13px;min-height:100vh}
/* HEADER */
.hdr{background:linear-gradient(90deg,#080d18,#0e1828,#080d18);border-bottom:1px solid var(--border);padding:0 22px;display:flex;align-items:center;gap:12px;height:54px;position:sticky;top:0;z-index:200}
.logo{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--accent),#1d4ed8);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.lt{font-size:15px;font-weight:700;letter-spacing:-.3px}.ls{font-size:10px;color:var(--text2);font-weight:300}
.nav{margin:0 auto;display:flex;gap:2px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:3px;overflow-x:auto;flex-shrink:1}
.tab{padding:6px 12px;border:none;background:none;color:var(--text2);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s;display:flex;align-items:center;gap:5px;white-space:nowrap}
.tab:hover{color:var(--text);background:var(--surface)}
.tab.on{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(59,130,246,.35)}
.tab.on.warn{background:var(--gold);box-shadow:0 2px 8px rgba(245,158,11,.35)}
.tab .n{border-radius:10px;padding:0 5px;font-size:10px;font-weight:700;background:rgba(255,255,255,.18);color:inherit}
.tab:not(.on) .n{background:var(--surface);color:var(--text3)}
.hdr-r{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.chip{background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:4px 10px;font-family:var(--mono);font-size:11px;color:var(--teal)}
/* PAGES */
.pg{display:none;padding:20px 22px;min-height:calc(100vh - 54px)}
.pg.on{display:block}
/* TOOLBAR */
.bar{display:flex;gap:8px;margin-bottom:15px;align-items:center;flex-wrap:wrap}
.srch{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:7px 12px;color:var(--text);font-family:var(--font);font-size:13px;width:270px;outline:none;transition:border-color .2s}
.srch:focus{border-color:var(--accent)}.srch::placeholder{color:var(--text3)}
select.sel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:7px 10px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;cursor:pointer}
.btn{padding:7px 13px;border-radius:var(--r);border:none;font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .2s;white-space:nowrap}
.bp{background:var(--accent);color:#fff}.bp:hover{background:var(--accent2)}
.bg{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.bg:hover{color:var(--text);border-color:var(--accent)}
.bred{background:var(--red);color:#fff}.bred:hover{opacity:.9}
.sm{padding:5px 10px;font-size:11px;border-radius:7px}
/* STATS */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:11px;margin-bottom:16px}
.sc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:13px;position:relative;overflow:hidden}
.sc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent)}
.sc.r::after{background:var(--red)}.sc.g::after{background:var(--gold)}.sc.n::after{background:var(--green)}.sc.t::after{background:var(--teal)}
.sl{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin-bottom:4px}
.sv{font-size:24px;font-weight:700;letter-spacing:-1px}.ss{font-size:10px;color:var(--text2);margin-top:2px}
/* TABLE */
.tw{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
table{width:100%;border-collapse:collapse}
th{background:var(--bg3);padding:9px 12px;text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text2);border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:9px 12px;border-bottom:1px solid rgba(37,51,82,.4);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(59,130,246,.04)}
.cuit{font-family:var(--mono);font-size:11px;color:var(--text2);white-space:nowrap}.rs{font-weight:500}
/* TAGS */
.tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;font-size:11px;font-weight:500;white-space:nowrap}
.tb{background:rgba(59,130,246,.15);color:var(--accent2)}.tg{background:rgba(16,185,129,.15);color:var(--green)}
.tgo{background:rgba(245,158,11,.15);color:var(--gold)}.tr{background:rgba(239,68,68,.15);color:var(--red)}
.tgr{background:rgba(71,85,105,.25);color:var(--text2)}.tt{background:rgba(6,182,212,.15);color:var(--teal)}
.tp{background:rgba(139,92,246,.15);color:var(--purple)}.tpj{background:rgba(139,92,246,.15);color:var(--purple);font-size:10px;padding:1px 6px}
.tpf{background:rgba(16,185,129,.12);color:var(--green);font-size:10px;padding:1px 6px}
/* CALENDAR */
.mb{margin-bottom:7px}
.mh{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:10px 15px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;transition:border-color .2s}
.mh:hover,.mh.on{border-color:rgba(59,130,246,.4)}.mn{font-size:14px;font-weight:700}.mm{display:flex;align-items:center;gap:9px}
.ma{color:var(--text3);transition:transform .2s;font-size:11px}.mh.on .ma{transform:rotate(180deg)}
.mbody{overflow:hidden;max-height:0;transition:max-height .3s ease}.mbody.on{max-height:9999px}
.dr{display:flex;padding:5px 0;align-items:flex-start;border-bottom:1px solid rgba(37,51,82,.3)}.dr:last-child{border-bottom:none}
.dd{width:84px;flex-shrink:0;font-family:var(--mono);font-size:11px;padding:2px 8px;margin-top:2px}
.dd.past{color:var(--text3)}.dd.today{color:var(--gold);font-weight:700}.dd.soon{color:var(--teal)}.dd.future{color:var(--text2)}
.dis{display:flex;flex-direction:column;gap:3px;flex:1}
.di{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:3px 6px;border-radius:6px;transition:background .15s}
.di:hover{background:rgba(59,130,246,.05)}
/* PENDIENTES */
.pc{background:var(--bg2);border:1px solid var(--border);border-radius:12px;margin-bottom:9px;overflow:hidden;transition:border-color .2s}
.pc:hover{border-color:rgba(245,158,11,.3)}
.pc-hd{display:flex;align-items:center;gap:11px;padding:13px 16px;cursor:pointer;user-select:none}
.pc-nm{font-weight:600;font-size:14px}.pc-cu{font-family:var(--mono);font-size:11px;color:var(--text2);margin-top:2px}
.pc-bd{display:none;padding:0 16px 13px;border-top:1px solid var(--border)}
.pc.open .pc-bd{display:block}
.ob-row{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:8px;margin-top:7px;background:var(--bg3);border:1px solid var(--border);transition:all .2s}
.ob-row:hover{border-color:rgba(59,130,246,.3)}
.ob-row.done{opacity:.55;border-style:dashed;background:transparent}
.done-lbl{font-size:10px;color:var(--green);font-weight:700;margin-left:4px;white-space:nowrap}
/* CLIENTES */
.cg{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:11px}
.cc{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:15px;transition:border-color .2s}
.cc:hover{border-color:rgba(59,130,246,.3)}
.cc-hd{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:11px}
.cc-nm{font-size:14px;font-weight:600;margin-bottom:3px}
.cr{display:flex;align-items:center;gap:6px;margin-bottom:5px}
.cl{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;width:74px;flex-shrink:0}
.cv{font-family:var(--mono);font-size:12px;color:var(--teal);background:rgba(6,182,212,.07);padding:3px 7px;border-radius:5px;cursor:pointer;transition:background .15s;flex:1;word-break:break-all}
.cv:hover{background:rgba(6,182,212,.15)}
.cpb{background:none;border:1px solid var(--border);border-radius:5px;color:var(--text3);padding:2px 6px;font-size:10px;cursor:pointer;transition:all .15s;flex-shrink:0}
.cpb:hover{border-color:var(--accent);color:var(--accent)}.ol{display:flex;flex-wrap:wrap;gap:4px;margin-top:7px}
/* ORGANISMOS */
.og{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:11px}
.oc{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:15px}
.oc-hd{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.oc-sig{width:42px;height:42px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
/* MODALS */
.ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:500;align-items:center;justify-content:center;padding:14px}
.ov.on{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:22px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px rgba(0,0,0,.5)}
.mw{max-width:740px}
.mt{font-size:15px;font-weight:700;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.ff{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:10px;color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.field input,.field select,.field textarea{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:8px 11px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border-color .2s;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}
.field textarea{resize:vertical;min-height:70px}
.mf{display:flex;justify-content:flex-end;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}
.ocg{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:6px;margin-top:4px}
.ock{display:flex;align-items:center;gap:7px;padding:6px 9px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;cursor:pointer;transition:border-color .2s}
.ock:hover{border-color:var(--accent)}.ock input{accent-color:var(--accent);width:13px;height:13px}.ock span{font-size:12px}
.sok{background:rgba(16,185,129,.15);color:var(--green);padding:2px 7px;border-radius:5px;font-size:11px}
.spr{background:rgba(245,158,11,.15);color:var(--gold);padding:2px 7px;border-radius:5px;font-size:11px}
.spe{background:rgba(239,68,68,.12);color:var(--red);padding:2px 7px;border-radius:5px;font-size:11px}
.toast{position:fixed;bottom:20px;right:20px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:10px 15px;font-size:13px;z-index:10000;transform:translateY(60px);opacity:0;transition:all .3s;display:flex;align-items:center;gap:7px;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.toast.on{transform:translateY(0);opacity:1}.toast.ok{border-left:3px solid var(--green)}.toast.err{border-left:3px solid var(--red)}
.empty{text-align:center;padding:42px 20px;color:var(--text3)}.empty .ico{font-size:36px;margin-bottom:10px}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

.ham-btn{display:none;background:var(--bg3);border:1px solid var(--border);
  border-radius:7px;color:var(--text);font-size:18px;padding:5px 10px;
  cursor:pointer;line-height:1;flex-shrink:0}
/* ══ RESPONSIVE MÓVIL ══ */
@media(max-width:768px){
  /* Layout general */
  .pg{padding:10px}
  .cg{grid-template-columns:1fr}
  .og{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .fg{grid-template-columns:1fr}

  /* Header: ocultar logo texto y reorganizar */
  .hdr{padding:0 10px;gap:8px;height:auto;min-height:54px;flex-wrap:wrap;padding-top:6px;padding-bottom:6px}
  .lt{font-size:13px}.ls{font-size:9px}

  /* Hamburger y nav */
  .ham-btn{display:flex}
  .nav{display:none;position:fixed;top:54px;left:0;right:0;
       background:var(--bg2);border-bottom:1px solid var(--border);
       z-index:300;flex-direction:column;padding:6px;gap:2px;
       box-shadow:0 4px 20px rgba(0,0,0,.4)}
  .nav.open{display:flex}
  .tab{padding:10px 14px;font-size:13px;border-radius:7px;justify-content:flex-start;width:100%}
  .tab .n{padding:0 5px;font-size:11px}

  /* Header right: compacto */
  .hdr-r{gap:5px;flex-shrink:0}
  .hdr-r .btn{padding:4px 8px;font-size:10px}
  .usr-chip{padding:4px 7px;font-size:11px}
  .chip{font-size:10px;padding:3px 7px}

  /* Barra de filtros */
  .bar{gap:6px}
  .srch{width:100%!important;font-size:12px}
  select.sel{font-size:12px;padding:6px 7px;max-width:120px}

  /* Tabla: scroll horizontal */
  .tw{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{min-width:600px}
  th,td{padding:7px 8px;font-size:11px}

  /* Cards clientes */
  .cc{padding:12px}
  .cc-nm{font-size:13px}
  .cr{flex-wrap:wrap}
  .cv{font-size:11px}

  /* Pendientes */
  .pc-hd{padding:10px 12px}
  .pc-nm{font-size:13px}
  .pc-bd{padding:0 12px 10px}
  .ob-row{padding:6px 9px}

  /* Modales */
  .modal,.modal.mw{max-width:100%!important;padding:16px;margin:6px;border-radius:10px}
  .ov{padding:6px;align-items:flex-start;padding-top:10px}
  .fg{grid-template-columns:1fr!important}
  .mf{flex-wrap:wrap;gap:6px}
  .mf .btn{flex:1;justify-content:center;min-width:100px}

  /* Login */
  .login-box{padding:16px}
  .login-card{padding:20px}
  .login-title{font-size:18px}

  /* Organismos */
  .oc{padding:12px}
  .oc-hd{gap:7px}

  /* Anuales - tabla scrollable */
  #an-out .tw{overflow-x:auto}

  /* Configuración */
  #pg-config>div{padding-bottom:20px}

  /* Selectores año/mes */
  select.sel[id^="fan"]{max-width:80px}
}

/* Pantallas muy pequeñas (iPhone SE, etc) */
@media(max-width:375px){
  .hdr-r .btn.sm:not(:last-child){display:none}
  .tab{padding:4px 6px;font-size:10px}
}
/* ── LOGIN ── */
#login-screen{position:fixed;inset:0;background:var(--bg);z-index:9999;display:none;align-items:center;justify-content:center}
#login-screen.visible{display:flex}
.login-box{width:100%;max-width:420px;padding:24px}
.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:32px;justify-content:center}
.login-title{font-size:22px;font-weight:700;letter-spacing:-.5px}
.login-sub{font-size:12px;color:var(--text2);margin-top:2px}
.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:28px}
.login-card h2{font-size:16px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.login-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.login-field label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text2)}
.login-field input{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:11px 13px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:border-color .2s;width:100%}
.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.login-err{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:9px 12px;font-size:12px;color:var(--red);margin-bottom:14px;display:none}
.login-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:9px;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:4px}
.login-btn:hover{background:var(--accent2);box-shadow:0 4px 12px rgba(59,130,246,.35)}
.login-footer{text-align:center;margin-top:14px;font-size:11px;color:var(--text3)}
/* APP */
.app-wrap{display:none}.app-wrap.on{display:block}
/* USUARIO */
.usr-chip{display:flex;align-items:center;gap:7px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:5px 10px;font-size:12px;cursor:pointer;transition:border-color .2s}
.usr-chip:hover{border-color:var(--accent)}
.usr-avatar{width:22px;height:22px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}
/* USUARIOS TAB */
.usr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:11px}
.usr-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px}
.usr-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}
.usr-role-admin{background:linear-gradient(135deg,var(--gold),#d97706)}
.usr-role-user{background:linear-gradient(135deg,var(--accent),#1d4ed8)}
.usr-role-readonly{background:linear-gradient(135deg,var(--text3),#334155)}
.role-badge{padding:2px 8px;border-radius:5px;font-size:10px;font-weight:700;text-transform:uppercase}
/* ── HONORARIOS ── */
.hon-cliente-card{background:var(--bg2);border:1px solid var(--border);border-radius:13px;margin-bottom:14px;overflow:hidden}
.hon-cliente-hdr{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;user-select:none;transition:background .15s}
.hon-cliente-hdr:hover{background:var(--bg3)}
.hon-cliente-nombre{font-weight:700;font-size:14px;flex:1}
.hon-cliente-cuit{font-size:11px;color:var(--text2);font-family:var(--mono)}
.hon-badge-importe{background:rgba(16,185,129,.13);color:var(--green);border:1px solid rgba(16,185,129,.25);border-radius:7px;padding:3px 10px;font-size:12px;font-weight:700;font-family:var(--mono)}
.hon-badge-alerta{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.25);border-radius:7px;padding:3px 10px;font-size:11px;font-weight:700}
.hon-badge-warn{background:rgba(245,158,11,.12);color:var(--gold);border:1px solid rgba(245,158,11,.25);border-radius:7px;padding:3px 10px;font-size:11px;font-weight:700}
.hon-badge-ok{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.2);border-radius:7px;padding:3px 10px;font-size:11px;font-weight:700}
.hon-tabla-wrap{padding:0 14px 14px}
.hon-tabla{width:100%;border-collapse:collapse;font-size:12px}
.hon-tabla th{text-align:left;padding:7px 10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text2);border-bottom:1px solid var(--border);background:var(--bg3)}
.hon-tabla td{padding:8px 10px;border-bottom:1px solid var(--border2,var(--border));vertical-align:middle}
.hon-tabla tr:last-child td{border-bottom:none}
.hon-tabla tr:hover td{background:var(--bg3)}
.hon-pct-pos{color:var(--green);font-weight:700}
.hon-pct-neg{color:var(--red);font-weight:700}
.hon-pct-neu{color:var(--text2)}
.hon-cobrado{color:var(--green);font-size:11px;font-weight:600}
.hon-pendiente{color:var(--gold);font-size:11px;font-weight:600}
.hon-stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 16px;min-width:170px;flex:1}
.hon-stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text2);margin-bottom:4px}
.hon-stat-val{font-size:20px;font-weight:800;font-family:var(--mono)}
.hon-anual-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:8px}
.hon-anual-table th{text-align:left;padding:6px 10px;font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text2);border-bottom:1px solid var(--border);background:var(--bg3)}
.hon-anual-table td{padding:7px 10px;border-bottom:1px solid var(--border)}
/* Dashboard honorarios */
.hon-dashboard{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:16px}
.hon-dashboard-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text2);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.hon-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:18px}
.hon-kpi{background:var(--bg3);border:1px solid var(--border);border-radius:11px;padding:14px 16px;position:relative;overflow:hidden}
.hon-kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.hon-kpi-pesos::before{background:linear-gradient(90deg,var(--accent),#1d4ed8)}
.hon-kpi-usd::before{background:linear-gradient(90deg,var(--green),#059669)}
.hon-kpi-clientes::before{background:linear-gradient(90deg,var(--gold),#d97706)}
.hon-kpi-alerta::before{background:linear-gradient(90deg,var(--red),#dc2626)}
.hon-kpi-pend::before{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}
.hon-kpi-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text2);margin-bottom:6px}
.hon-kpi-val{font-size:22px;font-weight:800;font-family:var(--mono);line-height:1.1}
.hon-kpi-sub{font-size:10px;color:var(--text3);margin-top:4px}
.hon-kpi-delta{font-size:11px;font-weight:700;margin-top:3px}
.hon-evol-table{width:100%;border-collapse:collapse;font-size:12px}
.hon-evol-table th{text-align:right;padding:7px 10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text2);border-bottom:2px solid var(--border);background:var(--bg3)}
.hon-evol-table th:first-child{text-align:left}
.hon-evol-table td{padding:8px 10px;border-bottom:1px solid var(--border);text-align:right;font-family:var(--mono)}
.hon-evol-table td:first-child{text-align:left;font-family:var(--font);font-weight:600}
.hon-evol-table tr:hover td{background:rgba(59,130,246,.04)}
.hon-evol-table tr.hon-evol-current td{background:rgba(59,130,246,.07)}
.hon-bar-wrap{display:flex;align-items:center;gap:8px;height:22px}
.hon-bar-track{flex:1;background:var(--bg);border-radius:4px;height:8px;overflow:hidden;min-width:60px}
.hon-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}
.hon-dolar-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.2);border-radius:7px;padding:3px 9px;font-size:11px;font-weight:700;color:var(--green);font-family:var(--mono)}
.hon-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text2);margin:14px 0 8px;padding-top:14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.rb-admin{background:rgba(245,158,11,.15);color:var(--gold)}
.rb-user{background:rgba(59,130,246,.15);color:var(--accent2)}
.rb-readonly{background:rgba(71,85,105,.2);color:var(--text2)}


/* ── Modal envío de email ── */
.menv-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:16px;z-index:9999;opacity:0;pointer-events:none;transition:opacity .22s}
.menv-backdrop.open{opacity:1;pointer-events:all}
.menv-box{background:var(--bg2);border:1px solid var(--border);border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.4);width:100%;max-width:540px;max-height:92vh;overflow-y:auto;transform:translateY(14px) scale(.98);transition:transform .22s}
.menv-backdrop.open .menv-box{transform:translateY(0) scale(1)}
.menv-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1}
.menv-titulo{font-size:15px;font-weight:700;color:var(--text)}
.menv-sub{font-size:11px;color:var(--text2);margin-top:2px}
.menv-cerrar{background:none;border:none;color:var(--text3);font-size:18px;cursor:pointer;padding:3px 8px;border-radius:5px;transition:color .15s}
.menv-cerrar:hover{color:var(--text)}
.menv-body{padding:18px 22px 22px}
.menv-chip{display:inline-flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:5px 14px 5px 7px;margin-bottom:16px}
.menv-chip-av{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.menv-chip-name{font-size:.84rem;font-weight:600;color:var(--text);line-height:1.3}
.menv-chip-email{font-size:.75rem;color:var(--text2)}
.menv-sin-email{background:rgba(200,50,50,.12);border:1px solid var(--red);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--red);margin-bottom:12px}
.menv-field{margin-bottom:14px}
.menv-field label{display:block;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text2);margin-bottom:5px}
.menv-field input,.menv-field textarea{width:100%;background:var(--bg3);border:1.5px solid var(--border);border-radius:8px;padding:9px 12px;font-family:var(--font);font-size:13px;color:var(--text);outline:none;transition:border-color .18s}
.menv-field input:focus,.menv-field textarea:focus{border-color:var(--accent)}
.menv-field textarea{resize:vertical;min-height:80px}
.menv-drop{position:relative;border:2px dashed var(--border);border-radius:8px;background:var(--bg3);padding:20px;text-align:center;cursor:pointer;transition:border-color .18s,background .18s}
.menv-drop:hover,.menv-drop.dragover{border-color:var(--accent);background:var(--bg)}
.menv-drop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.menv-drop-hint{font-size:12px;color:var(--text2);margin-top:4px}
.menv-file-list{margin-top:10px;display:flex;flex-direction:column;gap:6px}
.menv-fi{display:flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:6px 10px;font-size:12px}
.menv-fi-name{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.menv-fi-size{color:var(--text2);font-size:11px;flex-shrink:0}
.menv-fi-rm{background:none;border:none;cursor:pointer;color:var(--text3);font-size:.95rem;padding:1px 4px;border-radius:3px;transition:color .12s}
.menv-fi-rm:hover{color:var(--red)}
.menv-file-count{font-size:11px;color:var(--text2);margin-top:4px;text-align:right}
.menv-prog-wrap{display:none;margin-top:14px}
.menv-prog-bg{background:var(--bg3);border-radius:99px;height:5px;overflow:hidden}
.menv-prog-fill{height:100%;background:var(--accent);border-radius:99px;width:0%;transition:width .3s}
.menv-prog-lbl{font-size:11px;color:var(--text2);margin-bottom:4px}
.menv-alert{display:none;border-radius:8px;padding:10px 14px;font-size:12px;margin-bottom:12px;align-items:flex-start;gap:10px}
.menv-alert.show{display:flex}
.menv-alert-ok{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.4);color:#16a34a}
.menv-alert-err{background:rgba(220,38,38,.1);border:1px solid rgba(220,38,38,.4);color:var(--red)}
.btn-envmail{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:10px;width:100%;font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s,transform .1s;margin-top:4px}
.btn-envmail:hover{background:var(--accent2)}
.btn-envmail:active{transform:scale(.98)}
.btn-envmail:disabled{opacity:.5;cursor:not-allowed;transform:none}
.menv-spinner{width:15px;height:15px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══ ETAPA 3: INTELIGENCIA ══════════════════════════════════════════ */
.intel-wrap{padding:16px 0;max-width:1200px}
.intel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}
.intel-header h2{font-size:1.3rem;font-weight:700;color:var(--text);margin:0}
.intel-section{margin-bottom:28px}
.intel-section h3{font-size:1rem;font-weight:700;color:var(--text);margin:0 0 14px;display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.intel-badge{font-size:11px;font-weight:600;border-radius:99px;padding:2px 8px}
.intel-badge--danger{background:rgba(220,38,38,.15);color:var(--red)}
.intel-badge--warning{background:rgba(234,179,8,.15);color:#b45309}
.intel-badge--info{background:rgba(59,130,246,.15);color:#1d4ed8}

/* KPIs */
.intel-kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.intel-kpi{border-radius:10px;padding:14px 12px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;border:1px solid var(--border)}
.intel-kpi--ok{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.3)}
.intel-kpi--warning{background:rgba(234,179,8,.1);border-color:rgba(234,179,8,.4)}
.intel-kpi--danger{background:rgba(220,38,38,.09);border-color:rgba(220,38,38,.35)}
.intel-kpi-icono{font-size:1.4rem;line-height:1}
.intel-kpi-valor{font-size:1.2rem;font-weight:800;color:var(--text);line-height:1.2}
.intel-kpi-label{font-size:11px;color:var(--text2);line-height:1.3}

/* Filtros */
.intel-filtros{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.intel-filtros label{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:6px}
.intel-filtros select{font-size:12px;border:1px solid var(--border);border-radius:6px;padding:4px 8px;background:var(--bg2);color:var(--text)}

/* Alertas */
.intel-alerta{border-radius:9px;padding:12px 14px;margin-bottom:10px;border:1px solid transparent}
.intel-alerta--danger{background:rgba(220,38,38,.08);border-color:rgba(220,38,38,.3)}
.intel-alerta--warning{background:rgba(234,179,8,.08);border-color:rgba(234,179,8,.35)}
.intel-alerta--info{background:rgba(59,130,246,.07);border-color:rgba(59,130,246,.3)}
.intel-alerta-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:4px}
.intel-alerta-tipo{font-size:11px;color:var(--text2)}
.intel-alerta-msg{font-size:12px;color:var(--text);margin-bottom:4px}
.intel-alerta-accion{font-size:11px;color:var(--accent);font-style:italic}

/* Tabla riesgos */
.intel-table-wrap{overflow-x:auto}
.intel-table{width:100%;border-collapse:collapse;font-size:12px}
.intel-table th{background:var(--bg2);padding:8px 10px;text-align:left;font-weight:600;color:var(--text2);border-bottom:2px solid var(--border)}
.intel-table td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:top}
.intel-table tr:last-child td{border-bottom:none}
.intel-riesgo--alto td{background:rgba(220,38,38,.04)}
.intel-riesgo--medio td{background:rgba(234,179,8,.04)}
.intel-score{font-weight:800;font-size:1rem;display:inline-block;width:36px;text-align:center}
.intel-score--alto{color:var(--red)}
.intel-score--medio{color:#b45309}
.intel-score--bajo{color:var(--green)}
.intel-nivel{font-size:11px;font-weight:700;padding:2px 8px;border-radius:99px}
.intel-nivel--alto{background:rgba(220,38,38,.15);color:var(--red)}
.intel-nivel--medio{background:rgba(234,179,8,.15);color:#b45309}
.intel-nivel--bajo{background:rgba(34,197,94,.15);color:var(--green)}
.intel-motivos{margin:0;padding-left:14px;color:var(--text2);font-size:11px}
.intel-motivos li{margin-bottom:2px}
.intel-vacio{color:var(--text2);font-size:13px;font-style:italic;padding:8px 0}


/* ETAPA5 COMPLETA OPERATIVA */
.com-shell.pro{display:grid;grid-template-columns:minmax(280px,360px) minmax(420px,1fr) minmax(260px,320px);gap:14px;align-items:start}.com-side-panel{position:sticky;top:14px}.com-operativo-empty{font-size:13px;color:var(--text2);line-height:1.5}.com-op-card{border:1px solid var(--border);border-radius:14px;padding:12px;margin-bottom:10px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(148,163,184,.05))}.com-op-card h4{margin:0 0 8px;font-size:13px}.com-op-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-top:1px dashed rgba(148,163,184,.25);font-size:12px}.com-op-row:first-of-type{border-top:0}.com-risk{height:9px;border-radius:999px;background:#e5e7eb;overflow:hidden;margin:8px 0}.com-risk span{display:block;height:100%;background:linear-gradient(90deg,#22c55e,#f59e0b,#ef4444)}.com-nav-badge{display:none;margin-left:6px;min-width:18px;height:18px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;align-items:center;justify-content:center;padding:0 5px}.com-thread-item{transition:.15s transform,.15s border-color}.com-thread-item:hover{transform:translateY(-1px)}.com-kpi-card .v{letter-spacing:-.04em}.com-command-center{border:1px solid rgba(29,35,102,.18);background:linear-gradient(135deg,rgba(29,35,102,.06),rgba(59,130,246,.05))}.com-doc-card{align-items:center}
@media(max-width:1200px){.com-shell.pro{grid-template-columns:minmax(260px,340px) 1fr}.com-side-panel{grid-column:1/-1;position:static}}
@media(max-width:780px){.com-head.pro{display:block}.com-actions{margin-top:10px}.com-shell.pro{display:block}.com-inbox,.com-detail,.com-side-panel{margin-bottom:12px}.com-kpis-pro{grid-template-columns:1fr 1fr}.com-filters.pro{overflow:auto;white-space:nowrap}.com-client-head.pro{display:block}.com-tabs.pro{overflow:auto}.com-tab{white-space:nowrap}.com-case-grid{grid-template-columns:1fr}.com-workqueue{display:block}.com-workitem{width:100%;margin-bottom:8px}.com-doc-card{display:block}.com-side-panel{position:static}.tab{position:relative}}
@media(max-width:520px){.com-kpis-pro{grid-template-columns:1fr}.com-client-badges{margin-top:8px}.com-command-center textarea{min-height:120px}.bar{display:block}.bar .btn,.bar .sel{width:100%;margin:4px 0}}


/* FIX quirúrgico móvil honorarios: mostrar Historial en todos los clientes */
@media(max-width:768px){
  .hon-cliente-hdr{align-items:flex-start;flex-direction:column}
  .hon-actions{width:100%;display:flex!important;flex-wrap:wrap;gap:6px!important;align-items:center!important}
  .hon-actions .btn{display:inline-flex!important;flex:1 1 auto;justify-content:center;min-width:92px}
  .hon-actions .hon-btn-historial{display:inline-flex!important;visibility:visible!important;opacity:1!important}
}

/* V18 navegación modular por grupos */
.nav.nav-modular{overflow:visible;align-items:center;gap:4px;max-width:none}
.nav-group{position:relative;display:flex;align-items:center}
.nav-title{font-weight:700}
.nav-pop{display:none;position:absolute;top:calc(100% + 8px);left:0;min-width:250px;background:linear-gradient(180deg,#111827,#0b1220);border:1px solid var(--border);border-radius:14px;padding:8px;box-shadow:0 18px 50px rgba(0,0,0,.38);z-index:500;flex-direction:column;gap:4px}
.nav-group:hover .nav-pop,.nav-group:focus-within .nav-pop{display:flex;animation:navDrop .12s ease-out}
.nav-pop:before{content:"";position:absolute;top:-9px;left:18px;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:9px solid var(--border)}
.nav-pop .tab{width:100%;justify-content:flex-start;padding:9px 10px;font-size:12px;text-align:left}
@keyframes navDrop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.roadmap-shell{padding:18px;max-width:1180px;margin:0 auto}.roadmap-shell h2{margin:0 0 8px;font-size:22px}.roadmap-shell p{color:var(--text2);font-size:13px;margin:0 0 14px}.roadmap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.road-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px}.road-card strong{display:block;margin-bottom:6px}.road-card span{color:var(--text2);font-size:12px;line-height:1.45}.muted2{color:var(--text2)!important;font-size:13px!important}
@media(max-width:900px){.nav.nav-modular{overflow:auto}.nav-group{display:block;width:100%}.nav-pop{position:static;display:flex;background:transparent;border:0;box-shadow:none;padding:2px 0 8px;margin-left:10px}.nav-pop:before{display:none}.nav-title{background:var(--surface);width:100%;justify-content:flex-start}.nav-pop .tab{padding:8px 14px}}


/* V18.2 — navegación robusta y sin mezcla visual entre solapas */
.nav-group.active>.nav-title{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(59,130,246,.35)}
.nav-pop .tab.on{background:rgba(59,130,246,.18);color:#fff;box-shadow:none}
.pg[aria-hidden="true"]{display:none!important}
.pg.on[aria-hidden="false"]{display:block!important}
.empty{padding:22px;text-align:center;color:var(--text2);border:1px dashed var(--border);border-radius:12px;background:var(--bg3)}
.empty .ico{font-size:26px;margin-bottom:8px}


/* V18.4 — fix definitivo solapas + menú por módulos */
.pg{display:none!important}
.pg.on[aria-hidden="false"]{display:block!important}
.nav-group.active>.nav-title,.nav-title.on{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(59,130,246,.35)}
@media(min-width:901px){
  .nav-group:hover>.nav-pop,.nav-group:focus-within>.nav-pop{display:flex!important}
  .nav-pop{max-height:calc(100vh - 76px);overflow:auto}
}
.client-op-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:10px}
.client-op-card{border:1px solid var(--border);background:var(--bg2);border-radius:14px;padding:12px}
.client-op-card h4{margin:0 0 7px;font-size:13px}.client-op-card p{color:var(--text2);font-size:12px;line-height:1.45}
.client-op-row{display:flex;justify-content:space-between;gap:8px;align-items:center;border-top:1px solid var(--border);padding-top:8px;margin-top:8px;color:var(--text2);font-size:12px}
.client-op-state{border-radius:999px;border:1px solid var(--border);padding:3px 8px;font-size:11px}.client-op-state.ok{color:var(--green);border-color:rgba(16,185,129,.45)}.client-op-state.off{color:var(--text3)}
