/* ============================================================
   AB7 LeadForge 360 — Portal Stylesheet
   Palette: AB7 Blue #0074D9, Green #00D370, Sky #8DC1EE
   ============================================================ */
:root{
  --ab7-blue:#0074D9; --ab7-blue-deep:#005FB1; --ab7-blue-dark:#003F7A;
  --ab7-sky:#8DC1EE; --ab7-sky-soft:#DCECFA; --ab7-sky-ghost:#F0F7FD;
  --ab7-blue-glow:rgba(0,116,217,.18);
  --ab7-green:#00D370; --ab7-green-deep:#00B85F; --ab7-green-glow:rgba(0,211,112,.22);
  --ab7-teal:#14D8A6;
  --ab7-gradient:linear-gradient(90deg,#3B82F6 0%,#14D8A6 55%,#00D370 100%);
  --ink-950:#050B17; --ink-900:#0B1324; --ink-800:#121C31; --ink-700:#1E2A44;
  --ink-600:#334155; --ink-500:#475569; --ink-400:#64748B; --ink-300:#94A3B8;
  --ink-200:#CBD5E1; --ink-150:#E2E8F0; --ink-100:#F1F5F9; --ink-50:#F8FAFC;
  --white:#FFFFFF;
  --success:#059669; --danger:#DC2626; --warn:#F59E0B;
  --radius-sm:6px; --radius-md:10px; --radius-lg:18px; --radius-xl:28px;
  --shadow-sm:0 1px 2px rgba(11,19,36,.06),0 1px 3px rgba(11,19,36,.04);
  --shadow-md:0 8px 24px -8px rgba(11,19,36,.14),0 2px 6px rgba(11,19,36,.05);
  --shadow-lg:0 24px 48px -16px rgba(11,19,36,.24),0 6px 18px rgba(11,19,36,.08);
  --shadow-blue:0 20px 40px -18px var(--ab7-blue-glow);
  --font-sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font-sans);color:var(--ink-900);background:var(--ink-50);
  -webkit-font-smoothing:antialiased;line-height:1.55;overflow:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font:inherit;color:inherit}
/* Prominent always-visible scrollbars */
::-webkit-scrollbar{width:16px;height:16px}
::-webkit-scrollbar-track{background:var(--ink-100);border-radius:12px;border:1px solid var(--ink-150)}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--ab7-sky) 0%,var(--ab7-blue) 100%);border-radius:12px;border:3px solid var(--ink-100);min-height:50px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.25)}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--ab7-blue),var(--ab7-blue-deep))}
::-webkit-scrollbar-thumb:active{background:var(--ab7-blue-deep)}
::-webkit-scrollbar-corner{background:var(--ink-100)}
*{scrollbar-width:auto;scrollbar-color:var(--ab7-blue) var(--ink-100)}
/* Sidebar uses dark scrollbar to match its theme */
.sidebar::-webkit-scrollbar-track{background:#0A1430;border-color:rgba(141,193,238,.1)}
.sidebar::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--ab7-blue),var(--ab7-blue-deep));border-color:#0A1430}
.sidebar{scrollbar-color:var(--ab7-blue) #0A1430}

/* Floating scroll up / down controls — always shown when content is scrollable */
.scroll-ctrl{
  position:fixed;right:22px;bottom:28px;z-index:90;
  display:flex;flex-direction:column;gap:8px;
  opacity:0;transform:translateY(6px);transition:all .2s;pointer-events:none;
}
.scroll-ctrl.show{opacity:1;transform:translateY(0);pointer-events:auto}
.scroll-ctrl button{
  width:44px;height:44px;border-radius:50%;background:#fff;border:1px solid var(--ink-200);
  box-shadow:var(--shadow-md);color:var(--ab7-blue);font-size:18px;font-weight:800;
  display:grid;place-items:center;transition:all .15s;
}
.scroll-ctrl button:hover:not([disabled]){background:var(--ab7-blue);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-lg);border-color:var(--ab7-blue)}
.scroll-ctrl button[disabled]{opacity:.4;pointer-events:none;background:#fff;color:var(--ink-300);cursor:not-allowed}
.scroll-ctrl .sc-hint{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-400);text-align:center;background:#fff;padding:3px 8px;border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--ink-200)}

/* ============ LOGIN ============ */
#login-screen{
  position:fixed;inset:0;z-index:200;
  background:radial-gradient(1100px 520px at 82% -10%, rgba(0,116,217,.35), transparent 60%),
             radial-gradient(700px 400px at 0% 100%, rgba(141,193,238,.12), transparent 60%),
             linear-gradient(180deg,#050B17 0%,#0A1430 60%,#0B1730 100%);
  display:grid;place-items:center;color:#fff;
}
#login-screen::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(141,193,238,.05) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(141,193,238,.05) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse at 40% 40%,#000 40%,transparent 75%);
  pointer-events:none;
}
.login-card{
  position:relative;z-index:1;width:min(420px,92vw);
  background:rgba(10,18,36,.7);backdrop-filter:blur(18px);
  border:1px solid rgba(141,193,238,.2);border-radius:var(--radius-xl);
  padding:40px 36px;box-shadow:var(--shadow-lg);
}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.login-brand img{width:44px;height:44px;object-fit:contain;filter:drop-shadow(0 4px 16px var(--ab7-blue-glow))}
.login-brand .t{font-weight:800;font-size:17px;letter-spacing:-.02em}
.login-brand .s{font-size:10.5px;color:var(--ab7-sky);font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-top:2px}
#login-screen h1{font-size:28px;font-weight:800;letter-spacing:-.02em;margin-bottom:8px}
#login-screen h1 em{font-style:normal;background:var(--ab7-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
#login-screen .lede{color:#94A3B8;font-size:14px;margin-bottom:28px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:600;color:#CBD5E1;letter-spacing:.04em;margin-bottom:6px}
.field input{
  width:100%;padding:12px 14px;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid rgba(141,193,238,.18);
  color:#fff;font-size:14px;transition:all .15s;
}
.field input:focus{outline:none;border-color:var(--ab7-blue);box-shadow:0 0 0 3px var(--ab7-blue-glow)}
.login-btn{
  width:100%;margin-top:8px;padding:12px;border-radius:10px;font-weight:700;font-size:14px;
  background:var(--ab7-green);color:var(--ink-900);transition:all .15s;
}
.login-btn:hover{background:var(--ab7-green-deep);transform:translateY(-1px);box-shadow:0 12px 24px -8px var(--ab7-green-glow)}
.login-foot{margin-top:22px;padding-top:18px;border-top:1px solid rgba(141,193,238,.1);font-size:12px;color:#64748B;display:flex;justify-content:space-between;gap:8px}
.login-foot a{color:var(--ab7-sky)}
.login-sso{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.login-sso button{padding:10px;border-radius:8px;background:rgba(255,255,255,.04);border:1px solid rgba(141,193,238,.14);color:#CBD5E1;font-size:12.5px;font-weight:600;transition:all .15s}
.login-sso button:hover{background:rgba(255,255,255,.08);border-color:var(--ab7-sky)}

/* ============ APP SHELL ============ */
.hidden{display:none!important}
.app{display:grid;grid-template-columns:260px 1fr;height:100vh;overflow:hidden}

.sidebar{
  background:linear-gradient(180deg,#050B17 0%,#0A1430 100%);
  color:var(--ink-200);padding:20px 14px 20px;overflow-y:auto;
  border-right:1px solid rgba(255,255,255,.06);
}
.sb-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:14px}
.sb-brand img{width:36px;height:36px;object-fit:contain;filter:drop-shadow(0 4px 12px var(--ab7-blue-glow))}
.sb-brand .t{color:#fff;font-weight:800;font-size:14px;letter-spacing:-.02em;line-height:1.1}
.sb-brand .s{font-size:9.5px;color:var(--ab7-sky);font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-top:2px}

.sb-section{margin-top:12px}
.sb-title{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-400);opacity:.7;margin:8px 10px 4px}
.sb-link{
  display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:8px;
  color:var(--ink-200);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;
  position:relative;
}
.sb-link:hover{background:rgba(0,116,217,.12);color:#fff}
.sb-link.active{background:rgba(0,116,217,.22);color:#fff;box-shadow:inset 2px 0 0 var(--ab7-green)}
.sb-link svg{width:16px;height:16px;flex:none;opacity:.85}
.sb-link .badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--ab7-green);color:var(--ink-900);padding:2px 7px;border-radius:999px}
.sb-foot{margin-top:24px;padding-top:14px;border-top:1px solid rgba(255,255,255,.06);font-size:11px;color:var(--ink-400);padding-left:10px;padding-right:10px;line-height:1.55}

.main{display:flex;flex-direction:column;min-width:0;min-height:0;height:100vh;background:var(--ink-50);overflow:hidden}

.topbar{
  display:flex;align-items:center;gap:14px;padding:10px 22px;
  background:#fff;border-bottom:1px solid var(--ink-150);
  min-height:58px;flex:none;
}
.tb-search{
  flex:1;max-width:480px;position:relative;
}
.tb-search input{
  width:100%;padding:9px 14px 9px 38px;border-radius:10px;background:var(--ink-50);
  border:1px solid var(--ink-150);font-size:13.5px;transition:all .15s;
}
.tb-search input:focus{outline:none;background:#fff;border-color:var(--ab7-blue);box-shadow:0 0 0 3px var(--ab7-blue-glow)}
.tb-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--ink-400)}
.tb-search kbd{
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  font:600 10.5px var(--font-mono);padding:2px 6px;border-radius:4px;
  background:#fff;border:1px solid var(--ink-200);color:var(--ink-500);
}
.tb-spacer{flex:1}
.tb-btn{
  padding:8px 10px;border-radius:8px;color:var(--ink-600);position:relative;transition:all .15s;
}
.tb-btn:hover{background:var(--ink-100);color:var(--ink-900)}
.tb-btn svg{width:18px;height:18px}
.tb-btn .dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--ab7-green);border-radius:50%;border:2px solid #fff}
.tb-ai{
  display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:10px;
  background:var(--ab7-gradient);color:#fff;font-weight:700;font-size:12.5px;letter-spacing:.02em;
  transition:all .15s;box-shadow:0 6px 16px -6px rgba(59,130,246,.5);
}
.tb-ai:hover{transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(59,130,246,.6)}
.tb-ai svg{width:14px;height:14px}
.tb-user{
  display:inline-flex;align-items:center;gap:10px;padding:4px 12px 4px 4px;border-radius:999px;
  background:var(--ink-50);border:1px solid var(--ink-150);cursor:pointer;transition:all .15s;
}
.tb-user:hover{background:var(--ink-100)}
.tb-user .avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--ab7-blue),var(--ab7-blue-deep));color:#fff;display:grid;place-items:center;font-weight:800;font-size:12px}
.tb-user .nm{font-size:12.5px;font-weight:600}
.tb-user .rl{font-size:10.5px;color:var(--ink-400)}

.content{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;padding:24px 28px 110px;scroll-behavior:smooth}
.view{max-width:1400px;margin:0 auto}
.view.hidden{display:none}

/* ============ HEADINGS ============ */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px;flex-wrap:wrap}
.page-title{font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--ink-900)}
.page-sub{color:var(--ink-500);font-size:14px;margin-top:4px}
.page-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:7px;padding:0 16px;height:38px;
  border-radius:8px;font-weight:600;font-size:13px;transition:all .15s;white-space:nowrap;
}
.btn svg{width:14px;height:14px}
.btn-primary{background:var(--ab7-green);color:var(--ink-900);font-weight:700}
.btn-primary:hover{background:var(--ab7-green-deep);transform:translateY(-1px);box-shadow:0 10px 20px -8px var(--ab7-green-glow)}
.btn-blue{background:var(--ab7-blue);color:#fff}
.btn-blue:hover{background:var(--ab7-blue-deep);transform:translateY(-1px);box-shadow:0 8px 18px -6px var(--ab7-blue-glow)}
.btn-dark{background:var(--ink-900);color:#fff}
.btn-dark:hover{background:#000}
.btn-ghost{background:#fff;color:var(--ink-800);border:1px solid var(--ink-200)}
.btn-ghost:hover{background:var(--ink-50);border-color:var(--ab7-blue)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#B91C1C}
.btn-sm{height:32px;padding:0 12px;font-size:12px;border-radius:7px}
.btn-xs{height:26px;padding:0 10px;font-size:11px;border-radius:6px}
.btn[disabled]{opacity:.5;pointer-events:none}

/* ============ CARDS / TILES ============ */
.card{background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);padding:20px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.card-head h3{font-size:14.5px;font-weight:700;color:var(--ink-900);letter-spacing:-.01em}
.card-head .sub{font-size:12px;color:var(--ink-400)}

.grid{display:grid;gap:16px}
.g-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.g-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.g-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.g-5{grid-template-columns:repeat(5,minmax(0,1fr))}
@media (max-width:1100px){.g-4,.g-5{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:1fr}}

.kpi{
  background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);padding:18px 20px;
  display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden;
}
.kpi .lbl{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-400)}
.kpi .val{font-size:28px;font-weight:800;letter-spacing:-.025em;color:var(--ink-900);margin-top:6px}
.kpi .delta{font-size:12px;font-weight:600;display:inline-flex;gap:5px;align-items:center;margin-top:2px}
.kpi .delta.up{color:var(--ab7-green-deep)}
.kpi .delta.down{color:var(--danger)}
.kpi::after{content:"";position:absolute;right:-10px;bottom:-10px;width:70px;height:70px;border-radius:50%;background:var(--ab7-sky-ghost);opacity:.6}

/* ============ TAGS / BADGES ============ */
.tag{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:700;background:var(--ink-100);color:var(--ink-700);letter-spacing:.02em;white-space:nowrap}
.tag.blue{background:rgba(0,116,217,.1);color:var(--ab7-blue-deep)}
.tag.green{background:rgba(0,211,112,.14);color:var(--ab7-green-deep)}
.tag.sky{background:var(--ab7-sky-soft);color:var(--ab7-blue-dark)}
.tag.warn{background:#FEF3C7;color:#92400E}
.tag.danger{background:#FEE2E2;color:#B91C1C}
.tag.slate{background:var(--ink-100);color:var(--ink-700)}
.tag.gradient{background:var(--ab7-gradient);color:#fff}

/* ============ TABLE ============ */
.tbl-wrap{background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);overflow:hidden}
.tbl-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--ink-150);flex-wrap:wrap}
.tbl-search{
  flex:1;max-width:300px;position:relative;
}
.tbl-search input{width:100%;padding:7px 12px 7px 32px;border-radius:7px;background:var(--ink-50);border:1px solid var(--ink-150);font-size:12.5px}
.tbl-search input:focus{outline:none;border-color:var(--ab7-blue);background:#fff}
.tbl-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:13px;height:13px;color:var(--ink-400)}
select.filter,input.filter{padding:7px 10px;border-radius:7px;border:1px solid var(--ink-150);background:#fff;font-size:12.5px;color:var(--ink-700)}
select.filter:focus,input.filter:focus{outline:none;border-color:var(--ab7-blue)}

table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl thead th{
  text-align:left;padding:10px 14px;font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink-500);
  background:var(--ink-50);border-bottom:1px solid var(--ink-150);white-space:nowrap;
  cursor:pointer;user-select:none;position:sticky;top:0;
}
table.tbl thead th:hover{color:var(--ab7-blue)}
table.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--ink-100);vertical-align:middle}
table.tbl tbody tr{transition:background .1s}
table.tbl tbody tr:hover{background:var(--ab7-sky-ghost)}
table.tbl tbody tr.selected{background:rgba(0,116,217,.08)}
.tbl-empty{padding:48px;text-align:center;color:var(--ink-400);font-size:13px}
.tbl-foot{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--ink-150);font-size:12px;color:var(--ink-500)}
.pager{display:flex;gap:4px;align-items:center}
.pager button{padding:5px 10px;border-radius:6px;background:#fff;border:1px solid var(--ink-150);font-size:12px;color:var(--ink-700)}
.pager button:hover:not([disabled]){background:var(--ink-50);border-color:var(--ab7-blue);color:var(--ab7-blue)}
.pager button.active{background:var(--ab7-blue);color:#fff;border-color:var(--ab7-blue)}
.pager button[disabled]{opacity:.45;cursor:not-allowed}

.avatar-sm{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--ab7-blue),var(--ab7-blue-deep));color:#fff;display:inline-grid;place-items:center;font-weight:700;font-size:10.5px;flex:none}
.avatar-sm.g2{background:linear-gradient(135deg,var(--ab7-green),var(--ab7-green-deep))}
.avatar-sm.g3{background:linear-gradient(135deg,#8B5CF6,#6D28D9)}
.avatar-sm.g4{background:linear-gradient(135deg,#F59E0B,#D97706)}
.avatar-sm.g5{background:linear-gradient(135deg,#EC4899,#BE185D)}

.who{display:inline-flex;align-items:center;gap:8px}
.score-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:800;font-family:var(--font-mono)}
.score-pill.hot{background:rgba(220,38,38,.12);color:#B91C1C}
.score-pill.warm{background:#FEF3C7;color:#92400E}
.score-pill.cold{background:var(--ink-100);color:var(--ink-600)}
.score-pill.good{background:rgba(0,211,112,.14);color:var(--ab7-green-deep)}

/* ============ DRAWER / MODAL ============ */
.overlay{
  position:fixed;inset:0;background:rgba(5,11,23,.5);z-index:100;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.overlay.show{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(560px,92vw);
  background:#fff;z-index:101;box-shadow:-24px 0 48px -16px rgba(11,19,36,.25);
  transform:translateX(100%);transition:transform .25s cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;
}
.drawer.show{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--ink-150)}
.drawer-head h3{font-size:16px;font-weight:700}
.drawer-body{flex:1;overflow-y:auto;padding:20px 22px}
.drawer-foot{padding:14px 22px;border-top:1px solid var(--ink-150);display:flex;justify-content:flex-end;gap:8px;background:var(--ink-50)}

.modal{
  position:fixed;inset:0;z-index:110;display:none;place-items:center;background:rgba(5,11,23,.55);padding:20px;
}
.modal.show{display:grid}
.modal-card{background:#fff;border-radius:var(--radius-lg);width:min(560px,94vw);max-height:86vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
.modal-head{padding:16px 22px;border-bottom:1px solid var(--ink-150);display:flex;align-items:center;justify-content:space-between}
.modal-body{padding:20px 22px;overflow-y:auto}
.modal-foot{padding:14px 22px;border-top:1px solid var(--ink-150);display:flex;gap:8px;justify-content:flex-end;background:var(--ink-50)}

/* ============ FORMS ============ */
.fld{margin-bottom:14px}
.fld label{display:block;font-size:11.5px;font-weight:700;color:var(--ink-700);letter-spacing:.04em;margin-bottom:5px;text-transform:uppercase}
.fld input,.fld select,.fld textarea{
  width:100%;padding:9px 12px;border-radius:8px;background:#fff;border:1px solid var(--ink-200);
  font-size:13.5px;color:var(--ink-900);transition:all .15s;
}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--ab7-blue);box-shadow:0 0 0 3px var(--ab7-blue-glow)}
.fld textarea{resize:vertical;min-height:80px}
.fld .hint{font-size:11.5px;color:var(--ink-400);margin-top:4px}
.fld.err input,.fld.err select,.fld.err textarea{border-color:var(--danger);box-shadow:0 0 0 3px rgba(220,38,38,.15)}
.fld .err-msg{color:var(--danger);font-size:11.5px;font-weight:600;margin-top:4px;display:none}
.fld.err .err-msg{display:block}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ============ DASHBOARD ============ */
.hero-card{
  background:linear-gradient(135deg,#050B17 0%,#0A1430 50%,#003F7A 100%);
  color:#fff;border-radius:var(--radius-xl);padding:28px 32px;position:relative;overflow:hidden;margin-bottom:22px;
}
.hero-card::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(141,193,238,.05) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(141,193,238,.05) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(ellipse at 70% 40%,#000 30%,transparent 75%);
}
.hero-card .inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.hero-card h2{font-size:24px;font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:6px}
.hero-card h2 em{font-style:normal;background:var(--ab7-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-card p{color:#CBD5E1;font-size:14px;max-width:60ch}
.hero-quick{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.hero-quick button{
  padding:7px 14px;border-radius:999px;font-size:12.5px;font-weight:600;
  background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(141,193,238,.18);backdrop-filter:blur(8px);
  transition:all .15s;
}
.hero-quick button:hover{background:rgba(0,211,112,.15);border-color:var(--ab7-green)}

.activity-item{display:flex;gap:10px;padding:10px 2px;border-bottom:1px dashed var(--ink-150)}
.activity-item:last-child{border-bottom:0}
.activity-item .ic{width:30px;height:30px;border-radius:50%;background:var(--ab7-sky-ghost);display:grid;place-items:center;color:var(--ab7-blue);flex:none}
.activity-item .ic.g{background:rgba(0,211,112,.12);color:var(--ab7-green-deep)}
.activity-item .ic.w{background:#FEF3C7;color:#92400E}
.activity-item .ic.r{background:#FEE2E2;color:#B91C1C}
.activity-item .body{flex:1;min-width:0}
.activity-item .t{font-size:13px;color:var(--ink-800);line-height:1.45}
.activity-item .t b{font-weight:700;color:var(--ink-900)}
.activity-item .m{font-size:11px;color:var(--ink-400);margin-top:2px}

/* ============ CHARTS WRAP ============ */
.chart-wrap{position:relative;height:220px}

/* Dashboard compact layout — fits in a single viewport */
#view-dashboard{--dash-gap:12px}
#view-dashboard .hero-card{padding:18px 24px;margin-bottom:14px}
#view-dashboard .hero-card h2{font-size:20px;margin-bottom:4px}
#view-dashboard .hero-card p{font-size:13px}
#view-dashboard .hero-quick{margin-top:10px}
#view-dashboard .hero-quick button{padding:6px 12px;font-size:12px}
#view-dashboard .grid{gap:var(--dash-gap);margin-bottom:var(--dash-gap)!important}
#view-dashboard .card{padding:14px}
#view-dashboard .card-head{margin-bottom:10px}
#view-dashboard .kpi{padding:12px 14px}
#view-dashboard .kpi .val{font-size:22px;margin-top:2px}
#view-dashboard .kpi .lbl{font-size:10.5px}
#view-dashboard .chart-wrap{height:170px}
#view-dashboard .activity-item{padding:6px 2px}
#view-dashboard .activity-item .t{font-size:12px}
.content.dashboard-compact{padding:14px 22px 22px}

/* ============ KANBAN ============ */
/* Kanban: ALL stages always in a single horizontal row. Auto-flow column creates as many columns as stages; grid-auto-columns fixes their width; parent scrolls horizontally. */
.kanban-wrap{width:100%;overflow-x:auto;overflow-y:hidden;padding-bottom:14px;-webkit-overflow-scrolling:touch}
.kanban{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(240px,1fr);gap:12px;padding:2px}
.kanban-col{
  background:var(--ink-50);border:1px solid var(--ink-150);border-radius:12px;padding:10px;
  display:flex;flex-direction:column;min-height:440px;max-height:calc(100vh - 220px);
}
.kanban-col-body{flex:1;overflow-y:auto;padding-right:2px;margin-right:-2px}
.kanban-col-head{display:flex;justify-content:space-between;align-items:center;padding:4px 6px 10px;border-bottom:1px dashed var(--ink-200);margin-bottom:8px}
.kanban-col-head .title{font-size:11.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-700)}
.kanban-col-head .count{font-size:11px;color:var(--ink-500);font-weight:700;background:#fff;padding:1px 8px;border-radius:999px}
.kanban-col-head .value{font-size:10.5px;color:var(--ab7-blue-deep);font-weight:700;font-family:var(--font-mono)}
.kanban-card{
  background:#fff;border:1px solid var(--ink-150);border-radius:10px;padding:10px 12px;margin-bottom:8px;
  cursor:grab;transition:all .15s;position:relative;
}
.kanban-card:hover{border-color:var(--ab7-blue);box-shadow:var(--shadow-sm)}
.kanban-card.dragging{opacity:.45}
.kanban-card .title{font-size:13px;font-weight:700;color:var(--ink-900);margin-bottom:3px;line-height:1.3}
.kanban-card .co{font-size:11.5px;color:var(--ink-500)}
.kanban-card .row{display:flex;justify-content:space-between;margin-top:8px;align-items:center}
.kanban-card .amt{font-size:12px;font-weight:700;color:var(--ab7-green-deep);font-family:var(--font-mono)}
.kanban-col.drop-active{background:rgba(0,211,112,.06);border-color:var(--ab7-green);border-style:dashed}

/* ============ INBOX ============ */
.inbox{display:grid;grid-template-columns:260px 1fr 320px;gap:0;background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);overflow:hidden;height:calc(100vh - 180px);min-height:520px}
.inbox-list{border-right:1px solid var(--ink-150);overflow-y:auto}
.thread-item{padding:12px 14px;border-bottom:1px solid var(--ink-100);cursor:pointer;transition:background .1s}
.thread-item:hover{background:var(--ink-50)}
.thread-item.active{background:rgba(0,116,217,.08);border-left:3px solid var(--ab7-blue);padding-left:11px}
.thread-item .hdr{display:flex;justify-content:space-between;align-items:center;gap:6px}
.thread-item .nm{font-size:13px;font-weight:700;color:var(--ink-900)}
.thread-item .ts{font-size:10.5px;color:var(--ink-400);white-space:nowrap}
.thread-item .preview{font-size:12px;color:var(--ink-500);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.thread-item .chan{display:inline-flex;margin-top:4px}
.inbox-main{display:flex;flex-direction:column;overflow:hidden}
.inbox-head{padding:14px 18px;border-bottom:1px solid var(--ink-150);display:flex;align-items:center;gap:10px;background:#fff}
.inbox-msgs{flex:1;overflow-y:auto;padding:18px 22px;background:var(--ink-50);display:flex;flex-direction:column;gap:14px}
.msg{max-width:75%;display:flex;gap:8px;align-items:flex-start}
.msg .bubble{padding:9px 14px;border-radius:14px;background:#fff;border:1px solid var(--ink-150);font-size:13.5px;line-height:1.5;color:var(--ink-800)}
.msg .meta{font-size:10.5px;color:var(--ink-400);margin-top:4px;font-weight:600}
.msg.me{margin-left:auto;flex-direction:row-reverse}
.msg.me .bubble{background:var(--ab7-blue);color:#fff;border-color:var(--ab7-blue-deep)}
.msg.ai .bubble{background:linear-gradient(135deg,rgba(59,130,246,.1),rgba(20,216,166,.1));border-color:rgba(20,216,166,.3)}
.inbox-compose{padding:12px 18px;border-top:1px solid var(--ink-150);background:#fff}
.inbox-compose textarea{width:100%;border:1px solid var(--ink-150);border-radius:10px;padding:10px 12px;font-size:13px;resize:none;height:70px}
.inbox-compose textarea:focus{outline:none;border-color:var(--ab7-blue);box-shadow:0 0 0 3px var(--ab7-blue-glow)}
.inbox-compose .row{display:flex;gap:6px;align-items:center;margin-top:8px;flex-wrap:wrap}
.inbox-side{border-left:1px solid var(--ink-150);padding:18px;overflow-y:auto;background:var(--ink-50)}

/* ============ AGENT CARDS ============ */
.agent-card{
  background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);padding:18px;
  display:flex;flex-direction:column;gap:10px;transition:all .15s;position:relative;overflow:hidden;
}
.agent-card:hover{border-color:var(--ab7-blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.agent-card .hdr{display:flex;gap:10px;align-items:center}
.agent-card .ico{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--ab7-blue),var(--ab7-blue-deep));display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;flex:none}
.agent-card h4{font-size:14.5px;font-weight:700;color:var(--ink-900);letter-spacing:-.01em}
.agent-card .role{font-size:11px;color:var(--ink-500)}
.agent-card p{font-size:12.5px;color:var(--ink-500);line-height:1.5}
.agent-card .stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-top:6px}
.agent-card .stats div{background:var(--ink-50);border-radius:8px;padding:7px 9px}
.agent-card .stats .v{font-size:14px;font-weight:800;color:var(--ink-900);letter-spacing:-.02em}
.agent-card .stats .l{font-size:9.5px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.agent-card .ctrl{display:flex;gap:6px;margin-top:6px}
.agent-card .status-dot{position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%}
.agent-card.running .status-dot{background:var(--ab7-green);box-shadow:0 0 0 3px rgba(0,211,112,.2);animation:pulse 1.5s infinite}
.agent-card.paused .status-dot{background:var(--warn)}
.agent-card.idle .status-dot{background:var(--ink-300)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}

/* ============ WORKFLOW BUILDER ============ */
.wf-canvas{
  min-height:520px;background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);
  padding:28px;position:relative;overflow:auto;
  background-image:radial-gradient(circle,var(--ink-200) 1px,transparent 1px);
  background-size:22px 22px;
}
.wf-node{
  background:#fff;border:2px solid var(--ab7-sky);border-radius:12px;padding:12px 16px;
  position:relative;min-width:200px;box-shadow:var(--shadow-sm);cursor:pointer;transition:all .15s;
}
.wf-node:hover{border-color:var(--ab7-blue);box-shadow:var(--shadow-md)}
.wf-node .ty{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--ab7-blue-deep)}
.wf-node .tl{font-size:13px;font-weight:700;color:var(--ink-900);margin-top:3px}
.wf-node .sb{font-size:11px;color:var(--ink-500);margin-top:3px}
.wf-node.trigger{border-color:var(--ab7-green)}
.wf-node.trigger .ty{color:var(--ab7-green-deep)}
.wf-node.cond{border-color:var(--warn)}
.wf-node.cond .ty{color:#92400E}
.wf-node.action{border-color:var(--ab7-blue)}
.wf-chain{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.wf-chain .arrow{margin-left:16px;color:var(--ink-300);font-size:18px;line-height:1}

/* ============ MISC ============ */
.progress{width:100%;height:6px;background:var(--ink-100);border-radius:999px;overflow:hidden}
.progress .bar{height:100%;background:var(--ab7-gradient);border-radius:999px;transition:width .3s}

.command-palette{
  position:fixed;top:12vh;left:50%;transform:translateX(-50%);
  width:min(640px,92vw);background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);z-index:120;overflow:hidden;display:none;
}
.command-palette.show{display:block}
.command-palette input{
  width:100%;padding:16px 20px;font-size:15px;border:0;border-bottom:1px solid var(--ink-150);
}
.command-palette input:focus{outline:none}
.command-palette .results{max-height:52vh;overflow-y:auto}
.command-palette .result{padding:10px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--ink-100);cursor:pointer}
.command-palette .result:hover,.command-palette .result.active{background:var(--ab7-sky-ghost)}
.command-palette .result .ic{width:30px;height:30px;border-radius:7px;background:var(--ab7-sky-ghost);display:grid;place-items:center;color:var(--ab7-blue);flex:none}
.command-palette .result .t{font-size:13px;font-weight:600;color:var(--ink-900)}
.command-palette .result .d{font-size:11.5px;color:var(--ink-400)}
.command-palette .foot{padding:8px 18px;background:var(--ink-50);font-size:11px;color:var(--ink-500);display:flex;justify-content:space-between}
.command-palette kbd{font:600 10.5px var(--font-mono);padding:1px 5px;border-radius:4px;background:#fff;border:1px solid var(--ink-200);color:var(--ink-500)}

.toast-wrap{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:300}
.toast{
  background:var(--ink-900);color:#fff;padding:10px 14px;border-radius:10px;font-size:13px;
  box-shadow:var(--shadow-lg);animation:slidein .25s ease;display:flex;align-items:center;gap:8px;
  min-width:240px;border-left:3px solid var(--ab7-green);
}
.toast.err{border-left-color:var(--danger)}
.toast.info{border-left-color:var(--ab7-blue)}
@keyframes slidein{from{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ============ SEG CONTROL ============ */
.seg{display:inline-flex;background:var(--ink-100);border-radius:8px;padding:3px}
.seg button{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;color:var(--ink-600);transition:all .15s}
.seg button.active{background:#fff;color:var(--ink-900);box-shadow:var(--shadow-sm)}
.seg button:hover:not(.active){color:var(--ink-800)}

/* ============ PROFILE / CDP ============ */
.profile-grid{display:grid;grid-template-columns:320px 1fr;gap:18px}
@media (max-width:1100px){.profile-grid{grid-template-columns:1fr}}
.profile-head{background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);padding:20px}
.profile-head .ava{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--ab7-blue),var(--ab7-blue-deep));color:#fff;display:grid;place-items:center;font-weight:800;font-size:26px;margin-bottom:12px}
.profile-head h3{font-size:20px;font-weight:800;letter-spacing:-.02em}
.profile-head .sub{color:var(--ink-500);font-size:13px;margin-top:3px}
.kv{display:grid;grid-template-columns:110px 1fr;gap:6px 12px;font-size:13px;margin-top:16px}
.kv dt{color:var(--ink-400);font-size:12px;font-weight:600}
.kv dd{color:var(--ink-800);word-break:break-word}

/* ============ INTEGRATION TILE ============ */
.integ-tile{
  background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);padding:16px;
  display:flex;flex-direction:column;gap:8px;transition:all .15s;
}
.integ-tile:hover{border-color:var(--ab7-blue);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.integ-tile .ico{width:36px;height:36px;border-radius:10px;background:var(--ab7-sky-ghost);display:grid;place-items:center;color:var(--ab7-blue);font-weight:800;font-size:13px}
.integ-tile h4{font-size:13.5px;font-weight:700}
.integ-tile p{font-size:11.5px;color:var(--ink-500);line-height:1.5;flex:1}
.toggle{position:relative;width:36px;height:20px;border-radius:999px;background:var(--ink-200);cursor:pointer;transition:background .2s}
.toggle.on{background:var(--ab7-green)}
.toggle::after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}
.toggle.on::after{transform:translateX(16px)}

/* ============ MOBILE PREVIEW ============ */
.phone-frame{
  width:320px;height:640px;background:#050B17;border-radius:40px;padding:12px;margin:0 auto;
  box-shadow:0 40px 60px -20px rgba(5,11,23,.4),inset 0 0 0 2px rgba(141,193,238,.2);position:relative;
}
.phone-frame::before{content:"";position:absolute;top:16px;left:50%;transform:translateX(-50%);width:110px;height:22px;background:#050B17;border-radius:12px;z-index:2}
.phone-screen{width:100%;height:100%;background:#fff;border-radius:28px;overflow:hidden;position:relative}

/* ============ FOCUS ROWS / audit ============ */
.audit-row{display:grid;grid-template-columns:120px 150px 180px 1fr;gap:10px;padding:8px 0;border-bottom:1px dashed var(--ink-150);font-size:12px;color:var(--ink-700);font-family:var(--font-mono)}
.audit-row:last-child{border-bottom:0}
.audit-row .hash{color:var(--ab7-blue);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}


/* ============ MAIL MODULE ============ */
.mail-layout{display:grid;grid-template-columns:220px 340px 1fr;gap:0;background:#fff;border:1px solid var(--ink-150);border-radius:var(--radius-lg);overflow:hidden;height:calc(100vh - 180px);min-height:520px}
.mail-side{background:var(--ink-50);border-right:1px solid var(--ink-150);padding:14px;overflow-y:auto}
.mail-folder{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--ink-700);margin-bottom:2px;transition:all .12s}
.mail-folder:hover{background:var(--ink-100)}
.mail-folder.active{background:rgba(0,116,217,.1);color:var(--ab7-blue-deep);font-weight:700}
.mail-list{border-right:1px solid var(--ink-150);overflow-y:auto;display:flex;flex-direction:column}
.mail-toolbar{padding:10px 12px;border-bottom:1px solid var(--ink-150);background:#fff;position:sticky;top:0;z-index:2}
.mail-item{padding:12px 14px;border-bottom:1px solid var(--ink-100);cursor:pointer;transition:background .1s}
.mail-item:hover{background:var(--ab7-sky-ghost)}
.mail-item.active{background:rgba(0,116,217,.08);border-left:3px solid var(--ab7-blue);padding-left:11px}
.mail-item.unread .mail-item-from,.mail-item.unread .mail-item-subj{font-weight:800;color:var(--ink-900)}
.mail-item-head{display:flex;align-items:flex-start;gap:8px;margin-bottom:4px}
.mail-item-from{font-size:13px;font-weight:600;color:var(--ink-800);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mail-item-subj{font-size:12.5px;color:var(--ink-700);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mail-item-date{font-size:10.5px;color:var(--ink-400);white-space:nowrap}
.mail-item-preview{font-size:11.5px;color:var(--ink-500);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.mail-view{display:flex;flex-direction:column;overflow:hidden}
.mail-view-head{padding:16px 20px;border-bottom:1px solid var(--ink-150)}
.mail-view-body{flex:1;overflow-y:auto;padding:20px}
.mail-view-actions{padding:14px 20px;border-top:1px solid var(--ink-150);display:flex;gap:8px;background:var(--ink-50);flex-wrap:wrap}
@media (max-width:900px){.mail-layout{grid-template-columns:1fr;height:auto}.mail-side,.mail-list{display:none}}


/* ============ RESPONSIVE ============ */
@media (max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .tb-search{max-width:none}
  .g-2,.profile-grid{grid-template-columns:1fr}
  .inbox{grid-template-columns:1fr}
  .inbox-list,.inbox-side{display:none}
}