/* ── Reset & Base ─────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#f3f4f6;--bg-card:#fff;--bg-header:#1a1a2e;--bg-sidebar:#16213e;
  --text:#1f2937;--text-light:#6b7280;--text-on-dark:#fff;
  --primary:#4f46e5;--primary-light:#818cf8;--primary-bg:#eef2ff;
  --green:#10b981;--red:#ef4444;--orange:#f97316;--blue:#3b82f6;
  --purple:#a855f7;--yellow:#eab308;--pink:#ec4899;
  --border:#e5e7eb;--shadow:0 1px 3px rgba(0,0,0,.08);
  --radius:8px;--gap:20px;
  --sidebar-w:240px;
}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;font-size:14px}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:13px}

/* ── Login ────────────────────────────────────────────────── */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-header)}
.login-box{background:#fff;padding:40px;border-radius:12px;width:380px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.login-box h1{font-size:24px;margin-bottom:8px;color:var(--bg-header)}
.login-box p{color:var(--text-light);margin-bottom:24px;font-size:13px}
.login-box .form-group{margin-bottom:16px}
.login-box label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-light);margin-bottom:4px}
.login-box input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px}
.login-box input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}
.login-box button{width:100%;padding:12px;background:var(--bg-header);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;margin-top:8px}
.login-box button:hover{background:#2a2a4e}
.login-error{color:var(--red);font-size:13px;margin-top:8px;display:none}

/* ── Layout ───────────────────────────────────────────────── */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);color:var(--text-on-dark);padding:20px 0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s}
.sidebar .brand{padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:10px}
.sidebar .brand h2{font-size:18px;font-weight:700}
.sidebar .brand span{font-size:11px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1px}
.sidebar nav{flex:1}
.sidebar nav a{display:flex;align-items:center;gap:10px;padding:10px 20px;color:rgba(255,255,255,.7);font-size:13px;font-weight:500;transition:all .2s;border-left:3px solid transparent}
.sidebar nav a:hover{background:rgba(255,255,255,.05);color:#fff;text-decoration:none}
.sidebar nav a.active{background:rgba(255,255,255,.1);color:#fff;border-left-color:var(--primary-light)}
.sidebar nav a .icon{width:20px;text-align:center;font-size:16px}
.sidebar .user-info{padding:15px 20px;border-top:1px solid rgba(255,255,255,.1);font-size:12px}
.sidebar .user-info .name{font-weight:600;color:#fff}
.sidebar .user-info .role{color:rgba(255,255,255,.5);text-transform:capitalize}
.main{flex:1;margin-left:var(--sidebar-w);padding:24px 30px}
.main .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.main .page-header h1{font-size:22px;font-weight:700}

/* ── Buttons ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;border:1px solid var(--border);background:#fff;color:var(--text);transition:all .2s}
.btn:hover{background:var(--bg);text-decoration:none}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:#4338ca}
.btn-success{background:var(--green);color:#fff;border-color:var(--green)}
.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-group{display:flex;gap:8px;flex-wrap:wrap}

/* ── KPI Cards ────────────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--gap);margin-bottom:var(--gap)}
.kpi-card{background:var(--bg-card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow);transition:transform .2s}
.kpi-card:hover{transform:translateY(-2px)}
.kpi-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:6px}
.kpi-value{font-size:26px;font-weight:700;color:var(--bg-header)}
.kpi-sub{font-size:11px;color:var(--text-light);margin-top:4px}

/* ── Charts ───────────────────────────────────────────────── */
.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:var(--gap);margin-bottom:var(--gap)}
.chart-card{background:var(--bg-card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow)}
.chart-card h3{font-size:14px;font-weight:600;margin-bottom:16px}
.chart-card canvas{max-height:280px}

/* ── Filters Bar ──────────────────────────────────────────── */
.filters-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:var(--gap);padding:16px;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}
.filters-bar input,.filters-bar select{padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;background:#fff}
.filters-bar input:focus,.filters-bar select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg)}
.filters-bar .search-input{min-width:200px}
.filters-bar .filter-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-light);margin-right:4px}

/* ── Table ────────────────────────────────────────────────── */
.table-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-bottom:var(--gap)}
.table-card .table-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}
.table-card .table-header h3{font-size:14px;font-weight:600}
.table-wrapper{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{background:#f9fafb;padding:10px 12px;text-align:left;font-weight:600;font-size:12px;text-transform:uppercase;color:var(--text-light);border-bottom:2px solid var(--border);cursor:pointer;white-space:nowrap;user-select:none;letter-spacing:.3px}
th:hover{background:#f3f4f6;color:var(--text)}
td{padding:10px 12px;border-bottom:1px solid #f3f4f6;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
tr:hover{background:#fafbfc}
td input[type="checkbox"]{cursor:pointer}

/* ── Status Badges ────────────────────────────────────────── */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-green{background:#d1fae5;color:#065f46}
.badge-red{background:#fee2e2;color:#991b1b}
.badge-orange{background:#ffedd5;color:#9a3412}
.badge-blue{background:#dbeafe;color:#1e40af}
.badge-purple{background:#ede9fe;color:#5b21b6}
.badge-yellow{background:#fef9c3;color:#854d0e}
.badge-gray{background:#f3f4f6;color:#374151}
.badge-pink{background:#fce7f3;color:#9d174d}

/* ── Pagination ───────────────────────────────────────────── */
.pagination{display:flex;justify-content:center;align-items:center;gap:8px;padding:16px}
.pagination button{padding:6px 12px;border:1px solid var(--border);background:#fff;border-radius:4px;font-size:12px;font-weight:500}
.pagination button:hover{background:var(--bg)}
.pagination button.active{background:var(--bg-header);color:#fff;border-color:var(--bg-header)}
.pagination button:disabled{opacity:.4;cursor:not-allowed}
.pagination .page-info{font-size:12px;color:var(--text-light)}

/* ── Pipeline / Kanban ────────────────────────────────────── */
.pipeline{display:flex;gap:12px;overflow-x:auto;padding-bottom:20px;min-height:500px}
.pipeline-column{min-width:250px;max-width:280px;flex-shrink:0;background:var(--bg);border-radius:var(--radius);display:flex;flex-direction:column}
.pipeline-column-header{padding:12px 16px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius) var(--radius) 0 0;display:flex;justify-content:space-between;align-items:center}
.pipeline-column-header .count{background:rgba(0,0,0,.15);padding:2px 8px;border-radius:10px;font-size:11px}
.pipeline-cards{flex:1;padding:8px;overflow-y:auto;max-height:600px;display:flex;flex-direction:column;gap:8px}
.pipeline-card{background:#fff;border-radius:6px;padding:12px;box-shadow:0 1px 3px rgba(0,0,0,.06);cursor:pointer;transition:box-shadow .2s;border-left:3px solid transparent}
.pipeline-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1)}
.pipeline-card .card-code{font-size:11px;font-weight:600;color:var(--primary);margin-bottom:4px}
.pipeline-card .card-name{font-size:13px;font-weight:600;margin-bottom:4px}
.pipeline-card .card-product{font-size:12px;color:var(--text-light);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pipeline-card .card-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text-light)}

/* ── Payment Tags on Pipeline Cards ────────────────────── */
.pay-tag{position:absolute;top:6px;right:6px;font-size:8.5px;font-weight:700;padding:2px 7px;border-radius:8px;text-transform:uppercase;letter-spacing:.3px;line-height:1.4;white-space:nowrap}
.pay-tag.info-needed{background:#f1f5f9;color:#64748b}
.pay-tag.reimb-raised{background:#fef3c7;color:#92400e}
.pay-tag.reimb-paid{background:#dbeafe;color:#1e40af}
.pay-tag.fee-raised{background:#ffedd5;color:#c2410c}
.pay-tag.fully-paid{background:#d1fae5;color:#065f46}

/* ── Card Action Buttons ───────────────────────────────── */
.card-actions{display:flex;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid #f3f4f6}
.card-view-btn{flex:1;padding:4px 8px;font-size:11px;font-weight:600;background:#f9fafb;border:1px solid var(--border);border-radius:4px;color:var(--text);cursor:pointer;transition:all .15s}
.card-view-btn:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}
.card-next-btn{flex:1;padding:4px 8px;font-size:11px;font-weight:600;background:var(--primary-bg);border:1px solid var(--primary-light);border-radius:4px;color:var(--primary);cursor:pointer;transition:all .15s}
.card-next-btn:hover{background:var(--primary);color:#fff}

/* ── Modal ────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.modal{background:#fff;border-radius:12px;width:100%;max-width:800px;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:slideDown .3s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}
.modal-header h2{font-size:18px;font-weight:700}
.modal-close{background:none;border:none;font-size:24px;color:var(--text-light);cursor:pointer;padding:4px}
.modal-close:hover{color:var(--text)}
.modal-body{padding:24px;max-height:70vh;overflow-y:auto}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* ── Forms ────────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:0}
.form-group.full{grid-column:1/-1}
.form-group label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-light);margin-bottom:4px;letter-spacing:.3px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:6px;font-size:13px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg)}
.form-group textarea{resize:vertical;min-height:60px}
.form-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.form-section h3{font-size:14px;font-weight:600;margin-bottom:16px;color:var(--bg-header)}

/* ── Notifications ────────────────────────────────────────── */
.alert-list{display:flex;flex-direction:column;gap:10px;margin-bottom:var(--gap)}
.alert-item{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow);cursor:pointer;transition:transform .2s}
.alert-item:hover{transform:translateX(4px)}
.alert-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.alert-dot.high{background:var(--red)}
.alert-dot.medium{background:var(--orange)}
.alert-dot.low{background:var(--blue)}
.alert-content{flex:1}
.alert-content .alert-title{font-size:13px;font-weight:600}
.alert-content .alert-desc{font-size:12px;color:var(--text-light)}
.alert-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:4px;background:var(--bg)}

/* ── Activity / History ───────────────────────────────────── */
.history-list{display:flex;flex-direction:column;gap:8px}
.history-item{display:flex;gap:10px;font-size:12px;padding:8px 0;border-bottom:1px solid #f3f4f6}
.history-item .history-time{color:var(--text-light);white-space:nowrap;min-width:100px}
.history-item .history-user{font-weight:600;min-width:80px}
.history-item .history-detail{color:var(--text)}

/* ── Comments ─────────────────────────────────────────────── */
.comments-section{margin-top:16px}
.comment{padding:10px 0;border-bottom:1px solid #f3f4f6}
.comment .comment-header{display:flex;justify-content:space-between;margin-bottom:4px}
.comment .comment-author{font-size:12px;font-weight:600}
.comment .comment-time{font-size:11px;color:var(--text-light)}
.comment .comment-text{font-size:13px}
.comment-input{display:flex;gap:8px;margin-top:12px}
.comment-input input{flex:1}

/* ── Tabs ─────────────────────────────────────────────────── */
.tabs-nav{display:flex;gap:0;margin-bottom:var(--gap);border-bottom:2px solid var(--border)}
.tabs-nav button{padding:10px 20px;border:none;background:none;font-size:13px;font-weight:600;color:var(--text-light);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}
.tabs-nav button.active{color:var(--bg-header);border-bottom-color:var(--bg-header)}
.tabs-nav button:hover{color:var(--text)}
.tab-content{display:none}
.tab-content.active{display:block}

/* ── Import ───────────────────────────────────────────────── */
.import-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px;text-align:center;cursor:pointer;transition:all .2s}
.import-zone:hover{border-color:var(--primary);background:var(--primary-bg)}
.import-zone p{color:var(--text-light);margin-top:8px}

/* ── Toast ────────────────────────────────────────────────── */
.toast-container{position:fixed;top:20px;right:20px;z-index:300;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:8px;color:#fff;font-size:13px;font-weight:500;animation:slideIn .3s ease;box-shadow:0 4px 12px rgba(0,0,0,.15)}
@keyframes slideIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
.toast-success{background:var(--green)}
.toast-error{background:var(--red)}
.toast-info{background:var(--blue)}

/* ── Responsive ───────────────────────────────────────────── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .form-grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .charts-grid{grid-template-columns:1fr}
  .pipeline{flex-direction:column}
  .pipeline-column{min-width:100%;max-width:100%}
}

/* ── CRM Stage Progress ───────────────────────────────────── */
.stage-progress{display:flex;align-items:center;gap:0;margin-bottom:24px;overflow-x:auto;padding-bottom:4px}
.stage-step{display:flex;align-items:center;gap:0;flex-shrink:0}
.stage-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border:2px solid var(--border);background:#fff;color:var(--text-light);transition:all .3s;cursor:pointer;position:relative}
.stage-dot:hover{transform:scale(1.1)}
.stage-dot.active{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 0 0 3px var(--primary-bg)}
.stage-dot.done{border-color:var(--green);background:var(--green);color:#fff}
.stage-dot.skip{border-color:var(--red);background:var(--red);color:#fff}
.stage-connector{width:24px;height:2px;background:var(--border);flex-shrink:0}
.stage-connector.done{background:var(--green)}
.stage-label{position:absolute;top:32px;font-size:9px;white-space:nowrap;color:var(--text-light);font-weight:500;left:50%;transform:translateX(-50%)}
.stage-dot.active .stage-label{color:var(--primary);font-weight:700}

.crm-sections{display:flex;flex-direction:column;gap:0}
.crm-section{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:12px;transition:all .3s}
.crm-section.locked{opacity:.5}
.crm-section-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:#fafbfc;cursor:pointer;user-select:none;transition:background .2s}
.crm-section-header:hover{background:#f3f4f6}
.crm-section-header h3{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px}
.crm-section-header .section-badge{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600}
.crm-section-header .section-hint{font-size:10px;color:#6366f1;background:#ede9fe;padding:2px 8px;border-radius:10px;font-weight:500;margin-left:6px}
.crm-section-header .toggle-icon{font-size:12px;color:var(--text-light);transition:transform .2s}
.crm-section-header .toggle-icon.open{transform:rotate(90deg)}
.crm-section-body{padding:18px;display:none;border-top:1px solid var(--border)}
.crm-section-body.open{display:block}
.crm-section.highlight{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg)}
.crm-section.highlight .crm-section-header{background:var(--primary-bg)}

.crm-field-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid #f5f5f5}
.crm-field-row:last-child{border-bottom:none}
.crm-field-label{font-size:12px;font-weight:600;color:var(--text-light);min-width:140px;text-transform:uppercase;letter-spacing:.3px}
.crm-field-value{flex:1;font-size:13px}
.crm-field-value a{color:var(--primary)}
.crm-field-value input,.crm-field-value select,.crm-field-value textarea{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:4px}
.crm-field-value input:focus,.crm-field-value select:focus{outline:none;border-color:var(--primary)}

.crm-quick-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.crm-quick-actions button{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid;transition:all .2s}
.crm-quick-actions button:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.1)}

.insta-preview{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fafbfc;border-radius:6px;font-size:12px;color:var(--text-light)}
.insta-preview a{color:var(--primary);font-weight:500}

/* ── Utilities ────────────────────────────────────────────── */
.hidden{display:none!important}
.text-center{text-align:center}
.text-right{text-align:right}
.text-muted{color:var(--text-light)}
.text-sm{font-size:12px}
.mt-1{margin-top:8px}
.mt-2{margin-top:16px}
.mb-2{margin-bottom:16px}
.flex{display:flex}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.gap-2{gap:8px}
.w-full{width:100%}
.icon-check{color:var(--green);font-weight:bold}
.icon-cross{color:var(--red);font-weight:bold}
.select-all-checkbox{margin-right:4px}

/* ── UPI field with lock/edit layout ─────────────────────────────── */
.upi-field-wrap{display:flex;gap:8px;align-items:center}
.upi-field-wrap input{flex:1}

/* ── Payment status chips (replaces dropdowns) ───────────────────── */
.pay-action-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:4px 0}
.pay-status-chip{display:inline-block;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.3px;border:1px solid transparent}
.pay-status-chip.chip-unpaid{background:#f1f5f9;color:#64748b;border-color:#cbd5e1}
.pay-status-chip.chip-raised{background:#fef3c7;color:#92400e;border-color:#fcd34d}
.pay-status-chip.chip-paid{background:#d1fae5;color:#065f46;border-color:#6ee7b7}

/* ── Payment request button ──────────────────────────────────────── */
.pay-request-btn{font-size:12px!important;padding:5px 12px!important;white-space:nowrap;background:#eff6ff!important;color:#1d4ed8!important;border-color:#bfdbfe!important}
.pay-request-btn:hover{background:#dbeafe!important}

/* ── Lockable field (amount / fee) with inline Edit button ───────── */
.lockable-field-wrap{display:flex;gap:8px;align-items:center}
.lockable-field-wrap input{flex:1}
