/* RaMercadoPúblico v2 — estilos */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#f5f5f0;--card:#fff;--border:#e0ddd5;--text:#2c2c2c;--muted:#7a7a6e;
  --accent:#8b6914;--accent-light:#f5eed9;--accent-dark:#6b4f0e;
  --green:#2d6a30;--green-bg:#e8f5e9;--red:#a02020;--red-bg:#fdeaea;
  --blue:#1a5276;--blue-bg:#e8f0f8;--orange:#a05a00;--orange-bg:#fff3e0;
  --gray:#666;--gray-bg:#f0f0f0;--shadow:0 1px 3px rgba(0,0,0,.08);
  --radius:6px;
}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--text);font-size:13px;line-height:1.45}

button{cursor:pointer;font-family:inherit;font-size:13px;border:1px solid var(--border);
  background:var(--card);padding:6px 12px;border-radius:var(--radius);color:var(--text);transition:.1s}
button:hover{background:var(--accent-light);border-color:var(--accent)}
button.primary{background:var(--accent);color:#fff;border-color:var(--accent-dark)}
button.primary:hover{background:var(--accent-dark)}
button.success{background:var(--green);color:#fff;border-color:var(--green)}
button.danger{background:var(--red);color:#fff;border-color:var(--red)}
button.ghost{background:transparent;border-color:transparent;color:var(--muted)}
button:disabled{opacity:.5;cursor:not-allowed}

input,select,textarea{font-family:inherit;font-size:13px;padding:6px 10px;border:1px solid var(--border);
  border-radius:var(--radius);background:#fff;min-width:0}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
textarea{resize:vertical;min-height:60px;width:100%}
.check{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- Topbar ---- */
.topbar{background:#2c2c2c;color:#fff;padding:10px 20px;display:flex;align-items:center;gap:14px;
  position:sticky;top:0;z-index:100;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.topbar h1{font-size:15px;font-weight:600}
.topbar h1 span{color:var(--accent)}
.tabs{display:flex;gap:4px;margin-left:14px}
.tabs .tab{background:rgba(255,255,255,.05);border:1px solid #555;color:#bbb;padding:6px 14px}
.tabs .tab:hover{color:#fff;background:rgba(255,255,255,.12)}
.tabs .tab.active{background:var(--accent-dark);color:#fff;border-color:var(--accent)}
.badge{background:var(--accent);color:#fff;border-radius:10px;padding:1px 6px;font-size:10px;margin-left:4px;font-weight:600}
.user{font-size:11px;color:#bbb;display:flex;align-items:center;gap:8px}
.version-badge{margin-left:auto;font-size:10px;color:#777;font-family:ui-monospace,Menlo,Monaco,monospace;cursor:help;padding-right:6px}
.user .role-tag{color:var(--accent);font-weight:600;text-transform:lowercase}
.user button{background:transparent;border:1px solid #555;color:#bbb;font-size:11px;padding:3px 10px}
.user button:hover{color:#fff;border-color:#888}

/* ---- View ---- */
.view{padding:14px 20px;max-width:1500px;margin:0 auto}
.view.hidden{display:none}

/* ---- Filters ---- */
.filters-toggle{background:transparent;border:1px solid var(--border);color:var(--muted);
  padding:3px 10px;font-size:11px;cursor:pointer;border-radius:var(--radius);
  margin:0 0 8px 0;display:inline-flex;align-items:center;gap:4px;line-height:1.4}
.filters-toggle:hover{background:#f5f5f5;color:var(--text);border-color:#bbb}
#view-catalogo.filters-hidden .filter-chips{display:none}
#view-watchlist.filters-hidden .filters,
#view-logs.filters-hidden .filters{display:none}
.filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;background:#fff;
  padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;box-shadow:var(--shadow)}
.filters input,.filters select{height:32px}
.filters input[type=text]{min-width:240px}
.filters input[type=number]{width:90px}
.filters select{min-width:130px;height:32px}
.filters select[multiple]{height:auto;min-width:150px}
.result-info{font-size:11px;color:var(--muted);margin-bottom:8px;padding:4px 4px;display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.pagination{display:flex;gap:4px;align-items:center}
.pagination button{padding:3px 10px;font-size:12px;line-height:1.2}
.pagination .info{font-size:11px;color:var(--muted);padding:0 8px}

/* ---- Filter chips (rubros multi-select) ---- */
.filter-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px;align-items:center}
.filter-chips .label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-right:4px}
.filter-chip{padding:5px 12px;border-radius:14px;font-size:12px;border:1px solid var(--border);
  background:#fff;cursor:pointer;color:var(--text);transition:.1s;font-weight:500}
.filter-chip:hover{border-color:var(--accent);background:var(--accent-light)}
.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent-dark);font-weight:600}
.filter-chip .x{margin-left:4px;font-size:10px;opacity:.7}
.filter-chip.manual{background:#fff;border-color:var(--accent-dark);color:var(--accent-dark);font-style:italic}
.filter-chip.manual.active{background:var(--accent-dark);color:#fff;border-color:var(--accent-dark)}
.filter-chip.manual .x{cursor:pointer;font-style:normal;font-weight:700;margin-left:6px;padding-left:5px;border-left:1px solid currentColor;opacity:.85}
.filter-chip.add-btn{background:transparent;border-style:dashed;color:var(--muted);font-style:italic}
.filter-chip.add-btn:hover{color:var(--accent);border-color:var(--accent)}
.filter-chip .hide-x{margin-left:6px;padding-left:5px;border-left:1px solid currentColor;font-weight:700;font-size:11px;opacity:.4;cursor:pointer;transition:.1s}
.filter-chip:hover .hide-x{opacity:.9}
.filter-chip .hide-x:hover{color:#c33;opacity:1}
.filter-chip.predef-btn{background:#eef9ee;border-color:#8bc78b;color:#2d6e2d;border-style:dashed;font-weight:600}
.filter-chip.predef-btn:hover{background:#d4ecd4;border-color:#5fa15f}

/* ---- Multi-dropdown (regiones) ---- */
.multi-dropdown{position:relative;display:inline-block}
.multi-dropdown-btn{padding:6px 12px;border:1px solid var(--border);background:#fff;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text);min-width:140px;text-align:left}
.multi-dropdown-btn:hover{border-color:var(--accent)}
.multi-dropdown-panel{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 16px rgba(0,0,0,0.12);padding:6px;min-width:240px;max-height:380px;overflow-y:auto;z-index:50}
.multi-dropdown-panel.hidden{display:none}
.multi-dropdown-panel label{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:4px;font-size:12.5px;cursor:pointer;user-select:none}
.multi-dropdown-panel label:hover{background:var(--accent-light)}
.multi-dropdown-panel label input{margin:0}
.multi-dropdown-actions{display:flex;gap:4px;padding:4px 4px 8px;border-bottom:1px solid var(--border);margin-bottom:4px}
.multi-dropdown-actions button{flex:1;padding:4px 8px;font-size:11px;border:1px solid var(--border);background:#fff;border-radius:4px;cursor:pointer}
.multi-dropdown-actions button:hover{border-color:var(--accent);background:var(--accent-light)}
.multi-dropdown-actions button.primary{background:var(--accent);color:#fff;border-color:var(--accent-dark)}

/* ---- Date range (publicación desde/hasta) ---- */
.date-range{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--muted);padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:#fff}
.date-range:hover{border-color:var(--accent)}
.date-range span{white-space:nowrap;font-weight:500}
.date-range input{border:none;background:transparent;font-size:12px;padding:0;color:var(--text);outline:none;min-width:110px}

/* ---- Botón "marcar revisada" en catálogo ---- */
.check-btn{padding:2px 6px;border:1px solid var(--border);background:#fff;border-radius:4px;cursor:pointer;font-size:13px;color:var(--muted);margin-left:2px;line-height:1}
.check-btn:hover{border-color:#3b9d3b;color:#3b9d3b;background:#eef9ee}
.check-btn.done{background:#cfe6cf;border-color:#3b9d3b;color:#1e5e1e;font-weight:700}
tr.revisada{opacity:.55;background:#fafafa}
tr.revisada:hover{opacity:.85}

/* ---- Rubro bloque + sub-chips de criterios ---- */
.filter-row{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}
.rubro-bloque{display:flex;flex-direction:column;gap:2px;align-items:flex-start}
.criterios-row{display:flex;flex-wrap:wrap;gap:3px;padding:2px 6px;max-width:340px}
.criterio-chip{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:9px;font-size:10.5px;border:1px solid #ddd;background:#fafafa;color:#555;font-weight:500;line-height:1.3}
.criterio-chip .t{font-weight:700;font-size:11px;line-height:1}
.criterio-chip.pos{background:#eef7ee;border-color:#cfe6cf;color:#2c6e2c}
.criterio-chip.neg{background:#fbecec;border-color:#ecc7c7;color:#933}
.criterio-chip.onu{background:#eef0fb;border-color:#cfd5ec;color:#3a4798}
.criterio-chip.muted{background:transparent;border-style:dashed;cursor:pointer;color:var(--muted)}
.criterio-chip.muted:hover{background:#f0f0f0;color:var(--accent)}
.criterio-chip .hide-x{margin-left:3px;padding-left:4px;border-left:1px solid currentColor;font-weight:700;font-size:10px;opacity:.35;cursor:pointer;transition:.1s}
.criterio-chip:hover .hide-x{opacity:.85}
.criterio-chip .hide-x:hover{color:#c33;opacity:1}

/* ---- Table ---- */
.data{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.data.wide{min-width:1400px}
.data thead{background:#fafaf6;border-bottom:1px solid var(--border)}
.data th{padding:8px 10px;text-align:left;font-size:11px;text-transform:uppercase;
  letter-spacing:.5px;color:var(--muted);font-weight:600}
.data td{padding:8px 10px;border-top:1px solid #f0eee8;vertical-align:top;font-size:12px}
.data tbody tr{cursor:pointer;transition:background .1s}
.data tbody tr:hover{background:#fafaf6}
.data tbody tr.no-cand{opacity:.7}
.data .star-btn{background:transparent;border:none;font-size:18px;padding:0;color:#ddd;line-height:1}
.data .star-btn.active{color:var(--accent)}
.data .star-btn:hover{color:var(--accent)}

.score-cell{font-weight:700;color:var(--text)}
.score-cell.high{color:var(--green)}
.score-cell.med{color:var(--accent)}
.score-cell.low{color:var(--muted)}

/* ---- Pills / chips ---- */
.tipo-pill{display:inline-block;padding:2px 8px;border-radius:3px;font-size:10px;font-weight:700}
.tipo-pill.LIC{background:var(--blue-bg);color:var(--blue)}
.tipo-pill.OC{background:var(--accent-light);color:var(--accent-dark)}
.tipo-lic{font-size:10px;color:var(--muted);font-weight:600;margin-left:4px}

.estado-pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.estado-pill.siguiendo{background:var(--gray-bg);color:var(--gray)}
.estado-pill.postulando{background:var(--orange-bg);color:var(--orange)}
.estado-pill.postulada{background:var(--blue-bg);color:var(--blue)}
.estado-pill.via_agencia{background:#f0e4f5;color:#6a3a7e}
.estado-pill.ganada{background:var(--green-bg);color:var(--green)}
.estado-pill.perdida{background:var(--red-bg);color:var(--red)}
.estado-pill.descartada{background:#eee;color:#999;text-decoration:line-through}

.chip{display:inline-block;padding:1px 7px;border-radius:3px;font-size:10px;font-weight:600;margin-right:3px;margin-bottom:3px}
.chip.warn{background:var(--orange-bg);color:var(--orange)}
.chip.block{background:var(--red-bg);color:var(--red)}
.chip.info{background:var(--blue-bg);color:var(--blue)}

.org-name{color:var(--muted);font-size:11px;margin-top:1px}
.zona-svc{font-size:10px;color:var(--accent-dark);margin-top:1px}
.dias-cierre{font-weight:700}
.dias-cierre.urgent{color:var(--red)}
.dias-cierre.soon{color:var(--orange)}
.dias-cierre.ok{color:var(--green)}

/* ---- Drawer ---- */
.drawer-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;z-index:200;justify-content:flex-end}
.drawer-bg.open{display:flex}
.drawer{background:var(--card);width:100%;max-width:680px;height:100%;overflow-y:auto;
  box-shadow:-4px 0 16px rgba(0,0,0,.15)}
.drawer-head{position:sticky;top:0;padding:16px 20px;background:#fafaf6;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:flex-start;gap:10px;z-index:5}
.drawer-head h2{font-size:15px;font-weight:600;line-height:1.3}
.drawer-body{padding:16px 20px}
.drawer-section{margin-bottom:18px}
.drawer-section h4{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);
  margin-bottom:8px;font-weight:700}
.kv{display:grid;grid-template-columns:140px 1fr;gap:6px 12px;font-size:12px}
.kv dt{color:var(--muted)}
.kv dd{color:var(--text)}
.actions-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.score-breakdown{display:grid;grid-template-columns:repeat(2,1fr);gap:4px 14px;font-size:11px;
  background:var(--bg);padding:10px;border-radius:var(--radius)}
.score-breakdown div{display:flex;justify-content:space-between}
.score-breakdown b{font-weight:700}
.timeline{border-left:2px solid var(--border);margin-left:8px;padding-left:14px}
.timeline-item{margin-bottom:12px;position:relative}
.timeline-item::before{content:'';position:absolute;left:-21px;top:5px;width:10px;height:10px;
  background:var(--accent);border-radius:50%;border:2px solid var(--card)}
.timeline-item.sistema::before{background:var(--gray)}
.timeline-item .when{font-size:10px;color:var(--muted)}
.timeline-item .what{font-size:12px;margin-top:2px;white-space:pre-wrap}

/* ---- Claude analysis card ---- */
.claude-card{background:#f4eef9;border:1px solid #d8c8eb;border-left:3px solid #6750a4;
  border-radius:var(--radius);padding:12px 14px;margin-bottom:14px}
.claude-card .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.claude-card .head .title{font-size:12px;font-weight:700;color:#5b3eb1;text-transform:uppercase;letter-spacing:.5px}
.claude-card .head .when{font-size:10px;color:var(--muted)}
.claude-card pre{font-family:inherit;font-size:12px;white-space:pre-wrap;line-height:1.5;margin:0;color:var(--text)}

.bulk-bar{display:flex;gap:8px;align-items:center;padding:8px 12px;background:#f4eef9;border:1px solid #d8c8eb;
  border-radius:var(--radius);margin-bottom:8px;font-size:12px}
.bulk-bar.hidden{display:none}
.bulk-bar b{color:#5b3eb1}

.claude-cell{font-size:11px;line-height:1.35;color:var(--text);max-width:180px}
.claude-cell .none{color:var(--muted);font-style:italic;font-size:10px}
.claude-cell .tipo{display:inline-block;padding:1px 6px;background:#f4eef9;color:#5b3eb1;border-radius:3px;font-weight:600;font-size:10px;text-transform:uppercase}
.claude-cell .meta{font-size:10px;color:var(--muted);margin-top:2px}
.claude-cell .fechas{font-weight:600;margin-top:2px}

.link-btn{background:transparent;border:none;color:#5b3eb1;font-size:10px;cursor:pointer;padding:2px 0;margin-top:4px;display:block;text-decoration:underline}
.link-btn:hover{color:#6750a4;background:transparent}

/* ---- Admin ---- */
.admin-grid{display:grid;grid-template-columns:1fr 2fr;gap:14px;margin-bottom:14px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);margin-bottom:14px}
.card h3{font-size:13px;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.peso-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px dashed #eee;font-size:12px;gap:8px}
.peso-row .key{font-family:monospace;color:var(--gray);flex-shrink:0;min-width:200px}
.peso-row .desc{color:var(--muted);font-size:10px;flex:1}
.peso-row input[type=number]{width:70px;text-align:right}

.rubro-block{border:1px solid var(--border);border-radius:var(--radius);padding:10px;margin-bottom:10px}
.rubro-block h4{font-size:13px;color:var(--accent-dark);margin-bottom:8px}
.criterios{display:flex;flex-wrap:wrap;gap:5px}
.criterio{padding:2px 8px;background:var(--bg);border-radius:3px;font-size:11px;border:1px solid var(--border)}
.criterio.pos{background:#e8f5e9;border-color:#cce5cd}
.criterio.neg{background:#fdeaea;border-color:#f5c6c6}
.criterio.onu{background:var(--blue-bg);border-color:#bcd}
.criterio .x{cursor:pointer;color:var(--red);margin-left:4px;font-weight:700}

/* ---- Toast ---- */
.toast{position:fixed;bottom:20px;right:20px;background:var(--text);color:#fff;
  padding:10px 16px;border-radius:var(--radius);font-size:12px;z-index:300;display:none;
  box-shadow:0 4px 12px rgba(0,0,0,.2);max-width:400px}
.toast.show{display:block}
.toast.error{background:var(--red)}

.empty{padding:30px;text-align:center;color:var(--muted);font-style:italic;font-size:12px}

/* ---- Modal pequeño (promover Lead/Negocio) ---- */
.mini-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;z-index:300;align-items:center;justify-content:center;padding:20px}
.mini-modal-bg.open{display:flex}
.mini-modal{background:var(--card);border-radius:var(--radius);width:100%;max-width:520px;
  box-shadow:0 8px 32px rgba(0,0,0,.25);overflow:hidden}
.mini-modal h3{padding:14px 18px;background:#fafaf6;border-bottom:1px solid var(--border);font-size:14px}
.mini-modal .body{padding:16px 18px}
.mini-modal .body p{font-size:11px;color:var(--muted);margin-bottom:12px}
.mini-modal .form-group{margin-bottom:14px}
.mini-modal .form-group label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.5px;
  color:var(--muted);font-weight:700;margin-bottom:6px}
.mini-modal .form-group label .req{color:var(--red);margin-left:4px}
.mini-modal .form-group label .opt{color:var(--muted);font-style:italic;text-transform:none;letter-spacing:0;font-weight:400;font-size:10px;margin-left:6px}
.hotel-options{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.hotel-options.with-none{grid-template-columns:repeat(2,1fr) auto}
.hotel-opt{padding:10px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:#fff;
  font-size:12px;transition:.1s;text-align:left}
.hotel-opt:hover{border-color:var(--accent)}
.hotel-opt.active{background:var(--accent);color:#fff;border-color:var(--accent-dark)}
.hotel-opt .name{font-weight:700;font-size:13px}
.hotel-opt .desc{font-size:10px;opacity:.8;margin-top:2px}
.hotel-opt.suggested::after{content:'sugerido';display:inline-block;font-size:9px;font-weight:600;
  background:var(--green-bg);color:var(--green);padding:1px 6px;border-radius:8px;margin-left:6px;text-transform:uppercase}
.hotel-opt.active.suggested::after{background:rgba(255,255,255,.3);color:#fff}
.mini-modal .footer{padding:12px 18px;background:#fafaf6;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* role visibility */
.admin-only.hidden,.supervisor-only.hidden{display:none!important}
