/* GPL Marketing Eventos — Estilos globales */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --azul:#1565C0;--azul-dark:#0D47A1;--azul-light:#E3F2FD;
  --verde:#1FB714;--rojo:#E53935;--naranja:#F57C00;--morado:#7B1FA2;
  --gris-bg:#F4F6F9;--gris-card:#fff;--gris-border:#E0E4EA;
  --gris-text:#374151;--gris-muted:#9CA3AF;
  --font:'DM Sans',sans-serif;--mono:'DM Mono',monospace;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-lg:0 4px 16px rgba(0,0,0,.10);
}
body{font-family:var(--font);background:var(--gris-bg);color:var(--gris-text);font-size:14px;line-height:1.5}

/* LOADER */
#app-loader{position:fixed;inset:0;background:#1A1A2E;display:none;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .4s}
#app-loader.hide{opacity:0;display:none;pointer-events:none}
.loader-logo{color:#fff;font-size:28px;font-weight:600;letter-spacing:-1px;margin-bottom:8px}
.loader-logo span{color:#1FB714}
.loader-sub{color:#90CAF9;font-size:13px;margin-bottom:32px}
.loader-bar{width:200px;height:3px;background:rgba(255,255,255,.15);border-radius:99px;overflow:hidden}
.loader-fill{height:100%;background:linear-gradient(90deg,#1565C0,#1FB714);border-radius:99px;animation:load 1.2s ease forwards}
@keyframes load{from{width:0}to{width:100%}}

/* LAYOUT */
#app{display:none}
#app.show{display:block}

/* NAVBAR */
.nav{background:#1A1A2E;color:#fff;display:flex;align-items:center;padding:0 24px;height:56px;gap:8px;position:sticky;top:0;z-index:100}
.nav-logo{font-size:16px;font-weight:600;letter-spacing:-.5px;margin-right:16px}
.nav-logo span{color:#1FB714}
.nav-items{display:flex;gap:2px;flex:1}
.nav-btn{background:none;border:none;color:rgba(255,255,255,.65);padding:6px 14px;border-radius:6px;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;transition:all .15s;display:flex;align-items:center;gap:6px;outline:none}
.nav-btn:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-btn.active{background:rgba(255,255,255,.12);color:#fff}
.nav-user{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-avatar{width:32px;height:32px;border-radius:50%;background:#1565C0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff}
.nav-name{font-size:13px;color:rgba(255,255,255,.8)}
.badge-role{font-size:10px;padding:2px 8px;border-radius:99px;font-weight:600}
.badge-admin{background:rgba(31,183,20,.2);color:#4CAF50}
.badge-comercial{background:rgba(21,101,192,.3);color:#90CAF9}
.badge-produccion{background:rgba(245,124,0,.25);color:#FFB74D}

/* PÁGINAS */
.page{display:none;padding:16px 24px;max-width:1200px;margin:0 auto;width:100%}
.page.active{display:block}

@keyframes spin{to{transform:rotate(360deg)}}
/* ANALYTICS */
.an-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #F3F4F6}
.an-row:last-child{border-bottom:none}
.an-rank{width:22px;height:22px;border-radius:50%;background:#F3F4F6;color:var(--gris-muted);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.an-rank.gold{background:#FFF8E1;color:#F9A825}
.an-rank.silver{background:#F5F5F5;color:#757575}
.an-rank.bronze{background:#FBE9E7;color:#BF360C}
.an-bar-wrap{flex:1;background:#F3F4F6;border-radius:99px;height:6px;overflow:hidden}
.an-bar{height:6px;border-radius:99px;transition:width .5s}
/* DASHBOARD */
.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.stat-card{background:#fff;border:1px solid var(--gris-border);border-radius:10px;padding:16px 20px}
.stat-num{font-size:28px;font-weight:600;line-height:1;margin-bottom:4px}
.stat-lbl{font-size:12px;color:var(--gris-muted);text-transform:uppercase;letter-spacing:.5px}
.stat-card.azul .stat-num{color:var(--azul)}
.stat-card.verde .stat-num{color:var(--verde)}
.stat-card.naranja .stat-num{color:var(--naranja)}
.stat-card.rojo .stat-num{color:var(--rojo)}
.vendedores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.vend-card{background:#fff;border:1px solid var(--gris-border);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:12px}
.vend-avatar{width:40px;height:40px;border-radius:50%;background:var(--azul-light);color:var(--azul);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.vend-info{min-width:0}
.vend-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vend-stats{font-size:11px;color:var(--gris-muted)}

/* TABLA COTIZACIONES */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.page-title{font-size:20px;font-weight:600}
.btn-primary{background:var(--azul);color:#fff;border:none;padding:9px 18px;border-radius:8px;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;transition:background .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary:hover{background:var(--azul-dark)}
.btn-secondary{background:#fff;color:var(--gris-text);border:1px solid var(--gris-border);padding:8px 16px;border-radius:8px;cursor:pointer;font-family:var(--font);font-size:13px;transition:all .15s}
.btn-secondary:hover{border-color:#aaa}
.btn-sm{padding:4px 10px;font-size:11px;border-radius:7px}
.filtros{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.filtros input,.filtros select{padding:7px 12px;border:1px solid var(--gris-border);border-radius:7px;font-family:var(--font);font-size:13px;background:#fff;outline:none;transition:border .15s}
.filtros input:focus,.filtros select:focus{border-color:var(--azul)}
.filtros input{flex:1;min-width:180px}
.tabla-wrap{background:#fff;border:1px solid var(--gris-border);border-radius:10px;overflow:hidden}
.tabla-wrap table{width:100%;border-collapse:collapse;table-layout:auto}
.tabla-wrap th{background:#F8FAFC;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--gris-muted);padding:8px 10px;text-align:left;border-bottom:1px solid var(--gris-border);white-space:nowrap;overflow:hidden}
.tabla-wrap td{padding:8px 10px;border-bottom:1px solid #F3F4F6;font-size:12px;vertical-align:middle;overflow:hidden}
.tabla-wrap tr:last-child td{border-bottom:none}
.tabla-wrap tr:hover td{background:#FAFBFF}
.tabla-scroll{overflow-x:auto;border-radius:10px}
.estado-badge{display:inline-block;padding:2px 7px;border-radius:99px;font-size:10px;font-weight:600;white-space:nowrap}
.estado-ENVIADA{background:#FFF9C4;color:#7B6000}
.estado-APROBADA{background:#C8E6C9;color:#1B5E20}
.estado-EN-PROCESO{background:#BBDEFB;color:#0D47A1}
.estado-RECHAZADA{background:#FFCDD2;color:#B71C1C}
.estado-FACTURADA{background:#E1BEE7;color:#4A148C}
.acciones{display:flex;gap:3px;flex-wrap:nowrap}
/* Dropdown de acciones */
.acc-menu{position:relative;display:inline-block}
.acc-trigger{background:#fff;border:1px solid var(--gris-border);border-radius:6px;padding:5px 10px;cursor:pointer;font-size:13px;font-weight:700;color:var(--gris-text);transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;letter-spacing:1px}
.acc-trigger:hover{background:#F0F4FF;border-color:var(--azul);color:var(--azul)}
.acc-dropdown{display:none;position:fixed;background:#fff;border:1px solid var(--gris-border);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.15);z-index:200;min-width:210px;overflow:hidden}
.acc-dropdown.open{display:block}
.acc-dropdown-item{display:flex;align-items:center;gap:9px;padding:9px 14px;font-size:13px;cursor:pointer;transition:background .12s;border:none;background:none;width:100%;text-align:left;font-family:var(--font);color:var(--gris-text)}
.acc-dropdown-item:hover{background:#F0F4FF}
.acc-dropdown-item.verde{color:#1B5E20}.acc-dropdown-item.verde:hover{background:#F1F8E9}
.acc-dropdown-item.azul{color:#0D47A1}.acc-dropdown-item.azul:hover{background:#E3F2FD}
.acc-dropdown-item.naranja{color:#E65100}.acc-dropdown-item.naranja:hover{background:#FFF8E1}
.acc-dropdown-item.rojo{color:#B71C1C}.acc-dropdown-item.rojo:hover{background:#FFEBEE}
.acc-sep{height:1px;background:var(--gris-border);margin:3px 0}

/* FORMULARIO COTIZACIÓN */
.form-card{background:#fff;border:1px solid var(--gris-border);border-radius:10px;padding:20px 24px;margin-bottom:16px}
.form-card h3{font-size:14px;font-weight:600;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--gris-border);color:var(--azul);display:flex;align-items:center;gap:8px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid.cols3{grid-template-columns:1fr 1fr 1fr}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:12px;font-weight:500;color:var(--gris-muted);text-transform:uppercase;letter-spacing:.4px}
.form-group input,.form-group select,.form-group textarea{padding:8px 12px;border:1px solid var(--gris-border);border-radius:7px;font-family:var(--font);font-size:13px;outline:none;transition:border .15s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--azul)}
.form-group textarea{resize:vertical;min-height:70px}
.form-full{grid-column:1/-1}

/* TABLA DE ÍTEMS */
.items-table{width:100%;border-collapse:collapse;margin-bottom:12px}
.items-table th{background:#F8FAFC;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--gris-muted);padding:8px 10px;text-align:left;border-bottom:1px solid var(--gris-border)}
.items-table td{padding:6px 8px;border-bottom:1px solid #F3F4F6;vertical-align:top}
.items-table input{width:100%;padding:5px 8px;border:1px solid transparent;border-radius:5px;font-family:var(--font);font-size:12px;background:transparent;outline:none;transition:all .15s}
.items-table input:focus{border-color:var(--azul);background:#fff}
.items-table textarea.desc-input:focus{border-color:var(--azul);background:#fff;border:1px solid var(--azul)}
.items-table .num-input{width:70px;text-align:right}
.items-table .desc-input{width:100%;min-width:200px}
.items-table .total-cell{font-weight:600;color:var(--azul);font-family:var(--mono);font-size:12px;white-space:nowrap}
.btn-del-item{width:26px;height:26px;border:none;background:#FFEBEE;color:#E53935;border-radius:5px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
.btn-del-item:hover{background:#FFCDD2}
.totales-box{margin-left:auto;width:280px;background:#F8FAFC;border:1px solid var(--gris-border);border-radius:8px;overflow:hidden}
.totales-row{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid var(--gris-border)}
.totales-row:last-child{border-bottom:none;background:#1565C0;color:#fff}
.totales-row:nth-child(2){background:#548DD4;color:#fff}
.totales-lbl{font-size:12px;font-weight:500}
.totales-val{font-family:var(--mono);font-size:13px;font-weight:600}

/* BUSCADOR TARIFARIO */
.buscador-panel{background:#F0F7FF;border:1px solid #B5D4F4;border-radius:10px;padding:16px;margin-bottom:16px}
.buscador-panel h4{font-size:13px;font-weight:600;color:var(--azul);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.search-row{display:flex;gap:8px;margin-bottom:12px}
.search-row input{flex:1;padding:8px 14px;border:1px solid var(--gris-border);border-radius:7px;font-family:var(--font);font-size:13px;outline:none;background:#fff}
.search-row input:focus{border-color:var(--azul)}
.search-row button{padding:8px 18px;background:var(--azul);color:#fff;border:none;border-radius:7px;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500}
.tar-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;max-height:320px;overflow-y:auto}
.tar-card{background:#fff;border:1px solid var(--gris-border);border-radius:8px;padding:10px 12px;cursor:pointer;transition:all .15s}
.tar-card:hover{border-color:var(--azul);background:#F0F7FF}
.tar-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.tar-cod{font-size:10px;font-weight:700;color:var(--azul);background:var(--azul-light);padding:1px 6px;border-radius:3px;font-family:var(--mono)}
.tar-cat{font-size:9px;background:#1A1A2E;color:#fff;padding:1px 6px;border-radius:3px;margin-left:4px}
.tar-precio{font-size:12px;font-weight:700;color:#1B5E20;font-family:var(--mono)}
.tar-nom{font-size:12px;font-weight:600;margin-bottom:2px}
.tar-marca{font-size:10px;color:var(--gris-muted)}
.tar-desc{font-size:10px;color:#666;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.tar-empty{text-align:center;color:var(--gris-muted);padding:20px;grid-column:1/-1}

/* AUTOCOMPLETE */
.cli-sug-item{padding:8px 12px;cursor:pointer;border-bottom:1px solid #f0f0f0;font-size:13px}
.cli-sug-item:hover{background:#F0F7FF}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:800;align-items:center;justify-content:center}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:12px;padding:24px;width:90%;max-width:480px;box-shadow:var(--shadow-lg)}
.modal h3{font-size:16px;font-weight:600;margin-bottom:16px}
.modal-btns{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}

/* TOAST */
.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:999}
.toast{background:#1A1A2E;color:#fff;padding:12px 18px;border-radius:8px;font-size:13px;display:flex;align-items:center;gap:10px;animation:slideIn .25s ease;min-width:260px;box-shadow:var(--shadow-lg)}
.toast.ok{border-left:3px solid #1FB714}
.toast.err{border-left:3px solid #E53935}
.toast.info{border-left:3px solid #1565C0}
@keyframes slideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* UTIL */
.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:40px 20px;color:var(--gris-muted)}
.empty-state .empty-icon{font-size:40px;margin-bottom:12px}
.tag{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:500}
.divider{height:1px;background:var(--gris-border);margin:20px 0}
.text-muted{color:var(--gris-muted)}
.text-money{font-family:var(--mono);font-weight:600}
.flex{display:flex}.items-center{align-items:center}.gap8{gap:8px}.gap12{gap:12px}
.ml-auto{margin-left:auto}
.section-title{font-size:15px;font-weight:600;margin-bottom:14px}
.w100{width:100%}

@media(max-width:768px){
  .dash-grid{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .form-grid.cols3{grid-template-columns:1fr}
  .nav-items .nav-btn span{display:none}
  .filtros{flex-direction:column}
  .tar-results{grid-template-columns:1fr}
}
@media(max-width:480px){
  .dash-grid{grid-template-columns:1fr}
  .nav{padding:0 12px;gap:4px}
  .nav-items .nav-btn{padding:6px 8px;font-size:11px}
  .modal{width:95%;padding:16px;max-width:none}
  #panel-detalle{width:100%;right:-100%}
  #panel-detalle.open{right:0}
  .btn-accion{padding:4px 8px;font-size:11px}
  .toast-container{right:8px;bottom:12px;left:8px}
  .toast{min-width:auto}
  #docs-upload-grid{grid-template-columns:1fr}
}

/* ── TOOLTIP PERSONALIZADO (posición fija, nunca se corta) ─────────── */
#app-tooltip{
  position:fixed;z-index:9999;
  background:#1A1A2E;color:#fff;
  font-size:11px;font-family:var(--font);
  padding:5px 10px;border-radius:6px;
  pointer-events:none;white-space:nowrap;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
  opacity:0;transition:opacity .15s;
  transform:translateX(-50%);
}

/* ── BOTONES DE ACCIÓN CON TEXTO ───────────────────────── */
.btn-accion{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:500;border:1px solid var(--gris-border);border-radius:8px;background:#fff;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:var(--font);line-height:1.2}
.btn-accion:hover{background:#F0F4FF;border-color:#5C6BC0;color:#1A237E;transform:translateY(-1px)}
.btn-accion.verde{color:#1B5E20;border-color:#A5D6A7;background:#F1F8E9}
.btn-accion.verde:hover{background:#C8E6C9;border-color:#66BB6A;transform:translateY(-1px)}
.btn-accion.azul{color:#0D47A1;border-color:#90CAF9;background:#E3F2FD}
.btn-accion.azul:hover{background:#BBDEFB;border-color:#42A5F5;transform:translateY(-1px)}
.btn-accion.naranja{color:#E65100;border-color:#FFCC80;background:#FFF8E1}
.btn-accion.naranja:hover{background:#FFE0B2;border-color:#FFA726;transform:translateY(-1px)}
.btn-accion.rojo{color:#B71C1C;border-color:#FFCDD2;background:#FFEBEE}
.btn-accion.rojo:hover{background:#FFCDD2}

/* ── MODAL DE CONFIRMACIÓN ─────────────────────────────── */
#modal-confirm{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:900;display:none;align-items:center;justify-content:center}
#modal-confirm.open{display:flex}
.confirm-card{background:#fff;border-radius:14px;padding:28px;max-width:380px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.confirm-icon{font-size:36px;margin-bottom:12px;text-align:center}
.confirm-title{font-size:16px;font-weight:600;margin-bottom:8px;text-align:center}
.confirm-desc{font-size:13px;color:var(--gris-muted);text-align:center;margin-bottom:20px;line-height:1.5}
.confirm-btns{display:flex;gap:10px}
.confirm-btns button{flex:1;padding:10px;border-radius:8px;font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;border:none}
.confirm-cancel{background:var(--gris-bg);color:var(--gris-text)}
.confirm-ok{background:var(--azul);color:#fff}
.confirm-ok.danger{background:var(--rojo)}

/* ── PANEL DETALLE COTIZACIÓN ──────────────────────────── */
#panel-detalle{position:fixed;top:0;right:-480px;width:480px;height:100vh;background:#fff;box-shadow:-4px 0 24px rgba(0,0,0,.12);z-index:700;transition:right .3s ease;display:flex;flex-direction:column;overflow:hidden}
#panel-detalle.open{right:0}
.panel-header{padding:18px 20px;border-bottom:1px solid var(--gris-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.panel-body{flex:1;overflow-y:auto;padding:20px}
.panel-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #F3F4F6}
.panel-section:last-child{border-bottom:none}
.panel-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--gris-muted);margin-bottom:10px}
.det-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.det-label{font-size:12px;color:var(--gris-muted)}
.det-val{font-size:13px;font-weight:500}
.det-items-table{width:100%;border-collapse:collapse;font-size:11px}
.det-items-table th{background:#F8FAFC;padding:5px 7px;text-align:left;font-weight:600;color:var(--gris-muted);border-bottom:1px solid var(--gris-border)}
.det-items-table td{padding:5px 7px;border-bottom:1px solid #F9FAFB}
.det-totales{background:#F8FAFC;border-radius:8px;padding:12px 14px;margin-top:12px}
.det-total-row{display:flex;justify-content:space-between;font-size:12px;margin-bottom:4px}
.det-total-row.grande{font-size:15px;font-weight:700;color:var(--azul);border-top:1px solid var(--gris-border);padding-top:8px;margin-top:4px}

/* ── CALENDARIO ────────────────────────────────────────── */
.cal-layout{display:grid;grid-template-columns:1fr 280px;gap:18px;align-items:start}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cal-nav{display:flex;align-items:center;gap:10px}
.cal-mes{font-size:18px;font-weight:600}
.cal-nav-btn{background:none;border:1px solid var(--gris-border);border-radius:7px;padding:6px 12px;cursor:pointer;font-size:14px;transition:all .15s}
.cal-nav-btn:hover{background:var(--azul-light)}
.cal-grid-header{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.cal-grid-header div{text-align:center;font-size:11px;font-weight:600;color:var(--gris-muted);padding:4px;text-transform:uppercase}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-dia{min-height:70px;background:#fff;border:1px solid var(--gris-border);border-radius:7px;padding:5px;cursor:pointer;transition:all .15s;position:relative}
.cal-dia:hover{border-color:var(--azul);box-shadow:0 0 0 2px rgba(21,101,192,.1)}
.cal-dia.otro-mes{background:#F9FAFB;opacity:.5}
.cal-dia.hoy{border-color:var(--azul);border-width:2px}
.cal-dia.seleccionado{background:var(--azul-light);border-color:var(--azul)}
.cal-dia.tiene-eventos{background:#F0FFF4}
.cal-num{font-size:12px;font-weight:600;color:var(--gris-muted);margin-bottom:3px}
.cal-dia.hoy .cal-num{color:var(--azul)}
.cal-evento-pip{font-size:10px;padding:1px 5px;border-radius:3px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.cal-pip-aprobada{background:#C8E6C9;color:#1B5E20}
.cal-pip-proceso{background:#BBDEFB;color:#0D47A1}
.cal-pip-facturada{background:#E1BEE7;color:#4A148C}
.cal-sidebar{background:#fff;border:1px solid var(--gris-border);border-radius:10px;padding:16px}
.cal-sidebar h4{font-size:13px;font-weight:600;margin-bottom:12px;color:var(--gris-text)}
.cal-evento-item{border:1px solid var(--gris-border);border-radius:8px;padding:10px 12px;margin-bottom:8px;cursor:pointer;transition:all .15s}
.cal-evento-item:hover{border-color:var(--azul);background:#F8FAFF}
.cal-evento-fecha{font-size:10px;color:var(--gris-muted);margin-bottom:3px}
.cal-evento-cliente{font-size:13px;font-weight:600}
.cal-evento-proyecto{font-size:11px;color:var(--gris-muted)}
.cal-leyenda{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.cal-ley-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--gris-muted)}
.cal-ley-dot{width:10px;height:10px;border-radius:50%}

/* ── MÓDULO GASTOS ─────────────────────────────────────────────────── */
.badge-pagos{background:rgba(156,39,176,.25);color:#CE93D8}
.utilidad-card{background:#fff;border:1px solid var(--gris-border);border-radius:12px;overflow:hidden;margin-bottom:12px}
.utilidad-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;transition:background .15s;border-bottom:1px solid transparent}
.utilidad-header:hover{background:#FAFBFF}
.utilidad-header.open{border-bottom:1px solid var(--gris-border)}
.utilidad-nums{display:flex;gap:20px;align-items:center}
.util-num{text-align:right}
.util-num span{font-size:10px;color:var(--gris-muted);display:block;text-transform:uppercase;letter-spacing:.4px}
.util-num b{font-size:13px;font-family:var(--mono)}
.util-num.positivo b{color:#1B5E20}
.util-num.negativo b{color:#B71C1C}
.util-num.neutro b{color:var(--azul)}
.margen-badge{padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700}
.margen-alto{background:#C8E6C9;color:#1B5E20}
.margen-medio{background:#FFF9C4;color:#7B6000}
.margen-bajo{background:#FFCDD2;color:#B71C1C}
.utilidad-body{padding:16px 18px;display:none}
.utilidad-body.open{display:block}
.gastos-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:12px}
.gastos-table th{background:#F8FAFC;padding:6px 10px;text-align:left;font-weight:600;font-size:10px;text-transform:uppercase;color:var(--gris-muted);border-bottom:1px solid var(--gris-border)}
.gastos-table td{padding:7px 10px;border-bottom:1px solid #F9FAFB;vertical-align:middle}
.gastos-table tr:last-child td{border-bottom:none}
.cat-badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;background:#E3F2FD;color:#0D47A1}
.resumen-gastos{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-top:12px}
.resumen-card{background:#F8FAFC;border-radius:8px;padding:12px 14px;border-left:3px solid var(--azul)}
.resumen-card .rc-lbl{font-size:11px;color:var(--gris-muted);margin-bottom:3px}
.resumen-card .rc-val{font-size:15px;font-weight:700;font-family:var(--mono)}

/* ── SELECTOR DE ROL ───────────────────────────────────────────────── */
.rol-card{display:flex;flex-direction:column;gap:3px;padding:12px 14px;border:2px solid var(--gris-border);border-radius:10px;cursor:pointer;transition:all .15s;background:#fff;user-select:none}
.rol-card:hover{border-color:var(--azul);background:#F8FAFF}
.rol-card.selected{border-color:var(--azul);background:#E3F2FD;box-shadow:0 0 0 3px rgba(21,101,192,.1)}
/* Toggle switch de permisos */
.perm-toggle{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0}
.perm-toggle input{opacity:0;width:0;height:0}
.perm-slider{position:absolute;cursor:pointer;inset:0;background:#DDD;border-radius:99px;transition:.25s}
.perm-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.perm-toggle input:checked+.perm-slider{background:#8DBE22}
.perm-toggle input:checked+.perm-slider:before{transform:translateX(18px)}
/* Filas de permisos */
.perm-row{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-bottom:1px solid #F0F0F0;gap:12px;transition:background .1s}
.perm-row:last-child{border-bottom:none}
.perm-row:hover{background:#FAFBFF}
.perm-info{flex:1;min-width:0}
.perm-label{font-size:13px;font-weight:500;color:var(--gris-text)}
.perm-hint{font-size:11px;color:var(--gris-muted);margin-top:1px}
.perm-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--azul);padding:8px 14px 4px;background:#F8FAFF;border-bottom:1px solid #F0F0F0;border-top:1px solid #F0F0F0}
.rol-icon{font-size:22px;margin-bottom:2px}
.rol-nombre{font-size:13px;font-weight:700;color:var(--gris-text)}
.rol-desc{font-size:11px;color:var(--gris-muted);line-height:1.4}
.rol-perms{font-size:10px;color:var(--azul);margin-top:3px;font-weight:500}
/* Badges de rol en tabla */
.rol-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:600}
.rol-vendedor{background:#E3F2FD;color:#0D47A1}
.rol-produccion{background:#FFF3E0;color:#E65100}
.rol-pagos{background:#F3E5F5;color:#6A1B9A}
.rol-contabilidad{background:#E8F5E9;color:#1B5E20}
.rol-admin{background:#1A1A2E;color:#4CAF50}
/* Grid de roles en página usuarios */
.rol-group-card{background:#fff;border:1px solid var(--gris-border);border-radius:12px;overflow:hidden}
.rol-group-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--gris-border)}
.rol-group-header .rol-icon-lg{font-size:20px}
.rol-group-header h4{font-size:14px;font-weight:600;margin:0}
.rol-group-header p{font-size:11px;color:var(--gris-muted);margin:0}
.rol-group-users{padding:8px 0}
.rol-user-row{display:flex;align-items:center;justify-content:space-between;padding:8px 16px}
.rol-user-row:hover{background:#FAFBFF}
.rol-user-info{display:flex;align-items:center;gap:10px}
.rol-user-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.rol-user-name{font-size:13px;font-weight:600}
.rol-user-email{font-size:11px;color:var(--gris-muted)}
.doc-upload-item{background:#fff;border:1px solid #FFB74D;border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:7px}
.doc-label{font-size:12px;font-weight:600;color:#E65100}
.doc-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#FFF8E1;border:1px dashed #FFB74D;border-radius:7px;cursor:pointer;font-size:12px;color:#E65100;font-family:var(--font);transition:all .15s;width:100%;justify-content:center}
.doc-btn:hover{background:#FFE0B2;border-style:solid}
.doc-btn input[type=file]{display:none}
.doc-preview{font-size:11px;min-height:20px}
.doc-preview.ready{color:#1B5E20;background:#E8F5E9;padding:4px 8px;border-radius:5px;display:flex;align-items:center;gap:5px}
.doc-preview.ready::before{content:'✅ '}
.doc-preview.uploading{color:#1565C0}
.doc-preview.done{color:#1B5E20;font-weight:600}
.doc-preview.error{color:#B71C1C;background:#FFEBEE;padding:4px 8px;border-radius:5px}
.doc-upload-item.uploaded{border-color:#A5D6A7;background:#F9FFF9}
/* (moved to @media 480px breakpoint above) */
.sol-card{background:#fff;border:1px solid var(--gris-border);border-radius:10px;margin-bottom:10px;overflow:hidden;transition:box-shadow .15s}
.sol-card:hover{box-shadow:0 2px 12px rgba(0,0,0,.08)}
.sol-header{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 16px}
.sol-id{font-family:var(--mono);font-size:11px;color:var(--gris-muted);margin-bottom:2px}
.sol-desc{font-size:13px;font-weight:600;margin-bottom:3px}
.sol-meta{font-size:11px;color:var(--gris-muted)}
.sol-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;margin-left:12px}
.sol-valor{font-family:var(--mono);font-size:15px;font-weight:700}
.sol-acciones{display:flex;gap:6px;flex-wrap:wrap;padding:0 16px 14px}
/* Estado badges para solicitudes */
.sol-SOLICITADO{background:#EDE7F6;color:#4A148C}
.sol-APROBADO{background:#C8E6C9;color:#1B5E20}
.sol-ENTREGADO{background:#BBDEFB;color:#0D47A1}
.sol-LIQUIDADO{background:#E8F5E9;color:#1B5E20;border:1px solid #A5D6A7}
.sol-DENEGADO{background:#FFCDD2;color:#B71C1C}

/* Modal liquidar */
#modal-liquidar .form-group{margin-bottom:14px}
.modal-contab-header{background:linear-gradient(135deg,#1565C0,#0D47A1);color:#fff;padding:20px 24px;border-radius:12px 12px 0 0;margin:-20px -20px 20px}
.modal-contab-header h3{margin:0;font-size:16px;color:#fff}
.modal-contab-header p{margin:4px 0 0;font-size:12px;color:#90CAF9}
.contab-info-box{background:#F8FAFC;border-radius:8px;padding:14px 16px;margin-bottom:16px}
.contab-info-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;font-size:13px}
.contab-info-row:last-child{margin-bottom:0}
.contab-info-row span:first-child{color:var(--gris-muted);font-size:12px}
.contab-total-row{background:#1565C0;color:#fff;border-radius:7px;padding:10px 14px;display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.contab-total-row span:first-child{font-size:12px;color:#90CAF9}
.contab-total-row span:last-child{font-size:18px;font-weight:700}
#modal-preview-prod{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:900;display:none;align-items:center;justify-content:center;padding:16px}
#modal-preview-prod.open{display:flex}
.preview-card{background:#fff;border-radius:14px;width:100%;max-width:720px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(0,0,0,.3)}
.preview-header{padding:16px 20px;border-bottom:1px solid var(--gris-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:#1A1A2E;color:#fff;border-radius:14px 14px 0 0}
.preview-header h3{font-size:15px;font-weight:600;color:#fff}
.preview-body{flex:1;overflow-y:auto;padding:24px}
.preview-no-precios{background:linear-gradient(135deg,#FFF3E0,#FFF8E1);border:1px solid #FFB74D;border-radius:8px;padding:10px 14px;font-size:12px;color:#E65100;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.preview-section{margin-bottom:20px}
.preview-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--gris-muted);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #F3F4F6}
.preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 16px}
.preview-field{font-size:13px}.preview-field span{color:var(--gris-muted);font-size:11px;display:block}
.preview-items-table{width:100%;border-collapse:collapse;font-size:12px}
.preview-items-table th{background:#F8FAFC;padding:7px 10px;text-align:left;font-weight:600;font-size:10px;text-transform:uppercase;color:var(--gris-muted);border-bottom:1px solid var(--gris-border)}
.preview-items-table td{padding:7px 10px;border-bottom:1px solid #F9FAFB;vertical-align:top}
.preview-items-table tr:last-child td{border-bottom:none}
@media print{
  body > *:not(#modal-preview-prod){display:none!important}
  #modal-preview-prod{position:static!important;background:none!important;display:block!important}
  .preview-card{box-shadow:none!important;max-height:none!important;border-radius:0!important}
  .preview-header{border-radius:0!important;print-color-adjust:exact;-webkit-print-color-adjust:exact}
  .preview-close-btn,.preview-print-btn{display:none!important}
}
.prod-card{background:#fff;border:1px solid var(--gris-border);border-radius:12px;margin-bottom:16px;overflow:hidden}
.prod-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--gris-border);cursor:pointer;transition:background .15s}
.prod-header:hover{background:#FAFBFF}
.prod-header-left{display:flex;align-items:center;gap:12px}
.prod-fecha-badge{background:var(--azul-light);color:var(--azul);padding:6px 10px;border-radius:7px;text-align:center;flex-shrink:0;min-width:52px}
.prod-fecha-dia{font-size:20px;font-weight:700;line-height:1}
.prod-fecha-mes{font-size:10px;font-weight:600;text-transform:uppercase}
.prod-info h4{font-size:14px;font-weight:600;margin-bottom:2px}
.prod-info p{font-size:12px;color:var(--gris-muted)}
.prod-body{padding:16px 18px;display:none}
.prod-body.open{display:block}
.prod-items-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:8px}
.prod-items-table th{background:#F8FAFC;padding:7px 10px;text-align:left;font-weight:600;font-size:10px;text-transform:uppercase;color:var(--gris-muted);border-bottom:1px solid var(--gris-border)}
.prod-items-table td{padding:7px 10px;border-bottom:1px solid #F9FAFB;vertical-align:top}
.prod-items-table tr:last-child td{border-bottom:none}
.prod-chevron{transition:transform .2s;color:var(--gris-muted)}
.prod-chevron.open{transform:rotate(180deg)}
.dias-badge{display:inline-block;background:#FFF9C4;color:#7B6000;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:600}

/* ── CHECKLIST TABLE ──────────────────────────────────────────────── */
.chl-tabla {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  margin-bottom: 16px;
  table-layout: fixed;
}
.chl-tabla thead tr {
  background: #F0F4F8;
  border-bottom: 2px solid var(--gris-border);
}
.chl-tabla th {
  padding: 7px 8px;
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  color: var(--gris-muted);
  text-transform: uppercase;
  letter-spacing: .4px;
  white-space: nowrap;
}
.chl-tabla td {
  padding: 7px 8px;
  border-bottom: 1px solid #F5F5F5;
  vertical-align: middle;
}
.chl-tabla tr:hover td { background: #FAFBFC; }
.chl-tabla tr.acc-row td { background: #FAFBFC; }

/* Column widths */
.col-num  { width: 32px; text-align: center; color: var(--gris-muted); font-weight: 600; }
.col-desc { /* flex */ }
.col-falt { width: 52px; text-align: center; }
.col-check { width: 36px; text-align: center; cursor: pointer; font-size: 14px; }
.col-check.on { color: #1B5E20; }
.col-prov { width: 52px; color: var(--gris-muted); font-size: 11px; }
.col-del  { width: 36px; text-align: center; }

/* Check toggle hover */
td.col-check[onclick]:hover { background: #E8F5E9; border-radius: 4px; }

/* Category header */
.chl-cat-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: linear-gradient(90deg, #EEF2F7, transparent);
  border-left: 3px solid var(--azul);
  border-radius: 0 6px 6px 0;
  font-size: 12px;
  font-weight: 700;
  color: var(--gris-text);
  margin-top: 12px;
  margin-bottom: 4px;
}