/* ===== Evolv DNA CRM — modern dark theme ===== */
:root{
  --bg:#0a0d14; --bg2:#0e121c; --panel:#141a27; --panel2:#1b2333; --line:#283145;
  --txt:#eaeef7; --muted:#8b95ab; --faint:#5b6478;
  --accent:#10d9b6; --accent2:#6d5efc; --good:#2ecc71; --warn:#f7b733; --bad:#ff5470;
  --fb:#1877f2; --ig:#e1306c; --li:#0a66c2; --web:#10d9b6;
  --grad:linear-gradient(135deg,#10d9b6,#6d5efc);
  --grad-soft:linear-gradient(135deg,rgba(16,217,182,.16),rgba(109,94,252,.16));
  --shadow:0 8px 30px rgba(0,0,0,.35);
  --r:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font:15px/1.55 ui-sans-serif,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:radial-gradient(1200px 600px at 80% -10%,rgba(109,94,252,.10),transparent 60%),
             radial-gradient(900px 500px at -10% 10%,rgba(16,217,182,.08),transparent 55%),var(--bg);
  color:var(--txt);min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:none;opacity:.9}

/* header */
header{display:flex;align-items:center;gap:28px;padding:0 28px;position:sticky;top:0;z-index:20;
  background:rgba(12,16,24,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{font-weight:800;font-size:18px;letter-spacing:.2px;padding:16px 0;display:flex;align-items:center;gap:8px}
.brand .logo{font-size:22px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-sub{font-weight:600;color:var(--muted);font-size:13px;letter-spacing:2px;margin-left:2px}
nav{display:flex;gap:2px;flex-wrap:wrap}
nav a{padding:18px 16px;color:var(--muted);font-weight:600;font-size:14px;border-bottom:2px solid transparent;transition:.15s}
nav a:hover{color:var(--txt)}
nav a.on{color:var(--txt);border-bottom-color:var(--accent)}
.notif-ctl{margin-left:auto;display:flex;align-items:center;gap:8px}
.notif-ctl .pausegrp{display:flex;gap:6px}
.notif-ctl .btn.sm{padding:6px 10px;font-size:13px;border-radius:8px}
.notif-ctl .dnd{color:var(--warn);font-weight:700;font-size:14px}
.notif-ctl .bell{opacity:.7}
.who{color:var(--muted);font-size:13px;font-weight:600}
.logout{margin-left:12px;color:var(--muted);font-size:20px;text-decoration:none}
.logout:hover{color:var(--bad)}
.loginbox{max-width:360px;margin:12vh auto;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--r);padding:32px;box-shadow:var(--shadow);text-align:center}
.loginbox .brand{justify-content:center;font-size:20px;margin-bottom:6px}
.loginbox h2{color:var(--txt);text-transform:none;letter-spacing:0;font-size:18px;margin:6px 0 18px}
.loginbox form{display:flex;flex-direction:column;gap:12px}
.loginbox input{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:10px;padding:12px}
.loginbox input:focus{outline:none;border-color:var(--accent)}
.loginbox .dialbtn{width:100%;justify-content:center}
.loginerr{background:rgba(255,84,112,.14);border:1px solid var(--bad);color:#ffb3c1;border-radius:8px;padding:10px;margin-bottom:6px;font-size:14px}
main{max-width:1140px;margin:0 auto;padding:28px}

.page-head{margin-bottom:20px}
h1{margin:0;font-size:28px;font-weight:800;letter-spacing:-.5px}
.sub{color:var(--muted);margin:4px 0 0}
h2{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:28px 0 12px;font-weight:700}
h3{font-size:14px;color:var(--muted);margin:0 0 10px}
.muted{color:var(--muted)}

/* KPI hero cards */
.cards{display:grid;gap:14px}
.cards.hero{grid-template-columns:repeat(5,1fr)}
.card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);
  border-radius:var(--r);padding:20px;color:var(--txt);box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform .15s,border-color .15s}
a.card:hover{transform:translateY(-3px);border-color:var(--accent)}
.kpi .kpi-ico{font-size:20px;opacity:.9}
.kpi .n{font-size:34px;font-weight:800;letter-spacing:-1px;margin-top:6px;font-variant-numeric:tabular-nums}
.kpi .l{color:var(--muted);font-size:13px;margin-top:2px;font-weight:600}
.kpi.accent{background:var(--grad-soft);border-color:rgba(16,217,182,.45)}
.kpi.accent .n{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.kpi.warn .n{color:var(--warn)} .kpi.good .n{color:var(--good)}

/* channel tiles */
.channels{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}
.chan{display:flex;flex-direction:column;align-items:center;gap:2px;padding:16px 8px;border-radius:14px;
  background:var(--panel);border:1px solid var(--line);color:var(--txt);transition:.15s}
a.chan:hover{transform:translateY(-3px)}
.chan .ci{font-size:20px;height:26px;display:flex;align-items:center;justify-content:center;font-weight:800}
.chan b{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums}
.chan span:last-child{font-size:12px;color:var(--muted)}
.chan.call{border-color:rgba(46,204,113,.4)} .chan.call .ci{color:var(--good)}
.chan.mail{border-color:rgba(247,183,51,.4)} .chan.mail .ci{color:var(--warn)}
.chan.fb{border-color:rgba(24,119,242,.45)} .chan.fb .ci{color:var(--fb)}
.chan.ig{border-color:rgba(225,48,108,.45)} .chan.ig .ci{color:var(--ig)}
.chan.li .ci{color:var(--li);background:#fff;border-radius:4px;width:24px;height:22px;font-size:13px;font-style:italic}
.chan.li{border-color:rgba(10,102,194,.5)}
.chan.web{border-color:rgba(16,217,182,.4)} .chan.web .ci{color:var(--web)}
.chan.dead{opacity:.6}

/* panels */
.panel{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--shadow)}
.panel h2{margin-top:0}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.panel+.panel,.row2+.panel{margin-top:16px}
.soon .badge{font-size:11px;background:var(--grad-soft);border:1px solid var(--accent);color:var(--accent);
  padding:2px 8px;border-radius:20px;letter-spacing:0;text-transform:none;margin-left:6px}

table.tight{width:100%;border-collapse:collapse}
table.tight td,table.tight th{padding:8px;border-bottom:1px solid var(--line);text-align:left}
table.tight tr:last-child td{border-bottom:0}
.num{text-align:right;font-variant-numeric:tabular-nums}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{background:var(--panel2);border:1px solid var(--line);border-radius:30px;padding:7px 15px;color:var(--txt);font-size:14px;transition:.15s}
a.chip:hover{border-color:var(--accent);transform:translateY(-2px)}
.chip b{color:var(--accent);margin-left:4px}

/* pills */
.pill{display:inline-block;padding:3px 10px;border-radius:30px;font-size:12px;font-weight:600;background:var(--panel2);border:1px solid var(--line);color:var(--muted)}
.pill.cat{color:var(--accent);border-color:rgba(16,217,182,.5)}
.pill.new{color:#cbd5e1}.pill.no_answer{color:var(--warn);border-color:rgba(247,183,51,.4)}
.pill.callback{color:var(--accent);border-color:rgba(16,217,182,.5)}
.pill.interested{color:var(--good);border-color:rgba(46,204,113,.4)}
.pill.converted{color:#04210f;background:var(--good);border-color:var(--good)}
.pill.not_interested,.pill.do_not_call{color:var(--bad);border-color:rgba(255,84,112,.4)}
.pill.emailed{color:#c4b5fd;border-color:rgba(167,139,250,.5)}
.d-emailed{background:rgba(167,139,250,.16);border-color:rgba(167,139,250,.5);color:#d6c8ff}
.pill.spoke_dm{color:#fbbf24;border-color:rgba(245,158,11,.5)}
.d-spoke_dm{background:rgba(245,158,11,.16);border-color:rgba(245,158,11,.5);color:#fcd34d}
/* warmth meter 1-10, cold -> hot */
.warmth{display:inline-block;font-weight:700;font-size:.78rem;padding:1px 8px;border-radius:10px;border:1px solid;white-space:nowrap}
.w0{color:#64748b;border-color:#334155}
.w1,.w2,.w3{color:#7dd3fc;border-color:rgba(56,189,248,.5)}
.w4,.w5{color:#5eead4;border-color:rgba(45,212,191,.5)}
.w6,.w7{color:#fbbf24;border-color:rgba(245,158,11,.6)}
.w8,.w9,.w10{color:#fb7185;border-color:rgba(244,63,94,.6);background:rgba(244,63,94,.1)}
.stateform{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin:8px 0;font-size:.85rem;color:var(--muted)}
.stateform select{background:#0f1720;color:#e5edf5;border:1px solid #334155;border-radius:6px;padding:3px 6px}
.cold-state{font-weight:600}
.cold-state.protected{color:#5eead4}
.cold-state.coldok{color:#94a3b8}
/* clickable warmth heat-bar */
.warmth-meter{display:flex;align-items:center;gap:3px}
.wm-label{margin-right:8px;color:#cbd5e1;font-weight:600}
.wm-seg{width:30px;height:30px;border:1px solid #334155;background:#0f1720;color:#64748b;
  border-radius:6px;font-weight:700;font-size:.82rem;cursor:pointer;transition:transform .06s}
.wm-seg:hover{outline:2px solid #64748b;transform:translateY(-1px)}
.wm-seg.on.wseg1,.wm-seg.on.wseg2,.wm-seg.on.wseg3{background:#0ea5e9;color:#04212e;border-color:#0ea5e9}
.wm-seg.on.wseg4,.wm-seg.on.wseg5{background:#2dd4bf;color:#04231f;border-color:#2dd4bf}
.wm-seg.on.wseg6,.wm-seg.on.wseg7{background:#f59e0b;color:#2a1a00;border-color:#f59e0b}
.wm-seg.on.wseg8,.wm-seg.on.wseg9,.wm-seg.on.wseg10{background:#f43f5e;color:#2a0410;border-color:#f43f5e}
.wm-current{margin-left:10px;font-weight:700;color:#e5edf5}
.pill.engaged{color:#34d399;border-color:rgba(52,211,153,.5);background:rgba(52,211,153,.08)}
.pill.wrong_number{color:var(--muted)}

/* forms / buttons */
.filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.filters select,.filters input,.filters button,.btn{background:var(--panel2);color:var(--txt);
  border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit}
.filters select:focus,.filters input:focus{outline:none;border-color:var(--accent)}
.filters .cbk{color:var(--muted);font-size:14px;display:flex;align-items:center;gap:6px}
.btn,.filters button{cursor:pointer;font-weight:600;transition:.15s}
.btn:hover,.filters button:hover{border-color:var(--accent);color:var(--txt)}
.btn{background:var(--grad-soft);border-color:rgba(16,217,182,.4);color:var(--accent)}

/* call queue */
.qhead{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.callgrid{display:grid;grid-template-columns:1fr 290px;gap:18px}
.callcard{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.cc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.cc-top h2{margin:0;font-size:24px;color:var(--txt);text-transform:none;letter-spacing:-.5px;font-weight:800}
.meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-top:10px}
.lead-link{font-size:13px;white-space:nowrap;color:var(--muted)}
.dialrow{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin:20px 0 4px}
.phone{font-size:36px;font-weight:800;color:var(--good);letter-spacing:-1px}
.addr{color:var(--muted)}
.links{display:flex;gap:14px;margin:12px 0 4px;flex-wrap:wrap}
.callform{margin-top:20px;border-top:1px solid var(--line);padding-top:18px}
.callform textarea,.noteform textarea{width:100%;background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:10px;padding:11px;resize:vertical;font-family:inherit}
.callform textarea:focus,.noteform textarea:focus{outline:none;border-color:var(--accent)}
.contactfields{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.contactfields input{flex:1;min-width:120px;background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:10px;padding:9px 11px}
.contactfields input:focus{outline:none;border-color:var(--accent)}
.savebtn{background:var(--grad);color:#04210f;border:0;border-radius:10px;padding:9px 16px;cursor:pointer;font-weight:700}
.cb-row{margin:10px 0;color:var(--muted);font-size:14px}
.cb-row input{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:7px}
.disp{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px}
.disp button{border:1px solid var(--line);border-radius:11px;padding:11px 16px;font-weight:700;font-size:14px;cursor:pointer;background:var(--panel2);color:var(--txt);transition:.15s}
.disp button:hover{transform:translateY(-2px);border-color:var(--txt)}
.d-interested,.d-converted{background:rgba(46,204,113,.16);border-color:rgba(46,204,113,.5);color:#9af3c0}
.d-not_interested,.d-do_not_call{background:rgba(255,84,112,.14);border-color:rgba(255,84,112,.5);color:#ffb3c1}
.d-callback{background:rgba(16,217,182,.16);border-color:rgba(16,217,182,.5);color:#8ff0df}
.dialbtn{background:var(--grad);color:#04210f;border:0;border-radius:12px;padding:13px 26px;font-size:17px;font-weight:800;cursor:pointer;box-shadow:0 6px 18px rgba(16,217,182,.3);transition:.15s}
.dialbtn:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(16,217,182,.45)}
.dialopts{display:flex;gap:10px;flex-wrap:wrap}
.dialbtn.pc{background:linear-gradient(135deg,#6d5efc,#8b7bff);color:#fff;box-shadow:0 6px 18px rgba(109,94,252,.3)}
.dialbtn.pc:hover{box-shadow:0 10px 26px rgba(109,94,252,.45)}
.upnext{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px;height:fit-content}
.upnext ol{margin:0;padding-left:18px}.upnext li{margin-bottom:10px}
.empty{background:var(--panel);border:1px dashed var(--line);border-radius:var(--r);padding:48px;text-align:center;color:var(--muted)}

/* lead detail */
.back{display:inline-block;margin-bottom:10px;color:var(--muted)}
.chainbanner{background:var(--grad-soft);border:1px solid var(--accent);border-radius:12px;padding:11px 15px;margin-bottom:14px}
.hqbox{display:flex;gap:14px;align-items:center;flex-wrap:wrap;background:rgba(46,204,113,.10);border:1px solid rgba(46,204,113,.5);border-radius:12px;padding:12px 16px;margin:14px 0}
.hqlabel{font-weight:800;color:var(--good)}.hqphone{font-size:20px;font-weight:800}
.branches{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:14px;margin:14px 0}
.branches h3{color:var(--accent)}
.leadgrid{display:grid;grid-template-columns:1fr 360px;gap:18px}
table.rec{width:100%;border-collapse:collapse;margin:12px 0}
table.rec th{text-align:left;color:var(--muted);font-weight:500;width:90px;padding:7px 8px 7px 0;vertical-align:top}
table.rec td{padding:7px 0;border-bottom:1px solid var(--line)}
.cb{color:var(--accent)}
.history{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--shadow)}
.noteform{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.noteform button{align-self:flex-start;background:var(--grad);color:#04210f;border:0;border-radius:10px;padding:9px 16px;cursor:pointer;font-weight:700}
.timeline{list-style:none;margin:0;padding:0}
.timeline li{padding:11px 0;border-bottom:1px solid var(--line)}
.timeline .when{font-size:12px;color:var(--muted)}
.timeline .note{margin-top:4px;white-space:pre-wrap}
.timeline .t-call{border-left:3px solid var(--accent);padding-left:10px}

/* grids */
table.grid{width:100%;border-collapse:collapse;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
table.grid th,table.grid td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left}
table.grid th{color:var(--muted);font-weight:600;font-size:13px;background:var(--panel2)}
table.grid tr:last-child td{border-bottom:0}
table.grid tr[onclick]{cursor:pointer;transition:.1s}
table.grid tr[onclick]:hover td{background:var(--panel2)}
table.grid tr.overdue td{background:rgba(247,183,51,.12)}
.mono{font-variant-numeric:tabular-nums;color:var(--muted)}
.sendpacks{display:flex;gap:8px;flex-wrap:wrap}
.btn.whole{background:linear-gradient(135deg,rgba(109,94,252,.18),rgba(109,94,252,.10));border-color:rgba(109,94,252,.5);color:#c5bcff}
.linkbtn{background:none;border:0;color:var(--bad);cursor:pointer;font:inherit;padding:0;text-decoration:underline}
.linkbtn:hover{opacity:.8}

/* dial page */
.dialbox{max-width:540px;margin:48px auto;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--r);padding:36px;text-align:center;box-shadow:var(--shadow)}
.dialbox .phone{font-size:42px}.dialbox .good{color:var(--good)}.dialbox .bad{color:var(--bad)}
.dialnav{display:flex;gap:10px;justify-content:center;margin-top:20px}

@media(max-width:900px){
  .cards.hero{grid-template-columns:repeat(2,1fr)}
  .channels{grid-template-columns:repeat(3,1fr)}
  .callgrid,.leadgrid,.row2{grid-template-columns:1fr}
  header{gap:12px;padding:0 14px}main{padding:16px}
}
