/* ═══════════════════════════════════════════
   AGILE BUSINESS CRM — style.css
   Diseño premium con glassmorphism + gradientes
════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  /* Paleta */
  --acc:     #4f46e5;
  --acc2:    #7c3aed;
  --accl:    #818cf8;
  --grn:     #059669;
  --grnl:    #10b981;
  --amb:     #d97706;
  --ambl:    #f59e0b;
  --red:     #dc2626;
  --redl:    #ef4444;
  --sky:     #0284c7;
  --skyl:    #38bdf8;
  /* Neutros */
  --txt:     #0f172a;
  --txt2:    #334155;
  --txt3:    #64748b;
  --txt4:    #94a3b8;
  --b:       rgba(148,163,184,.2);
  --bs:      rgba(148,163,184,.4);
  /* Superficies */
  --glass:   rgba(255,255,255,.72);
  --glass2:  rgba(255,255,255,.55);
  --glassd:  rgba(255,255,255,.35);
  --surf:    #ffffff;
  --bg-card: rgba(255,255,255,.8);
  /* Misc */
  --fn:   'Inter', sans-serif;
  --mono: 'JetBrains Mono', monospace;
  --r:    8px;
  --rl:   14px;
  --sh:   0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shm:  0 4px 16px rgba(0,0,0,.10), 0 2px 6px rgba(0,0,0,.06);
  --shx:  0 12px 40px rgba(0,0,0,.14), 0 4px 12px rgba(0,0,0,.08);
}

/* ── RESET ── */
*{margin:0;padding:0;box-sizing:border-box}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(79,70,229,.3);border-radius:4px}

/* ── BODY / BG ── */
body {
  font-family:var(--fn);
  color:var(--txt);
  min-height:100vh;
  font-size:12.5px;
  line-height:1.5;
  overflow-x:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 20% -10%, rgba(124,58,237,.18) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 80% 10%, rgba(79,70,229,.14) 0%, transparent 50%),
    radial-gradient(ellipse 70% 60% at 50% 100%, rgba(5,150,105,.1) 0%, transparent 60%),
    linear-gradient(160deg, #f0f4ff 0%, #faf5ff 30%, #f0fdf4 60%, #eff6ff 100%);
  background-attachment:fixed;
}

/* ── INPUTS ── */
input,select,textarea {
  width:100%;padding:8px 11px;
  background:rgba(255,255,255,.9);
  border:1px solid var(--b);border-radius:var(--r);
  color:var(--txt);font-family:var(--fn);font-size:12px;
  transition:border .15s,box-shadow .15s;
  backdrop-filter:blur(4px);
}
input:focus,select:focus,textarea:focus {
  outline:none;border-color:var(--acc);
  box-shadow:0 0 0 3px rgba(79,70,229,.12);
  background:#fff;
}
input::placeholder,textarea::placeholder{color:var(--txt4)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-color:rgba(255,255,255,.9);padding-right:32px;cursor:pointer}
select[multiple]{background-image:none;padding-right:11px;min-height:100px}
textarea{resize:vertical;min-height:80px;line-height:1.6}
label{display:block;font-size:10.5px;font-weight:600;color:var(--txt3);margin-bottom:4px;letter-spacing:.3px;text-transform:uppercase}
.hint{font-size:10px;color:var(--txt4);margin-top:3px}

/* ── LOGIN ── */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-box {
  background:var(--glass);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.8);
  border-radius:20px;
  padding:40px 36px;
  width:100%;max-width:380px;
  box-shadow:var(--shx), 0 0 0 1px rgba(79,70,229,.08);
  text-align:center;
}
.login-logo{width:68px;margin-bottom:16px;filter:drop-shadow(0 4px 12px rgba(79,70,229,.3))}
.login-brand{font-size:10px;font-weight:700;letter-spacing:3px;color:var(--acc);text-transform:uppercase;margin-bottom:4px}
.login-title{font-size:22px;font-weight:700;color:var(--txt);margin-bottom:24px;letter-spacing:-.3px;background:linear-gradient(135deg,var(--acc),var(--acc2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.login-tabs{display:flex;gap:4px;margin-bottom:20px;background:rgba(0,0,0,.06);padding:4px;border-radius:10px}
.ltab{flex:1;padding:8px;border:none;border-radius:7px;background:transparent;color:var(--txt3);font-family:var(--fn);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
.ltab.on{background:#fff;color:var(--acc);box-shadow:var(--sh)}
.lerr{background:rgba(220,38,38,.08);border:1px solid rgba(220,38,38,.2);color:var(--red);padding:9px 12px;border-radius:8px;margin-bottom:14px;font-size:11.5px;font-weight:500;display:none}
.fg{margin-bottom:12px;text-align:left}
.btn-login{width:100%;padding:10px;border:none;border-radius:var(--r);background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;font-family:var(--fn);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(79,70,229,.35);margin-top:6px}
.btn-login:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(79,70,229,.4)}
.btn-login:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ── UTILS ── */
.hidden{display:none!important}
.app{display:flex;min-height:100vh}

/* ── SIDEBAR ── */
.sidebar {
  width:218px;min-width:218px;
  background:var(--glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-right:1px solid rgba(255,255,255,.6);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:200;
  transition:transform .3s;
  box-shadow:2px 0 20px rgba(79,70,229,.06);
}
.sb-brand{padding:16px 14px 12px;border-bottom:1px solid var(--b);display:flex;align-items:center;gap:9px}
.sb-brand img{height:32px;filter:drop-shadow(0 2px 6px rgba(79,70,229,.25))}
.sb-brand .bname{font-size:12.5px;font-weight:700;color:var(--txt);letter-spacing:-.2px}
.sb-brand .bsub{font-size:9px;color:var(--txt4);letter-spacing:.5px;text-transform:uppercase;margin-top:1px}
.sb-user{padding:10px 12px;border-bottom:1px solid var(--b)}
.uchip{display:flex;align-items:center;gap:8px;background:rgba(79,70,229,.06);border-radius:9px;padding:7px 9px;border:1px solid rgba(79,70,229,.1)}
.uav{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--acc2));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 8px rgba(79,70,229,.3)}
.uemail{font-size:10.5px;font-weight:500;color:var(--txt2);max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.urole{font-size:9px;color:var(--txt4)}

/* GCal badge */
.gcal-status{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;border:1px solid var(--b);margin:8px 12px;font-size:10.5px;font-weight:600;cursor:pointer;transition:all .2s;background:rgba(255,255,255,.5)}
.gcal-status.disconnected{color:var(--txt4)}.gcal-status.disconnected:hover{border-color:var(--acc);color:var(--acc);background:rgba(79,70,229,.06)}
.gcal-status.connected{color:var(--grn);background:rgba(5,150,105,.06);border-color:rgba(5,150,105,.25)}
.gcal-dot{width:7px;height:7px;border-radius:50%;background:var(--red);flex-shrink:0;box-shadow:0 0 6px currentColor}.gcal-status.connected .gcal-dot{background:var(--grn)}

.sb-nav{flex:1;padding:8px;overflow-y:auto}
.nlabel{font-size:9px;font-weight:700;letter-spacing:1.5px;color:var(--txt4);text-transform:uppercase;padding:10px 8px 4px;margin-top:2px}
.ni{display:flex;align-items:center;gap:8px;padding:8px 9px;border-radius:9px;margin-bottom:1px;cursor:pointer;transition:all .15s;color:var(--txt3);font-size:12px;font-weight:500;border:none;background:transparent;width:100%;text-align:left}
.ni:hover{background:rgba(79,70,229,.06);color:var(--txt)}.ni.on{background:linear-gradient(135deg,rgba(79,70,229,.12),rgba(124,58,237,.08));color:var(--acc);font-weight:600;border:1px solid rgba(79,70,229,.15)}
.ni .ic{font-size:14px;flex-shrink:0;width:18px;text-align:center}
.ni .nbadge{margin-left:auto;background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;font-size:9px;font-weight:700;padding:2px 7px;border-radius:10px;min-width:18px;text-align:center;box-shadow:0 2px 6px rgba(79,70,229,.3)}
.sb-foot{padding:10px 8px;border-top:1px solid var(--b)}
.btn-out{display:flex;align-items:center;gap:7px;width:100%;padding:8px 9px;border-radius:8px;background:transparent;border:1px solid var(--b);color:var(--txt4);font-size:11.5px;font-weight:500;cursor:pointer;transition:all .2s;font-family:var(--fn)}
.btn-out:hover{background:rgba(220,38,38,.06);border-color:rgba(220,38,38,.2);color:var(--red)}

/* ── TOPBAR / MAIN ── */
.main{flex:1;margin-left:218px;display:flex;flex-direction:column;min-height:100vh}
.topbar{background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.6);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 12px rgba(79,70,229,.06)}
.ptitle{font-size:14px;font-weight:700;color:var(--txt)}.psub{font-size:10.5px;color:var(--txt4);margin-top:1px}
.tbar-actions{display:flex;gap:7px;align-items:center}
.btn-sm{padding:6px 13px;border-radius:8px;border:1px solid var(--b);background:var(--glass2);color:var(--txt2);font-family:var(--fn);font-size:11.5px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px;backdrop-filter:blur(8px);box-shadow:var(--sh)}
.btn-sm:hover{background:rgba(255,255,255,.9);color:var(--acc);border-color:rgba(79,70,229,.25)}
.btn-sm.acc{background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;border-color:transparent;box-shadow:0 4px 14px rgba(79,70,229,.3)}.btn-sm.acc:hover{box-shadow:0 6px 20px rgba(79,70,229,.4);transform:translateY(-1px)}
.ham{display:none;padding:6px;background:none;border:none;color:var(--txt3);cursor:pointer;font-size:18px}
.sb-back{display:none;position:fixed;inset:0;background:rgba(15,23,42,.4);z-index:190;backdrop-filter:blur(2px)}
.content{flex:1;padding:20px 24px}

/* ── PANELS / GLASS CARDS ── */
.panel{background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.7);border-radius:var(--rl);overflow:hidden;margin-bottom:16px;box-shadow:var(--shm)}
.ph{padding:13px 18px;border-bottom:1px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.4)}
.ph-title{font-size:12.5px;font-weight:700;color:var(--txt)}
.pb{padding:16px}

/* ── STATS ── */
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:18px}
.scard{background:var(--glass);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.7);border-radius:var(--rl);padding:16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shm);transition:all .25s;position:relative;overflow:hidden}
.scard::before{content:'';position:absolute;inset:0;border-radius:var(--rl);opacity:0;transition:opacity .25s;background:linear-gradient(135deg,rgba(79,70,229,.06),rgba(124,58,237,.04))}
.scard:hover{transform:translateY(-2px);box-shadow:var(--shx)}.scard:hover::before{opacity:1}
.sic{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;box-shadow:var(--sh)}
.sic.g{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.sic.b{background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}.sic.a{background:linear-gradient(135deg,#fef3c7,#fde68a)}.sic.r{background:linear-gradient(135deg,#fee2e2,#fecaca)}.sic.p{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.sic.t{background:linear-gradient(135deg,#d1fae5,#6ee7b7)}
.snum{font-size:26px;font-weight:700;letter-spacing:-1px;line-height:1;margin-bottom:2px}
.snum.g{color:var(--grn)}.snum.b{color:var(--acc)}.snum.a{color:var(--amb)}.snum.r{color:var(--red)}.snum.p{color:var(--acc2)}.snum.t{color:var(--grn)}
.slbl{font-size:10.5px;font-weight:500;color:var(--txt3)}

/* ── FORM ELEMENTS ── */
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:13px}.fgrid .s2{grid-column:span 2}.fg2{display:flex;flex-direction:column;gap:4px}
.tipo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}.tr{display:none}
.tl{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 6px;border-radius:10px;border:1px solid var(--b);background:rgba(255,255,255,.6);cursor:pointer;transition:all .2s;font-size:10.5px;font-weight:600;color:var(--txt3);text-align:center;backdrop-filter:blur(4px)}
.tl .ti{font-size:18px}.tr:checked+.tl{border-color:var(--acc);background:linear-gradient(135deg,rgba(79,70,229,.1),rgba(124,58,237,.06));color:var(--acc);box-shadow:0 0 0 2px rgba(79,70,229,.2),var(--sh)}
.btn-full{width:100%;padding:10px 16px;border:none;border-radius:var(--r);background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;font-family:var(--fn);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(79,70,229,.3);display:flex;align-items:center;justify-content:center;gap:6px}
.btn-full:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(79,70,229,.4)}.btn-full:disabled{opacity:.45;cursor:not-allowed;transform:none}
.btn-ghost{padding:9px 14px;border:1px solid var(--b);border-radius:var(--r);background:rgba(255,255,255,.6);color:var(--txt3);font-family:var(--fn);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
.btn-ghost:hover{background:rgba(255,255,255,.9);border-color:var(--bs)}.brow{display:flex;gap:9px;margin-top:16px}
.banner{display:none;align-items:center;gap:7px;padding:10px 13px;border-radius:9px;font-size:12px;font-weight:600;margin-bottom:14px;backdrop-filter:blur(8px)}
.banner.ok{background:rgba(5,150,105,.1);border:1px solid rgba(5,150,105,.25);color:var(--grn)}.banner.warn{background:rgba(217,119,6,.1);border:1px solid rgba(217,119,6,.25);color:var(--amb)}.banner.err{background:rgba(220,38,38,.1);border:1px solid rgba(220,38,38,.25);color:var(--red)}

/* ══════════════════════════════════
   PIPELINE KANBAN — ESTILO HUBSPOT
══════════════════════════════════ */
.kanban-wrap{display:flex;gap:14px;overflow-x:auto;padding-bottom:12px;align-items:flex-start;min-height:calc(100vh - 180px)}
.kanban-wrap::-webkit-scrollbar{height:6px}

/* Columna */
.kb-col{flex:0 0 260px;display:flex;flex-direction:column;border-radius:var(--rl);overflow:hidden;background:rgba(255,255,255,.45);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);box-shadow:var(--sh)}
.kb-col-head{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.5)}
.kb-col-head .col-title{font-size:11.5px;font-weight:700;letter-spacing:.3px}
.kb-col-head .col-count{font-size:10px;font-weight:700;background:rgba(0,0,0,.08);padding:2px 7px;border-radius:10px;color:var(--txt2)}
.kb-col-head .col-total{font-size:10px;font-weight:600;color:var(--txt3)}
/* Colores de cabecera por estado */
.kb-col.col-nuevo .kb-col-head{background:linear-gradient(135deg,rgba(5,150,105,.12),rgba(16,185,129,.06));border-bottom-color:rgba(5,150,105,.2)}
.kb-col.col-nuevo .col-title{color:var(--grn)}
.kb-col.col-gestionado .kb-col-head{background:linear-gradient(135deg,rgba(79,70,229,.12),rgba(124,58,237,.06));border-bottom-color:rgba(79,70,229,.2)}
.kb-col.col-gestionado .col-title{color:var(--acc)}
.kb-col.col-potencial .kb-col-head{background:linear-gradient(135deg,rgba(217,119,6,.12),rgba(245,158,11,.06));border-bottom-color:rgba(217,119,6,.2)}
.kb-col.col-potencial .col-title{color:var(--amb)}
.kb-col.col-perdido .kb-col-head{background:linear-gradient(135deg,rgba(220,38,38,.1),rgba(239,68,68,.06));border-bottom-color:rgba(220,38,38,.15)}
.kb-col.col-perdido .col-title{color:var(--red)}

.kb-cards{padding:8px;display:flex;flex-direction:column;gap:8px;min-height:120px;flex:1;overflow-y:auto;max-height:calc(100vh - 230px)}
.kb-cards.drag-over{background:rgba(79,70,229,.06);border-radius:8px}

/* ── TARJETA KANBAN ── */
.kb-card {
  background:var(--glass);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.8);
  border-radius:11px;
  padding:12px;
  cursor:grab;
  transition:all .2s;
  box-shadow:var(--sh);
  position:relative;
  user-select:none;
}
.kb-card:hover{box-shadow:var(--shm);transform:translateY(-2px);border-color:rgba(79,70,229,.2)}
.kb-card.dragging{opacity:.5;cursor:grabbing;transform:rotate(2deg) scale(1.02)}
.kb-card.drag-placeholder{background:rgba(79,70,229,.06);border:2px dashed rgba(79,70,229,.3);box-shadow:none}

/* Franja de color izquierda */
.kb-card::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:4px}
.col-nuevo .kb-card::before{background:var(--grn)}
.col-gestionado .kb-card::before{background:var(--acc)}
.col-potencial .kb-card::before{background:var(--amb)}
.col-perdido .kb-card::before{background:var(--red)}

.kc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:7px;padding-left:8px}
.kc-name{font-size:12.5px;font-weight:700;color:var(--txt);line-height:1.3;flex:1;min-width:0}
.kc-empresa{font-size:10.5px;color:var(--txt3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kc-btns{display:flex;gap:2px;flex-shrink:0;margin-left:6px}
.kc-btn{width:22px;height:22px;border-radius:5px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;font-size:11px;background:transparent;color:var(--txt4)}
.kc-btn:hover{background:rgba(0,0,0,.06)}
.kc-btn.del:hover{background:rgba(220,38,38,.1);color:var(--red)}

.kc-body{padding-left:8px}
.kc-servicio{font-size:11px;color:var(--txt2);margin-bottom:6px;display:flex;align-items:center;gap:4px;font-weight:500}
.kc-valor{font-size:13px;font-weight:700;color:var(--grn);letter-spacing:-.3px}
.kc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.kc-tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:9.5px;font-weight:600;background:rgba(79,70,229,.08);color:var(--acc);border:1px solid rgba(79,70,229,.15)}
.kc-tag.lead{background:rgba(217,119,6,.08);color:var(--amb);border-color:rgba(217,119,6,.2)}
.kc-tag.bd{background:rgba(5,150,105,.08);color:var(--grn);border-color:rgba(5,150,105,.2)}
.kc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:7px;border-top:1px solid rgba(0,0,0,.05);padding-left:8px}
.kc-date{font-size:9.5px;color:var(--txt4);font-family:var(--mono)}
.kc-actions{display:flex;gap:4px}
.kc-action-btn{padding:3px 8px;border-radius:5px;border:1px solid rgba(79,70,229,.2);background:rgba(79,70,229,.06);color:var(--acc);font-size:9.5px;font-weight:600;cursor:pointer;font-family:var(--fn);transition:all .15s;white-space:nowrap}
.kc-action-btn:hover{background:rgba(79,70,229,.12)}
.kc-action-btn.cal{border-color:rgba(2,132,199,.2);background:rgba(2,132,199,.06);color:var(--sky)}
.kc-action-btn.cal:hover{background:rgba(2,132,199,.12)}

/* Botón agregar card */
.kb-add-btn{width:100%;padding:7px;border:1px dashed rgba(79,70,229,.25);border-radius:8px;background:transparent;color:var(--acc);font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--fn);margin:4px 0}
.kb-add-btn:hover{background:rgba(79,70,229,.06);border-color:rgba(79,70,229,.4)}

/* ── AGENDA ── */
.agenda-layout{display:grid;grid-template-columns:1fr 340px;gap:16px}
.gcal-preview-box{background:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.7);border-radius:10px;padding:13px;margin-top:12px;backdrop-filter:blur(8px)}
.gcp-title{font-size:9px;font-weight:700;color:var(--txt4);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.gcp-row{display:flex;gap:8px;margin-bottom:6px;align-items:flex-start}
.gcp-lbl{font-size:10px;font-weight:700;color:var(--txt4);min-width:70px;padding-top:1px}.gcp-val{font-size:11px;color:var(--txt);line-height:1.5;word-break:break-all}
.btn-gcal{width:100%;padding:11px;border:none;border-radius:var(--r);background:linear-gradient(135deg,#1a73e8,#1557b0);color:#fff;font-family:var(--fn);font-size:12.5px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px rgba(26,115,232,.3)}
.btn-gcal:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(26,115,232,.4)}.btn-gcal:disabled{opacity:.4;cursor:not-allowed;transform:none}.gcal-svg{width:17px;height:17px}
.att-list{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px;min-height:24px}
.att-chip{display:inline-flex;align-items:center;gap:4px;background:rgba(79,70,229,.1);border:1px solid rgba(79,70,229,.2);color:var(--acc);padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600}
.att-chip button{background:none;border:none;color:var(--acc);cursor:pointer;font-size:14px;line-height:1;padding:0 0 0 2px;font-weight:700}
.att-input-row{display:flex;gap:6px;margin-top:6px}.att-input-row input{flex:1}
.btn-att{padding:7px 12px;border:none;border-radius:var(--r);background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;font-family:var(--fn);font-size:11.5px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;box-shadow:0 2px 8px rgba(79,70,229,.25)}
.meet-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:rgba(255,255,255,.5);border:1px solid var(--b);border-radius:8px}
.meet-row input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--acc)}

/* ── MEETINGS ── */
.mlist{display:flex;flex-direction:column;gap:9px}
.mi{background:var(--glass);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.7);border-radius:var(--rl);padding:13px 15px;display:flex;align-items:flex-start;gap:11px;box-shadow:var(--sh)}
.mdot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0;box-shadow:0 0 8px currentColor}
.mdot.presencial{color:var(--grn);background:var(--grn)}.mdot.virtual{color:var(--acc);background:var(--acc)}.mdot.llamada{color:var(--amb);background:var(--amb)}.mdot.seguimiento{color:var(--acc2);background:var(--acc2)}
.mi-info{flex:1;min-width:0}.mi-name{font-size:12.5px;font-weight:700;color:var(--txt)}.mi-type{font-size:10.5px;color:var(--txt4);margin-bottom:2px}
.mi-fecha{font-size:10.5px;font-weight:600;color:var(--acc);font-family:var(--mono)}.mi-notes{font-size:11px;color:var(--txt3);margin-top:3px;line-height:1.5}
.btn-mi{padding:5px 10px;border-radius:6px;border:1px solid rgba(79,70,229,.2);background:rgba(79,70,229,.07);color:var(--acc);font-size:10px;font-weight:600;cursor:pointer;font-family:var(--fn);transition:all .15s;white-space:nowrap;flex-shrink:0}
.btn-mi:hover{background:rgba(79,70,229,.14)}

/* ── VENTAS ── */
.vgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;max-height:60vh;overflow-y:auto}
.vc{background:var(--glass);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.7);border-radius:var(--rl);padding:14px;box-shadow:var(--sh)}
.vc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:9px}
.vc-name{font-size:13px;font-weight:700;color:var(--txt)}.vc-monto{font-size:18px;font-weight:700;color:var(--grn);letter-spacing:-.5px}.vc-comision{font-size:10px;color:var(--txt3);margin-top:1px}
.vc-rows{display:flex;flex-direction:column;gap:5px}.vc-row{display:flex;justify-content:space-between;font-size:11px}.vc-row .vl{color:var(--txt3)}.vc-row .vv{color:var(--txt);font-weight:500;text-align:right}
.comision-display{background:rgba(5,150,105,.08);border:1px solid rgba(5,150,105,.2);border-radius:9px;padding:11px;margin-top:8px;display:flex;align-items:center;justify-content:space-between}
.cd-label{font-size:11px;color:var(--grn);font-weight:600}.cd-value{font-size:20px;font-weight:700;color:var(--grn);font-family:var(--mono)}

/* ── MODAL ── */
.modal-wrap{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:500;padding:20px;overflow-y:auto}
.modal-wrap.on{display:flex}
.modal{background:var(--glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.8);border-radius:18px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:var(--shx);animation:mi .22s ease-out}
@keyframes mi{from{opacity:0;transform:scale(.95) translateY(18px)}to{opacity:1;transform:scale(1) translateY(0)}}
.mh{padding:15px 20px;border-bottom:1px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:space-between}
.mh-title{font-size:13.5px;font-weight:700;color:var(--txt)}
.mcl{width:28px;height:28px;border-radius:7px;border:1px solid var(--b);background:rgba(255,255,255,.5);color:var(--txt3);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.mcl:hover{background:rgba(220,38,38,.1);border-color:rgba(220,38,38,.2);color:var(--red)}
.mb{padding:18px}
.detail-block{background:rgba(255,255,255,.5);border-radius:10px;padding:14px;margin-bottom:15px;border:1px solid rgba(255,255,255,.7)}
.db-name{font-size:15px;font-weight:700;color:var(--txt);margin-bottom:10px}
.dgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.di .dl{font-size:9.5px;font-weight:700;color:var(--txt4);letter-spacing:.3px;margin-bottom:2px;text-transform:uppercase}.di .dv{font-size:12px;color:var(--txt2);font-weight:500}
.gsec-title{font-size:12px;font-weight:700;color:var(--txt);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.gform{background:rgba(255,255,255,.5);border-radius:10px;padding:13px;margin-bottom:12px;border:1px solid rgba(255,255,255,.7)}
.gform label{font-size:10px;font-weight:700;color:var(--txt4);display:block;margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}
.btn-ag{padding:8px 13px;border:none;border-radius:8px;background:linear-gradient(135deg,var(--grn),#047857);color:#fff;font-family:var(--fn);font-size:12px;font-weight:600;cursor:pointer;margin-top:7px;transition:all .2s;box-shadow:0 2px 8px rgba(5,150,105,.25)}
.btn-ag:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(5,150,105,.35)}
.glist{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}
.gi{background:rgba(255,255,255,.6);border-radius:8px;padding:10px 12px;border-left:3px solid var(--acc);box-shadow:var(--sh)}
.gi-date{font-size:9.5px;color:var(--txt4);font-family:var(--mono);margin-bottom:3px}.gi-text{font-size:11.5px;color:var(--txt2);line-height:1.5}
.mf{padding:13px 20px;border-top:1px solid rgba(255,255,255,.5);display:flex;gap:9px;justify-content:flex-end}
.btn-mc{padding:8px 15px;border:1px solid var(--b);border-radius:8px;background:rgba(255,255,255,.5);color:var(--txt3);font-family:var(--fn);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.btn-mc:hover{background:rgba(255,255,255,.9)}.btn-ms{padding:8px 18px;border:none;border-radius:8px;background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;font-family:var(--fn);font-size:12px;font-weight:600;cursor:pointer;box-shadow:0 2px 10px rgba(79,70,229,.3)}
.btn-ms:hover{box-shadow:0 4px 16px rgba(79,70,229,.4);transform:translateY(-1px)}

/* BADGE */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700}
.badge.nuevo{background:rgba(5,150,105,.1);color:var(--grn);border:1px solid rgba(5,150,105,.2)}.badge.gestionado{background:rgba(79,70,229,.1);color:var(--acc);border:1px solid rgba(79,70,229,.2)}
.badge.potencial{background:rgba(217,119,6,.1);color:var(--amb);border:1px solid rgba(217,119,6,.2)}.badge.perdido{background:rgba(220,38,38,.1);color:var(--red);border:1px solid rgba(220,38,38,.2)}
.badge.lead{background:rgba(217,119,6,.1);color:var(--amb);border:1px solid rgba(217,119,6,.2)}.badge.bd{background:rgba(5,150,105,.1);color:var(--grn);border:1px solid rgba(5,150,105,.2)}

/* TOAST */
.toast{position:fixed;bottom:22px;right:22px;background:linear-gradient(135deg,var(--txt),#1e293b);color:#fff;padding:10px 16px;border-radius:10px;font-size:12px;font-weight:600;display:none;z-index:999;box-shadow:0 8px 24px rgba(0,0,0,.25);animation:fiu .3s ease;backdrop-filter:blur(8px)}
@keyframes fiu{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.empty{text-align:center;padding:50px 20px;color:var(--txt4)}.empty .eic{font-size:32px;margin-bottom:10px;opacity:.35}.empty p{font-size:12.5px;font-weight:500}

/* ══ RESPONSIVE — MOBILE FIRST ══ */

/* Tablet */
@media(max-width:1100px){
  .agenda-layout{grid-template-columns:1fr}
  .sgrid{grid-template-columns:repeat(4,1fr)}
}

/* Mobile */
@media(max-width:768px){
  /* Sidebar */
  .sidebar{transform:translateX(-100%);width:82vw;max-width:300px}
  .sidebar.open{transform:translateX(0);box-shadow:var(--shx)}
  .sb-back.show{display:block}
  .ham{display:block}
  .main{margin-left:0}

  /* Topbar */
  .topbar{padding:10px 14px}
  .ptitle{font-size:13px}
  .tbar-actions .btn-sm:not(.acc){display:none} /* solo muestra + Nuevo en mobile */

  /* Content */
  .content{padding:12px}

  /* Stats - 2 columnas compactas */
  .sgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}
  .scard{padding:12px;gap:9px}
  .sic{width:34px;height:34px;font-size:15px}
  .snum{font-size:22px}
  .slbl{font-size:10px}

  /* Forms - 1 columna */
  .fgrid{grid-template-columns:1fr}
  .fgrid .s2{grid-column:span 1}
  .tipo-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .tl{padding:9px 6px;font-size:10px}
  .tl .ti{font-size:16px}

  /* Panel */
  .panel{border-radius:10px}
  .pb{padding:12px}
  .ph{padding:11px 14px}

  /* Kanban — scroll horizontal nativo */
  .kanban-wrap{gap:10px;padding-bottom:16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .kb-col{flex:0 0 78vw;max-width:280px;scroll-snap-align:start}
  .kb-cards{max-height:55vh}
  .kb-card{padding:11px}
  .kc-name{font-size:12px}
  .kc-valor{font-size:12px}

  /* Agenda */
  .agenda-layout{grid-template-columns:1fr;gap:12px}

  /* Modal */
  .modal{border-radius:14px 14px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:92vh;animation:slideUp .25s ease-out}
  @keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
  .modal-wrap{align-items:flex-end;padding:0}
  .dgrid{grid-template-columns:1fr}
  .mb{padding:14px}
  .mf{padding:12px 14px}

  /* Meetings */
  .mi{padding:11px 12px}

  /* Ventas grid */
  .vgrid{grid-template-columns:1fr;max-height:none}

  /* Botones */
  .btn-full{font-size:12.5px;padding:10px}
  .brow{flex-direction:column;gap:7px}
  .btn-ghost{width:100%;text-align:center}

  /* Attendees */
  .att-input-row{flex-direction:column}
  .btn-att{width:100%}

  /* Toast - abajo centrado */
  .toast{left:50%;right:auto;transform:translateX(-50%);bottom:16px;white-space:nowrap}
}

/* Mobile XS */
@media(max-width:375px){
  .sgrid{grid-template-columns:repeat(2,1fr);gap:6px}
  .kb-col{flex:0 0 88vw}
  .content{padding:10px}
  .topbar{padding:9px 12px}
}

/* Touch devices — quitar hover effects que no aplican */
@media(hover:none){
  .scard:hover{transform:none;box-shadow:var(--shm)}
  .btn-full:hover{transform:none}
  .kb-card:hover{transform:none;box-shadow:var(--sh)}
}

.tab-pane{display:none}.tab-pane.on{display:block}
