:root {
  --bg:#f8f9fb;
  --bg2:#ffffff;
  --bg3:#f1f3f7;
  --card:#ffffff;
  --card2:#f8f9fb;
  --border:#e5e8ed;
  --border2:#d0d7de;
  --gold:#e65100;
  --gold2:#f57c00;
  --gold3:#ffb74d;
  --green:#f57c00;
  --red:#e53e3e;
  --sky:#3b82f6;
  --amber:#f59e0b;
  --text:#111827;
  --text2:#4b5563;
  --text3:#9ca3af;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.04);
  --shadow-md:0 4px 24px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);
  --glow:0 0 0 3px rgba(245,124,0,.1);
  --topbar-h:54px;
  --dp-w:420px;
}

/* ── TIPE PROPERTI CHIPS ───────────────────────────── */
.tipe-chip {
  padding:7px 10px;
  border-radius:10px;
  border:1.5px solid var(--border2);
  background:var(--bg3);
  color:var(--text2);
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  transition:all .15s;
  font-family:'Montserrat',sans-serif;
  line-height:1.4;
  text-align:center;
  white-space:nowrap;
  width:100%;
}
.tipe-chip:hover {
  border-color:var(--gold2);
  color:var(--gold2);
  background:rgba(245,124,0,.05);
}
.tipe-chip.active {
  background:rgba(245,124,0,.12);
  border-color:var(--gold2);
  color:var(--gold);
  font-weight:700;
}

*,*::before,*::after {
  box-sizing:border-box;
  margin:0;
  padding:0}
html,body {
  height:100%;
  font-family:'Montserrat',sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow:hidden}
#login-screen {
  position:fixed;
  inset:0;
  background:var(--bg);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1000}
.login-bg {
  position:absolute;
  inset:0;
  overflow:hidden}
.login-bg::before {
  content:'';
  position:absolute;
  width:700px;
  height:700px;
  background:radial-gradient(circle,rgba(45,138,78,.09) 0%,transparent 65%);
  top:-200px;
  left:-150px;
  animation:gp 10s ease-in-out infinite}
.login-bg::after {
  content:'';
  position:absolute;
  width:500px;
  height:500px;
  background:radial-gradient(circle,rgba(45,138,78,.05) 0%,transparent 65%);
  bottom:-100px;
  right:-100px;
  animation:gp 10s ease-in-out infinite reverse}

@keyframes gp {
  0%,100% {
  transform:scale(1) rotate(0deg)}
50% {
  transform:scale(1.15) rotate(5deg)}
}
.login-card {
  position:relative;
  z-index:1;
  width:440px;
  padding:52px 44px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:20px;
  box-shadow:0 8px 40px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04)}
.login-brand {
  text-align:center;
  margin-bottom:36px}
.login-brand .wordmark {
  font-family:Rajdhani,sans-serif;
  font-size:34px;
  font-weight:700;
  letter-spacing:8px;
  color:var(--gold2)}
.login-brand .tagline {
  font-size:11px;
  color:var(--text3);
  letter-spacing:3px;
  text-transform:uppercase;
  margin-top:4px}
.login-card h2 {
  font-family:Rajdhani,sans-serif;
  font-size:24px;
  font-weight:700;
  margin-bottom:6px;
  letter-spacing:.5px}
.login-card>p {
  font-size:12px;
  color:var(--text2);
  margin-bottom:28px;
  font-family:'Montserrat',sans-serif;
  letter-spacing:.3px}
.fg {
  margin-bottom:16px}
.fg label {
  display:block;
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--text3);
  margin-bottom:7px;
  font-family:'Montserrat',sans-serif}
.fg input {
  width:100%;
  padding:12px 16px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:10px;
  color:var(--text);
  font-family:'Montserrat',sans-serif;
  font-size:14px;
  outline:none;
  transition:border-color .2s,box-shadow .2s}
.fg input:focus {
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(245,124,0,.1)}
.btn-login {
  width:100%;
  padding:14px;
  margin-top:6px;
  background:linear-gradient(135deg,var(--gold),#ef6c00);
  border:none;
  border-radius:10px;
  color:#fff;
  font-family:'Montserrat',sans-serif;
  font-size:13px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  cursor:pointer;
  transition:opacity .2s,transform .15s}
.btn-login:hover {
  opacity:.9;
  transform:translateY(-1px)}
.demo-section {
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid var(--border)}
.demo-section p {
  font-size:12px;
  color:var(--text3);
  text-align:center;
  margin-bottom:10px}
.demo-chips {
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:center}
.demo-chip {
  padding:5px 14px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:20px;
  font-size:12px;
  color:var(--text2);
  cursor:pointer;
  transition:all .15s}
.demo-chip:hover {
  border-color:var(--gold);
  color:var(--gold2)}
.login-err {
  color:var(--red);
  font-size:13px;
  margin-top:8px;
  display:none}
#app {
  display:none;
  height:100vh;
  flex-direction:column}
#app.show {
  display:flex}
.topbar {
  height:56px;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  padding:0 24px;
  gap:16px;
  flex-shrink:0;
  box-shadow:0 1px 0 var(--border)}
.topbar .wordmark {
  font-family:Rajdhani,sans-serif;
  font-size:19px;
  font-weight:800;
  letter-spacing:5px;
  color:var(--gold);
  text-transform:uppercase}
.topbar .sep {
  width:1px;
  height:16px;
  background:var(--border)}
.topbar .pgtitle {
  font-size:13px;
  font-weight:500;
  color:var(--text3);
  letter-spacing:.3px}
.topbar-right {
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:12px}
.user-pill {
  display:flex;
  align-items:center;
  gap:8px;
  padding:5px 12px;
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:20px}
.user-pill .av {
  width:22px;
  height:22px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
  font-weight:700;
  color:#0c0b09}
.user-pill .uname {
  font-size:13px;
  font-weight:600}
.user-pill .urole {
  font-size:10px;
  color:var(--text3)}
.btn-out {
  padding:5px 14px;
  background:transparent;
  border:1px solid var(--border2);
  border-radius:8px;
  color:var(--text3);
  font-size:12px;
  cursor:pointer;
  transition:all .15s}
.btn-out:hover {
  border-color:var(--red);
  color:var(--red)}
.layout {
  display:flex;
  flex:1;
  overflow:hidden}
.sidebar {
  width:220px;
  background:var(--bg2);
  border-right:1px solid var(--border);
  padding:0;
  flex-shrink:0;
  overflow-x:hidden;
  overflow-y:auto;
  transition:width .22s cubic-bezier(.4,0,.2,1);
  position:relative}
.sb-inner {
  padding:8px;
  min-width:220px}
.sb-toggle-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 10px 8px;
  border-bottom:1px solid var(--border);
  margin-bottom:6px;
  min-width:220px}
.sb-brand-mini {
  font-family:Rajdhani,sans-serif;
  font-size:13px;
  font-weight:700;
  letter-spacing:4px;
  color:var(--gold2);
  white-space:nowrap;
  overflow:hidden;
  transition:opacity .18s,width .22s;
  opacity:1}
.sb-toggle-btn {
  width:28px;
  height:28px;
  border-radius:7px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:var(--text3);
  border:1px solid var(--border);
  background:transparent;
  transition:all .15s;
  flex-shrink:0;
  font-size:15px}
.sb-toggle-btn:hover {
  background:var(--bg3);
  color:var(--text);
  border-color:var(--border2)}
.sb-lbl {
  font-size:9.5px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--text3);
  padding:10px 12px 4px;
  font-family:'Montserrat',sans-serif;
  white-space:nowrap;
  overflow:hidden;
  transition:opacity .18s;
  opacity:1}
.ni {
  display:flex;
  align-items:center;
  gap:9px;
  padding:8px 12px;
  cursor:pointer;
  border-radius:8px;
  font-size:12.5px;
  font-weight:500;
  color:var(--text2);
  transition:all .12s;
  margin-bottom:1px;
  font-family:'Montserrat',sans-serif;
  border-left:none;
  white-space:nowrap;
  position:relative}
.ni:hover {
  background:var(--bg3);
  color:var(--text)}
.ni.active {
  background:rgba(245,124,0,.09);
  color:var(--gold);
  font-weight:600}
.ni .ic {
  width:18px;
  text-align:center;
  font-size:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:inherit}

/* ── COLLAPSED STATE ───────────────────── */
.sidebar.collapsed {
  width:52px}
.sidebar.collapsed .sb-inner {
  padding:8px 6px;
  min-width:52px}
.sidebar.collapsed .sb-toggle-row {
  justify-content:center;
  padding:10px 0 8px;
  min-width:auto}
.sidebar.collapsed .sb-brand-mini {
  opacity:0;
  width:0;
  overflow:hidden}
.sidebar.collapsed .sb-lbl {
  opacity:0;
  height:0;
  padding:0;
  margin:0;
  overflow:hidden}
.sidebar.collapsed .ni {
  padding:9px;
  justify-content:center;
  gap:0}
.sidebar.collapsed .ni .ic {
  width:22px;
  font-size:18px}
/* hide text but keep icon */
.sidebar.collapsed .ni-txt {
  display:none}
/* badge → tiny dot */
.sidebar.collapsed .ni-badge {
  position:absolute;
  top:5px;
  right:5px;
  min-width:8px;
  height:8px;
  padding:0;
  font-size:0;
  border-radius:50%}
/* tooltip */
.sidebar.collapsed .ni::after {
  content:attr(data-sb-label);
  position:fixed;
  left:62px;
  top:auto;
  background:#4e342e;
  color:#fff;
  padding:5px 12px;
  border-radius:7px;
  font-size:12px;
  font-weight:500;
  font-family:'Montserrat',sans-serif;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  z-index:9999;
  box-shadow:0 4px 16px rgba(0,0,0,.18);
  transition:opacity .12s;
  display:block}
.sidebar.collapsed .ni:hover::after {
  opacity:1}
i.ph,i.ph-bold,i.ph-fill,i.ph-thin,i.ph-light,i.ph-duotone {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  vertical-align:middle;
  flex-shrink:0}
.ph-sm{font-size:13px}
.ph-md{font-size:18px}
.ph-lg{font-size:20px}
.ph-xl{font-size:24px}
.ni-badge {
  margin-left:auto;
  padding:1px 7px;
  border-radius:10px;
  font-size:10px;
  font-weight:700;
  color:#fff}
.badge-red {
  background:var(--red)}
.badge-orange {
  background:var(--amber)}
.content {
  flex:1;
  overflow-y:auto;
  padding:22px;
  background:var(--bg)}
.page {
  display:none}
.page.active {
  display:block}
.pg-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:20px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border)}
.pg-title {
  font-family:'Montserrat',sans-serif;
  font-size:18px;
  font-weight:700;
  letter-spacing:-.2px;
  color:var(--text)}
.pg-actions {
  display:flex;
  gap:8px}
.kpi-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-bottom:22px}
.kpi {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  box-shadow:var(--shadow);
  transition:box-shadow .2s,transform .15s}
.kpi:hover {
  box-shadow:var(--shadow-md);
  transform:translateY(-1px)}
.kpi .k-ic {
  font-size:20px;
  margin-bottom:10px}
.kpi .k-val {
  font-family:Rajdhani,sans-serif;
  font-size:28px;
  font-weight:700;
  line-height:1;
  letter-spacing:.5px}
.kpi .k-lbl {
  font-size:12px;
  color:var(--text2);
  margin-top:5px}
.kpi .k-delta {
  font-size:11px;
  margin-top:8px}
.up {
  color:var(--green)}
.dn {
  color:var(--red)}
.tbl-wrap {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--shadow)}
table {
  width:100%;
  border-collapse:collapse}
th {
  padding:10px 16px;
  text-align:left;
  font-size:10px;
  font-weight:700;
  letter-spacing:.6px;
  text-transform:uppercase;
  color:var(--text3);
  background:var(--bg2);
  font-family:'Montserrat',sans-serif;
  border-bottom:1px solid var(--border)}
td {
  padding:11px 16px;
  font-size:13px;
  border-top:1px solid var(--border);
  vertical-align:middle;
  color:var(--text)}
tr:hover td {
  background:var(--bg2)}
.clickrow {
  cursor:pointer}
.badge {
  display:inline-block;
  padding:3px 9px;
  border-radius:20px;
  font-size:11px;
  font-weight:600}
.b-inquiry {
  background:rgba(96,165,196,.15);
  color:#60a5c4}
.b-followup {
  background:rgba(45,138,78,.15);
  color:var(--gold2)}
.b-viewing {
  background:rgba(224,124,58,.15);
  color:#e07c3a}
.b-nego {
  background:rgba(200,100,200,.18);
  color:#d88fd8}
.b-booking {
  background:rgba(76,175,125,.15);
  color:#ffb74d}
.b-akad {
  background:rgba(76,175,125,.25);
  color:#ffe0b2}
.b-batal {
  background:rgba(224,92,92,.15);
  color:#e05c5c}
.b-hot {
  background:rgba(224,92,92,.15);
  color:#e05c5c}
.b-warm {
  background:rgba(224,124,58,.15);
  color:#e07c3a}
.b-cold {
  background:rgba(107,92,74,.2);
  color:var(--text3)}
.b-stale3 {
  background:rgba(245,158,11,.15);
  color:#f59e0b}
.b-stale7 {
  background:rgba(224,92,92,.15);
  color:#e05c5c}
.btn {
  padding:8px 16px;
  border-radius:9px;
  font-family:'Montserrat',sans-serif;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  transition:all .15s;
  border:none;
  display:inline-flex;
  align-items:center;
  gap:6px;
  letter-spacing:0;
  white-space:nowrap}
.btn-gold {
  background:var(--green);
  color:#fff;
  box-shadow:0 1px 4px rgba(45,138,78,.25)}
.btn-gold:hover {
  background:#ef6c00;
  box-shadow:0 2px 8px rgba(45,138,78,.35)}
.btn-ghost {
  background:transparent;
  border:1px solid var(--border2);
  color:var(--text2)}
.btn-ghost:hover {
  background:var(--bg3);
  border-color:var(--border2);
  color:var(--text)}
.btn-sm {
  padding:5px 11px;
  font-size:11px;
  border-radius:7px}
.btn-red {
  background:rgba(224,92,92,.1);
  border:1px solid rgba(224,92,92,.25);
  color:var(--red)}
.btn-grn {
  background:rgba(76,175,125,.1);
  border:1px solid rgba(76,175,125,.25);
  color:var(--green)}
.btn-wa {
  background:#25D366;
  color:#fff;
  border:none}
.btn-wa:hover {
  background:#f57c00}
.overlay {
  position:fixed;
  inset:0;
  background:rgba(30,45,35,.25);
  backdrop-filter:blur(6px);
  z-index:500;
  display:none;
  align-items:center;
  justify-content:center}
.overlay.open {
  display:flex}
.modal {
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:18px;
  padding:32px;
  width:600px;
  max-width:95vw;
  max-height:88vh;
  overflow-y:auto;
  box-shadow:var(--shadow);
  animation:mIn .2s ease}
.modal.modal-lg {
  width:700px}
.modal.modal-xl {
  width:820px}

@keyframes mIn {
  from {
  opacity:0;
  transform:translateY(24px)}
to {
  opacity:1;
  transform:translateY(0)}
}
.modal h3 {
  font-family:Rajdhani,sans-serif;
  font-size:22px;
  font-weight:700;
  margin-bottom:20px;
  letter-spacing:.5px}
.m2col {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px}
.m3col {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:12px}
.fg2 {
  margin-bottom:14px}
.fg2 label {
  display:block;
  font-size:11px;
  font-weight:600;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--text3);
  margin-bottom:6px}
.fg2 input,.fg2 select,.fg2 textarea {
  width:100%;
  padding:10px 13px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:8px;
  color:var(--text);
  font-family:'Montserrat',sans-serif;
  font-size:13px;
  outline:none;
  transition:border-color .2s}
.fg2 input:focus,.fg2 select:focus,.fg2 textarea:focus {
  border-color:var(--gold)}
.fg2 select {
  appearance:none;
  cursor:pointer}
.fg2 textarea {
  resize:vertical;
  min-height:72px}
.mfooter {
  position:sticky;
  bottom:0;
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:20px;
  padding-top:16px;
  border-top:1px solid var(--border);
  background:var(--card);
  z-index:2}
.detail-panel {
  position:fixed;
  right:0;
  top:var(--topbar-h);
  bottom:0;
  width:var(--dp-w);
  background:#ffffff;
  border-left:1px solid var(--border);
  z-index:200;
  padding:24px;
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1)}
.detail-panel.open {
  transform:translateX(0)}
.dp-close {
  position:absolute;
  top:16px;
  right:16px;
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--card2);
  border:1px solid var(--border2);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:12px;
  color:var(--text2);
  transition:all .15s}
.dp-close:hover {
  background:var(--bg3);
  color:var(--text)}
.timeline {
  display:flex;
  flex-direction:column}
.tl-item {
  display:flex;
  gap:12px;
  padding-bottom:16px;
  position:relative}
.tl-line {
  display:flex;
  flex-direction:column;
  align-items:center;
  width:20px;
  flex-shrink:0}
.tl-dot {
  width:10px;
  height:10px;
  border-radius:50%;
  flex-shrink:0;
  margin-top:2px;
  border:2px solid;
  box-shadow:0 0 6px currentColor}
.tl-tail {
  width:1px;
  flex:1;
  background:var(--border);
  margin-top:4px}
.tl-body {
  flex:1;
  padding-bottom:4px}
.tl-title {
  font-size:13px;
  font-weight:600;
  line-height:1.4}
.tl-sub {
  font-size:11px;
  color:var(--text3);
  margin-top:2px}
.tl-note {
  font-size:12px;
  color:var(--text2);
  margin-top:5px;
  background:var(--bg3);
  border-radius:6px;
  padding:8px;
  line-height:1.5}
.kanban {
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding-bottom:8px}
.k-col {
  min-width:200px;
  background:var(--card2);
  border-radius:12px;
  padding:12px;
  border:1px solid var(--border)}
.k-col-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px}
.k-col-title {
  font-size:11px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase}
.k-cnt {
  font-size:10px;
  background:var(--bg3);
  padding:2px 7px;
  border-radius:10px;
  color:var(--text2)}
.k-cards {
  display:flex;
  flex-direction:column;
  gap:7px;
  min-height:30px}
.k-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:9px;
  padding:11px;
  cursor:pointer;
  transition:border-color .15s,box-shadow .15s}
.k-card:hover {
  border-color:var(--border2);
  box-shadow:0 4px 12px rgba(0,0,0,.06)}
.kc-name {
  font-size:13px;
  font-weight:600;
  margin-bottom:3px}
.kc-tipe {
  font-size:11px;
  color:var(--text3);
  margin-bottom:7px}
.kc-row {
  display:flex;
  align-items:center;
  justify-content:space-between}
.kc-budget {
  font-size:12px;
  font-weight:700;
  color:var(--gold2)}
.pipeline-board {
  display:flex;
  gap:12px;
  overflow-x:auto;
  padding-bottom:12px;
  min-height:420px;
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:var(--border2) transparent}
.pipeline-board::-webkit-scrollbar{height:6px}
.pipeline-board::-webkit-scrollbar-track{background:transparent;border-radius:3px}
.pipeline-board::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
.pipeline-board::-webkit-scrollbar-thumb:hover{background:var(--text3)}
.pk-col {
  min-width:195px;
  max-width:195px;
  background:var(--card2);
  border-radius:14px;
  padding:12px;
  border:1px solid var(--border);
  display:flex;
  flex-direction:column;
  transition:border-color .2s}
.pk-col.drag-over {
  border-color:var(--gold2);
  box-shadow:0 0 0 2px rgba(45,138,78,.25);
  background:rgba(45,138,78,.05)}
.pk-col-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px;
  flex-shrink:0}
.pk-col-title {
  font-size:10px;
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase}
.pk-col-meta {
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:2px}
.pk-cnt {
  font-size:10px;
  background:var(--bg3);
  padding:2px 7px;
  border-radius:10px;
  color:var(--text2);
  font-weight:700}
.pk-val {
  font-size:9px;
  color:var(--text3)}
.pk-drop-zone {
  flex:1;
  min-height:60px;
  display:flex;
  flex-direction:column;
  gap:7px;
  border-radius:8px;
  transition:background .2s;
  padding:2px}
.pk-drop-zone.drag-active {
  background:rgba(45,138,78,.07);
  border:1.5px dashed rgba(45,138,78,.3)}
.pk-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:10px;
  padding:11px;
  cursor:grab;
  transition:all .18s;
  position:relative;
  user-select:none}
.pk-card:hover {
  border-color:var(--border2);
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  transform:translateY(-1px)}
.pk-card.dragging {
  opacity:.35;
  transform:scale(.97);
  cursor:grabbing}
/* ── Sortable.js — touch drag visual feedback ── */
/* Ghost: placeholder di posisi asal saat sedang di-drag */
.pk-sortable-ghost {
  opacity:.25 !important;
  background:rgba(45,138,78,.06) !important;
  border:2px dashed rgba(45,138,78,.4) !important;
  border-radius:10px !important;
  box-shadow:none !important}
/* Chosen: kartu saat ditekan sebelum drag dimulai */
.pk-sortable-chosen {
  opacity:.9 !important;
  transform:scale(1.01);
  z-index:10}
/* Drag class: pakai forceFallback — Sortable buat clone-nya sendiri */
.pk-sortable-drag {
  display:none !important}
/* Fallback clone: elemen yang benar-benar melayang saat di-drag */
.pk-sortable-fallback {
  background:#ffffff !important;
  border:1.5px solid rgba(45,138,78,.5) !important;
  border-radius:10px !important;
  box-shadow:0 8px 28px rgba(0,0,0,.14) !important;
  opacity:1 !important;
  transform:scale(1.03) !important;
  z-index:9999 !important;
  pointer-events:none !important;
  /* Pastikan tidak ada overflow atau clip yang menyebabkan artefak */
  overflow:visible !important;
  max-width:200px}
.pk-col.sortable-over {
  border-color:var(--gold2);
  background:rgba(45,138,78,.05)}
.pk-card.drag-clone {
  opacity:.92;
  box-shadow:0 12px 36px rgba(0,0,0,.08);
  transform:scale(1.03) rotate(1.5deg);
  pointer-events:none;
  z-index:9999}
.pkc-name {
  font-size:12.5px;
  font-weight:700;
  margin-bottom:2px;
  line-height:1.3}
.pkc-proj {
  font-size:10px;
  color:var(--text3);
  margin-bottom:7px}
.pkc-budget {
  font-size:13px;
  font-weight:700;
  color:var(--gold2);
  font-family:Rajdhani,sans-serif}
.pkc-bottom {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:6px}
.pkc-prob {
  height:3px;
  background:var(--bg3);
  border-radius:2px;
  overflow:hidden;
  margin:5px 0}
.pkc-prob-fill {
  height:100%;
  border-radius:2px;
  background:var(--gold)}
.pkc-drag-hint {
  font-size:9px;
  color:var(--text3);
  opacity:0;
  transition:opacity .15s;
  margin-left:auto;
  flex-shrink:0}
.pk-card:hover .pkc-drag-hint {
  opacity:1}
.pk-empty {
  text-align:center;
  padding:24px 10px;
  color:var(--text3);
  font-size:11px;
  border:1.5px dashed var(--border);
  border-radius:8px;
  flex:1}
.pk-stage-stats {
  display:flex;
  align-items:center;
  gap:6px;
  padding:8px 0;
  border-top:1px solid var(--border);
  margin-top:6px;
  flex-shrink:0}
.pk-stage-val {
  font-family:Rajdhani,sans-serif;
  font-size:13px;
  font-weight:700;
  color:var(--gold2)}
.pk-stage-lbl {
  font-size:9px;
  color:var(--text3)}
.pipeline-filter {
  display:flex;
  gap:8px;
  margin-bottom:14px;
  align-items:center;
  flex-wrap:wrap}
.pipe-summary {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin-bottom:16px}
.pipe-sum-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px}
.psc-val {
  font-family:Rajdhani,sans-serif;
  font-size:22px;
  font-weight:700;
  line-height:1}
.psc-lbl {
  font-size:10px;
  color:var(--text3);
  margin-top:4px;
  text-transform:uppercase;
  letter-spacing:.5px}
.funnel {
  display:flex;
  flex-direction:column;
  gap:6px}
.f-stage {
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 12px;
  background:var(--card2);
  border-radius:8px;
  border-left:3px solid}
.f-lbl {
  font-size:12px;
  color:var(--text2);
  min-width:100px}
.f-track {
  flex:1;
  height:5px;
  background:var(--bg3);
  border-radius:3px;
  overflow:hidden}
.f-fill {
  height:100%;
  border-radius:3px;
  transition:width .8s ease}
.f-cnt {
  font-size:12px;
  font-weight:700;
  min-width:24px;
  text-align:right}
.f-val {
  font-size:11px;
  color:var(--text3);
  min-width:80px;
  text-align:right}
.bar-chart {
  display:flex;
  align-items:flex-end;
  gap:8px;
  height:110px;
  padding:0 4px}
.bc-col {
  display:flex;
  flex-direction:column;
  align-items:center;
  flex:1;
  gap:3px;
  height:100%;
  justify-content:flex-end}
.bc-fill {
  width:100%;
  border-radius:4px 4px 0 0;
  transition:height .7s cubic-bezier(.34,1.56,.64,1);
  min-height:3px}
.bc-lbl {
  font-size:9px;
  color:var(--text3);
  text-align:center;
  line-height:1.2}
.bc-val {
  font-size:9px;
  font-weight:700;
  color:var(--text2)}
.act-feed {
  display:flex;
  flex-direction:column}
.act-item {
  display:flex;
  gap:11px;
  padding:11px 0;
  border-bottom:1px solid var(--border)}
.act-item:last-child {
  border-bottom:none}
.act-dot {
  width:7px;
  height:7px;
  border-radius:50%;
  margin-top:5px;
  flex-shrink:0}
.act-body .at {
  font-size:13px;
  line-height:1.5}
.act-body .at2 {
  font-size:11px;
  color:var(--text3);
  margin-top:2px}
.pc {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  transition:border-color .2s}
.pc:hover {
  border-color:var(--border2)}
.pc-head {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px}
.pc-name {
  font-family:Rajdhani,sans-serif;
  font-size:16px;
  font-weight:600}
.pc-sub {
  font-size:11px;
  color:var(--text3)}
.pc-stats {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-bottom:12px}
.ps {
  text-align:center;
  background:var(--card2);
  border-radius:8px;
  padding:8px}
.ps .sv {
  font-family:Rajdhani,sans-serif;
  font-size:20px;
  font-weight:700}
.ps .sl {
  font-size:9px;
  color:var(--text3);
  margin-top:2px;
  text-transform:uppercase;
  letter-spacing:.5px}
.pc-bar-wrap {
  height:5px;
  background:var(--bg3);
  border-radius:3px;
  overflow:hidden}
.pc-bar {
  height:100%;
  border-radius:3px;
  transition:width .8s ease}
.pc-foot {
  display:flex;
  justify-content:space-between;
  font-size:11px;
  color:var(--text3);
  margin-top:6px}
.toast {
  position:fixed;
  bottom:22px;
  right:22px;
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:13px 18px;
  box-shadow:var(--shadow);
  z-index:900;
  display:flex;
  align-items:center;
  gap:9px;
  font-size:13px;
  transform:translateY(70px);
  opacity:0;
  transition:all .3s ease;
  pointer-events:none}
.toast.show {
  transform:translateY(0);
  opacity:1}

/* Shift toast left when a side panel is open (desktop only) */
@media(min-width:769px){
  body.dp-open .toast{right:calc(var(--dp-w) + 18px);transition:right .3s ease,all .3s ease}
  body.wa-open .toast{right:calc(clamp(320px,28vw,480px) + 18px);transition:right .3s ease,all .3s ease}
}

.wa-template {
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:10px;
  padding:14px;
  margin-bottom:10px;
  cursor:pointer;
  transition:all .15s}
.wa-template:hover {
  border-color:var(--gold);
  background:rgba(45,138,78,.06)}
.wa-template.selected {
  border-color:#25D366;
  background:rgba(37,211,102,.06)}
.wa-tpl-label {
  font-size:12px;
  font-weight:700;
  color:var(--text2);
  margin-bottom:6px}
.wa-tpl-preview {
  font-size:12px;
  color:var(--text3);
  line-height:1.5;
  white-space:pre-wrap}
.stale-card {
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px;
  background:var(--card2);
  border-radius:10px;
  margin-bottom:8px;
  cursor:pointer;
  transition:all .15s;
  border:1px solid var(--border)}
.stale-card:hover {
  border-color:var(--border2)}
.stale-card.stale7 {
  border-left:3px solid var(--red)}
.stale-card.stale3 {
  border-left:3px solid var(--amber)}
.komisi-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:20px;
  margin-bottom:16px}
.rate-chip {
  display:inline-block;
  padding:4px 12px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:20px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  margin:4px;
  transition:all .15s}
.rate-chip:hover,.rate-chip.active {
  background:rgba(45,138,78,.15);
  border-color:var(--gold);
  color:var(--gold2)}
.kpr-result {
  background:var(--bg3);
  border-radius:10px;
  padding:16px;
  margin-top:14px}
.kpr-row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:8px 0;
  border-bottom:1px solid var(--border)}
.kpr-row:last-child {
  border-bottom:none}
.kpr-row .kr-lbl {
  font-size:12px;
  color:var(--text2)}
.kpr-row .kr-val {
  font-family:Rajdhani,sans-serif;
  font-size:16px;
  font-weight:700}
.g2 {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px}
.g3 {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:14px}
.card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  padding:20px;
  box-shadow:0 1px 3px rgba(0,0,0,.05)}
.card-title {
  font-size:12px;
  font-weight:700;
  letter-spacing:0;
  text-transform:none;
  color:var(--text2);
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:6px}
.av {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  font-weight:700;
  color:#0c0b09;
  flex-shrink:0}
.av-sm {
  width:26px;
  height:26px;
  font-size:11px}
.av-md {
  width:38px;
  height:38px;
  font-size:15px}
.av-lg {
  width:50px;
  height:50px;
  font-size:20px}
.empty {
  text-align:center;
  padding:50px 20px;
  color:var(--text3)}
.empty .ei {
  font-size:36px;
  margin-bottom:10px}
.empty p {
  font-size:13px}
.divider {
  height:1px;
  background:var(--border);
  margin:16px 0}
.filter-row {
  display:flex;
  gap:9px;
  margin-bottom:14px;
  align-items:center}
.sbox,.fsel {
  padding:8px 13px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  color:var(--text);
  font-family:'Montserrat',sans-serif;
  font-size:13px;
  outline:none}
.sbox {
  flex:1}
.sbox:focus,.fsel:focus {
  border-color:var(--gold)}
.fsel {
  appearance:none;
  cursor:pointer;
  color:var(--text2)}
.gold-line {
  width:40px;
  height:2px;
  background:var(--gold);
  border-radius:1px;
  margin:8px 0 16px}
.dash-section-label {
  display:flex;
  align-items:center;
  gap:6px;
  font-size:10px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--text3);
  padding:6px 0 8px;
  border-bottom:1px solid var(--border);
  margin-bottom:12px;
  margin-top:4px}
.info-chip {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:3px 10px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:20px;
  font-size:11px;
  color:var(--text2)}
.dash-layout {
  display:grid;
  grid-template-columns:1fr 340px;
  gap:16px;
  align-items:start}
.dash-kpi {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-bottom:16px}
.dk {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px 18px;
  display:flex;
  align-items:center;
  gap:14px;
  box-shadow:var(--shadow);
  transition:box-shadow .2s,transform .15s;
  cursor:default}
.dk:hover {
  box-shadow:var(--shadow-md);
  transform:translateY(-1px)}
.dk-ic {
  width:40px;
  height:40px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  flex-shrink:0}
.dk-body .dk-val {
  font-family:Rajdhani,sans-serif;
  font-size:26px;
  font-weight:700;
  line-height:1}
.dk-body .dk-lbl {
  font-size:11px;
  color:var(--text3);
  margin-top:3px}
.dk-body .dk-sub {
  font-size:10px;
  margin-top:5px;
  font-weight:600}
.lead-inbox {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--shadow)}
.li-header {
  padding:13px 18px;
  background:var(--bg3);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between}
.li-title {
  font-size:12px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--text3)}
.li-tabs {
  display:flex;
  gap:0;
  border-bottom:1px solid var(--border)}
.li-tab {
  padding:10px 16px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  color:var(--text3);
  border-bottom:2px solid transparent;
  transition:all .15s;
  white-space:nowrap}
.li-tab:hover {
  color:var(--text2)}
.li-tab.active {
  color:var(--gold2);
  border-bottom-color:var(--gold)}
.li-body {
  max-height:520px;
  overflow-y:auto}
.li-row {
  display:flex;
  align-items:center;
  gap:12px;
  padding:13px 18px;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background .12s}
.li-row:hover {
  background:rgba(45,138,78,.04)}
.li-row:last-child {
  border-bottom:none}
.li-dot {
  width:8px;
  height:8px;
  border-radius:50%;
  flex-shrink:0}
.li-main {
  flex:1;
  min-width:0}
.li-name {
  font-size:13px;
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis}
.li-meta {
  font-size:11px;
  color:var(--text3);
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis}
.li-right {
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:4px;
  flex-shrink:0}
.li-actions {
  display:flex;
  gap:5px;
  flex-shrink:0}
.li-sumber {
  font-size:10px;
  color:var(--text3);
  background:var(--bg3);
  border-radius:4px;
  padding:2px 6px}
.dash-sidebar {
  display:flex;
  flex-direction:column;
  gap:14px}

/* ── TUGAS HARI INI WIDGET ──────────────────────── */
.tugas-widget {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  margin-bottom:14px}
.tugas-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 16px;
  border-bottom:1px solid var(--border);
  background:var(--card2)}
.tugas-title {
  font-size:13px;
  font-weight:700;
  color:var(--text)}
.tugas-date {
  font-size:10px;
  color:var(--text3)}
.tugas-urgent-badge {
  background:#e53e3e;
  color:#fff;
  font-size:9px;
  font-weight:800;
  padding:2px 8px;
  border-radius:20px;
  letter-spacing:.3px}
.tugas-list {
  display:flex;
  flex-direction:column}
.tugas-item {
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 16px;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background .15s}
.tugas-item:last-child {
  border-bottom:none}
.tugas-item:hover {
  background:var(--bg2) !important}
.tugas-dot {
  width:7px;
  height:7px;
  border-radius:50%;
  flex-shrink:0}
.tugas-ic {
  font-size:15px;
  flex-shrink:0;
  width:20px;
  text-align:center}
.tugas-body {
  flex:1;
  min-width:0}
.tugas-item-title {
  font-size:12px;
  font-weight:600;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis}
.tugas-item-sub {
  font-size:10px;
  color:var(--text3);
  margin-top:1px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis}
.tugas-n {
  font-size:11px;
  font-weight:700;
  padding:2px 8px;
  border-radius:12px;
  border:1px solid;
  flex-shrink:0;
  background:transparent}
.tugas-arrow {
  font-size:13px;
  flex-shrink:0;
  opacity:.6}
.ds-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--shadow)}
.ds-card-head {
  padding:12px 16px;
  background:var(--bg3);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between}
.ds-card-title {
  font-size:10px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--text3)}
.ds-card-body {
  padding:14px 16px}
.priority-item {
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 0;
  border-bottom:1px solid var(--border)}
.priority-item:last-child {
  border-bottom:none}
.pi-rank {
  width:20px;
  height:20px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:9px;
  font-weight:700;
  flex-shrink:0}
.pi-name {
  font-size:12px;
  font-weight:600;
  flex:1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis}
.pi-badge {
  font-size:9px;
  background:var(--bg3);
  border-radius:4px;
  padding:2px 6px;
  color:var(--text3)}
.stage-mini {
  display:flex;
  flex-direction:column;
  gap:5px}
.sm-row {
  display:flex;
  align-items:center;
  gap:8px}
.sm-lbl {
  font-size:11px;
  color:var(--text2);
  min-width:80px}
.sm-bar {
  flex:1;
  height:4px;
  background:var(--bg3);
  border-radius:2px;
  overflow:hidden}
.sm-fill {
  height:100%;
  border-radius:2px}
.sm-cnt {
  font-size:11px;
  font-weight:700;
  min-width:20px;
  text-align:right}
.sm-row:hover .sm-lbl {
  color:var(--text)}
.quick-add {
  background:linear-gradient(135deg,rgba(45,138,78,.12),rgba(45,138,78,.04));
  border:1px solid rgba(45,138,78,.3);
  border-radius:14px;
  padding:16px;
  display:flex;
  align-items:center;
  gap:14px;
  cursor:pointer;
  transition:all .2s}
.quick-add:hover {
  border-color:var(--gold2);
  background:rgba(45,138,78,.15)}
.qa-ic {
  width:44px;
  height:44px;
  background:linear-gradient(135deg,var(--gold),#ef6c00);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  flex-shrink:0}
.qa-text .qa-title {
  font-size:14px;
  font-weight:700;
  color:var(--gold2)}
.qa-text .qa-sub {
  font-size:11px;
  color:var(--text3);
  margin-top:2px}
.today-strip {
  background:var(--card2);
  border-radius:10px;
  padding:10px 14px;
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  transition:background .15s;
  border:1px solid var(--border)}
.today-strip:hover {
  background:var(--card);
  border-color:var(--border2)}
.ts-ic {
  font-size:16px}
.ts-body {
  flex:1}
.ts-title {
  font-size:12px;
  font-weight:600}
.ts-sub {
  font-size:10px;
  color:var(--text3);
  margin-top:1px}
.dash-layout-koord {
  display:grid;
  grid-template-columns:1fr 360px;
  gap:16px;
  align-items:start}
.dash-kpi-wide {
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:11px;
  margin-bottom:16px}
.dk-wide {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px 16px;
  box-shadow:var(--shadow);
  transition:box-shadow .2s,transform .15s;
  cursor:pointer}
.dk-wide:hover {
  box-shadow:var(--shadow-md);
  transform:translateY(-1px)}
.dk-wide .dkw-top {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:8px}
.dk-wide .dkw-ic {
  font-size:18px}
.dk-wide .dkw-trend {
  font-size:10px;
  font-weight:700;
  padding:2px 7px;
  border-radius:20px}
.dk-wide .dkw-val {
  font-family:Rajdhani,sans-serif;
  font-size:28px;
  font-weight:700;
  line-height:1;
  margin-bottom:3px}
.dk-wide .dkw-lbl {
  font-size:11px;
  color:var(--text3)}
.dk-wide .dkw-sub {
  font-size:10px;
  color:var(--text3);
  margin-top:4px}
.sales-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-bottom:16px}
.sg-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px;
  cursor:pointer;
  transition:all .15s}
.sg-card:hover {
  border-color:var(--gold);
  box-shadow:0 2px 10px rgba(45,138,78,.08);
  transform:translateY(-1px)}
.sg-head {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px}
.sg-stats {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:6px;
  margin-bottom:10px}
.sg-stat {
  text-align:center;
  background:var(--bg3);
  border-radius:7px;
  padding:6px 4px}
.sg-stat .sv {
  font-family:Rajdhani,sans-serif;
  font-size:17px;
  font-weight:700}
.sg-stat .sl {
  font-size:9px;
  color:var(--text3);
  margin-top:1px;
  text-transform:uppercase}
.sg-bar-wrap {
  height:3px;
  background:var(--bg3);
  border-radius:2px;
  overflow:hidden}
.sg-bar {
  height:100%;
  border-radius:2px;
  transition:width .8s ease}
.act-mini {
  display:flex;
  flex-direction:column}
.am-item {
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:9px 0;
  border-bottom:1px solid var(--border)}
.am-item:last-child {
  border-bottom:none}
.am-dot {
  width:28px;
  height:28px;
  border-radius:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  flex-shrink:0;
  margin-top:1px}
.am-body {
  flex:1;
  min-width:0}
.am-title {
  font-size:12px;
  font-weight:600;
  line-height:1.4}
.am-sub {
  font-size:10px;
  color:var(--text3);
  margin-top:2px}
.target-row {
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 0;
  border-bottom:1px solid var(--border)}
.target-row:last-child {
  border-bottom:none}
.tr-lbl {
  font-size:12px;
  color:var(--text2);
  min-width:110px}
.tr-bar {
  flex:1;
  height:6px;
  background:var(--bg3);
  border-radius:3px;
  overflow:hidden}
.tr-fill {
  height:100%;
  border-radius:3px;
  transition:width .8s ease}
.tr-pct {
  font-size:12px;
  font-weight:700;
  min-width:36px;
  text-align:right}
.sumber-dot {
  width:8px;
  height:8px;
  border-radius:50%;
  flex-shrink:0}
.agenda-item {
  display:flex;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid var(--border);
  align-items:flex-start}
.agenda-item:last-child {
  border-bottom:none}
.ag-time {
  font-size:11px;
  font-weight:700;
  color:var(--gold2);
  min-width:38px;
  margin-top:2px}
.ag-body {
  flex:1}
.ag-title {
  font-size:12px;
  font-weight:600}
.ag-sub {
  font-size:10px;
  color:var(--text3);
  margin-top:2px}
.mini-funnel {
  display:flex;
  flex-direction:column;
  gap:3px}
.mf-row {
  display:flex;
  align-items:center;
  gap:8px;
  padding:4px 0}
.mf-lbl {
  font-size:10px;
  color:var(--text2);
  min-width:76px}
.mf-bar-wrap {
  flex:1;
  height:14px;
  background:var(--bg3);
  border-radius:4px;
  overflow:hidden;
  position:relative}
.mf-bar {
  height:100%;
  border-radius:4px;
  transition:width .8s ease;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  padding-right:4px}
.mf-bar span {
  font-size:9px;
  font-weight:700;
  color:#fff}
.mf-cnt {
  font-size:11px;
  font-weight:700;
  min-width:20px;
  text-align:right}
.mf-val {
  font-size:10px;
  color:var(--text3);
  min-width:72px;
  text-align:right}
.heat-row {
  display:flex;
  align-items:center;
  gap:6px;
  margin-bottom:5px}
.heat-lbl {
  font-size:11px;
  color:var(--text2);
  min-width:72px}
.heat-dots {
  display:flex;
  gap:3px;
  flex:1}
.heat-dot {
  width:14px;
  height:14px;
  border-radius:3px}
.task-item {
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 0;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background .12s}
.task-item:last-child {
  border-bottom:none}
.task-item:hover {
  background:rgba(45,138,78,.03);
  border-radius:8px;
  padding-left:6px}
.task-check {
  width:18px;
  height:18px;
  border-radius:50%;
  border:2px solid var(--border2);
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
  transition:all .15s}
.task-check.done {
  background:var(--green);
  border-color:var(--green);
  color:#fff}
.task-check.urgent {
  border-color:var(--red);
  background:rgba(224,92,92,.1)}
.task-body {
  flex:1;
  min-width:0}
.task-title {
  font-size:12px;
  font-weight:600;
  line-height:1.3}
.task-sub {
  font-size:10px;
  color:var(--text3);
  margin-top:1px}
.task-badge {
  font-size:9px;
  font-weight:700;
  padding:2px 6px;
  border-radius:8px;
  flex-shrink:0}
.score-ring-wrap {
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0}
.score-ring {
  width:64px;
  height:64px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative}
.score-ring::before {
  content:'';
  position:absolute;
  inset:0;
  border-radius:50%;
  background:conic-gradient(var(--ring-clr) var(--ring-pct),var(--bg3) 0)}
.score-ring::after {
  content:'';
  position:absolute;
  inset:6px;
  border-radius:50%;
  background:var(--card)}
.score-ring-val {
  position:relative;
  z-index:1;
  font-family:Rajdhani,sans-serif;
  font-size:16px;
  font-weight:700;
  line-height:1;
  text-align:center}
.score-ring-lbl {
  font-size:8px;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.5px}
.koord-sales-table {
  display:flex;
  flex-direction:column;
  gap:6px}
.kst-row {
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 14px;
  background:var(--card2);
  border-radius:10px;
  cursor:pointer;
  transition:all .15s;
  border:1px solid transparent}
.kst-row:hover {
  border-color:var(--border2);
  background:var(--card)}
.kst-info {
  flex:1;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:6px;
  margin-left:4px}
.kst-cell {
  text-align:center}
.kst-cell .kc-v {
  font-size:14px;
  font-weight:700;
  font-family:Rajdhani,sans-serif}
.kst-cell .kc-l {
  font-size:9px;
  color:var(--text3);
  text-transform:uppercase;
  margin-top:1px}
.comm-row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:8px 0;
  border-bottom:1px solid var(--border)}
.comm-row:last-child {
  border-bottom:none}
.comm-lbl {
  font-size:12px;
  color:var(--text2)}
.comm-val {
  font-family:Rajdhani,sans-serif;
  font-size:15px;
  font-weight:700;
  color:var(--gold2)}
.proj-mini-row {
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 0;
  border-bottom:1px solid var(--border)}
.proj-mini-row:last-child {
  border-bottom:none}
.insight-banner {
  border-radius:12px;
  padding:12px 16px;
  margin-bottom:14px;
  display:flex;
  align-items:flex-start;
  gap:12px}
.ib-ic {
  font-size:20px;
  flex-shrink:0;
  margin-top:2px}
.ib-body {
  flex:1}
.ib-title {
  font-size:13px;
  font-weight:700;
  margin-bottom:3px}
.ib-desc {
  font-size:11px;
  color:var(--text2);
  line-height:1.5}
.wa-bell {
  position:relative;
  width:36px;
  height:36px;
  border-radius:10px;
  background:var(--card2);
  border:1px solid var(--border2);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .15s;
  font-size:16px}
.wa-bell:hover {
  border-color:#25D366;
  background:rgba(37,211,102,.1)}
.wa-bell.has-unread {
  border-color:#25D366;
  background:rgba(37,211,102,.12);
  animation:waPulse 2s ease-in-out infinite}

@keyframes waPulse {
  0%,100% {
  box-shadow:0 0 0 0 rgba(37,211,102,.4)}
50% {
  box-shadow:0 0 0 6px rgba(37,211,102,0)}
}
.wa-badge {
  position:absolute;
  top:-5px;
  right:-5px;
  min-width:16px;
  height:16px;
  background:#e05c5c;
  border-radius:10px;
  font-size:9px;
  font-weight:800;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 3px;
  border:2px solid var(--bg2);
  display:none}
.wa-badge.show {
  display:flex}
.wa-panel {
  position:fixed;
  right:0;
  top:var(--topbar-h);
  bottom:0;
  width:clamp(320px,28vw,480px);
  background:var(--card);
  border-left:1px solid var(--border2);
  z-index:300;
  display:flex;
  flex-direction:column;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  box-shadow:-8px 0 32px rgba(0,0,0,.10)}
.wa-panel.open {
  transform:translateX(0)}
.wap-header {
  padding:16px 18px;
  background:#f57c00;
  border-bottom:1px solid rgba(37,211,102,.2);
  display:flex;
  align-items:center;
  gap:12px;
  flex-shrink:0}
.wap-logo {
  width:32px;
  height:32px;
  background:#25D366;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  flex-shrink:0}
.wap-title {
  font-size:14px;
  font-weight:700;
  color:#fff;
  flex:1}
.wap-sub {
  font-size:11px;
  color:rgba(255,255,255,.5);
  margin-top:1px}
.wap-close {
  width:28px;
  height:28px;
  border-radius:50%;
  background:rgba(255,255,255,.1);
  border:none;
  cursor:pointer;
  color:#fff;
  font-size:13px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .15s}
.wap-close:hover {
  background:rgba(255,255,255,.2)}
.wap-filter {
  display:flex;
  gap:6px;
  padding:10px 14px;
  background:var(--card2);
  border-bottom:1px solid var(--border);
  flex-shrink:0}
.wap-tab {
  padding:5px 12px;
  border-radius:20px;
  font-size:11px;
  font-weight:600;
  cursor:pointer;
  color:var(--text3);
  border:1px solid transparent;
  transition:all .15s}
.wap-tab:hover {
  color:var(--text2)}
.wap-tab.active {
  background:rgba(37,211,102,.12);
  border-color:rgba(37,211,102,.3);
  color:#ffcc80}
.wap-list {
  flex:1;
  overflow-y:auto}
.wap-row {
  display:flex;
  align-items:flex-start;
  gap:11px;
  padding:13px 16px;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background .12s;
  position:relative}
.wap-row:hover {
  background:rgba(45,138,78,.05)}
.wap-row.unread {
  background:rgba(45,138,78,.06)}
.wap-row.unread::before {
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background:#25D366;
  border-radius:0 2px 2px 0}
.wap-av {
  width:40px;
  height:40px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:15px;
  font-weight:700;
  color:#0c0b09;
  flex-shrink:0;
  position:relative}
.wap-unread-dot {
  position:absolute;
  bottom:0;
  right:0;
  width:12px;
  height:12px;
  background:#25D366;
  border-radius:50%;
  border:2px solid var(--card);
  display:none}
.wap-row.unread .wap-unread-dot {
  display:block}
.wap-body {
  flex:1;
  min-width:0}
.wap-name {
  font-size:13px;
  font-weight:700;
  margin-bottom:3px;
  display:flex;
  align-items:center;
  gap:6px}
.wap-preview {
  font-size:12px;
  color:var(--text3);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.4}
.wap-row.unread .wap-preview {
  color:var(--text2);
  font-weight:500}
.wap-meta {
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:4px;
  flex-shrink:0}
.wap-time {
  font-size:10px;
  color:var(--text3)}
.wap-unread-cnt {
  min-width:18px;
  height:18px;
  background:#25D366;
  border-radius:10px;
  font-size:9px;
  font-weight:800;
  color:#000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 4px}
.wap-empty {
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:var(--text3);
  gap:10px;
  padding:40px}
.wap-empty .we-ic {
  font-size:40px}
.wap-empty p {
  font-size:13px}
.wap-chat {
  position:absolute;
  inset:0;
  background:var(--card);
  display:flex;
  flex-direction:column;
  transform:translateX(100%);
  transition:transform .28s ease;
  z-index:2}
.wap-chat.open {
  transform:translateX(0)}
.wap-chat-header {
  padding:12px 16px;
  background:#f57c00;
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0}
.wap-back {
  background:none;
  border:none;
  color:#fff;
  font-size:18px;
  cursor:pointer;
  padding:0 6px 0 0;
  line-height:1}
.wap-chat-av {
  width:36px;
  height:36px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:700;
  color:#0c0b09;
  flex-shrink:0}
.wap-chat-name {
  font-size:13px;
  font-weight:700;
  color:#fff;
  flex:1}
.wap-chat-sub {
  font-size:10px;
  color:rgba(255,255,255,.5);
  margin-top:1px}
.wap-chat-body {
  flex:1;
  overflow-y:auto;
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
  background:#fafafa}
.wap-bubble {
  max-width:80%;
  padding:9px 12px;
  border-radius:12px;
  font-size:13px;
  line-height:1.5;
  position:relative}
.wap-bubble.incoming {
  background:#fff3e0;
  border:1px solid var(--border);
  border-radius:4px 12px 12px 12px;
  align-self:flex-start}
.wap-bubble.outgoing {
  background:linear-gradient(135deg,#f57c00,#e65100);
  border:1px solid rgba(37,211,102,.2);
  border-radius:12px 4px 12px 12px;
  align-self:flex-end}
.wap-bubble-time {
  font-size:9px;
  color:var(--text3);
  margin-top:5px;
  text-align:right}
.wap-bubble.incoming .wap-bubble-time {
  text-align:left}
.wap-date-divider {
  text-align:center;
  font-size:10px;
  color:var(--text3);
  background:var(--card2);
  border-radius:20px;
  padding:3px 12px;
  align-self:center;
  border:1px solid var(--border)}
.wap-chat-footer {
  padding:12px 14px;
  background:var(--card2);
  border-top:1px solid var(--border);
  display:flex;
  flex-direction:column;
  gap:8px;
  flex-shrink:0}
.wap-quick-replies {
  display:flex;
  gap:6px;
  flex-wrap:wrap}
.wap-qr {
  padding:5px 12px;
  background:rgba(37,211,102,.1);
  border:1px solid rgba(37,211,102,.25);
  border-radius:20px;
  font-size:11px;
  color:#ffcc80;
  cursor:pointer;
  transition:all .12s;
  white-space:nowrap}
.wap-qr:hover {
  background:rgba(37,211,102,.2)}
.wap-input-row {
  display:flex;
  gap:8px}
.wap-input {
  flex:1;
  padding:9px 13px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:20px;
  color:var(--text);
  font-family:'Montserrat',sans-serif;
  font-size:13px;
  outline:none;
  transition:border-color .2s}
.wap-input:focus {
  border-color:#25D366}
.wap-send {
  width:38px;
  height:38px;
  background:#25D366;
  border:none;
  border-radius:50%;
  color:#000;
  font-size:16px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .15s;
  flex-shrink:0}
.wap-send:hover {
  background:#f57c00;
  transform:scale(1.05)}
.wa-toast {
  position:fixed;
  bottom:76px;
  right:22px;
  background:#f57c00;
  border:1px solid rgba(37,211,102,.3);
  border-radius:14px;
  padding:13px 16px;
  z-index:950;
  display:flex;
  align-items:center;
  gap:12px;
  font-size:13px;
  transform:translateY(80px);
  opacity:0;
  transition:all .35s cubic-bezier(.34,1.56,.64,1);
  pointer-events:none;
  box-shadow:0 8px 32px rgba(0,0,0,.12);
  max-width:320px}
.wa-toast.show {
  transform:translateY(0);
  opacity:1;
  pointer-events:auto}
.wa-toast-av {
  width:38px;
  height:38px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:700;
  color:#0c0b09;
  flex-shrink:0}
.wa-toast-body {
  flex:1;
  min-width:0}
.wa-toast-name {
  font-size:12px;
  font-weight:700;
  color:#ffcc80}
.wa-toast-msg {
  font-size:12px;
  color:rgba(255,255,255,.7);
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis}
.wa-toast-btn {
  background:rgba(37,211,102,.2);
  border:1px solid rgba(37,211,102,.3);
  border-radius:8px;
  color:#ffcc80;
  font-size:11px;
  font-weight:700;
  padding:5px 10px;
  cursor:pointer;
  flex-shrink:0}
.wa-toast-btn:hover {
  background:rgba(37,211,102,.35)}
::-webkit-scrollbar {
  width:4px;
  height:4px}
::-webkit-scrollbar-track {
  background:transparent}
::-webkit-scrollbar-thumb {
  background:#ffe0b2;
  border-radius:10px}

@media(max-width:1000px) {
  .kpi-grid {
  grid-template-columns:1fr 1fr}
.g2,.g3 {
  grid-template-columns:1fr}
}
.wap-new-lead-banner {
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  background:rgba(37,211,102,.08);
  border-bottom:1px solid rgba(37,211,102,.25);
  flex-shrink:0;
  cursor:pointer;
  transition:background .15s}
.wap-new-lead-banner:hover {
  background:rgba(37,211,102,.15)}
.wap-new-lead-icon {
  width:32px;
  height:32px;
  border-radius:50%;
  background:#25D366;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  flex-shrink:0}
.wap-new-lead-body {
  flex:1;
  min-width:0}
.wap-new-lead-title {
  font-size:12px;
  font-weight:700;
  color:#f57c00}
.wap-new-lead-sub {
  font-size:10px;
  color:var(--text3);
  margin-top:1px}
.wap-new-lead-btn {
  font-size:10px;
  font-weight:700;
  padding:4px 10px;
  background:#25D366;
  color:#000;
  border:none;
  border-radius:6px;
  cursor:pointer;
  flex-shrink:0;
  transition:background .15s}
.wap-new-lead-btn:hover {
  background:#f57c00}
.new-lead-toast {
  position:fixed;
  bottom:76px;
  left:22px;
  background:linear-gradient(135deg,#f57c00,#e65100);
  border:1px solid rgba(37,211,102,.4);
  border-radius:14px;
  padding:14px 18px;
  z-index:960;
  display:flex;
  align-items:center;
  gap:12px;
  transform:translateX(-120%);
  opacity:0;
  transition:all .4s cubic-bezier(.34,1.56,.64,1);
  pointer-events:none;
  box-shadow:0 8px 32px rgba(0,0,0,.15);
  max-width:340px}
.new-lead-toast.show {
  transform:translateX(0);
  opacity:1;
  pointer-events:auto}
.nlt-ic {
  font-size:24px;
  flex-shrink:0}
.nlt-body {
  flex:1;
  min-width:0}
.nlt-title {
  font-size:13px;
  font-weight:700;
  color:#ffcc80;
  margin-bottom:2px}
.nlt-sub {
  font-size:11px;
  color:rgba(255,255,255,.75);
  line-height:1.4}
.nlt-btn {
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25);
  border-radius:8px;
  color:#fff;
  font-size:11px;
  font-weight:700;
  padding:5px 10px;
  cursor:pointer;
  flex-shrink:0;
  white-space:nowrap}
.nlt-btn:hover {
  background:rgba(255,255,255,.25)}
.wap-row.unknown-lead {
  background:rgba(37,211,102,.04)}
.wap-new-badge {
  font-size:9px;
  font-weight:700;
  padding:2px 6px;
  background:#25D366;
  color:#000;
  border-radius:8px;
  margin-left:4px}
.wap-unassigned-tag {
  font-size:9px;
  color:#e07c3a;
  font-weight:600;
  background:rgba(224,124,58,.1);
  border-radius:4px;
  padding:1px 5px;
  margin-left:4px}
.al-info-row {
  display:flex;
  align-items:flex-start;
  gap:8px;
  padding:8px;
  background:var(--bg3);
  border-radius:8px;
  margin-bottom:8px}
.al-info-bubble {
  flex:1;
  background:#fff3e0;
  border:1px solid var(--border);
  border-radius:4px 12px 12px 12px;
  padding:8px 11px;
  font-size:12px;
  color:var(--text2);
  line-height:1.5;
  font-style:italic}
.al-parsed-tag {
  display:inline-block;
  padding:2px 8px;
  border-radius:20px;
  font-size:10px;
  font-weight:600;
  background:rgba(45,138,78,.12);
  color:var(--gold2);
  border:1px solid rgba(45,138,78,.2);
  margin:2px 2px 0 0}
.al-auto-detect {
  font-size:11px;
  color:var(--gold2);
  font-weight:600;
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:5px}
.lap-nav {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:14px 16px;
  margin-bottom:18px;
  display:flex;
  flex-direction:column;
  gap:12px}
.lap-nav-row {
  display:flex;
  align-items:center;
  gap:8px}
.lap-nav-label {
  font-size:10px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--text3);
  min-width:52px;
  flex-shrink:0}
.lap-nav-divider {
  width:1px;
  height:28px;
  background:var(--border);
  flex-shrink:0}
.lap-period-group {
  display:flex;
  gap:4px;
  background:var(--bg3);
  border-radius:8px;
  padding:3px}
.lap-period {
  padding:5px 14px;
  border-radius:6px;
  font-size:12px;
  font-weight:600;
  color:var(--text3);
  cursor:pointer;
  transition:all .15s;
  white-space:nowrap;
  border:none;
  background:transparent}
.lap-period:hover {
  color:var(--text2);
  background:var(--card)}
.lap-period.active {
  background:var(--gold);
  color:#fff;
  box-shadow:0 2px 8px rgba(45,138,78,.3)}
.lap-tabs-group {
  display:flex;
  gap:2px}
.lap-tab {
  display:flex;
  align-items:center;
  gap:6px;
  padding:6px 16px;
  border-radius:8px;
  font-size:12px;
  font-weight:600;
  color:var(--text3);
  cursor:pointer;
  transition:all .15s;
  white-space:nowrap;
  border:1px solid transparent}
.lap-tab:hover {
  color:var(--text);
  background:var(--bg3);
  border-color:var(--border)}
.lap-tab.active {
  background:var(--bg3);
  color:var(--gold2);
  border-color:var(--border2);
  box-shadow:inset 0 -2px 0 var(--gold)}
.lap-tab .tab-ic {
  font-size:14px}
.lap-filters {
  display:flex;
  align-items:center;
  gap:8px;
  flex:1;
  flex-wrap:wrap}
.lap-filter-sel {
  padding:6px 12px;
  border:1px solid var(--border2);
  border-radius:8px;
  font-size:12px;
  background:var(--bg3);
  color:var(--text);
  font-family:'Montserrat',sans-serif;
  outline:none;
  cursor:pointer;
  transition:border-color .15s}
.lap-filter-sel:hover,.lap-filter-sel:focus {
  border-color:var(--gold)}
.lap-actions {
  display:flex;
  gap:6px;
  flex-shrink:0}
.wab-hero {
  background:linear-gradient(135deg,#e65100 0%,#f57c00 50%,#fb8c00 100%);
  border-radius:16px;
  padding:32px;
  margin-bottom:22px;
  color:#fff;
  position:relative;
  overflow:hidden}
.wab-hero::before {
  content:'';
  position:absolute;
  right:-40px;
  top:-40px;
  width:200px;
  height:200px;
  border-radius:50%;
  background:rgba(255,255,255,.04)}
.wab-hero-top {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:20px;
  position:relative;
  z-index:1}
.wab-logo {
  display:flex;
  align-items:center;
  gap:12px}
.wab-logo-ic {
  width:48px;
  height:48px;
  background:#25D366;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  box-shadow:0 4px 16px rgba(0,0,0,.2)}
.wab-logo-text h2 {
  font-family:Rajdhani,sans-serif;
  font-size:22px;
  font-weight:700;
  letter-spacing:1px}
.wab-logo-text p {
  font-size:11px;
  opacity:.7;
  margin-top:2px}
.wab-status-pill {
  padding:6px 16px;
  border-radius:20px;
  font-size:12px;
  font-weight:700;
  border:2px solid;
  display:flex;
  align-items:center;
  gap:6px}
.wab-status-pill.disconnected {
  border-color:rgba(255,255,255,.3);
  color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.08)}
.wab-status-pill.connecting {
  border-color:#fbbf24;
  color:#fbbf24;
  background:rgba(251,191,36,.1)}
.wab-status-pill.connected {
  border-color:#ffcc80;
  color:#ffcc80;
  background:rgba(74,222,128,.1)}
.wab-status-dot {
  width:8px;
  height:8px;
  border-radius:50%;
  background:currentColor}
.wab-status-dot.pulse {
  animation:wab-pulse 1.5s ease-in-out infinite}

@keyframes wab-pulse {
  0%,100% {
  opacity:1;
  transform:scale(1)}
50% {
  opacity:.5;
  transform:scale(1.3)}
}
.wab-stats-row {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  position:relative;
  z-index:1}
.wab-stat {
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  border-radius:10px;
  padding:12px 14px}
.wab-stat .ws-val {
  font-size:22px;
  font-weight:700;
  font-family:Rajdhani,sans-serif}
.wab-stat .ws-lbl {
  font-size:10px;
  opacity:.7;
  margin-top:3px}
.wab-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:16px}
.wab-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:20px}
.wab-card-title {
  font-size:12px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--text3);
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:6px}
.wab-card-full {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:20px;
  margin-bottom:16px}
.wab-steps {
  display:flex;
  flex-direction:column;
  gap:10px}
.wab-step {
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:12px;
  border-radius:10px;
  border:1px solid var(--border);
  background:var(--bg3);
  transition:all .2s}
.wab-step.active {
  border-color:var(--gold);
  background:rgba(45,138,78,.06)}
.wab-step.done {
  border-color:var(--green);
  background:rgba(76,175,125,.06)}
.wab-step-num {
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--border2);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:700;
  color:var(--text3);
  flex-shrink:0}
.wab-step.active .wab-step-num {
  background:var(--gold);
  color:#fff}
.wab-step.done .wab-step-num {
  background:var(--green);
  color:#fff}
.wab-step-body {
  flex:1}
.wab-step-title {
  font-size:13px;
  font-weight:600;
  margin-bottom:2px}
.wab-step-sub {
  font-size:11px;
  color:var(--text3)}
.wab-qr-wrap {
  text-align:center;
  padding:20px 0}
.wab-qr-box {
  width:180px;
  height:180px;
  margin:0 auto 12px;
  border:3px solid var(--border2);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  position:relative;
  overflow:hidden}
.wab-qr-inner {
  width:160px;
  height:160px;
  background:repeating-conic-gradient(#f57c00 0% 25%,#fff 0% 50%) 0 0/16px 16px;
  border-radius:4px;
  opacity:.9}
.wab-qr-scan-line {
  position:absolute;
  width:100%;
  height:3px;
  background:linear-gradient(90deg,transparent,#25D366,transparent);
  animation:wab-scan 2s ease-in-out infinite}

@keyframes wab-scan {
  0% {
  top:0;
  opacity:1}
100% {
  top:100%;
  opacity:.3}
}
.wab-qr-label {
  font-size:12px;
  color:var(--text3)}
.wab-phone-input {
  display:flex;
  gap:8px;
  align-items:stretch}
.wab-cc {
  padding:10px 14px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:8px;
  font-size:13px;
  font-weight:600;
  color:var(--text2);
  white-space:nowrap}
.wab-phone-field {
  flex:1;
  padding:10px 14px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:8px;
  font-size:13px;
  color:var(--text);
  outline:none;
  transition:border-color .2s}
.wab-phone-field:focus {
  border-color:var(--gold)}
.wab-verify-btn {
  padding:10px 18px;
  background:#25D366;
  color:#000;
  border:none;
  border-radius:8px;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  white-space:nowrap}
.wab-verify-btn:hover {
  background:#f57c00}
.wab-otp-row {
  display:flex;
  gap:8px;
  justify-content:center;
  margin:12px 0}
.wab-otp-digit {
  width:44px;
  height:52px;
  border:2px solid var(--border2);
  border-radius:10px;
  font-size:22px;
  font-weight:700;
  text-align:center;
  background:var(--bg3);
  color:var(--text);
  outline:none;
  transition:border-color .2s}
.wab-otp-digit:focus {
  border-color:var(--gold)}
.wab-feature-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px}
.wab-feature {
  border:1px solid var(--border);
  border-radius:10px;
  padding:14px;
  text-align:center;
  cursor:pointer;
  transition:all .2s;
  position:relative}
.wab-feature:hover {
  border-color:var(--gold);
  background:rgba(45,138,78,.04)}
.wab-feature.enabled {
  border-color:var(--green);
  background:rgba(76,175,125,.06)}
.wab-feature-ic {
  font-size:24px;
  margin-bottom:8px}
.wab-feature-title {
  font-size:12px;
  font-weight:700;
  color:var(--text);
  margin-bottom:3px}
.wab-feature-sub {
  font-size:10px;
  color:var(--text3)}
.wab-feature-badge {
  position:absolute;
  top:8px;
  right:8px;
  padding:2px 6px;
  border-radius:10px;
  font-size:9px;
  font-weight:700}
.wab-feature-badge.on {
  background:#fff3e0;
  color:#e65100}
.wab-feature-badge.off {
  background:var(--bg3);
  color:var(--text3)}
.wab-log {
  max-height:200px;
  overflow-y:auto}
.wab-log-item {
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:8px 0;
  border-bottom:1px solid var(--border);
  font-size:11px}
.wab-log-item:last-child {
  border-bottom:none}
.wab-log-dot {
  width:8px;
  height:8px;
  border-radius:50%;
  flex-shrink:0;
  margin-top:3px}
.wab-log-dot.in {
  background:#25D366}
.wab-log-dot.out {
  background:var(--sky)}
.wab-log-dot.sys {
  background:var(--amber)}
.wab-log-dot.err {
  background:var(--red)}
.wab-log-body {
  flex:1;
  min-width:0}
.wab-log-msg {
  color:var(--text2);
  line-height:1.4}
.wab-log-meta {
  color:var(--text3);
  margin-top:2px}
.wab-toggle {
  position:relative;
  width:40px;
  height:22px;
  flex-shrink:0}
.wab-toggle input {
  opacity:0;
  width:0;
  height:0}
.wab-toggle-slider {
  position:absolute;
  cursor:pointer;
  inset:0;
  background:var(--border2);
  border-radius:22px;
  transition:.3s}
.wab-toggle-slider:before {
  content:"";
  position:absolute;
  height:16px;
  width:16px;
  left:3px;
  bottom:3px;
  background:#fff;
  border-radius:50%;
  transition:.3s}
.wab-toggle input:checked+.wab-toggle-slider {
  background:#25D366}
.wab-toggle input:checked+.wab-toggle-slider:before {
  transform:translateX(18px)}
.wab-api-field {
  font-family:monospace;
  font-size:12px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:8px;
  padding:10px 14px;
  width:100%;
  color:var(--text2);
  outline:none;
  letter-spacing:.5px}
.wab-copy-btn {
  padding:8px 14px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:8px;
  font-size:11px;
  font-weight:600;
  color:var(--text2);
  cursor:pointer;
  transition:all .15s;
  white-space:nowrap}
.wab-copy-btn:hover {
  border-color:var(--gold);
  color:var(--gold2)}
.wab-tpl-list {
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height:260px;
  overflow-y:auto}
.wab-tpl-item {
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px;
  display:flex;
  align-items:flex-start;
  gap:10px}
.wab-tpl-cat {
  font-size:9px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  padding:2px 7px;
  border-radius:20px;
  background:rgba(45,138,78,.1);
  color:var(--gold2);
  flex-shrink:0;
  margin-top:2px}
.wab-tpl-body {
  flex:1;
  min-width:0}
.wab-tpl-name {
  font-size:12px;
  font-weight:700;
  margin-bottom:2px}
.wab-tpl-preview {
  font-size:11px;
  color:var(--text3);
  line-height:1.4;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis}
.wab-tpl-actions {
  display:flex;
  gap:4px;
  flex-shrink:0}
.mode-toggle-wrap {
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 16px;
  background:var(--card2);
  border-radius:10px;
  border:1px solid var(--border)}
.mode-toggle-lbl {
  font-size:11px;
  font-weight:700;
  letter-spacing:.5px;
  color:var(--text2)}
.mode-btn {
  padding:5px 14px;
  border-radius:6px;
  font-size:11px;
  font-weight:700;
  cursor:pointer;
  border:none;
  transition:all .15s}
.mode-btn.mode-manual {
  background:var(--bg3);
  color:var(--text3)}
.mode-btn.mode-auto {
  background:rgba(45,138,78,.12);
  color:var(--gold2);
  border:1px solid rgba(45,138,78,.3)}
.mode-btn.active-manual {
  background:var(--sky);
  color:#fff}
.mode-btn.active-auto {
  background:linear-gradient(135deg,var(--gold),#ef6c00);
  color:#fff}
.mode-badge {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:2px 8px;
  border-radius:20px;
  font-size:10px;
  font-weight:700}
.mode-badge.manual {
  background:rgba(96,165,196,.15);
  color:#60a5c4}
.mode-badge.auto {
  background:rgba(45,138,78,.15);
  color:var(--gold2)}
.pamflet-card {
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px;
  cursor:pointer;
  transition:all .15s;
  position:relative}
.pamflet-card:hover {
  border-color:var(--border2);
  box-shadow:0 4px 12px rgba(0,0,0,.06);
  transform:translateY(-1px)}
.pamflet-card.selected {
  border-color:var(--gold);
  background:rgba(45,138,78,.04)}
.pamflet-thumb {
  width:48px;
  height:48px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  margin-bottom:10px}
.pamflet-nama {
  font-size:13px;
  font-weight:700;
  margin-bottom:4px}
.pamflet-desc {
  font-size:11px;
  color:var(--text3);
  line-height:1.4;
  margin-bottom:6px}
.pamflet-note {
  font-size:10px;
  font-weight:600;
  color:var(--gold2);
  background:rgba(45,138,78,.08);
  border-radius:4px;
  padding:3px 7px;
  display:inline-block}
.unit-stat-bar {
  display:flex;
  height:8px;
  border-radius:4px;
  overflow:hidden;
  margin:8px 0}
.unit-status-chip {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:3px 10px;
  border-radius:20px;
  font-size:11px;
  font-weight:600;
  cursor:pointer;
  border:none;
  transition:all .15s}
.usc-avail {
  background:rgba(76,175,125,.15);
  color:var(--green)}
.usc-booked {
  background:rgba(45,138,78,.12);
  color:var(--gold2)}
.usc-sold {
  background:rgba(224,92,92,.12);
  color:var(--red)}
.unit-row-admin {
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-bottom:1px solid var(--border);
  transition:background .12s}
.unit-row-admin:hover {
  background:rgba(45,138,78,.03)}
.unit-row-admin:last-child {
  border-bottom:none}
.as-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  margin-bottom:16px}
.as-urgent {
  border-color:rgba(224,92,92,.3);
  background:rgba(224,92,92,.02)}
.as-item {
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px;
  background:var(--card2);
  border-radius:10px;
  border:1px solid var(--border);
  margin-bottom:8px;
  transition:all .15s}
.as-item:hover {
  border-color:var(--border2);
  box-shadow:0 2px 8px rgba(0,0,0,.05)}
.as-item.urgent {
  border-color:rgba(224,92,92,.3)}
.as-item.warning {
  border-color:rgba(224,124,58,.25)}
.as-icon {
  width:44px;
  height:44px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  flex-shrink:0}
.as-countdown {
  display:inline-block;
  padding:2px 8px;
  border-radius:8px;
  font-size:11px;
  font-weight:700}
.as-countdown.today {
  background:rgba(224,92,92,.15);
  color:var(--red)}
.as-countdown.soon {
  background:rgba(224,124,58,.15);
  color:var(--amber)}
.as-countdown.upcoming {
  background:rgba(96,165,196,.12);
  color:#60a5c4}
.hb-section {
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  margin-bottom:10px}
.hb-header {
  padding:12px 16px;
  background:var(--card2);
  display:flex;
  align-items:center;
  gap:10px}
.hb-buyers {
  padding:8px 16px}
.hb-buyer-row {
  display:flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  background:var(--bg3);
  border-radius:7px;
  margin-bottom:5px}
.hb-buyer-row:last-child {
  margin-bottom:0}
.pipe-lock-modal {
  position:fixed;
  inset:0;
  background:rgba(10,20,15,.7);
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  backdrop-filter:blur(4px)}
.pipe-lock-card {
  background:var(--card);
  border-radius:18px;
  padding:28px;
  max-width:480px;
  width:calc(100% - 32px);
  box-shadow:0 24px 64px rgba(0,0,0,.16);
  border:1.5px solid var(--border)}
.pipe-lock-title {
  font-family:Rajdhani,sans-serif;
  font-size:20px;
  font-weight:700;
  color:var(--text);
  margin-bottom:4px}
.pipe-lock-sub {
  font-size:12px;
  color:var(--text3);
  margin-bottom:18px}
.pipe-lock-rule {
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 12px;
  border-radius:9px;
  margin-bottom:8px}
.pipe-lock-rule.fail {
  background:rgba(224,92,92,.08);
  border:1px solid rgba(224,92,92,.2)}
.pipe-lock-rule.pass {
  background:rgba(45,138,78,.06);
  border:1px solid rgba(45,138,78,.18)}
.pipe-lock-icon {
  width:22px;
  height:22px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  font-size:12px;
  font-weight:700;
  margin-top:1px}
.pipe-lock-icon.fail {
  background:var(--red);
  color:#fff}
.pipe-lock-icon.pass {
  background:var(--green);
  color:#fff}
.pipe-lock-text {
  font-size:12px;
  color:var(--text2);
  line-height:1.5}
.pipe-lock-field {
  font-weight:700;
  color:var(--text)}
.pk-lock-badge {
  display:inline-flex;
  align-items:center;
  gap:3px;
  background:rgba(224,92,92,.12);
  border:1px solid rgba(224,92,92,.25);
  border-radius:5px;
  font-size:9px;
  font-weight:700;
  color:var(--red);
  padding:1px 6px;
  margin-bottom:5px}
.prop-admin-badge {
  display:inline-flex;
  align-items:center;
  gap:4px;
  background:rgba(124,58,237,.12);
  border:1px solid rgba(124,58,237,.25);
  border-radius:6px;
  padding:2px 8px;
  font-size:10px;
  font-weight:700;
  color:#7c3aed}
.prop-admin-pill {
  background:linear-gradient(135deg,#7c3aed,#5b21b6);
  color:#fff;
  font-size:9px;
  font-weight:700;
  padding:2px 7px;
  border-radius:8px;
  letter-spacing:.5px}
.prop-admin-only {
  display:none}
body.role-admin-properti .prop-admin-only {
  display:flex}
body.role-admin-properti .sales-only {
  display:none}
body.role-admin-properti .koord-only {
  display:none}
.prop-kpi-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-bottom:18px}
.prop-kpi-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  position:relative;
  overflow:hidden;
  transition:box-shadow .15s}
.prop-kpi-card:hover {
  box-shadow:0 4px 16px rgba(0,0,0,.07)}
.prop-kpi-card .pk-accent {
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  border-radius:14px 14px 0 0}
.prop-kpi-card .pk-ic {
  font-size:22px;
  margin-bottom:10px;
  width:40px;
  height:40px;
  background:var(--bg3);
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center}
.prop-kpi-card .pk-val {
  font-family:Rajdhani,sans-serif;
  font-size:30px;
  font-weight:700;
  line-height:1}
.prop-kpi-card .pk-lbl {
  font-size:11px;
  color:var(--text3);
  margin-top:5px;
  font-weight:600;
  letter-spacing:0}
.prop-section {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:20px;
  margin-bottom:16px}
.prop-section-title {
  font-family:Rajdhani,sans-serif;
  font-size:17px;
  font-weight:700;
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:8px}
.unit-status-dot {
  width:8px;
  height:8px;
  border-radius:50%;
  flex-shrink:0}
.activity-feed-item {
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 0;
  border-bottom:1px solid var(--border)}
.activity-feed-item:last-child {
  border-bottom:none}
.proyek-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  transition:all .15s;
  position:relative;
  overflow:hidden}
.proyek-card:hover {
  box-shadow:0 4px 16px rgba(0,0,0,.07);
  border-color:var(--border2)}
.proyek-card .pk-stripe {
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px}
.proyek-stat {
  display:flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  margin-bottom:4px}
.proyek-stat .dot {
  width:8px;
  height:8px;
  border-radius:50%;
  flex-shrink:0}
.galeri-thumb {
  width:100%;
  aspect-ratio:16/10;
  background:var(--bg3);
  border-radius:10px;
  border:2px dashed var(--border2);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .15s;
  overflow:hidden;
  position:relative}
.galeri-thumb:hover {
  border-color:var(--gold);
  background:var(--bg3)}
.galeri-thumb img {
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:8px}
.galeri-doc {
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  background:var(--bg3);
  border-radius:8px;
  border:1px solid var(--border);
  margin-bottom:6px;
  cursor:pointer;
  transition:all .15s}
.galeri-doc:hover {
  border-color:var(--gold2);
  background:var(--card2)}
.kpr-result {
  background:linear-gradient(135deg,var(--gold),#ef6c00);
  border-radius:14px;
  padding:20px;
  color:#fff;
  text-align:center}
.kpr-result .kr-val {
  font-family:Rajdhani,sans-serif;
  font-size:32px;
  font-weight:700;
  line-height:1}
.kpr-result .kr-lbl {
  font-size:11px;
  opacity:.8;
  margin-top:4px;
  text-transform:uppercase;
  letter-spacing:.5px}
.alert-item {
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px;
  border-radius:12px;
  margin-bottom:10px;
  border:1px solid}
.alert-critical {
  background:rgba(220,38,38,.05);
  border-color:rgba(220,38,38,.2)}
.alert-warning {
  background:rgba(217,119,6,.05);
  border-color:rgba(217,119,6,.2)}
.alert-info {
  background:rgba(37,99,235,.05);
  border-color:rgba(37,99,235,.15)}
.alert-icon {
  width:38px;
  height:38px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  flex-shrink:0}
.st-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px;
  margin-bottom:10px;
  transition:all .15s}
.st-card:hover {
  border-color:var(--border2);
  box-shadow:0 2px 10px rgba(0,0,0,.06)}
.st-status {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:3px 10px;
  border-radius:20px;
  font-size:11px;
  font-weight:700}
.st-scheduled {
  background:rgba(37,99,235,.1);
  color:var(--sky)}
.st-done {
  background:rgba(45,138,78,.1);
  color:var(--green)}
.st-cancelled {
  background:rgba(220,38,38,.08);
  color:var(--red)}
.la-stat {
  background:var(--card2);
  border-radius:10px;
  padding:14px;
  text-align:center}
.la-stat .v {
  font-family:Rajdhani,sans-serif;
  font-size:26px;
  font-weight:700}
.la-stat .l {
  font-size:10px;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.5px;
  margin-top:3px}
.doc-template-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:18px;
  cursor:pointer;
  transition:all .15s}
.doc-template-card:hover {
  border-color:var(--gold);
  box-shadow:0 4px 14px rgba(0,0,0,.07);
  transform:translateY(-1px)}
.doc-preview {
  background:var(--bg3);
  border-radius:8px;
  padding:14px;
  font-size:11px;
  color:var(--text2);
  line-height:1.8;
  white-space:pre-wrap;
  font-family:monospace;
  max-height:200px;
  overflow-y:auto;
  border:1px solid var(--border)}
.hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  padding:8px;
  border-radius:8px;
  transition:background .15s;
  z-index:1001;
  background:none;
  border:none}
.hamburger:hover {
  background:var(--bg3)}
.hamburger span {
  display:block;
  width:22px;
  height:2px;
  background:var(--text2);
  border-radius:2px;
  transition:all .25s}
.hamburger.open span:nth-child(1) {
  transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2) {
  opacity:0}
.hamburger.open span:nth-child(3) {
  transform:translateY(-7px) rotate(-45deg)}
.sb-overlay {
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.5);
  z-index:999;
  backdrop-filter:blur(2px);
  pointer-events:none}
.sb-overlay.show {
  display:block;
  pointer-events:auto}

/* ═══════════════════════════════════════════════
   DESKTOP MEDIUM — Tablet Landscape (769px–1000px)
═══════════════════════════════════════════════ */
@media(min-width:769px) and (max-width:1000px){
  /* Content padding */
  .content{padding:14px !important}

  /* KPI grid 2-kolom */
  .kpi-grid{grid-template-columns:repeat(2,1fr) !important}
  .dash-kpi-strip{grid-template-columns:repeat(3,1fr) !important}
  .dash-kpi-wide{grid-template-columns:repeat(3,1fr) !important}

  /* Pipeline columns lebih ramping */
  .pk-col{min-width:170px !important;max-width:170px !important}

  /* Detail panel lebih ramping */
  .detail-panel{width:340px !important}

  /* Chart grid stack */
  .chart-grid-2{grid-template-columns:1fr !important}
  .chart-grid-3{grid-template-columns:1fr 1fr !important}

  /* Dashboard layout stack */
  .dash-layout{grid-template-columns:1fr !important}
  .dash-sidebar{display:none}

  /* Dash koordinator */
  .dash-layout-koord{grid-template-columns:1fr !important}
  .sg-stats{grid-template-columns:repeat(2,1fr) !important}

  /* Page header */
  .pg-header{flex-wrap:wrap !important;gap:8px}
  .pg-actions{flex-wrap:wrap !important}

  /* Grid 3-col → 2-col */
  .g3{grid-template-columns:1fr 1fr !important}
  .m3col{grid-template-columns:1fr 1fr !important}

  /* Inline grid overrides */
  div[style*="grid-template-columns:repeat(4,1fr)"],
  div[style*="grid-template-columns: repeat(4, 1fr)"]{
    grid-template-columns:repeat(2,1fr) !important}
  div[style*="grid-template-columns:3fr 2fr"],
  div[style*="grid-template-columns: 3fr 2fr"]{
    grid-template-columns:1fr !important}
}

/* ═══════════════════════════════════════════════
   MOBILE RESPONSIVE — Tablet (≤768px)
═══════════════════════════════════════════════ */
@media(max-width:768px){
  /* Sidebar */
  .hamburger{display:flex}
  .sidebar{
    position:fixed !important;
    left:-260px;top:0;
    height:100vh;width:240px !important;
    z-index:1000;
    transition:left .28s cubic-bezier(.4,0,.2,1);
    box-shadow:none;
    padding-top:56px;
    overflow-y:auto}
  .sidebar.open{
    left:0;
    box-shadow:6px 0 28px rgba(0,0,0,.18)}
  .app{margin-left:0 !important}

  /* Topbar */
  .topbar{padding:0 12px !important;gap:8px;height:50px !important}
  .tp-title{font-size:14px !important;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .tnav-right{gap:6px !important}
  #tnav-mode{display:none !important}
  .user-pill{padding:4px 10px !important}
  .user-pill .uname{
    max-width:80px;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
    font-size:12px !important}
  .user-pill .urole{display:none}
  .btn-out{padding:5px 10px !important;font-size:11px !important}

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

  /* Page header */
  .pg-header{
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:10px !important}
  .pg-title{font-size:20px !important}
  .pg-actions{
    width:100%;display:flex;
    flex-wrap:wrap;gap:6px}
  .pg-actions .btn{
    flex:1;justify-content:center;
    min-width:110px}

  /* KPI Grid — 2 kolom di tablet */
  .kpi-grid{grid-template-columns:repeat(2,1fr) !important;gap:10px !important}

  /* Inline grid overrides — JS-generated dashboards */
  div[style*="grid-template-columns:repeat(4,1fr)"],
  div[style*="grid-template-columns: repeat(4, 1fr)"]{
    grid-template-columns:repeat(2,1fr) !important}
  div[style*="grid-template-columns:3fr 2fr"],
  div[style*="grid-template-columns: 3fr 2fr"]{
    grid-template-columns:1fr !important}
  .kpi{padding:14px 12px !important}
  .k-val{font-size:26px !important}
  .k-lbl{font-size:10px !important}
  .k-delta{font-size:10px !important}

  /* Grid layouts */
  .g2,.g3{grid-template-columns:1fr !important}
  .m2col{grid-template-columns:1fr 1fr !important}
  .m3col{grid-template-columns:1fr 1fr !important}
  .dash-layout{grid-template-columns:1fr !important}
  .dash-sidebar{display:none}

  /* Tables */
  .tbl-wrap{overflow-x:auto !important;-webkit-overflow-scrolling:touch}
  table{min-width:480px}

  /* Modals — bottom sheet */
  .modal{
    width:100% !important;max-width:100vw !important;
    border-radius:20px 20px 0 0 !important;
    padding:16px 14px !important;
    position:fixed !important;
    bottom:0 !important;left:0 !important;right:0 !important;
    margin:0 !important;
    max-height:85vh !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch}
  .overlay{align-items:flex-end !important;z-index:1100 !important}
  .mfooter{flex-wrap:wrap !important;gap:8px !important}
  .mfooter .btn{flex:1;min-width:120px;justify-content:center}

  /* Pipeline kanban */
  .pipe-board{overflow-x:auto !important;-webkit-overflow-scrolling:touch}
  .pipe-col{min-width:220px !important;max-width:220px !important}

  /* Lead detail panel */
  .detail-panel{
    width:100% !important;
    position:fixed !important;
    bottom:0 !important;left:0 !important;right:0 !important;
    height:90vh !important;
    border-radius:20px 20px 0 0 !important;
    z-index:950;
    -webkit-overflow-scrolling:touch}

  /* WA panel */
  .wa-panel{
    width:100% !important;right:0 !important;left:0 !important;
    border-radius:0 !important;height:100vh !important;
    z-index:940 !important}

  /* Buttons — min 44px touch target */
  .btn{min-height:44px !important}
  .btn-sm{min-height:34px !important;padding:6px 12px !important}

  /* Sidebar nav items */
  .ni{padding:11px 16px !important;font-size:13px !important}
  .ni .ic{font-size:15px !important}
  .pkc{font-size:11px !important}

  /* Proyek/unit cards */
  .proyek-card{min-width:100% !important}
  .lead-inbox{max-width:100% !important}

  /* Filter bar scroll */
  .filter-bar{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    flex-wrap:nowrap !important;
    padding-bottom:4px}
  .filter-bar::-webkit-scrollbar{height:3px}
  .filter-bar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

  /* Search bar full width */
  .search-row{flex-direction:column !important;gap:8px !important}
  .search-row input{width:100% !important}

  /* Cards stack */
  div[style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr) !important}
  div[style*="grid-template-columns:repeat(3"]{grid-template-columns:repeat(2,1fr) !important}
  /* Varian dengan spasi (JS inline style bisa generate keduanya) */
  div[style*="grid-template-columns: repeat(4"]{grid-template-columns:repeat(2,1fr) !important}
  div[style*="grid-template-columns: repeat(3"]{grid-template-columns:repeat(2,1fr) !important}
}

/* ═══════════════════════════════════════════════
   MOBILE RESPONSIVE — Phone (≤480px)
═══════════════════════════════════════════════ */
@media(max-width:480px){
  /* Login card */
  .login-card{
    width:calc(100vw - 24px) !important;
    padding:32px 20px !important;
    border-radius:16px !important;
    margin:12px}
  .login-brand .wordmark{font-size:26px !important;letter-spacing:5px !important}
  .login-card h2{font-size:20px !important}
  .fg input{font-size:16px !important;padding:14px 14px !important}
  .btn-login{padding:15px !important;font-size:13px !important}

  /* KPI Grid — 2 kolom tetap di phone */
  .kpi-grid{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}

  /* Inline grid overrides — JS-generated dashboards */
  div[style*="grid-template-columns:repeat(4,1fr)"],
  div[style*="grid-template-columns:repeat(3,1fr)"],
  div[style*="grid-template-columns: repeat(4, 1fr)"],
  div[style*="grid-template-columns: repeat(3, 1fr)"]{
    grid-template-columns:repeat(2,1fr) !important}
  div[style*="grid-template-columns:3fr 2fr"],
  div[style*="grid-template-columns: 3fr 2fr"]{
    grid-template-columns:1fr !important}
  .kpi{padding:12px 10px !important;border-radius:12px !important}
  .k-ic{font-size:16px !important;margin-bottom:6px !important}
  .k-val{font-size:22px !important}
  .k-lbl{font-size:9px !important}

  /* Grid */
  .m2col,.m3col{grid-template-columns:1fr !important}
  .g2,.g3{grid-template-columns:1fr !important}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr 1fr !important}
  div[style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr 1fr !important}
  div[style*="auto-fill,minmax(260px"]{grid-template-columns:1fr !important}
  div[style*="auto-fill,minmax(240px"]{grid-template-columns:1fr !important}
  div[style*="auto-fill,minmax(200px"]{grid-template-columns:1fr !important}

  /* Topbar */
  .tp-breadcrumb{display:none}
  .tp-title,.pgtitle{max-width:90px !important}
  .av.av-sm{width:30px !important;height:30px !important}

  /* Page title */
  .pg-title{font-size:18px !important}
  .card-title{font-size:13px !important}

  /* Tables — sembunyikan kolom 5+ */
  table th:nth-child(n+5),table td:nth-child(n+5){display:none}
  table{min-width:360px}

  /* Modal */
  .modal{max-height:80vh !important;padding:14px 12px !important}
  .modal h3{font-size:16px !important}

  /* Buttons */
  .tnav-right .btn{padding:5px 8px !important;font-size:11px !important}
  .btn{min-height:44px !important;font-size:12px !important}
  .btn-sm{min-height:36px !important;padding:6px 10px !important}

  /* Content */
  .content{padding:10px !important}

  /* Pipeline */
  .pipe-col{min-width:200px !important;max-width:200px !important}

  /* Sidebar */
  .sb-lbl{padding:8px 14px 3px !important;font-size:9px !important}
  .ni{padding:10px 14px !important;font-size:12.5px !important}

  /* WA badge */
  .wa-bell{width:36px !important;height:36px !important}

  /* Form groups — 16px prevents iOS auto-zoom on focus */
  .fg input,.fg select,.fg textarea,
  .fg2 input,.fg2 select,.fg2 textarea{font-size:16px !important}

  /* Cards padding */
  .card{padding:14px !important}
  .tbl-wrap{border-radius:10px !important}
  th{padding:9px 12px !important;font-size:9px !important;letter-spacing:1px !important}
  td{padding:9px 12px !important;font-size:12px !important}
}

@media print {
  .sidebar,.topbar,.wa-bell,.hamburger,.sb-overlay {
  display:none !important}
.app {
  margin:0 !important}
.content {
  padding:0 !important}
.modal {
  position:static !important;
  box-shadow:none !important}
}

/* ── CHART CONTAINERS ───────────────────────────── */
.chart-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  box-shadow:var(--shadow)}
.chart-card-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px}
.chart-card-title {
  font-size:11px;
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase;
  color:var(--text3)}
.chart-wrap {
  position:relative}
.chart-grid-2 {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:14px}
.chart-grid-3 {
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:14px;
  margin-bottom:14px}

/* ── DASH KPI STRIP ─────────────────────────────── */
.dash-kpi-strip {
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:12px;
  margin-bottom:16px}
.dks {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px;
  box-shadow:var(--shadow);
  cursor:pointer;
  transition:box-shadow .2s,transform .15s;
  position:relative;
  overflow:hidden}
.dks::after {
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;
  width:3px;
  border-radius:3px 0 0 3px;
  background:var(--dks-clr,var(--gold))}
.dks:hover {
  box-shadow:var(--shadow-md);
  transform:translateY(-2px)}
.dks-top {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:8px}
.dks-ic {
  font-size:18px}
.dks-badge {
  font-size:10px;
  font-weight:700;
  padding:2px 8px;
  border-radius:20px}
.dks-val {
  font-family:Rajdhani,sans-serif;
  font-size:28px;
  font-weight:700;
  line-height:1;
  margin-bottom:2px}
.dks-lbl {
  font-size:11px;
  color:var(--text3)}
.dks-sub {
  font-size:10px;
  color:var(--text3);
  margin-top:4px}

/* ── INSIGHT STRIP ──────────────────────────────── */
.alert-strip {
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:16px}
.alert-item {
  display:flex;
  align-items:center;
  gap:12px;
  padding:11px 16px;
  border-radius:10px;
  border:1px solid}
.alert-item .ai-ic {
  font-size:18px;
  flex-shrink:0}
.alert-item .ai-body {
  flex:1}
.alert-item .ai-title {
  font-size:13px;
  font-weight:700}
.alert-item .ai-desc {
  font-size:11px;
  margin-top:2px;
  opacity:.8}

/* ── STAT NUMBER ────────────────────────────────── */
.stat-num {
  font-family:Rajdhani,sans-serif;
  font-weight:700;
  line-height:1}

/* ═══════════════════════════════════════════════
   MOBILE FIX — Tablet ≤768px (tambahan)
═══════════════════════════════════════════════ */
@media(max-width:768px){

  /* Dashboard koordinator: 2-kolom → 1-kolom */
  .dash-layout-koord{grid-template-columns:1fr !important}
  .dash-kpi-strip{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}
  .dash-kpi-wide{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}

  /* Sales card inner stats */
  .kst-info{grid-template-columns:repeat(3,1fr) !important}
  .sg-stats{grid-template-columns:repeat(2,1fr) !important}

  /* Filter bar lead list — bungkus ke 2 baris */
  .filter-row{flex-wrap:wrap !important}
  .filter-row .sbox{flex:0 0 100% !important;min-width:0 !important}
  .filter-row .fsel{flex:1 1 calc(50% - 5px) !important;min-width:120px !important}

  /* Laporan view tabs — scroll horizontal */
  .li-tabs,.laporan-tabs,.report-tabs{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    flex-wrap:nowrap !important}
  .li-tabs::-webkit-scrollbar,.laporan-tabs::-webkit-scrollbar{height:3px}
  .li-tabs::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

  /* Pipeline — fix class name yang salah */
  .pipeline-board{overflow-x:auto !important;-webkit-overflow-scrolling:touch}
  .pk-col{min-width:220px !important;max-width:220px !important}

  /* Toast — full-width di mobile, above panels */
  .toast{
    left:12px !important;right:12px !important;
    bottom:16px !important;width:auto !important;
    max-width:100% !important;
    z-index:970 !important}

  /* Topbar title tidak wrap */
  .tp-title,.pgtitle{
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    max-width:130px !important}

  /* Chart grid responsive */
  .chart-grid-2,.chart-grid-3{grid-template-columns:1fr !important}

  /* Pipe summary 2 cols */
  .pipe-summary{grid-template-columns:repeat(2,1fr) !important}
}

/* ═══════════════════════════════════════════════
   MOBILE FIX — Phone ≤480px (tambahan)
═══════════════════════════════════════════════ */
@media(max-width:480px){

  /* Dashboard KPI 2x2 */
  .dash-kpi-strip{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}
  .dash-kpi-wide{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}
  .dks{padding:12px !important}
  .dks-val{font-size:22px !important}

  /* Sales card stats stack */
  .kst-info{grid-template-columns:repeat(2,1fr) !important}
  .sg-stats{grid-template-columns:repeat(2,1fr) !important}
  .sales-grid{grid-template-columns:1fr !important}

  /* Filter row — 1 kolom penuh */
  .filter-row{flex-direction:column !important;gap:8px !important}
  .filter-row .sbox,
  .filter-row .fsel{width:100% !important;flex:none !important}

  /* Laporan: period tabs & content tabs scroll */
  .lap-tabs-group{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    flex-wrap:nowrap !important;
    padding-bottom:4px;
    scrollbar-width:none;
    -ms-overflow-style:none}
  .lap-tabs-group::-webkit-scrollbar{display:none}
  .lap-period-group{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    flex-wrap:nowrap !important;
    scrollbar-width:none}
  .lap-period-group::-webkit-scrollbar{display:none}
  .lap-nav-row{flex-wrap:wrap !important;gap:8px !important}

  /* Inline grid: 6 kolom → 3 kolom, 5 kolom → 2 kolom */
  div[style*="repeat(6,1fr)"]{grid-template-columns:repeat(3,1fr) !important}
  div[style*="repeat(5,1fr)"]{grid-template-columns:repeat(2,1fr) !important}

  /* Lead table — sembunyikan kolom 4+ agar muat */
  #lead-tbl-wrap table th:nth-child(n+4),
  #lead-tbl-wrap table td:nth-child(n+4){display:none}
  #lead-tbl-wrap table{min-width:280px !important}

  /* Pipeline columns lebih ramping */
  .pk-col{min-width:200px !important;max-width:200px !important}

  /* KPI cards dashboard koordinator */
  .dk-wide{padding:12px !important}
  .dk-wide .dkw-val{font-size:22px !important}

  /* Tab scroll */
  .li-tabs,.laporan-tabs,.report-tabs,.pill-tabs{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    flex-wrap:nowrap !important;
    -ms-overflow-style:none;
    scrollbar-width:none}
  .li-tabs::-webkit-scrollbar{display:none}

  /* Insight banner stack */
  .insight-banner{flex-direction:column !important;gap:8px !important}

  /* Page header actions full width */
  .pg-actions{width:100% !important}
  .pg-actions .btn{flex:1 !important;justify-content:center !important}

  /* WA panel full screen */
  .wa-panel{width:100vw !important;left:0 !important;right:0 !important}

  /* Stale card wrap */
  .stale-card{flex-wrap:wrap !important;gap:8px !important}

  /* Detail panel handle indicator */
  .detail-panel::before{
    content:'';
    display:block;
    width:40px;height:4px;
    background:var(--border2);
    border-radius:2px;
    margin:0 auto 16px}

  /* Alert strip */
  .alert-item{flex-wrap:wrap !important}
  .alert-item .ai-body{min-width:0 !important}

  /* Reminder stale cards */
  .stale-card .sc-actions{flex-wrap:wrap !important;gap:6px !important}
  .stale-card .sc-actions .btn{flex:1;min-width:100px}

  /* Table min-width global dikurangi */
  table{min-width:280px !important}
  th{padding:8px 10px !important;font-size:9px !important}
  td{padding:8px 10px !important;font-size:12px !important}

  /* Notif panel — jangan keluar layar di mobile */
  #notif-panel{
    right:8px !important;
    left:8px !important;
    width:auto !important;
    max-width:420px !important;
  }
}
