/* ============================================================
   AMARTA MLM — Main CSS v4 (Collapsible Sidebar)
   ============================================================ */
:root {
  --primary:       #1a5f3f;
  --primary-dark:  #0d3320;
  --primary-mid:   #2d8a5e;
  --primary-light: #e8f5ee;
  --accent:        #f5a623;
  --danger:        #e53935;
  --warning:       #f57c00;
  --success:       #2e7d32;
  --info:          #1565c0;
  --bg:            #f0f4f2;
  --surface:       #ffffff;
  --surface2:      #f7faf8;
  --border:        #dde5e0;
  --text-dark:     #1a2b22;
  --text-muted:    #5a7568;
  --sidebar-w:     240px;
  --sidebar-mini:  64px;
  --topbar-h:      60px;
  --radius:        10px;
  --shadow-sm:     0 1px 4px rgba(0,0,0,.07);
  --shadow:        0 2px 12px rgba(0,0,0,.09);
  --transition:    .25s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:14px;scroll-behavior:smooth;}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text-dark);min-height:100vh;line-height:1.5;}

/* ============================================================ LAYOUT */
.layout{display:flex;min-height:100vh;}

/* ============================================================ SIDEBAR */
.sidebar{
  width:var(--sidebar-w);
  background:linear-gradient(180deg,var(--primary-dark) 0%,var(--primary) 100%);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;
  z-index:200;overflow:hidden;
  transition:width var(--transition);
  flex-shrink:0;
}
.sidebar::-webkit-scrollbar{width:3px;}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);}

/* COLLAPSED state */
.sidebar.collapsed{width:var(--sidebar-mini);}
.sidebar.collapsed .logo-text,
.sidebar.collapsed .logo-sub,
.sidebar.collapsed .sidebar-user-name,
.sidebar.collapsed .sidebar-user-code,
.sidebar.collapsed .nav-label,
.sidebar.collapsed .nav-badge,
.sidebar.collapsed .nav-section{
  opacity:0;width:0;overflow:hidden;white-space:nowrap;
  transition:opacity .15s,width .15s;
}
.sidebar.collapsed .sidebar-header{padding:.85rem;justify-content:center;}
.sidebar.collapsed .sidebar-user{padding:.6rem;justify-content:center;margin:.4rem;}
.sidebar.collapsed .sidebar-user .sidebar-avatar{margin:0;}
.sidebar.collapsed .nav-item{padding:.65rem;justify-content:center;gap:0;}
.sidebar.collapsed .nav-icon{width:22px;font-size:1.1rem;}
.sidebar.collapsed .nav-item.active::before{width:3px;}
.sidebar.collapsed .collapse-btn .ico-collapse{transform:rotate(180deg);}
.sidebar.collapsed .sidebar-nav{overflow-y:auto;overflow-x:hidden;}

/* Tooltip on collapsed */
.sidebar.collapsed .nav-item{position:relative;}
.sidebar.collapsed .nav-item:hover::after{
  content:attr(data-tooltip);
  position:absolute;left:calc(var(--sidebar-mini) + 8px);top:50%;transform:translateY(-50%);
  background:rgba(13,51,32,.95);color:#fff;padding:.35rem .75rem;border-radius:6px;
  font-size:.78rem;font-weight:600;white-space:nowrap;z-index:300;
  pointer-events:none;box-shadow:0 4px 12px rgba(0,0,0,.2);
}

/* Collapse button */
.collapse-btn{
  display:flex;align-items:center;justify-content:flex-end;
  padding:.5rem .75rem .5rem 1rem;
  border-top:1px solid rgba(255,255,255,.1);
  cursor:pointer;background:none;border:none;width:100%;
  color:rgba(255,255,255,.6);font-size:.78rem;gap:.5rem;
  transition:background .15s;flex-shrink:0;
}
.collapse-btn:hover{background:rgba(255,255,255,.08);color:#fff;}
.ico-collapse{
  width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.15);
  display:grid;place-items:center;font-size:.65rem;flex-shrink:0;
  transition:transform var(--transition);
}
.sidebar.collapsed .collapse-btn{justify-content:center;padding:.5rem;}
.sidebar.collapsed .collapse-btn .collapse-label{display:none;}

/* HEADER */
.sidebar-header{
  padding:1rem 1rem .85rem;
  border-bottom:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;gap:.6rem;flex-shrink:0;
  overflow:hidden;white-space:nowrap;
}
.logo-icon{font-size:1.75rem;line-height:1;flex-shrink:0;}
.logo-text{font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:.04em;line-height:1.1;transition:opacity var(--transition),width var(--transition);}
.logo-sub{font-size:.62rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.06em;transition:opacity var(--transition),width var(--transition);}

/* USER CARD */
.sidebar-user{
  display:flex;align-items:center;gap:.65rem;
  padding:.8rem 1rem;background:rgba(0,0,0,.18);
  margin:.5rem .55rem .2rem;border-radius:8px;
  overflow:hidden;white-space:nowrap;flex-shrink:0;
  transition:padding var(--transition),margin var(--transition);
}
.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:var(--primary-dark);display:grid;place-items:center;font-weight:700;font-size:.88rem;flex-shrink:0;}
.sidebar-user-name{font-size:.8rem;font-weight:700;color:#fff;overflow:hidden;transition:opacity var(--transition),width var(--transition);}
.sidebar-user-code{font-size:.67rem;color:rgba(255,255,255,.45);margin-top:1px;overflow:hidden;transition:opacity var(--transition),width var(--transition);}

/* NAV */
.sidebar-nav{padding:.3rem 0 .5rem;flex:1;overflow-y:auto;overflow-x:hidden;}
.nav-section{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.3);padding:.85rem 1rem .25rem;overflow:hidden;white-space:nowrap;transition:opacity var(--transition),width var(--transition);}
.nav-item{
  display:flex;align-items:center;gap:.6rem;
  padding:.58rem 1rem;color:rgba(255,255,255,.72);
  text-decoration:none;font-size:.82rem;font-weight:500;
  transition:background .15s,color .15s,padding var(--transition),justify-content var(--transition);
  position:relative;cursor:pointer;border:none;background:none;width:100%;overflow:hidden;
}
.nav-item:hover{background:rgba(255,255,255,.09);color:#fff;}
.nav-item.active{background:rgba(255,255,255,.14);color:#fff;font-weight:600;}
.nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);border-radius:0 2px 2px 0;}
.nav-icon{font-size:1rem;flex-shrink:0;width:20px;text-align:center;transition:width var(--transition);}
.nav-label{flex:1;overflow:hidden;white-space:nowrap;transition:opacity var(--transition),width var(--transition);}
.nav-badge{background:var(--danger);color:#fff;font-size:.6rem;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;flex-shrink:0;transition:opacity var(--transition),width var(--transition);}

/* ============================================================ MAIN WRAP */
.main-wrap{
  margin-left:var(--sidebar-w);
  flex:1;display:flex;flex-direction:column;min-height:100vh;min-width:0;
  transition:margin-left var(--transition);
}
.sidebar.collapsed ~ .main-wrap,
body.sidebar-collapsed .main-wrap{margin-left:var(--sidebar-mini);}

/* ============================================================ TOPBAR */
.topbar{
  height:var(--topbar-h);background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 1.25rem;gap:.85rem;
  position:sticky;top:0;z-index:100;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.topbar-title{font-size:.92rem;font-weight:600;flex:1;color:var(--text-dark);}
.topbar-actions{display:flex;align-items:center;gap:.65rem;}
.menu-toggle{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-dark);padding:.3rem .4rem;border-radius:6px;line-height:1;transition:background .15s;display:none;}
.menu-toggle:hover{background:var(--primary-light);}

/* Breadcrumb */
.breadcrumb{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem;}
.breadcrumb a{color:var(--primary);text-decoration:none;}
.breadcrumb a:hover{text-decoration:underline;}
.breadcrumb-sep{color:var(--border);}

/* ============================================================ CONTENT */
.content-area{flex:1;padding:1.35rem 1.5rem;}

/* OVERLAY (mobile) */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:150;}
.sidebar-overlay.show{display:block;}

/* ============================================================ FLASH */
.flash-msg{padding:.75rem 1.5rem;font-size:.87rem;font-weight:500;display:flex;align-items:center;gap:.6rem;}
.flash-msg button{margin-left:auto;background:none;border:none;cursor:pointer;font-size:1rem;opacity:.6;}
.flash-msg button:hover{opacity:1;}
.flash-success{background:#e8f5e9;color:#2e7d32;border-bottom:2px solid #a5d6a7;}
.flash-danger {background:#fce4ec;color:#c62828;border-bottom:2px solid #f9c6c6;}
.flash-warning{background:#fff8e1;color:#e65100;border-bottom:2px solid #ffe082;}
.flash-info   {background:#e3f2fd;color:#1565c0;border-bottom:2px solid #90caf9;}

/* ============================================================ PAGE HEADER */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.35rem;flex-wrap:wrap;gap:.75rem;}
.page-title{font-size:1.25rem;font-weight:700;color:var(--text-dark);margin:0 0 .15rem;}
.page-subtitle{font-size:.8rem;color:var(--text-muted);margin:0;}

/* ============================================================ METRICS */
.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.9rem;margin-bottom:1.35rem;}
.metric-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:1rem 1.1rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s;}
.metric-card:hover{box-shadow:var(--shadow);}
.metric-icon{width:40px;height:40px;border-radius:9px;display:grid;place-items:center;font-size:1.15rem;margin-bottom:.6rem;}
.metric-value{font-size:1.4rem;font-weight:800;color:var(--text-dark);line-height:1.1;margin-bottom:.2rem;}
.metric-label{font-size:.75rem;color:var(--text-muted);font-weight:500;}
.metric-change{font-size:.7rem;color:var(--text-muted);margin-top:.2rem;}

/* ============================================================ CARDS */
.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.15rem;border-bottom:1px solid var(--border);background:var(--surface2);gap:.75rem;flex-wrap:wrap;}
.card-title{font-size:.9rem;font-weight:700;color:var(--text-dark);margin:0;}
.card-body{padding:1.15rem;}

/* ============================================================ BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.46rem .9rem;border-radius:7px;font-size:.81rem;font-weight:600;cursor:pointer;border:1px solid transparent;text-decoration:none;transition:all .15s;white-space:nowrap;line-height:1.4;}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary-dark);}
.btn-primary:hover{background:var(--primary-dark);}
.btn-outline{background:transparent;border-color:var(--primary);color:var(--primary);}
.btn-outline:hover{background:var(--primary-light);}
.btn-danger{background:var(--danger);color:#fff;border-color:#b71c1c;}
.btn-danger:hover{background:#c62828;}
.btn-success{background:var(--success);color:#fff;border-color:#1b5e20;}
.btn-success:hover{background:#1b5e20;}
.btn-warning{background:#ff9800;color:#fff;border-color:#e65100;}
.btn-sm{padding:.3rem .7rem;font-size:.76rem;border-radius:6px;}
.btn-xs{padding:.2rem .5rem;font-size:.7rem;border-radius:5px;}
.btn-lg{padding:.7rem 1.4rem;font-size:.88rem;}

/* ============================================================ FORMS */
.form-group{margin-bottom:.9rem;}
.form-label{display:block;font-weight:600;font-size:.8rem;color:var(--text-dark);margin-bottom:.3rem;}
.form-control{display:block;width:100%;padding:.5rem .8rem;border:1px solid var(--border);border-radius:7px;font-size:.86rem;background:#fff;color:var(--text-dark);transition:border-color .15s,box-shadow .15s;}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,95,63,.1);}
.form-hint{font-size:.73rem;color:var(--text-muted);margin-top:.22rem;}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 .9rem;}
@media(max-width:600px){.form-grid-2{grid-template-columns:1fr;}}

/* ============================================================ TABLE */
.data-table{width:100%;border-collapse:collapse;font-size:.83rem;}
.data-table thead tr{background:#f5f7f6;border-bottom:2px solid var(--border);}
.data-table th{padding:.6rem .9rem;text-align:left;font-weight:600;font-size:.69rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);white-space:nowrap;}
.data-table td{padding:.6rem .9rem;border-bottom:1px solid var(--border);vertical-align:middle;}
.data-table tbody tr:hover{background:#fafcfb;}
.data-table tbody tr:last-child td{border-bottom:none;}
.text-muted{color:var(--text-muted)!important;}

/* ============================================================ BADGES */
.badge{display:inline-flex;align-items:center;padding:.16rem .6rem;border-radius:20px;font-size:.7rem;font-weight:700;}
.badge-diamond{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#0d47a1;}
.badge-gold   {background:linear-gradient(135deg,#fff8e1,#ffe082);color:#e65100;}
.badge-silver {background:linear-gradient(135deg,#f5f5f5,#e0e0e0);color:#424242;}
.badge-bronze {background:linear-gradient(135deg,#fbe9e7,#ffccbc);color:#bf360c;}
.badge-member {background:#e8f5e9;color:#2e7d32;}
.badge-active {background:#e8f5e9;color:#2e7d32;}
.badge-inactive,.badge-suspended,.badge-banned{background:#fce4ec;color:#c62828;}
.badge-pending   {background:#fff8e1;color:#f57f17;}
.badge-confirmed {background:#e8f5e9;color:#2e7d32;}
.badge-rejected  {background:#fce4ec;color:#c62828;}
.badge-calculated{background:#e3f2fd;color:#1565c0;}
.badge-approved  {background:#e8f5e9;color:#2e7d32;}
.badge-paid      {background:#e0f2f1;color:#00695c;}
.badge-resolved  {background:#e8f5e9;color:#2e7d32;}
.badge-false-alarm{background:#f5f5f5;color:#757575;}

/* CRM Status badges */
.badge-crm-hot     {background:#fce4ec;color:#c62828;border:1px solid #f9c6c6;}
.badge-crm-active  {background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;}
.badge-crm-warming {background:#fff8e1;color:#e65100;border:1px solid #ffe082;}
.badge-crm-cold    {background:#fce4ec;color:#c62828;border:1px solid #f9c6c6;}
.badge-crm-new     {background:#e3f2fd;color:#1565c0;border:1px solid #90caf9;}
.badge-crm-dormant {background:#f5f5f5;color:#757575;border:1px solid #e0e0e0;}

/* ============================================================ TABS */
.tabs{display:flex;border-bottom:2px solid var(--border);overflow-x:auto;}
.tab-btn{background:none;border:none;padding:.65rem 1.1rem;font-size:.81rem;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:color .15s,border-color .15s;}
.tab-btn:hover{color:var(--primary);}
.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);}
.tab-content{display:none;padding-top:1rem;}
.tab-content.active{display:block;}

/* ============================================================ MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;}
.modal{background:#fff;border-radius:14px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.25);max-height:92vh;display:flex;flex-direction:column;}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.4rem;border-bottom:1px solid var(--border);flex-shrink:0;}
.modal-title{font-size:.92rem;font-weight:700;margin:0;}
.modal-body{padding:1.15rem 1.4rem;overflow-y:auto;flex:1;}
.modal-footer{padding:.85rem 1.4rem;border-top:1px solid var(--border);display:flex;gap:.55rem;justify-content:flex-end;flex-shrink:0;}
.modal-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted);padding:.2rem;border-radius:4px;}
.modal-close:hover{background:#f5f5f5;}

/* ============================================================ LOGIN */
.login-body{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 60%,var(--primary-dark) 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;}
.login-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.35);}
.login-header{background:linear-gradient(135deg,var(--primary),var(--primary-mid));padding:2.25rem 2rem;text-align:center;color:#fff;}
.login-logo{font-size:2.75rem;margin-bottom:.4rem;}
.login-title{font-size:1.4rem;font-weight:800;margin:0 0 .2rem;}
.login-subtitle{font-size:.82rem;opacity:.75;margin:0;}
.login-error{background:#fce4ec;color:#c62828;border:1px solid #f9c6c6;padding:.7rem 1.25rem;font-size:.83rem;}
.login-form{padding:1.6rem 1.85rem 1.85rem;}

/* ============================================================ MEMBER HERO */
.member-hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-mid) 60%,var(--primary-dark) 100%);border-radius:14px;padding:1.6rem;color:#fff;position:relative;overflow:hidden;margin-bottom:0;}
.hero-content{display:flex;align-items:center;gap:1rem;position:relative;}
.hero-avatar{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.2);border:3px solid rgba(255,255,255,.4);display:grid;place-items:center;font-size:1.7rem;font-weight:700;color:#fff;flex-shrink:0;}
.hero-info{flex:1;}
.hero-name{font-size:1.25rem;font-weight:700;margin:0 0 .15rem;}
.hero-meta{font-size:.8rem;opacity:.75;margin-bottom:.3rem;}
.hero-rank{text-align:center;background:rgba(255,255,255,.12);border-radius:10px;padding:.6rem .9rem;flex-shrink:0;}
.rank-label{font-size:.62rem;opacity:.7;text-transform:uppercase;letter-spacing:.05em;}
.rank-icon{font-size:1.7rem;line-height:1.2;}
.rank-name{font-size:.8rem;font-weight:700;margin-top:.15rem;}
.hero-progress{margin-top:1rem;position:relative;}
.progress-label{display:flex;justify-content:space-between;font-size:.77rem;opacity:.85;margin-bottom:.3rem;}
.hero-progress-bar{background:rgba(255,255,255,.2);border-radius:5px;height:7px;overflow:hidden;}
.hero-progress-fill{height:100%;background:linear-gradient(90deg,#f9c74f,#f4a261);border-radius:5px;transition:width .8s ease;}

/* ============================================================ MEMBER SIDEBAR */
.sidebar-member-card{display:flex;align-items:center;gap:.65rem;padding:.8rem .9rem;background:rgba(255,255,255,.08);margin:.5rem .55rem .2rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);overflow:hidden;white-space:nowrap;}
.sm-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--primary-dark);display:grid;place-items:center;font-weight:700;font-size:.95rem;flex-shrink:0;}
.sm-name{font-weight:700;color:#fff;font-size:.8rem;}
.sm-code{font-size:.67rem;color:rgba(255,255,255,.55);margin-bottom:.12rem;}
.sidebar.collapsed .sidebar-member-card{justify-content:center;padding:.6rem;}
.referral-box{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border:1px solid #a5d6a7;border-radius:10px;padding:.85rem 1.1rem;}
.referral-link{background:#fff;border:1px solid var(--border);border-radius:6px;padding:.4rem .7rem;font-size:.76rem;color:var(--text-muted);word-break:break-all;margin:.4rem 0;font-family:monospace;}

/* ============================================================ TOPBAR MEMBER */
.topbar-notif{position:relative;font-size:1.15rem;text-decoration:none;color:var(--text-dark);padding:.3rem;}
.notif-dot{position:absolute;top:0;right:0;background:var(--danger);color:#fff;font-size:.56rem;font-weight:700;min-width:14px;height:14px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;}
.topbar-avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:inline-grid;place-items:center;font-weight:700;font-size:.8rem;}

/* ============================================================ AUTOCOMPLETE */
.ac-wrap{position:relative;}
.ac-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:500;max-height:260px;overflow-y:auto;display:none;margin-top:2px;}
.ac-item{padding:.55rem .9rem;cursor:pointer;border-bottom:1px solid #f5f5f5;display:flex;flex-direction:column;gap:.08rem;}
.ac-item:hover{background:var(--primary-light);}
.ac-item strong{font-size:.86rem;color:var(--text-dark);}
.ac-meta{font-size:.72rem;color:var(--text-muted);}

/* ============================================================ MLM */
.mlm-mode-btn{padding:.38rem .85rem;border-radius:20px;border:2px solid var(--border);background:#fff;cursor:pointer;font-size:.76rem;font-weight:600;color:var(--text-muted);transition:all .15s;}
.mlm-mode-btn.active{border-color:var(--primary);background:var(--primary);color:#fff;}
.mlm-mode-btn:hover:not(.active){border-color:var(--primary);color:var(--primary);}

/* ============================================================ CRM */
.crm-segment-card{border-radius:10px;padding:1rem 1.15rem;display:flex;align-items:center;gap:.9rem;border:1px solid transparent;cursor:pointer;transition:all .2s;}
.crm-segment-card:hover{transform:translateY(-1px);box-shadow:var(--shadow);}
.crm-segment-icon{width:44px;height:44px;border-radius:10px;display:grid;place-items:center;font-size:1.3rem;flex-shrink:0;}
.crm-segment-count{font-size:1.5rem;font-weight:800;line-height:1;}
.crm-segment-label{font-size:.8rem;font-weight:600;margin:.1rem 0;}
.crm-segment-sub{font-size:.71rem;opacity:.7;}
.crm-score-bar{height:6px;border-radius:3px;background:#f0f0f0;overflow:hidden;margin-top:.3rem;}
.crm-score-fill{height:100%;border-radius:3px;transition:width .6s;}
.crm-timeline{display:flex;flex-direction:column;gap:.5rem;}
.crm-tl-item{display:flex;gap:.75rem;align-items:flex-start;}
.crm-tl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:.35rem;}
.crm-tl-line{width:1px;background:var(--border);flex-shrink:0;margin:0 4.5px;}
.crm-activity-heat{display:grid;grid-template-columns:repeat(12,1fr);gap:3px;margin-top:.5rem;}
.crm-heat-cell{aspect-ratio:1;border-radius:2px;background:#f0f0f0;cursor:pointer;}
.priority-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0;}
.note-bubble{background:#f9fff9;border:1px solid #a5d6a7;border-radius:10px;padding:.6rem .85rem;font-size:.82rem;margin-bottom:.5rem;position:relative;}
.note-bubble::before{content:'"';font-size:1.5rem;color:#a5d6a7;line-height:0;vertical-align:-0.4rem;margin-right:.2rem;}

/* ============================================================ MISC */
.alert{padding:.8rem 1.15rem;border-radius:8px;margin-bottom:1.1rem;font-size:.85rem;}
.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;}
.alert-danger{background:#fce4ec;color:#c62828;border:1px solid #f9c6c6;}
.alert-warning{background:#fff8e1;color:#e65100;border:1px solid #ffe082;}
.alert-info{background:#e3f2fd;color:#1565c0;border:1px solid #90caf9;}
.section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.55rem;padding-bottom:.3rem;border-bottom:1px solid var(--border);}

/* ============================================================ RESPONSIVE */
@media(max-width:900px){
  .menu-toggle{display:flex!important;}
  .sidebar{transform:translateX(-100%);width:var(--sidebar-w)!important;}
  .sidebar.open{transform:translateX(0);}
  .main-wrap{margin-left:0!important;}
}
@media(max-width:600px){
  .content-area{padding:.9rem;}
  .metrics-grid{grid-template-columns:1fr 1fr!important;}
  .page-header{flex-direction:column;align-items:flex-start;}
}

::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;}
