/* ═══════════════════════════════════════
   MÉTODO TRG CRM — Estilos globales
═══════════════════════════════════════ */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --verde:#1f4d3a;--verde2:#2a6650;--verde3:#d4edda;--verde4:#e8f5ee;
  --bg:#f0f4f2;--bg2:#ffffff;--bg3:#f8faf9;
  --text:#1a2e25;--text2:#4a6358;--text3:#8aab9a;
  --border:#d6e4dd;--border2:#c2d8cc;
  --danger:#c0392b;--danger-bg:#fdf0ef;
  --warn:#b7770d;--warn-bg:#fef9ec;
  --info:#1d6fa4;--info-bg:#eaf4fb;
  --radius:8px;--radius-lg:12px;
  --shadow:0 1px 4px rgba(0,0,0,.07);
  --font:'Segoe UI',system-ui,Arial,sans-serif;
  --sidebar:230px;
}
body{font-family:var(--font);background:var(--bg);color:var(--text);display:flex;min-height:100vh}

/* ── SIDEBAR ── */
.sidebar{width:var(--sidebar);flex-shrink:0;background:var(--verde);color:#fff;
  display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;overflow-y:auto}
.sidebar-brand{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.12)}
.sidebar-brand h2{font-size:16px;font-weight:600;color:#fff}
.sidebar-brand p{font-size:11px;color:rgba(255,255,255,.5);margin-top:2px}
.sidebar-nav{padding:10px 0;flex:1}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;
  color:rgba(255,255,255,.75);text-decoration:none;font-size:13px;
  border-left:3px solid transparent;transition:all .15s}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{background:rgba(255,255,255,.13);color:#fff;border-left-color:#7fccaa;font-weight:500}
.nav-item i{font-size:17px;width:20px;flex-shrink:0}
.sidebar-footer{padding:12px 18px;border-top:1px solid rgba(255,255,255,.12);font-size:12px;color:rgba(255,255,255,.6)}
.rol-badge{font-size:10px;background:rgba(255,255,255,.15);padding:1px 7px;border-radius:10px;margin-left:4px}
.btn-logout{display:inline-flex;align-items:center;gap:5px;margin-top:8px;
  color:rgba(255,255,255,.7);text-decoration:none;font-size:12px}
.btn-logout:hover{color:#fff}

/* ── MAIN ── */
.main{margin-left:var(--sidebar);flex:1;padding:20px 24px;min-height:100vh}
.page-title{font-size:20px;font-weight:600;color:var(--verde);margin-bottom:4px}
.page-sub{font-size:13px;color:var(--text2);margin-bottom:20px}

/* ── CARDS ── */
.card{background:var(--bg2);border:0.5px solid var(--border);border-radius:var(--radius-lg);
  padding:18px;margin-bottom:16px;box-shadow:var(--shadow)}
.card-title{font-size:14px;font-weight:600;color:var(--verde);margin-bottom:14px;
  display:flex;align-items:center;gap:8px}
.card-title i{font-size:17px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}

/* ── STATS ── */
.stat{background:var(--bg2);border:0.5px solid var(--border);border-radius:var(--radius);padding:14px 16px}
.stat-label{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.stat-value{font-size:22px;font-weight:600;color:var(--verde)}

/* ── FORMS ── */
.form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.form-group label{font-size:12px;color:var(--text2);font-weight:500}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:8px 10px;border:0.5px solid var(--border2);border-radius:var(--radius);
  font-size:13px;font-family:var(--font);background:var(--bg2);color:var(--text);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--verde2);box-shadow:0 0 0 3px rgba(31,77,58,.1)}
.form-group textarea{min-height:70px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius);
  font-size:13px;font-family:var(--font);cursor:pointer;border:0.5px solid var(--border2);
  background:var(--bg2);color:var(--text);font-weight:500;text-decoration:none}
.btn:hover{background:var(--bg3)}.btn:active{transform:scale(.98)}
.btn-verde{background:var(--verde);color:#fff;border-color:var(--verde)}
.btn-verde:hover{background:var(--verde2);color:#fff}
.btn-sm{padding:5px 9px;font-size:12px}
.btn-danger{color:var(--danger);border-color:var(--danger);background:none}
.btn-danger:hover{background:var(--danger-bg)}
.btn-warn{color:var(--warn);border-color:var(--warn);background:none}
.btn-warn:hover{background:var(--warn-bg)}

/* ── ALERTS ── */
.alert{padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.alert-success{background:var(--verde3);color:var(--verde);border:0.5px solid var(--border)}
.alert-danger{background:var(--danger-bg);color:var(--danger)}
.alert-warn{background:var(--warn-bg);color:var(--warn)}
.alert-info{background:var(--info-bg);color:var(--info)}

/* ── TABLE ── */
.table-wrap{border-radius:var(--radius-lg);border:0.5px solid var(--border);overflow:hidden;background:var(--bg2)}
table{width:100%;border-collapse:collapse;table-layout:fixed}
th{font-size:11px;color:var(--text2);text-align:left;padding:9px 12px;
  border-bottom:0.5px solid var(--border);font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;background:var(--bg3)}
td{padding:9px 12px;border-bottom:0.5px solid var(--border);font-size:13px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--verde4)}

/* ── PILLS ── */
.pill{display:inline-block;font-size:11px;padding:2px 9px;border-radius:20px;font-weight:500}
.p-activo{background:var(--verde3);color:var(--verde)}
.p-inactivo{background:#f0f0f0;color:#666}
.p-alta{background:var(--info-bg);color:var(--info)}
.p-agendada{background:#fff3cd;color:#856404}
.p-confirmada{background:var(--info-bg);color:var(--info)}
.p-asistio{background:var(--verde3);color:var(--verde)}
.p-noasistio{background:var(--danger-bg);color:var(--danger)}
.p-cancelada{background:#f5e6e6;color:#9b2226}
.p-reagendada{background:var(--warn-bg);color:var(--warn)}

/* ── AVATAR ── */
.avatar{width:32px;height:32px;border-radius:50%;background:var(--verde3);color:var(--verde);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}

/* ── STORAGE BAR ── */
.storage-bar{display:flex;align-items:center;gap:8px;background:var(--verde4);
  border:0.5px solid var(--verde3);border-left:3px solid var(--verde);
  border-radius:var(--radius);padding:8px 14px;font-size:12px;color:var(--text2);margin-bottom:18px}

/* ── SEARCH BAR ── */
.search-bar{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.search-bar input,.search-bar select{padding:8px 10px;border:0.5px solid var(--border2);
  border-radius:var(--radius);font-size:13px;font-family:var(--font);background:var(--bg2);color:var(--text);outline:none}
.search-bar input:focus,.search-bar select:focus{border-color:var(--verde2)}
.search-bar input{flex:1;min-width:140px}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;
  align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--bg2);border-radius:var(--radius-lg);padding:24px;width:100%;
  max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,.2)}
.modal-title{font-size:16px;font-weight:600;color:var(--verde);margin-bottom:16px;
  display:flex;justify-content:space-between;align-items:center}
.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--text2)}
.modal-close:hover{color:var(--text)}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:16px;
  padding-top:14px;border-top:0.5px solid var(--border)}

/* ── FICHA ── */
.ficha-header{display:flex;align-items:center;gap:14px;margin-bottom:16px;
  padding-bottom:14px;border-bottom:0.5px solid var(--border)}
.ficha-avatar{width:52px;height:52px;border-radius:50%;background:var(--verde);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;flex-shrink:0}
.info-item{display:flex;gap:8px;font-size:13px;padding:6px 0;border-bottom:0.5px solid var(--border)}
.info-item:last-child{border-bottom:none}
.info-label{color:var(--text2);width:150px;flex-shrink:0;font-size:12px}
.info-val{color:var(--text);font-weight:500;word-break:break-word}

/* ── PROGRESS BAR ── */
.progress-track{background:var(--bg);border-radius:4px;height:8px;overflow:hidden;
  border:0.5px solid var(--border);flex:1}
.progress-fill{height:100%;border-radius:4px;background:var(--verde2)}
.progress-fill.warn{background:#e67e22}
.progress-fill.danger{background:var(--danger)}

/* ── FILE ── */
.file-drop{border:1.5px dashed var(--border2);border-radius:var(--radius);padding:18px;
  text-align:center;cursor:pointer;transition:border-color .2s;background:var(--bg3)}
.file-drop:hover,.file-drop.dragover{border-color:var(--verde2);background:var(--verde4)}
.file-drop i{font-size:24px;color:var(--text3);display:block;margin-bottom:6px}
.file-drop p{font-size:12px;color:var(--text2)}
.file-item{display:flex;align-items:center;gap:10px;padding:8px 10px;
  background:var(--bg3);border:0.5px solid var(--border);border-radius:var(--radius);margin-bottom:6px}
.file-icon{font-size:20px;color:var(--verde);flex-shrink:0}
.file-name{font-size:13px;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-size{font-size:11px;color:var(--text3);flex-shrink:0}

/* ── METODO BARS ── */
.metodo-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.metodo-bar-label{width:120px;font-size:12px;color:var(--text2);flex-shrink:0}
.metodo-bar-track{flex:1;background:var(--bg);border-radius:4px;height:8px;overflow:hidden;border:0.5px solid var(--border)}
.metodo-bar-fill{height:100%;border-radius:4px;background:var(--verde2)}
.metodo-bar-val{width:70px;text-align:right;font-size:12px;color:var(--text2);flex-shrink:0}

/* ── SECTION LABEL ── */
.section-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;
  letter-spacing:.05em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.divider{height:0.5px;background:var(--border);margin:14px 0}
.empty{text-align:center;padding:2.5rem 1rem;color:var(--text2);font-size:13px}
.empty i{font-size:28px;display:block;margin-bottom:8px;color:var(--text3)}

/* ── TOAST ── */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--verde);color:#fff;padding:10px 20px;border-radius:var(--radius);
  font-size:13px;transition:transform .25s;pointer-events:none;z-index:999;
  white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.2)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.error{background:var(--danger)}

/* ── LOGIN ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-box{background:var(--bg2);border:0.5px solid var(--border);border-radius:var(--radius-lg);
  padding:36px 32px;width:100%;max-width:380px;box-shadow:var(--shadow)}
.login-logo{text-align:center;margin-bottom:24px}
.login-logo h1{font-size:22px;font-weight:600;color:var(--verde)}
.login-logo p{font-size:13px;color:var(--text2);margin-top:4px}

@media(max-width:900px){
  .grid2,.grid3,.form-row,.form-row3{grid-template-columns:1fr}
  .grid4{grid-template-columns:repeat(2,1fr)}
  .sidebar{width:200px}
  .main{margin-left:200px}
}
@media(max-width:600px){
  .sidebar{display:none}
  .main{margin-left:0}
}
