:root,
[data-theme="light"] {
  --bg-primary: #f0f4f8;
  --bg-secondary: #ffffff;
  --bg-card: #ffffff;
  --bg-card-hover: #f8fafc;
  --bg-input: #f1f5f9;
  --sidebar-bg: #ffffff;
  --sidebar-border: #e2e8f0;
  --sidebar-text: #475569;
  --sidebar-text-muted: #94a3b8;
  --sidebar-text-active: #0f172a;
  --sidebar-hover-bg: #f1f5f9;
  --sidebar-active-bg: rgba(59,130,246,0.1);
  --sidebar-shadow: 0 0 0 1px rgba(0,0,0,0.04), 4px 0 24px rgba(0,0,0,0.06);
  --border: #e2e8f0;
  --border-light: #cbd5e1;
  --text-primary: #0f172a;
  --text-secondary: #475569;
  --text-muted: #94a3b8;
  --accent-blue: #3b82f6;
  --accent-blue-glow: rgba(59,130,246,0.12);
  --accent-cyan: #06b6d4;
  --accent-green: #10b981;
  --accent-yellow: #f59e0b;
  --accent-orange: #f97316;
  --accent-red: #ef4444;
  --accent-purple: #8b5cf6;
  --accent-pink: #ec4899;
  --status-new: #3b82f6;
  --status-pending: #f59e0b;
  --status-verify: #f97316;
  --status-approved: #10b981;
  --status-disbursed: #8b5cf6;
  --status-rejected: #ef4444;
  --status-overdue: #dc2626;
  --status-closed: #6b7280;
  --shadow-card: 0 4px 24px rgba(0,0,0,0.08);
  --shadow-glow: 0 0 30px rgba(59,130,246,0.08);
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --sidebar-width: 260px;
  --header-height: 64px;
  --transition: all 0.2s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="dark"] {
  --bg-primary: #0a0d14;
  --bg-secondary: #0f1420;
  --bg-card: #141926;
  --bg-card-hover: #1a2035;
  --bg-input: #1e2540;
  --sidebar-bg: #0c1018;
  --sidebar-border: #1e2a3a;
  --sidebar-text: #8a9bb8;
  --sidebar-text-muted: #4a5a72;
  --sidebar-text-active: #e8edf5;
  --sidebar-hover-bg: #141926;
  --sidebar-active-bg: rgba(59,130,246,0.15);
  --sidebar-shadow: none;
  --border: #1e2a3a;
  --border-light: #253045;
  --text-primary: #e8edf5;
  --text-secondary: #8a9bb8;
  --text-muted: #4a5a72;
  --accent-blue-glow: rgba(59,130,246,0.15);
  --shadow-card: 0 4px 24px rgba(0,0,0,0.4);
  --shadow-glow: 0 0 30px rgba(59,130,246,0.1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;font-size:14px;line-height:1.5}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:10px}

/* ===== LOGIN PAGE ===== */
#login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);position:relative;overflow:hidden}
#login-page::before{content:'';position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(59,130,246,0.08) 0%,transparent 70%);top:-100px;right:-100px;pointer-events:none}
#login-page::after{content:'';position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,0.06) 0%,transparent 70%);bottom:-50px;left:-50px;pointer-events:none}
.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:48px 40px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:var(--shadow-card)}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:32px}
.login-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:10px;display:flex;align-items:center;justify-content:center}
.login-logo-img{height:44px;width:auto;max-width:200px;object-fit:contain;display:block}
.login-logo--brand{justify-content:center;margin-bottom:28px}
.login-logo-text{font-size:22px;font-weight:800;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.login-title{font-size:24px;font-weight:700;margin-bottom:6px}
.login-sub{color:var(--text-secondary);margin-bottom:32px;font-size:13px}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.5px}
.form-input{width:100%;background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);padding:11px 14px;font-size:14px;font-family:inherit;outline:none;transition:var(--transition)}
.form-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-glow)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:inherit;border:none;cursor:pointer;transition:var(--transition);white-space:nowrap;text-decoration:none}
.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 14px rgba(59,130,246,0.3)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(59,130,246,0.4)}
.btn-full{width:100%;padding:12px}
.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-light)}
.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--bg-card-hover);color:var(--text-primary)}
.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 14px rgba(16,185,129,0.3)}
.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-icon{padding:8px;aspect-ratio:1}
.btn.is-loading{cursor:wait;pointer-events:none;opacity:.92}
.btn.is-loading:hover{transform:none;box-shadow:inherit}
.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-spin .65s linear infinite;flex-shrink:0}
.btn-label{display:inline-block;line-height:1.2}
@keyframes btn-spin{to{transform:rotate(360deg)}}

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

/* ===== SIDEBAR ===== */
.sidebar{
  width:var(--sidebar-width);
  background:var(--sidebar-bg);
  border-right:1px solid var(--sidebar-border);
  box-shadow:var(--sidebar-shadow);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;height:100vh;z-index:100;
  transition:transform 0.3s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  color:var(--sidebar-text);
}
.sidebar-header{padding:8px 20px 8px;border-bottom:1px solid var(--sidebar-border);flex-shrink:0}
.sidebar-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.sidebar-logo-icon{width:34px;height:34px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar-logo-img{height:46px;width:auto;max-width:180px;object-fit:contain;display:block;flex-shrink:0}
.sidebar-logo-text{font-size:17px;font-weight:800;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.sidebar-logo-sub{font-size:9px;color:var(--sidebar-text-muted);font-weight:500;letter-spacing:1px;text-transform:uppercase;display:block;margin-top:-2px}
.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px}
.nav-section{margin-bottom:6px}
.nav-section-label{font-size:9px;font-weight:700;color:var(--sidebar-text-muted);text-transform:uppercase;letter-spacing:1.5px;padding:8px 10px 4px}
.sidebar .nav-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 10px;border-radius:var(--radius-sm);
  cursor:pointer;transition:var(--transition);
  color:var(--sidebar-text);font-size:13px;font-weight:500;
  position:relative;text-decoration:none;border:1px solid transparent;
}
.sidebar .nav-item:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-active)}
.sidebar .nav-item.active{
  background:var(--sidebar-active-bg);
  color:var(--accent-blue);
  border-color:rgba(59,130,246,0.25);
}
.sidebar .nav-item.active .nav-icon{color:var(--accent-blue)}
.nav-icon{width:16px;height:16px;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--accent-red);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:20px}
.sidebar-footer{padding:14px;border-top:1px solid var(--sidebar-border);flex-shrink:0}
.sidebar-user{display:flex;align-items:center;gap:10px}
.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.sidebar-user-info{flex:1;min-width:0}
.sidebar-user-name{font-size:12px;font-weight:600;color:var(--sidebar-text-active);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:10px;color:var(--sidebar-text-muted)}
.sidebar .btn-ghost{color:var(--sidebar-text);border-color:var(--sidebar-border)}
.sidebar .btn-ghost:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-active);border-color:var(--border-light)}

/* ===== MAIN CONTENT ===== */
.main{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-height:100vh}
.header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:50;backdrop-filter:blur(10px)}
.header-menu-btn{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px}
.header-title{font-size:16px;font-weight:700;flex:1}
.header-search{display:flex;align-items:center;gap:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 14px;width:260px}
.header-search input{background:none;border:none;outline:none;color:var(--text-primary);font-size:13px;font-family:inherit;width:100%}
.header-search input::placeholder{color:var(--text-muted)}
.header-actions{display:flex;align-items:center;gap:8px}
.icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);color:var(--text-secondary);position:relative}
.icon-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}
.notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--accent-red);border-radius:50%;border:2px solid var(--bg-secondary)}
.theme-toggle{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:var(--transition)}
.theme-toggle:hover{color:var(--text-primary)}
.header-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;cursor:pointer}
.content{flex:1;padding:24px;overflow-y:auto}

/* ===== PAGES ===== */
.page{display:none}
.page.active{display:block}

/* ===== PAGE HEADER ===== */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.page-title{font-size:20px;font-weight:800}
.page-sub{font-size:12px;color:var(--text-secondary);margin-top:2px}
.page-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ===== KPI CARDS ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;transition:var(--transition)}
.kpi-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-card)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius) var(--radius) 0 0}
.kpi-card.blue::before{background:linear-gradient(90deg,#3b82f6,#06b6d4)}
.kpi-card.green::before{background:linear-gradient(90deg,#10b981,#34d399)}
.kpi-card.yellow::before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.kpi-card.red::before{background:linear-gradient(90deg,#ef4444,#f97316)}
.kpi-card.purple::before{background:linear-gradient(90deg,#8b5cf6,#ec4899)}
.kpi-card.cyan::before{background:linear-gradient(90deg,#06b6d4,#3b82f6)}
.kpi-card.orange::before{background:linear-gradient(90deg,#f97316,#ef4444)}
.kpi-card.indigo::before{background:linear-gradient(90deg,#6366f1,#8b5cf6)}
.kpi-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.kpi-icon.blue{background:rgba(59,130,246,0.12);color:#3b82f6}
.kpi-icon.green{background:rgba(16,185,129,0.12);color:#10b981}
.kpi-icon.yellow{background:rgba(245,158,11,0.12);color:#f59e0b}
.kpi-icon.red{background:rgba(239,68,68,0.12);color:#ef4444}
.kpi-icon.purple{background:rgba(139,92,246,0.12);color:#8b5cf6}
.kpi-icon.cyan{background:rgba(6,182,212,0.12);color:#06b6d4}
.kpi-icon.orange{background:rgba(249,115,22,0.12);color:#f97316}
.kpi-icon.indigo{background:rgba(99,102,241,0.12);color:#6366f1}
.kpi-value{font-size:26px;font-weight:800;line-height:1;margin-bottom:5px;font-family:'JetBrains Mono',monospace}
.kpi-label{font-size:11px;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:0.5px}
.kpi-change{font-size:11px;font-weight:600;margin-top:8px;display:flex;align-items:center;gap:3px}
.kpi-change.up{color:var(--accent-green)}
.kpi-change.down{color:var(--accent-red)}

/* ===== CHARTS ROW ===== */
.charts-row{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:24px}
.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.chart-title{font-size:14px;font-weight:700}
.chart-sub{font-size:11px;color:var(--text-secondary);margin-top:2px}
.chart-container{position:relative;height:220px}

/* ===== TABLES ===== */
.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:24px}
.table-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:10px}
.table-title{font-size:14px;font-weight:700}
.table-controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.filter-select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);padding:7px 12px;border-radius:var(--radius-sm);font-size:12px;font-family:inherit;outline:none;cursor:pointer;transition:var(--transition)}
.filter-select:focus{border-color:var(--accent-blue)}
.search-input-sm{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);padding:7px 12px;border-radius:var(--radius-sm);font-size:12px;font-family:inherit;outline:none;width:180px;transition:var(--transition)}
.search-input-sm:focus{border-color:var(--accent-blue)}
.table-wrapper{overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:600px}
thead th{background:var(--bg-secondary);padding:10px 16px;text-align:left;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;white-space:nowrap;border-bottom:1px solid var(--border)}
tbody tr{border-bottom:1px solid var(--border);transition:var(--transition)}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--bg-card-hover)}
tbody td{padding:12px 16px;font-size:13px;color:var(--text-primary);white-space:nowrap}
.table-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.pagination{display:flex;gap:4px}
.page-btn{width:30px;height:30px;border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);color:var(--text-secondary);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);font-family:inherit;text-decoration:none}
.page-btn-nav{width:auto;min-width:30px;padding:0 12px;font-weight:500}
.page-btn:hover:not(:disabled):not(.disabled),.page-btn.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}
.page-btn:disabled,.page-btn.disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
.page-btn-ellipsis{border:none!important;background:transparent!important;min-width:auto;width:auto;padding:0 4px;cursor:default;pointer-events:none}

/* ===== MASTER LIST (DataTables + pagingLink) ===== */
.master-list-card .dataTables_wrapper{padding:0}
.master-list-card table.dataTable{width:100%!important;margin:0!important;border-collapse:collapse!important}
.master-list-card table.dataTable thead th,
.master-list-card table.dataTable tbody td{border-color:var(--border)!important}
.master-list-card table.dataTable thead th{background:var(--bg-secondary)!important;color:var(--text-muted)!important;font-size:10px!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.8px!important;padding:10px 16px!important}
.master-list-card table.dataTable tbody td{color:var(--text-primary)!important;padding:12px 16px!important;font-size:13px!important;vertical-align:middle!important}
.master-list-card table.dataTable tbody tr:hover{background:var(--bg-card-hover)!important}
.master-list-card table.dataTable.no-footer{border-bottom:none!important}
.master-list-card .dataTables_empty{text-align:center!important;color:var(--text-muted)!important;padding:24px!important}
.table-footer .master-pagination{margin-left:auto}
.master-pagination .tp-pagination nav ul{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.master-pagination .tp-pagination nav ul li{margin:0;padding:0}
.master-pagination .tp-pagination nav ul li a,
.master-pagination .tp-pagination nav ul li span{display:flex;align-items:center;justify-content:center;min-width:30px;height:30px;padding:0 8px;border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);color:var(--text-secondary);font-size:12px;text-decoration:none;transition:var(--transition);font-family:inherit}
.master-pagination .tp-pagination nav ul li a:hover,
.master-pagination .tp-pagination nav ul li span.current{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}
.master-pagination .tp-pagination nav ul li span.current{font-weight:700}
.master-pagination .tp-pagination nav ul li span.disabled{opacity:.45;cursor:not-allowed}
.master-pagination .tp-pagination nav ul li span.dots{border:none;background:transparent;min-width:auto;padding:0 4px}

/* ===== AJAX LIST LOADER ===== */
.preloader{display:flex;align-items:center;justify-content:center}
.preloader-fixed{position:fixed;inset:0;z-index:9999;background:rgba(15,23,42,0.55);backdrop-filter:blur(1px)}
.preloader .loader{width:40px;height:40px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent-blue);animation:masterSpin .8s linear infinite}
.master-list-card{position:relative}
@keyframes masterSpin{to{transform:rotate(360deg)}}
.master-list-card .dataTables_wrapper>.row:last-child{margin:0!important;padding:12px 20px;border-top:1px solid var(--border);display:flex!important;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;width:100%}
.master-list-card .dataTables_wrapper>.row:last-child>[class*="col-"]{flex:0 0 auto;width:auto!important;max-width:none;padding:0}
.master-list-card .dataTables_wrapper>.row:last-child>[class*="col-md-5"]{margin-right:auto}
.master-list-card .dataTables_wrapper>.row:last-child>[class*="col-md-7"]{margin-left:auto;padding-right:2px}
.master-list-card .dataTables_wrapper .dataTables_info.table-info{font-size:11px;color:var(--text-muted);padding:0;margin:0;float:none}
.master-list-card .dataTables_wrapper .dataTables_paginate.pagination{float:none!important;margin:0;padding:0;text-align:right}
.master-list-card .dataTables_wrapper .dataTables_paginate.pagination ul,
.master-list-card .dataTables_wrapper .dataTables_paginate.pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:4px;list-style:none!important;margin:0;padding:0}
.master-list-card .dataTables_wrapper .dataTables_paginate ul.pagination{margin:0;padding:0}
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item,
.master-list-card .dataTables_wrapper .dataTables_paginate .pagination .page-item{list-style:none!important;margin:0!important;padding:0!important;border:none!important;background:transparent!important;box-sizing:border-box}
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item > a.page-link,
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item > span,
.master-list-card .dataTables_wrapper .dataTables_paginate span.paginate_button.page-btn{display:flex!important;align-items:center;justify-content:center;min-width:30px;height:30px;padding:0 8px!important;margin:0!important;border-radius:var(--radius-sm)!important;border:1px solid var(--border)!important;background:var(--bg-input)!important;color:var(--text-secondary)!important;font-size:12px!important;text-decoration:none!important;box-shadow:none!important;line-height:1;box-sizing:border-box}
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item.first > a.page-link,
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item.previous > a.page-link,
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item.next > a.page-link,
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item.last > a.page-link{min-width:30px;font-weight:600!important}
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item.page-btn.active > a.page-link,
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item.active > a.page-link,
.master-list-card .dataTables_wrapper .dataTables_paginate span.paginate_button.page-btn.current,
.master-list-card .dataTables_wrapper .dataTables_paginate span.paginate_button.page-btn.active{background:var(--accent-blue)!important;color:#fff!important;border-color:var(--accent-blue)!important}
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.page-item:not(.active):not(.disabled) > a.page-link:hover,
.master-list-card .dataTables_wrapper .dataTables_paginate span.paginate_button.page-btn:not(.disabled):not(.active):not(.current):hover{background:var(--accent-blue)!important;color:#fff!important;border-color:var(--accent-blue)!important}
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.disabled,
.master-list-card .dataTables_wrapper .dataTables_paginate span.paginate_button.disabled{opacity:.45;pointer-events:none}
.master-list-card .dataTables_wrapper .dataTables_paginate li.paginate_button.disabled > a.page-link{opacity:.45;pointer-events:none}
.master-list-card .dataTables_wrapper .dataTables_paginate .ellipsis{border:none!important;background:transparent!important;min-width:auto;width:auto;padding:0 4px;color:var(--text-muted);pointer-events:none}
.table-info{font-size:11px;color:var(--text-muted)}
.cell-name{font-weight:600;color:var(--text-primary)}
.cell-sub{font-size:11px;color:var(--text-muted);margin-top:2px}
.cell-mono{font-family:'JetBrains Mono',monospace;font-size:12px}
.avatar-cell{display:flex;align-items:center;gap:10px}
.mini-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}

/* ===== STATUS BADGES ===== */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}
.badge-new{background:rgba(59,130,246,0.12);color:#3b82f6}
.badge-new::before{background:#3b82f6}
.badge-pending{background:rgba(245,158,11,0.12);color:#f59e0b}
.badge-pending::before{background:#f59e0b}
.badge-verify{background:rgba(249,115,22,0.12);color:#f97316}
.badge-verify::before{background:#f97316}
.badge-approved{background:rgba(16,185,129,0.12);color:#10b981}
.badge-approved::before{background:#10b981}
.badge-disbursed{background:rgba(139,92,246,0.12);color:#8b5cf6}
.badge-disbursed::before{background:#8b5cf6}
.badge-rejected{background:rgba(239,68,68,0.12);color:#ef4444}
.badge-rejected::before{background:#ef4444}
.badge-overdue{background:rgba(220,38,38,0.12);color:#dc2626}
.badge-overdue::before{background:#dc2626}
.badge-closed{background:rgba(107,114,128,0.12);color:#6b7280}
.badge-closed::before{background:#6b7280}
.badge-active{background:rgba(16,185,129,0.12);color:#10b981}
.badge-active::before{background:#10b981}
.badge-inactive{background:rgba(107,114,128,0.12);color:#6b7280}
.badge-inactive::before{background:#6b7280}
.badge-mobile{background:rgba(59,130,246,0.12);color:#3b82f6}
.badge-mobile::before{background:#3b82f6}
.badge-personal{background:rgba(139,92,246,0.12);color:#8b5cf6}
.badge-personal::before{background:#8b5cf6}
.badge-wheeler{background:rgba(6,182,212,0.12);color:#06b6d4}
.badge-wheeler::before{background:#06b6d4}
/* Lead loan types */
.badge-loan-mobile{background:rgba(59,130,246,0.12);color:#3b82f6}
.badge-loan-mobile::before{background:#3b82f6}
.badge-loan-two-wheeler{background:rgba(6,182,212,0.12);color:#06b6d4}
.badge-loan-two-wheeler::before{background:#06b6d4}
.badge-loan-gold{background:rgba(234,179,8,0.14);color:#ca8a04}
.badge-loan-gold::before{background:#eab308}
.badge-loan-property{background:rgba(139,92,246,0.12);color:#7c3aed}
.badge-loan-property::before{background:#8b5cf6}
.badge-loan-other{background:rgba(107,114,128,0.12);color:#6b7280}
.badge-loan-other::before{background:#6b7280}
/* Lead EMI types */
.badge-emi-monthly{background:rgba(59,130,246,0.12);color:#3b82f6}
.badge-emi-monthly::before{background:#3b82f6}
.badge-emi-quarterly{background:rgba(20,184,166,0.12);color:#0d9488}
.badge-emi-quarterly::before{background:#14b8a6}
.badge-emi-half-yearly{background:rgba(249,115,22,0.12);color:#ea580c}
.badge-emi-half-yearly::before{background:#f97316}
.badge-emi-yearly{background:rgba(139,92,246,0.12);color:#7c3aed}
.badge-emi-yearly::before{background:#8b5cf6}
/* Lead status */
.badge-status-pending{background:rgba(59,130,246,0.12);color:#2563eb}
.badge-status-pending::before{background:#3b82f6}
.badge-status-assigned{background:rgba(245,158,11,0.12);color:#d97706}
.badge-status-assigned::before{background:#f59e0b}
.badge-status-verified{background:rgba(16,185,129,0.12);color:#059669}
.badge-status-verified::before{background:#10b981}
.badge-status-rejected{background:rgba(239,68,68,0.12);color:#dc2626}
.badge-status-rejected::before{background:#ef4444}

/* EMI tracking */
.kpi-filter-card{cursor:pointer;transition:box-shadow 0.2s ease,border-color 0.2s ease}
.kpi-filter-card.is-active{box-shadow:0 0 0 2px var(--accent-blue);border-color:var(--accent-blue)}
.data-table tbody tr.row-highlight{background:rgba(59,130,246,0.06)}
.data-table tbody tr.row-highlight td{font-weight:600}

/* ===== DETAIL PAGE ===== */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.detail-section-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.detail-row{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--border)}
.detail-row:last-child{border-bottom:none}
.detail-key{font-size:12px;color:var(--text-secondary);font-weight:500}
.detail-val{font-size:13px;font-weight:600;text-align:right}
.cibil-score-display{text-align:center;padding:20px}
.cibil-ring{width:120px;height:120px;margin:0 auto 14px;position:relative}
.cibil-ring svg{transform:rotate(-90deg)}
.cibil-ring-val{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:28px;font-weight:800;font-family:'JetBrains Mono',monospace}
.cibil-label{font-size:12px;color:var(--text-secondary)}

/* ===== PROGRESS ===== */
.progress-bar{background:var(--bg-input);border-radius:20px;height:6px;overflow:hidden}
.progress-fill{height:100%;border-radius:20px;transition:width 0.6s ease}
.stage-track{display:flex;align-items:center;gap:0;margin:16px 0}
.stage-step{display:flex;align-items:center;flex:1}
.stage-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;position:relative;z-index:1;transition:var(--transition)}
.stage-dot.done{background:var(--accent-green);border-color:var(--accent-green);color:#fff}
.stage-dot.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}
.stage-line{flex:1;height:2px;background:var(--border)}
.stage-line.done{background:var(--accent-green)}
.stage-name{font-size:9px;color:var(--text-muted);text-align:center;margin-top:5px;white-space:nowrap}

/* ===== FORM LAYOUTS ===== */
.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.form-group-inline{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:16px}
.form-section-title{font-size:13px;font-weight:700;margin-bottom:16px;color:var(--text-primary);display:flex;align-items:center;gap:8px}
.form-section-title::after{content:'';flex:1;height:1px;background:var(--border)}

/* ===== CENTERED MASTER CREATE/EDIT ===== */
.form-page{display:flex;flex-direction:column;width:100%;padding-bottom:32px}
.form-page > .page-header{width:100%;margin-bottom:20px}
.form-page-block{width:100%;max-width:640px;margin:0 auto}
.form-page-block > .alert{margin-bottom:16px}
.master-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card)}
.master-form-body{padding:28px 32px}
.master-form-card .form-grid{grid-template-columns:1fr;gap:20px}
.master-form-card .form-group{margin-bottom:0}
.settings-form{padding:20px}
.settings-form-actions{padding:16px 20px 20px;border-top:1px solid var(--border)}
.form-hint{font-size:11px;color:var(--text-muted);margin:6px 0 0}
.rating-stars-display{font-size:16px;letter-spacing:2px;line-height:1;color:#f59e0b;white-space:nowrap}
.input-money-group{display:flex;align-items:stretch;width:100%}
.input-money-prefix{display:flex;align-items:center;padding:0 12px;border:1px solid var(--border);border-right:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);font-size:13px;font-weight:600}
.input-money-group .input-money{flex:1;border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.text-money{font-family:'JetBrains Mono',monospace}
.settings-meta{font-size:11px;color:var(--text-muted);margin-top:4px}
.settings-panel-general .settings-section{margin-bottom:0}
.table-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:6px}
.customer-profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:20px}
.customer-profile-wide{grid-column:1/-1}
.customer-profile-card .table-header{padding:14px 20px}
.customer-profile-body{padding:12px 20px 16px}
.customer-profile-head{display:flex;align-items:center;gap:16px;padding:20px}
.customer-profile-avatar{width:52px;height:52px;font-size:16px}
.customer-profile-name{font-size:18px;font-weight:700;color:var(--text-primary)}
.customer-profile-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;font-size:12px;color:var(--text-muted)}
.profile-empty-note{margin:0;font-size:13px}
.customer-stats-row{display:flex;flex-wrap:wrap;gap:12px;padding:0 20px 20px}
.stat-pill{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;min-width:120px}
.stat-pill-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:4px}
.stat-pill-value{font-size:16px;font-weight:700;color:var(--text-primary)}
@media(max-width:900px){.customer-profile-grid{grid-template-columns:1fr}}
.master-form-footer{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:12px;padding:20px 32px;border-top:1px solid var(--border);background:var(--bg-secondary)}
.master-form-footer-actions{display:flex;align-items:center;gap:10px}
.form-error-list{margin:0;padding-left:18px}

/* ===== MASTER TABLES ===== */
.master-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);transition:var(--transition)}
.master-row:hover{background:var(--bg-card-hover)}
.master-row:last-child{border-bottom:none}
.master-range{font-size:13px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--accent-cyan)}
.master-detail{flex:1;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.master-item{text-align:center}
.master-item-val{font-size:13px;font-weight:700;color:var(--text-primary)}
.master-item-lbl{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px}

/* ===== PERMISSION TABLE ===== */
.perm-table{width:100%;border-collapse:collapse}
.perm-table th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}
.perm-table th.perm-role-col{text-align:center;vertical-align:middle}
.perm-table td{padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.perm-table tr:hover td{background:var(--bg-card-hover)}
.perm-table tr.perm-module-row:hover td{background:#f8fafc}
.check-cell{text-align:center;vertical-align:middle}
.check-cell .perm-check{display:block;margin:0 auto}
.perm-check{width:18px;height:18px;accent-color:var(--accent-blue);cursor:pointer}

/* ===== NOTIFICATIONS ===== */
.notif-item{display:flex;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);transition:var(--transition);cursor:pointer}
.notif-item:hover{background:var(--bg-card-hover)}
.notif-item.unread{background:rgba(59,130,246,0.04)}
.notif-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-content{flex:1;min-width:0}
.notif-title{font-size:13px;font-weight:600}
.notif-desc{font-size:12px;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-time{font-size:10px;color:var(--text-muted);margin-top:4px}
.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-blue);flex-shrink:0;margin-top:4px}

/* ===== ACTIVITY LOG ===== */
.timeline{padding:0 20px}
.timeline-item{display:flex;gap:14px;padding:14px 0;border-left:2px solid var(--border);padding-left:20px;margin-left:8px;position:relative}
.timeline-item::before{content:'';position:absolute;left:-7px;top:18px;width:12px;height:12px;border-radius:50%;background:var(--bg-card);border:2px solid var(--border)}
.timeline-item.info::before{border-color:var(--accent-blue);background:var(--accent-blue)}
.timeline-item.success::before{border-color:var(--accent-green);background:var(--accent-green)}
.timeline-item.warning::before{border-color:var(--accent-yellow);background:var(--accent-yellow)}
.timeline-item.error::before{border-color:var(--accent-red);background:var(--accent-red)}
.timeline-content{flex:1}
.timeline-title{font-size:13px;font-weight:600}
.timeline-desc{font-size:12px;color:var(--text-secondary);margin-top:2px}
.timeline-time{font-size:10px;color:var(--text-muted);margin-top:4px}

/* ===== SETTINGS ===== */
.settings-grid{display:grid;grid-template-columns:220px 1fr;gap:20px}
.settings-nav{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:8px;height:fit-content}
.settings-nav-item{padding:9px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:var(--transition);display:flex;align-items:center;gap:8px}
.settings-nav-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}
.settings-nav-item.active{background:var(--accent-blue-glow);color:var(--accent-blue)}
.settings-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.settings-section{margin-bottom:28px}
.settings-section:last-child{margin-bottom:0}
.settings-section-title{font-size:13px;font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.toggle-row:last-child{border-bottom:none}
.toggle-info .toggle-title{font-size:13px;font-weight:600}
.toggle-info .toggle-desc{font-size:11px;color:var(--text-secondary);margin-top:2px}
.toggle{position:relative;width:40px;height:22px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--bg-input);border:1px solid var(--border);border-radius:20px;transition:var(--transition)}
.toggle-slider::before{content:'';position:absolute;width:16px;height:16px;left:2px;bottom:2px;background:var(--text-muted);border-radius:50%;transition:var(--transition)}
.toggle input:checked + .toggle-slider{background:var(--accent-blue);border-color:var(--accent-blue)}
.toggle input:checked + .toggle-slider::before{transform:translateX(18px);background:#fff}

/* ===== EMPTY & LOADING STATES ===== */
.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}
.empty-state svg{margin:0 auto 14px;opacity:0.3}
.empty-state p{font-size:13px}
.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ===== ALERTS ===== */
.alert{display:flex;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);border:1px solid;margin-bottom:12px;font-size:13px;align-items:flex-start}
.alert-info{background:rgba(59,130,246,0.08);border-color:rgba(59,130,246,0.2);color:#93c5fd}
.alert-success{background:rgba(16,185,129,0.08);border-color:rgba(16,185,129,0.2);color:#6ee7b7}
.alert-warning{background:rgba(245,158,11,0.08);border-color:rgba(245,158,11,0.2);color:#fcd34d}
.alert-danger{background:rgba(239,68,68,0.08);border-color:rgba(239,68,68,0.2);color:#fca5a5}

/* ===== OVERLAY / MODAL ===== */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:200;align-items:center;justify-content:center;padding:20px}
.overlay.open{display:flex}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:modalIn 0.2s ease}
@keyframes modalIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg-card);z-index:1}
.modal-title{font-size:16px;font-weight:700}
.modal-body{padding:20px 24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}

/* ===== MOBILE SIDEBAR OVERLAY ===== */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:99}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .charts-row{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr}
  .settings-grid{grid-template-columns:1fr}
  .settings-nav{display:flex;flex-wrap:wrap;gap:4px;height:auto}
  .master-detail{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  :root{--sidebar-width:260px}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.open{display:block}
  .main{margin-left:0}
  .header-menu-btn{display:flex}
  .header-search{display:none}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .form-group-inline{grid-template-columns:1fr}
  .master-form-body{padding:20px}
  .master-form-footer{padding:16px 20px}
  .page-actions .btn span{display:none}
  .content{padding:16px}
  .table-controls{flex-direction:column;align-items:stretch}
  .search-input-sm{width:100%}
  .header-title{font-size:14px}
  .cibil-score-display{padding:10px}
  .master-detail{grid-template-columns:repeat(2,1fr)}
  .page-header{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .kpi-value{font-size:20px}
  .charts-row{grid-template-columns:1fr}
  .login-card{padding:32px 24px}
  .modal{margin:10px;max-height:95vh}
}

/* Scrollable table for very small screens */
@media(max-width:600px){
  .table-header{flex-direction:column;align-items:flex-start}
}

/* ===== RECHARTS ALTERNATIVE - Chart.js Canvas ===== */
canvas{max-width:100%}

/* ===== MISC ===== */
.divider{height:1px;background:var(--border);margin:16px 0}
.chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;background:var(--bg-input);border:1px solid var(--border);color:var(--text-secondary)}
.text-success{color:var(--accent-green)}
.text-danger{color:var(--accent-red)}
.text-warning{color:var(--accent-yellow)}
.text-info{color:var(--accent-blue)}
.text-muted{color:var(--text-muted)}
.text-mono{font-family:'JetBrains Mono',monospace}
.fw-bold{font-weight:700}
.fw-600{font-weight:600}
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.mb-16{margin-bottom:16px}
.gap-8{gap:8px}
.flex{display:flex}
.flex-col{flex-direction:column}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.flex-wrap{flex-wrap:wrap}
.w-full{width:100%}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.score-excellent{color:#10b981}
.score-good{color:#3b82f6}
.score-average{color:#f59e0b}
.score-poor{color:#ef4444}
.login-logo-sub{font-size:9px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}
.login-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;font-size:12px}
.login-remember{display:flex;align-items:center;gap:6px;cursor:pointer;color:var(--text-secondary)}
.login-forgot{color:var(--accent-blue);text-decoration:none}
.login-version{margin-top:20px;text-align:center;font-size:11px;color:var(--text-muted)}
.status-card{max-width:480px;text-align:center}
.status-code{font-size:72px;font-weight:800;line-height:1;margin:8px 0 12px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.status-icon{font-size:48px;line-height:1;margin:8px 0 12px}
.status-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:28px}
.kpi-grid-4{grid-template-columns:repeat(4,1fr)}
.stage-funnel{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;text-align:center}
.stage-box{border-radius:var(--radius-sm);padding:10px 4px;font-size:18px;font-weight:800}
.stage-label{font-size:9px;color:var(--text-muted);margin-top:4px}
.stage-blue{background:rgba(59,130,246,0.15);border:1px solid rgba(59,130,246,0.3);color:#3b82f6}
.stage-cyan{background:rgba(6,182,212,0.15);border:1px solid rgba(6,182,212,0.3);color:#06b6d4}
.stage-yellow{background:rgba(245,158,11,0.15);border:1px solid rgba(245,158,11,0.3);color:#f59e0b}
.stage-orange{background:rgba(249,115,22,0.15);border:1px solid rgba(249,115,22,0.3);color:#f97316}
.stage-green{background:rgba(16,185,129,0.15);border:1px solid rgba(16,185,129,0.3);color:#10b981}
.stage-purple{background:rgba(139,92,246,0.15);border:1px solid rgba(139,92,246,0.3);color:#8b5cf6}
.stage-red{background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.3);color:#ef4444}
.stage-gray{background:rgba(107,114,128,0.15);border:1px solid rgba(107,114,128,0.3);color:#6b7280}
.stage-funnel-btn{display:block;width:100%;cursor:pointer;font:inherit;transition:transform 0.15s ease,box-shadow 0.15s ease}
.stage-funnel-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,0.08)}
.stage-funnel-btn.is-active{outline:2px solid var(--accent-blue);outline-offset:2px}
@media (max-width:1100px){.stage-funnel{grid-template-columns:repeat(4,1fr)}}
@media (max-width:640px){.stage-funnel{grid-template-columns:repeat(2,1fr)}}
.chart-card-mb{margin-bottom:20px}
.chart-title-mb{margin-bottom:14px}
.header-search-icon{color:var(--text-muted);flex-shrink:0}
#toast{position:fixed;bottom:24px;right:24px;z-index:500;transition:all 0.3s ease;transform:translateX(200px);opacity:0}
.toast-inner{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 18px;box-shadow:var(--shadow-card);display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;min-width:220px}
#toastIcon{width:18px;height:18px;border-radius:50%;flex-shrink:0}
.alert-icon{flex-shrink:0}
.modal-info{margin-bottom:16px}
.master-header-row{padding:8px 16px 4px;display:grid;grid-template-columns:140px 1fr auto;gap:8px;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}
.depreciation-title{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:10px}
.btn-convert{margin-left:4px}
.master-range-wrap{min-width:140px}
.limit-green{color:#10b981}
.limit-blue{color:#3b82f6}
.limit-yellow{color:#f59e0b}
.limit-red{color:#ef4444}
.limit-purple{color:#8b5cf6}
.master-actions{display:flex;gap:6px}
.readonly-muted{color:var(--text-muted)}
.page-content{animation:fadeIn 0.2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

.master-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:16px}
.photo-gallery-item{display:flex;flex-direction:column;gap:8px;min-width:0}
.photo-gallery-label{font-size:12px;font-weight:600;color:var(--text-secondary);line-height:1.3}
.photo-gallery-link{position:relative;display:block;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--bg-secondary);aspect-ratio:4/3}
.photo-gallery-link img{width:100%;height:100%;object-fit:cover;display:block}
.photo-gallery-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.5);color:#fff;font-size:12px;font-weight:600;opacity:0;transition:opacity 0.2s ease;pointer-events:none}
.photo-gallery-link:hover .photo-gallery-zoom{opacity:1}
.photo-gallery-file{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:120px;padding:16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);text-decoration:none;transition:border-color 0.2s,background 0.2s}
.photo-gallery-file:hover{border-color:var(--accent-blue);background:var(--bg-card);color:var(--accent-blue)}
.photo-gallery-file-text{font-size:12px;font-weight:600}
.photo-gallery-empty{margin:0;font-size:13px}
.photo-gallery-empty-slot{display:flex;align-items:center;justify-content:center;aspect-ratio:4/3;border-radius:var(--radius-sm);border:1px dashed var(--border);background:var(--bg-secondary);color:var(--text-muted);font-size:12px;font-weight:500}
.detail-empty{color:var(--text-muted)}
.visit-accordion{display:flex;flex-direction:column;gap:14px;padding:16px 20px 20px}
.visit-history-card{padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-card);box-shadow:0 1px 2px rgba(15,23,42,0.04)}
.visit-history-card+.visit-history-card{margin-top:0}
.visit-history-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}
.visit-history-head-static{padding:20px;margin-bottom:0}
.visit-history-title{font-size:15px;font-weight:700;color:var(--text-primary)}
.visit-history-meta{display:block;font-size:12px;color:var(--text-muted);margin-top:4px}
.visit-accordion-trigger{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 20px;border:0;background:var(--bg-secondary);color:inherit;text-align:left;cursor:pointer;transition:background 0.2s ease}
.visit-accordion-trigger:hover{background:var(--bg-card)}
.visit-accordion-item.is-open .visit-accordion-trigger{background:var(--bg-card)}
.visit-accordion-trigger-main{flex:1;min-width:0}
.visit-accordion-trigger-end{display:flex;align-items:center;gap:10px;flex-shrink:0}
.visit-accordion-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--accent-blue);white-space:nowrap}
.visit-accordion-chevron{transition:transform 0.3s ease;flex-shrink:0}
.visit-accordion-item.is-open .visit-accordion-chevron{transform:rotate(180deg)}
.visit-accordion-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows 0.35s ease}
.visit-accordion-item.is-open .visit-accordion-panel,
.visit-history-card:not(.visit-accordion-item) .visit-accordion-panel{grid-template-rows:1fr}
.visit-accordion-panel-inner{overflow:hidden}
.visit-accordion-panel-inner>.visit-history-details{padding:0 20px 4px}
.visit-accordion-panel-inner>.visit-history-photos{padding:0 20px 20px}
.visit-history-details{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 24px;padding:0}
.visit-history-card:not(.visit-accordion-item) .visit-history-details{padding:0 20px 4px}
.visit-history-card:not(.visit-accordion-item) .visit-history-photos{padding:0 20px 20px}
.visit-detail-wide{grid-column:1/-1}
.visit-history-photos{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
@media(max-width:700px){
	.visit-history-details{grid-template-columns:1fr}
	.visit-accordion-trigger{align-items:flex-start;flex-wrap:wrap}
	.visit-accordion-trigger-end{width:100%;justify-content:space-between;margin-top:8px}
}
.document-preview-modal{max-width:min(920px,96vw)}
.document-preview-body{padding:12px;text-align:center;background:var(--bg-secondary)}
.document-preview-body img{max-width:100%;max-height:75vh;object-fit:contain;display:block;margin:0 auto;border-radius:var(--radius-sm)}
.document-preview-actions{display:flex;gap:8px;justify-content:flex-end}
.activity-log-json{font-family:var(--font-mono);font-size:11px;line-height:1.45;max-height:220px;overflow:auto;margin:0;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word}

.mt-12{margin-top:12px}

.staff-admin-actions{display:flex;flex-direction:column;gap:20px;padding:16px 20px 20px}
.staff-action-block{padding-top:16px;border-top:1px solid var(--border)}
.staff-action-block:first-child{padding-top:0;border-top:none}
.staff-action-title{font-weight:600;font-size:14px;margin-bottom:8px}
.staff-action-desc{font-size:13px;margin:0 0 10px}
.staff-inline-form .form-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}
@media(max-width:600px){.staff-inline-form .form-grid-2{grid-template-columns:1fr}}
.staff-confirm-modal{max-width:480px}
.staff-confirm-message{margin:0;font-size:14px;line-height:1.5;color:var(--text-secondary)}
.customer-profile-avatar.mini-avatar{width:48px;height:48px;font-size:14px}
