/* ATP Admin - MorMan style theme */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#0c5e54;
  --primary-dark:#084842;
  --primary-light:#0e7066;
  --sidebar:#0c5e54;
  --sidebar-active:#0e8073;
  --sidebar-hover:#0a4d45;
  --bg:#f3f6f8;
  --card:#ffffff;
  --border:#e3e8ed;
  --text:#2d3748;
  --text-light:#718096;
  --text-muted:#a0aec0;
  --success:#0c9d65;
  --danger:#e53e3e;
  --warning:#f59e0b;
  --info:#3b82f6;
  --money-pos:#0c9d65;
  --money-neg:#e53e3e;
  --header:#0c5e54;
}
html,body{height:100%;font-family:'Segoe UI','Helvetica Neue',Arial,sans-serif;font-size:13px;color:var(--text);background:var(--bg);overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:13px}

/* ============ LOGIN ============ */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f3f6f8;padding:20px}
.login-box{background:#fff;border-radius:8px;box-shadow:0 8px 30px rgba(0,0,0,.08);padding:40px;width:100%;max-width:420px}
.login-logo{text-align:center;margin-bottom:8px}
.login-logo h1{font-size:42px;font-weight:800;color:var(--primary);font-family:Georgia,serif;letter-spacing:-1px}
.login-sub{text-align:center;color:var(--text-light);font-size:12px;margin-bottom:24px;text-transform:uppercase;letter-spacing:.5px}
.login-divider{display:flex;align-items:center;gap:10px;color:var(--text-light);margin:18px 0;font-size:12px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.login-field{position:relative;margin-bottom:14px}
.login-field i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted)}
.login-field input{width:100%;padding:12px 14px 12px 40px;border:1px solid var(--border);border-radius:24px;outline:none;background:#fafbfc}
.login-field input:focus{border-color:var(--primary);background:#fff}
.login-forgot{text-align:right;margin-bottom:18px}
.login-forgot a{color:var(--info);font-size:12px}
.login-btn{width:100%;padding:12px;background:#fff;border:1.5px solid var(--primary);color:var(--primary);border-radius:24px;font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:center;gap:8px;transition:.15s}
.login-btn:hover{background:var(--primary);color:#fff}
.login-foot{text-align:center;margin-top:18px;color:var(--text-light);font-size:13px}
.login-foot a{color:var(--info);font-weight:600}
.login-error{background:#fff5f5;color:var(--danger);padding:10px;border-radius:6px;margin-bottom:14px;font-size:12px;text-align:center;border:1px solid #fed7d7}
.demo-hint{background:#f0fdf4;color:var(--primary);padding:10px;border-radius:6px;margin-top:10px;font-size:11px;border:1px solid #c6f6d5;line-height:1.6}

/* ============ APP SHELL ============ */
.app{display:flex;min-height:100vh}
.sidebar{width:230px;background:var(--sidebar);color:#fff;display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}
.sb-brand{padding:18px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.08)}
.sb-brand h1{font-family:Georgia,serif;font-weight:800;font-size:22px;letter-spacing:-.5px}
.sb-brand .toggle{color:#fff;opacity:.7;font-size:16px;cursor:pointer}
.sb-menu{flex:1;padding:8px 0}
.sb-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:rgba(255,255,255,.88);font-size:13px;cursor:pointer;border-left:3px solid transparent;position:relative;user-select:none}
.sb-item:hover{background:var(--sidebar-hover)}
.sb-item.active{background:var(--sidebar-active);border-left-color:#fff;color:#fff;font-weight:500}
.sb-item > i.fa-chevron-right{margin-left:auto;font-size:9px;opacity:.6;transition:.2s}
.sb-item.open > i.fa-chevron-right{transform:rotate(90deg)}
.sb-badge{margin-left:auto;background:#e53e3e;color:#fff;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:600}
.sb-item.open + .sb-sub,.sb-sub.open{display:block}
.sb-sub{display:none;background:rgba(0,0,0,.12)}
.sb-subitem{padding:8px 20px 8px 46px;font-size:12px;color:rgba(255,255,255,.78);cursor:pointer;display:flex;align-items:center;gap:8px}
.sb-subitem::before{content:'▸';font-size:9px;opacity:.6}
.sb-subitem:hover{background:var(--sidebar-hover);color:#fff}
.sb-subitem.active{background:var(--sidebar-active);color:#fff;font-weight:500}
.sb-foot{padding:14px 20px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;color:rgba(255,255,255,.55);line-height:1.6}
.sb-foot a{color:#fff;text-decoration:underline}

.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{background:var(--header);color:#fff;height:50px;display:flex;align-items:center;padding:0 20px;gap:14px;position:sticky;top:0;z-index:50}
.topbar .branch-pick{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500}
.topbar .branch-pick i{font-size:10px}
.topbar .spacer{flex:1}
.tb-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;position:relative}
.tb-icon:hover{background:rgba(255,255,255,.12)}
.tb-bad-debt{background:rgba(255,255,255,.14);padding:5px 14px;border-radius:18px;font-size:12px;display:flex;align-items:center;gap:6px;cursor:pointer}
.tb-user{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:4px;position:relative}
.tb-user:hover{background:rgba(255,255,255,.1)}
.tb-user .avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#ec4899);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;font-size:12px}
.tb-user .name{font-size:13px;font-weight:500}
.user-menu{position:absolute;top:44px;right:0;background:#fff;color:var(--text);border-radius:6px;box-shadow:0 6px 20px rgba(0,0,0,.15);min-width:200px;padding:6px;z-index:100;display:none}
.user-menu.show{display:block}
.user-menu a{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:13px}
.user-menu a:hover{background:#f7fafc}
.user-menu .sep{height:1px;background:var(--border);margin:4px 0}

.content{flex:1;padding:16px;overflow-x:auto}
.page-title{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-size:15px;color:var(--text);font-weight:500}
.page-title i{color:var(--primary);background:#dcfce7;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px}
.crumb{color:var(--text-light);font-weight:400}

/* ============ CARDS / KPI ============ */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:14px}
.kpi{background:#fff;border-radius:8px;padding:18px;display:flex;justify-content:space-between;align-items:flex-start;box-shadow:0 1px 3px rgba(0,0,0,.04);position:relative;overflow:hidden}
.kpi.kpi-money{background:linear-gradient(135deg,#0e7066 0%,#0c5e54 100%);color:#fff}
.kpi.kpi-money .kpi-label{color:rgba(255,255,255,.85)}
.kpi.kpi-money .kpi-value{color:#fff}
.kpi-info .kpi-label{font-size:13px;color:var(--text);font-weight:500;margin-bottom:4px}
.kpi-info .kpi-sub{font-size:11px;color:var(--text-light);margin-bottom:8px}
.kpi-info .kpi-value{font-size:28px;font-weight:700;color:var(--text)}
.kpi-info .kpi-foot{font-size:11px;color:var(--text-light);margin-top:6px}
.kpi-icon{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.bg-orange{background:#fff4e6;color:#f59e0b}
.bg-purple{background:#f3e8ff;color:#9333ea}
.bg-green{background:#dcfce7;color:#16a34a}
.bg-blue{background:#dbeafe;color:#2563eb}
.bg-red{background:#fee2e2;color:#dc2626}
.kpi.kpi-money .kpi-icon{background:rgba(255,255,255,.15);color:#fff}

/* table panel */
.panel{background:#fff;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.04);margin-bottom:14px;overflow:hidden}
.panel-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.panel-head h3{font-size:14px;font-weight:600;color:var(--text)}
.panel-body{padding:14px 16px}
.panel-body.no-pad{padding:0}

/* filters bar */
.filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;padding:14px 16px;background:#fff;border-radius:8px;margin-bottom:10px;box-shadow:0 1px 3px rgba(0,0,0,.04);align-items:end}
.field label{display:block;font-size:11px;color:var(--text-light);margin-bottom:4px;font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:5px;background:#fff;outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary)}
.field-actions{display:flex;gap:8px;grid-column:1/-1;justify-content:flex-end;flex-wrap:wrap}
.field-actions .btn{min-width:86px;justify-content:center}
.btn{padding:8px 16px;border-radius:5px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;border:1px solid transparent;cursor:pointer;transition:.15s}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-dark)}
.btn-success{background:var(--success);color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-warn{background:var(--warning);color:#fff}
.btn-outline{background:#fff;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:#f0fdf4}
.btn-soft{background:#f0fdf4;color:var(--primary);border:1px solid #c6f6d5}
.btn-soft:hover{background:#dcfce7}
.btn-icon{width:32px;height:32px;padding:0;justify-content:center;border-radius:5px;background:#fff;color:var(--text);border:1px solid var(--border)}
.btn-icon:hover{background:#f7fafc;color:var(--primary)}
.btn-sm{padding:5px 10px;font-size:12px}

/* tables */
.tbl-wrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl thead th{background:#f7fafc;padding:10px 12px;text-align:left;font-weight:600;color:var(--text);border-bottom:2px solid var(--border);white-space:nowrap;font-size:12px}
.tbl thead th .sub{display:block;font-weight:400;color:var(--danger);font-size:11px;margin-top:2px}
.tbl tbody td{padding:10px 12px;border-bottom:1px solid #edf0f4;vertical-align:top}
.tbl tbody tr:hover{background:#f7fafc}
.tbl .col-money{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.tbl .col-center{text-align:center}
.tbl .money-pos{color:var(--money-pos);font-weight:500}
.tbl .money-neg{color:var(--money-neg);font-weight:500}
.tbl .code-link{color:var(--info);font-weight:500;cursor:pointer}
.tbl .sub-text{font-size:11px;color:var(--text-light);margin-top:2px}
.row-actions{display:flex;gap:4px;justify-content:flex-end}
.row-actions a,.row-actions button{width:26px;height:26px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;background:#f0fdf4;color:var(--primary);font-size:11px;cursor:pointer;border:0;text-decoration:none}
.row-actions a:hover,.row-actions button:hover{background:var(--primary);color:#fff}
.row-actions a.del,.row-actions button.del{background:#fff5f5;color:var(--danger)}
.row-actions a.del:hover,.row-actions button.del:hover{background:var(--danger);color:#fff}

.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap}
.badge-success{background:#dcfce7;color:#15803d}
.badge-danger{background:#fee2e2;color:#b91c1c}
.badge-warning{background:#fef3c7;color:#a16207}
.badge-info{background:#dbeafe;color:#1d4ed8}
.badge-muted{background:#f1f5f9;color:#475569}

.pagination{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-light);border-top:1px solid var(--border)}
.pagination .pages{display:flex;gap:4px}
.pagination .pages a{width:28px;height:28px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);color:var(--text);cursor:pointer}
.pagination .pages a.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* charts row */
.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}
.chart-box{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.chart-box h4{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--text)}
.chart-box .chart-host{position:relative;height:240px}

/* totals stat */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;background:#fff;border-radius:8px;padding:18px;box-shadow:0 1px 3px rgba(0,0,0,.04);margin-bottom:14px}
.stat-cell{text-align:center;position:relative}
.stat-cell + .stat-cell{border-left:1px solid var(--border)}
.stat-cell .icn{font-size:22px;color:var(--primary);margin-bottom:6px}
.stat-cell .lbl{font-size:11px;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin:6px 0 4px}
.stat-cell .val{font-size:18px;font-weight:700;color:var(--text)}
.stat-cell .val.pos{color:var(--success)}
.stat-cell .val.neg{color:var(--danger)}
.stat-cell .val.total{color:var(--danger);font-size:22px}

/* Modal */
.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal{background:#fff;border-radius:8px;max-width:720px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}
.modal.wide{max-width:1000px}
.modal-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:#f7fafc}
.modal-head h3{font-size:15px;color:var(--primary);font-weight:600}
.modal-head .x{cursor:pointer;color:var(--text-light);font-size:18px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px}
.modal-head .x:hover{background:#edf0f4}
.modal-body{padding:18px;overflow-y:auto;flex:1}
.modal-foot{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:#f7fafc}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.form-grid.g2{grid-template-columns:repeat(2,1fr)}

/* tabs */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:14px}
.tabs .tab{padding:10px 16px;color:var(--text-light);cursor:pointer;border-bottom:2px solid transparent;font-size:13px;font-weight:500}
.tabs .tab:hover{color:var(--primary)}
.tabs .tab.active{color:var(--primary);border-bottom-color:var(--primary)}

.tab-pane{display:none}
.tab-pane.active{display:block}

/* Toast */
.toast-wrap{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{background:#fff;border-left:4px solid var(--success);padding:12px 16px;border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.12);min-width:260px;font-size:13px;animation:slideIn .25s}
.toast.err{border-left-color:var(--danger)}
.toast.warn{border-left-color:var(--warning)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* Footer */
.app-foot{padding:12px 18px;color:var(--text-light);font-size:12px;text-align:center;border-top:1px solid var(--border);background:#fff}

/* Empty state */
.empty{text-align:center;padding:40px 20px;color:var(--text-light)}
.empty i{font-size:48px;color:var(--text-muted);margin-bottom:12px;display:block}

/* toggle switch */
.switch{position:relative;display:inline-block;width:42px;height:22px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:#cbd5e0;border-radius:22px;cursor:pointer;transition:.2s}
.slider::before{content:'';position:absolute;left:3px;top:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .slider{background:var(--success)}
.switch input:checked + .slider::before{transform:translateX(20px)}

/* Sidebar collapsed */
.app.collapsed .sidebar{width:60px}
.app.collapsed .sb-brand{padding:12px 8px;justify-content:center;flex-direction:column;gap:10px}
.app.collapsed .sb-logo-tag,.app.collapsed .sb-foot,.app.collapsed .sb-sub,.app.collapsed .sb-badge,.app.collapsed .sb-item .fa-chevron-right{display:none}
.app.collapsed .sb-logo-img{width:40px;height:40px;border-radius:10px}
.app.collapsed .sb-brand .toggle{display:flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:6px;background:rgba(255,255,255,.12);opacity:1;font-size:18px;flex-shrink:0}
.app.collapsed .sb-role-chip{width:42px;height:42px;margin:8px auto;padding:0;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:0;overflow:hidden}
.app.collapsed .sb-role-chip i{font-size:16px}
.app.collapsed .sb-item{justify-content:center;padding:12px}
.app.collapsed .sb-item span{display:none}

@media (max-width:768px){
  .sidebar{position:fixed;left:-230px;z-index:100;transition:.2s}
  .sidebar.show{left:0}
  .topbar .branch-pick span{display:none}
  .kpi-value{font-size:22px !important}
}

/* ============ ATP v2 ADDITIONS ============ */

/* Dashboard command center */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:14px;margin-bottom:14px}
.link-more{margin-left:auto;font-size:12px;color:var(--info);cursor:pointer;font-weight:500}
.link-more:hover{text-decoration:underline}
.dash-hero{background:radial-gradient(circle at top left,rgba(126,200,80,.35),transparent 28%),linear-gradient(135deg,#0b4f48,#0e7066 58%,#123c36);color:#fff;border-radius:20px;padding:24px;margin-bottom:14px;display:grid;grid-template-columns:minmax(280px,1fr) minmax(360px,520px);gap:18px;align-items:center;box-shadow:0 16px 40px rgba(12,94,84,.22);overflow:hidden;position:relative}
.dash-hero:after{content:'';position:absolute;right:-80px;top:-80px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.08)}
.dash-eyebrow{text-transform:uppercase;letter-spacing:1.8px;font-size:11px;color:#baf7dd;font-weight:800;margin-bottom:8px}
.dash-hero h1{font-size:30px;line-height:1.12;margin-bottom:8px;position:relative;z-index:1}
.dash-hero p{color:rgba(255,255,255,.82);font-size:13px;max-width:640px;line-height:1.6;position:relative;z-index:1}
.dash-filter-card{position:relative;z-index:1;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:14px;backdrop-filter:blur(10px);box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}
.segmented{display:inline-flex;background:rgba(255,255,255,.13);border-radius:999px;padding:4px;margin-bottom:12px;gap:4px}
.segmented button{border:0;background:transparent;color:rgba(255,255,255,.82);padding:8px 16px;border-radius:999px;font-weight:700;cursor:pointer}
.segmented button.active{background:#fff;color:var(--primary);box-shadow:0 6px 16px rgba(0,0,0,.12)}
.dash-filter-row{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.dash-filter-row .field{min-width:118px;flex:1}.dash-filter-row label{color:rgba(255,255,255,.78)}
.dash-filter-row input,.dash-filter-row select{width:100%;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.94);border-radius:10px;padding:9px 10px;color:var(--text)}
.dash-filter-row .btn{height:38px}.dash-day,.dash-month{display:none}.dash-day.show,.dash-month.show{display:block}
.dash-period-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}.dash-period-strip span{background:#fff;border:1px solid #e8edf2;border-radius:999px;padding:8px 12px;color:var(--text-light);font-size:12px;box-shadow:0 1px 3px rgba(0,0,0,.03)}.dash-period-strip span:first-child{color:var(--primary);font-weight:800;background:#ecfdf5;border-color:#bbf7d0}
.exec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;margin-bottom:14px}.exec-card{background:#fff;border-radius:16px;padding:18px;position:relative;overflow:hidden;min-height:138px;box-shadow:0 8px 24px rgba(15,23,42,.06);border:1px solid #eef2f6}.exec-card:before{content:'';position:absolute;inset:0 0 auto 0;height:4px;background:var(--primary)}.exec-card.primary:before{background:#0e7066}.exec-card.success:before{background:#10b981}.exec-card.warn:before{background:#f59e0b}.exec-card.danger:before{background:#ef4444}.exec-card span{display:block;color:var(--text-light);font-size:12px;font-weight:700;margin-bottom:10px}.exec-card b{display:block;color:var(--text);font-size:25px;line-height:1.15;margin-bottom:10px}.exec-card em{font-style:normal;font-size:11px;color:var(--text-light);font-weight:700}.exec-card em.good{color:#059669}.exec-card em.bad{color:#dc2626}.exec-card>i{position:absolute;right:16px;bottom:14px;font-size:42px;color:rgba(12,94,84,.10)}
.ops-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(320px,.8fr);gap:14px;margin-bottom:14px}.ops-grid.lower{grid-template-columns:1fr 1fr}.dash-chart-panel .chart-host{height:340px;padding:14px}.panel-note{font-size:12px;color:var(--text-light);margin-left:auto}.risk-card{background:linear-gradient(180deg,#fff,#f8fffc);border:1px solid #e6f4ee;border-radius:16px;padding:18px;box-shadow:0 8px 24px rgba(15,23,42,.06)}.risk-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.risk-head span{color:var(--text-light);font-size:12px;font-weight:700}.risk-head b{font-size:24px}.risk-head .good{color:#059669}.risk-head .warn{color:#d97706}.risk-head .bad{color:#dc2626}.risk-sub{font-size:11.5px;color:var(--text-light);line-height:1.45;margin-bottom:10px}.risk-ring{--p:80;width:160px;height:160px;border-radius:50%;margin:12px auto;background:conic-gradient(#0e7066 calc(var(--p)*1%),#e5e7eb 0);display:flex;align-items:center;justify-content:center;position:relative}.risk-ring:after{content:'';position:absolute;width:118px;height:118px;border-radius:50%;background:#fff}.risk-ring span{position:relative;z-index:1;font-size:26px;font-weight:900;color:var(--primary)}.risk-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.risk-list div{background:#f8fafc;border-radius:12px;padding:10px;text-align:center}.risk-list b{display:block;font-size:20px;color:var(--text)}.risk-list span{font-size:11px;color:var(--text-light)}
.smart-grid{display:grid;grid-template-columns:1.25fr .85fr .9fr;gap:14px;margin-bottom:14px}.smart-list,.staff-rank,.todo-list,.ops-alerts,.cash-feed{display:flex;flex-direction:column;gap:8px;padding:14px}.smart-item{display:grid;grid-template-columns:38px 1fr auto;gap:10px;align-items:center;padding:12px;border-radius:12px;background:#f8fafc;border:1px solid #eef2f6;cursor:pointer;transition:.15s}.smart-item:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(15,23,42,.08)}.smart-item i{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#ecfdf5;color:#059669}.smart-item.warn i{background:#fef3c7;color:#d97706}.smart-item.danger i{background:#fee2e2;color:#dc2626}.smart-item b,.todo-row b,.cash-row b{display:block;color:var(--text);font-size:13px}.smart-item span,.todo-row span,.cash-row span{display:block;color:var(--text-light);font-size:11.5px;margin-top:3px}.smart-item em{font-style:normal;color:var(--primary);font-size:12px;font-weight:800}.staff-rank-row,.todo-row,.cash-row{display:grid;grid-template-columns:42px 1fr auto;gap:10px;align-items:center;background:#f8fafc;border-radius:12px;padding:11px 12px}.staff-rank-row b{color:var(--primary)}.staff-rank-row span small{display:block;color:var(--text-light);font-size:11px;margin-top:2px}.staff-rank-row em,.todo-row em,.cash-row em{font-style:normal;font-weight:800;color:var(--primary);white-space:nowrap}.todo-row{grid-template-columns:1fr auto;cursor:pointer}.todo-row:hover{background:#ecfdf5}.ops-alert{display:grid;grid-template-columns:38px 1fr;gap:10px;align-items:start;padding:12px;border-radius:12px;background:#f8fafc;border-left:4px solid var(--info);cursor:pointer}.ops-alert.warn{border-left-color:var(--warning)}.ops-alert.danger{border-left-color:var(--danger)}.ops-alert i{width:34px;height:34px;border-radius:10px;background:#e0f2fe;color:#0369a1;display:flex;align-items:center;justify-content:center}.ops-alert.danger i{background:#fee2e2;color:#dc2626}.ops-alert b{display:block;font-size:13px}.ops-alert span{display:block;color:var(--text-light);font-size:11.5px;margin-top:3px;line-height:1.45}.cash-row{grid-template-columns:38px 1fr auto}.cash-row .cash-ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center}.cash-row.thu .cash-ic{background:#dcfce7;color:#059669}.cash-row.chi .cash-ic{background:#fee2e2;color:#dc2626}.cash-row.thu em{color:#059669}.cash-row.chi em{color:#dc2626}
@media(max-width:1100px){.dash-hero,.ops-grid,.ops-grid.lower,.smart-grid{grid-template-columns:1fr}.exec-card b{font-size:22px}}

/* KPI gradients */
.kpi.grad-1{background:linear-gradient(135deg,#0e7066,#0c5e54);color:#fff}
.kpi.grad-2{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}
.kpi.grad-3{background:linear-gradient(135deg,#9333ea,#6d28d9);color:#fff}
.kpi.grad-4{background:linear-gradient(135deg,#f59e0b,#dc2626);color:#fff}
.kpi.grad-1 .kpi-label,.kpi.grad-2 .kpi-label,.kpi.grad-3 .kpi-label,.kpi.grad-4 .kpi-label,
.kpi.grad-1 .kpi-sub,.kpi.grad-2 .kpi-sub,.kpi.grad-3 .kpi-sub,.kpi.grad-4 .kpi-sub,
.kpi.grad-1 .kpi-foot,.kpi.grad-2 .kpi-foot,.kpi.grad-3 .kpi-foot,.kpi.grad-4 .kpi-foot{color:rgba(255,255,255,.9)}
.kpi.grad-1 .kpi-value,.kpi.grad-2 .kpi-value,.kpi.grad-3 .kpi-value,.kpi.grad-4 .kpi-value{color:#fff}
.kpi.grad-1 .kpi-icon,.kpi.grad-2 .kpi-icon,.kpi.grad-3 .kpi-icon,.kpi.grad-4 .kpi-icon{background:rgba(255,255,255,.18);color:#fff}

/* Sidebar ATP logo + role chip */
.sb-logo{display:flex;align-items:center;gap:10px;min-width:0}
.sb-logo-img{width:58px;height:58px;border-radius:12px;object-fit:cover;background:#fff;display:block;flex-shrink:0}
.sb-logo-mark{width:36px;height:36px;border-radius:8px;background:#fff;color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-family:Georgia,serif;font-size:16px}
.sb-logo-tag{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-role-chip{display:inline-block;margin:8px 20px;padding:4px 10px;border-radius:12px;background:rgba(255,255,255,.14);font-size:11px;font-weight:500;color:#fff}

/* Alerts dropdown */
.alerts-drop{position:absolute;top:44px;right:0;background:#fff;color:var(--text);border-radius:6px;box-shadow:0 6px 20px rgba(0,0,0,.15);min-width:320px;max-height:420px;overflow-y:auto;z-index:100;display:none}
.alerts-drop.show{display:block}
.alerts-drop .ad-head{padding:10px 14px;border-bottom:1px solid var(--border);font-weight:600;font-size:13px;position:sticky;top:0;background:#fff}
.ad-item{padding:10px 14px;border-bottom:1px solid #edf0f4;cursor:pointer;display:flex;gap:10px;font-size:12.5px}
.ad-item:hover{background:#f7fafc}
.ad-item i{color:var(--warning);margin-top:2px}
.ad-item.danger i{color:var(--danger)}
.ad-item .ad-title{font-weight:500;margin-bottom:2px}
.ad-item .ad-sub{color:var(--text-light);font-size:11px}

/* Notification Center */
.notif-hero{background:linear-gradient(135deg,#0c5e54,#0e8073);color:#fff;border-radius:14px;padding:22px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center;gap:16px;box-shadow:0 8px 24px rgba(12,94,84,.18)}
.notif-hero h2{font-size:22px;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.notif-hero p{color:rgba(255,255,255,.82)}
.notif-hero-actions{display:flex;gap:8px;flex-wrap:wrap}.notif-hero .btn-outline{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.35)}
.notif-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:14px}
.notif-summary>div{background:#fff;border-radius:12px;padding:14px 16px;box-shadow:0 1px 3px rgba(0,0,0,.04);border-left:4px solid var(--primary)}
.notif-summary>div.danger{border-left-color:var(--danger)}.notif-summary>div.warn{border-left-color:var(--warning)}
.notif-summary span{display:block;color:var(--text-light);font-size:12px;margin-bottom:6px}.notif-summary b{font-size:24px;color:var(--text)}
.notif-layout{display:grid;grid-template-columns:240px 1fr;gap:14px;align-items:start}
.notif-side{background:#fff;border-radius:12px;padding:10px;box-shadow:0 1px 3px rgba(0,0,0,.04);position:sticky;top:64px}
.notif-side button{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:8px;color:var(--text);font-weight:500}
.notif-side button:hover,.notif-side button.active{background:#ecfdf5;color:var(--primary)}.notif-side b{font-size:12px;background:#f1f5f9;padding:2px 8px;border-radius:10px}
.notif-content{min-width:0}.notif-tools{background:#fff;border-radius:12px;padding:12px;margin-bottom:10px;display:flex;gap:8px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.notif-tools input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:8px;outline:none}.notif-tools input:focus{border-color:var(--primary)}
.notif-list{display:flex;flex-direction:column;gap:10px}.notif-item{background:#fff;border-radius:12px;padding:14px;display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:start;box-shadow:0 1px 3px rgba(0,0,0,.04);border-left:4px solid var(--info)}
.notif-item.danger{border-left-color:var(--danger)}.notif-item.warn{border-left-color:var(--warning)}.notif-item.info{border-left-color:var(--info)}.notif-item.read{opacity:.72}
.notif-ic{width:40px;height:40px;border-radius:12px;background:#ecfdf5;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:17px}
.notif-item.danger .notif-ic{background:#fee2e2;color:var(--danger)}.notif-item.warn .notif-ic{background:#fef3c7;color:var(--warning)}
.notif-title{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:4px}.notif-title b{font-size:14px}.notif-type{font-size:11px;background:#e0f2fe;color:#0369a1;padding:3px 8px;border-radius:10px;font-weight:600}
.notif-msg{color:var(--text);font-size:13px;line-height:1.45}.notif-meta{color:var(--text-light);font-size:11.5px;margin-top:5px}.notif-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
@media(max-width:900px){.notif-layout{grid-template-columns:1fr}.notif-side{position:static}.notif-item{grid-template-columns:40px 1fr}.notif-actions{grid-column:1 / -1;justify-content:flex-start}}

/* iCloud command center */
.ic-page-v2{display:flex;flex-direction:column;gap:14px}.ic-hero-v2{position:relative;overflow:hidden;background:linear-gradient(135deg,#f8fffc,#eefdf7 48%,#eaf4ff);border:1px solid #d9f2e8;border-radius:24px;padding:28px;display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:20px;box-shadow:0 18px 42px rgba(15,23,42,.08)}.ic-hero-v2:before{content:'';position:absolute;right:-90px;top:-90px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,#0e706633,transparent 68%)}.ic-hero-copy{position:relative;z-index:1}.ic-pill{display:inline-flex;gap:8px;align-items:center;background:#fff;border:1px solid #dbeafe;color:#0e7066;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:800;margin-bottom:14px}.ic-hero-v2 h1{font-size:34px;color:#0f2f2b;margin-bottom:10px}.ic-hero-v2 p{max-width:720px;color:#64748b;line-height:1.65;font-size:14px}.ic-hero-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}.ic-hero-actions .btn-outline{background:#fff}.ic-orbit-card{position:relative;z-index:1;background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.9);border-radius:22px;padding:18px;box-shadow:0 16px 36px rgba(15,23,42,.10);backdrop-filter:blur(10px)}.ic-orbit{width:178px;height:178px;border-radius:50%;margin:0 auto 14px;background:conic-gradient(#0e7066 0 78%,#dbeafe 0);display:flex;align-items:center;justify-content:center;flex-direction:column;box-shadow:inset 0 0 0 24px #fff}.ic-orbit span{font-size:38px;font-weight:900;color:#0e7066}.ic-orbit small{color:#64748b;font-weight:700}.ic-orbit-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.ic-orbit-stats div{background:#f8fafc;border-radius:14px;padding:10px;text-align:center}.ic-orbit-stats b{display:block;font-size:20px;color:#0f172a}.ic-orbit-stats span{font-size:10.5px;color:#64748b}.ic-status-rail{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px}.ic-status-rail button{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #eef2f7;border-radius:16px;padding:13px 14px;box-shadow:0 8px 22px rgba(15,23,42,.04);cursor:pointer}.ic-status-rail button.active{border-color:var(--c);box-shadow:0 12px 28px color-mix(in srgb,var(--c) 20%,transparent)}.ic-status-rail i{width:12px;height:12px;border-radius:50%;background:var(--c);box-shadow:0 0 0 5px color-mix(in srgb,var(--c) 14%,transparent)}.ic-status-rail span{font-weight:800;color:#334155}.ic-status-rail b{margin-left:auto;color:#0f172a;font-size:20px}.ic-overview-v2{display:grid;grid-template-columns:minmax(320px,1.1fr) minmax(280px,.8fr) minmax(260px,.65fr);gap:14px}.ic-focus-card,.ic-map-card,.ic-action-card{background:#fff;border:1px solid #eef2f7;border-radius:20px;padding:16px;box-shadow:0 10px 26px rgba(15,23,42,.05)}.ic-focus-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.ic-focus-head span,.ic-action-card h3,.ic-map-card h3{font-weight:900;color:#0f2f2b}.ic-focus-head b{font-size:28px;color:#dc2626}.ic-focus-list{display:flex;flex-direction:column;gap:9px}.ic-focus-item{display:grid;grid-template-columns:42px 1fr 44px;gap:10px;align-items:center;border-radius:16px;padding:11px;background:#f8fafc;border:1px solid #eef2f7;cursor:pointer}.ic-focus-item:hover{background:#ecfdf5}.ic-focus-item.critical{border-left:4px solid #dc2626}.ic-focus-item.high{border-left:4px solid #f59e0b}.ic-device-icon{width:42px;height:42px;border-radius:14px;background:#e0f2fe;color:#0369a1;display:flex;align-items:center;justify-content:center}.ic-focus-item b{display:block;color:#0f172a}.ic-focus-item span{display:block;font-size:12px;color:#64748b;margin:2px 0}.ic-focus-item em{display:flex;gap:5px;flex-wrap:wrap;font-style:normal}.ic-focus-item strong{font-size:22px;color:#0e7066;text-align:right}.ic-map-card{position:relative;overflow:hidden;min-height:240px;background:linear-gradient(145deg,#0f172a,#164e49);color:#fff}.ic-map-card h3,.ic-map-card p{position:relative;z-index:1;color:#fff}.ic-map-card p{font-size:12px;color:rgba(255,255,255,.7);margin-top:4px}.ic-map-glow{position:absolute;inset:30px;border-radius:50%;background:radial-gradient(circle,rgba(34,197,94,.28),transparent 68%);filter:blur(4px)}.ic-map-points{position:relative;z-index:1;height:128px;margin-top:18px}.ic-map-points span{position:absolute;width:10px;height:10px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 5px rgba(34,197,94,.15)}.ic-map-points span:nth-child(3n){left:18%;top:26%}.ic-map-points span:nth-child(3n+1){left:58%;top:46%}.ic-map-points span:nth-child(3n+2){left:76%;top:22%}.ic-map-points span.high{background:#f59e0b}.ic-map-points span.critical{background:#ef4444}.ic-map-foot{position:relative;z-index:1;display:flex;gap:8px;flex-wrap:wrap}.ic-map-foot span{background:rgba(255,255,255,.12);padding:6px 10px;border-radius:999px;font-size:11px}.ic-action-card{display:flex;flex-direction:column;gap:10px}.ic-action-card button{display:grid;grid-template-columns:34px 1fr auto;gap:10px;align-items:center;border:1px solid #eef2f7;background:#f8fafc;border-radius:14px;padding:11px;cursor:pointer;text-align:left}.ic-action-card button:hover{background:#ecfdf5}.ic-action-card i{width:34px;height:34px;border-radius:12px;background:#fff;color:#0e7066;display:flex;align-items:center;justify-content:center}.ic-action-card span{font-weight:800;color:#334155}.ic-action-card b{font-size:20px;color:#0f172a}.ic-board{border-radius:20px;overflow:hidden}.ic-board-head{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 18px;border-bottom:1px solid #eef2f7;flex-wrap:wrap}.ic-board-head h3{font-size:18px;color:#0f2f2b}.ic-board-head p{font-size:12px;color:#64748b}.ic-board-tools{display:flex;gap:8px;align-items:center;flex:1;max-width:680px}.ic-board-tools input{flex:1;border:1px solid #e2e8f0;border-radius:12px;padding:11px 13px}.ic-device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;padding:14px;background:#fbfdfc}.ic-device-card{background:#fff;border:1px solid #edf2f7;border-radius:18px;padding:14px;cursor:pointer;box-shadow:0 6px 18px rgba(15,23,42,.04);position:relative;overflow:hidden}.ic-device-card:before{content:'';position:absolute;inset:0 0 auto 0;height:4px;background:#22c55e}.ic-device-card.watch:before{background:#f59e0b}.ic-device-card.high:before{background:#f97316}.ic-device-card.critical:before{background:#dc2626}.ic-device-card:hover{transform:translateY(-2px);box-shadow:0 16px 30px rgba(15,23,42,.10)}.ic-device-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.ic-phone{width:44px;height:44px;border-radius:15px;background:linear-gradient(135deg,#0e7066,#14b8a6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px}.ic-device-code{text-align:right;font-size:11px;color:#64748b;margin-top:5px}.ic-device-card h4{font-size:15px;color:#0f172a;margin-bottom:3px}.ic-device-card p{font-size:12px;color:#64748b;margin-bottom:10px}.ic-device-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:10px}.ic-device-meta span{background:#f8fafc;border-radius:10px;padding:6px;text-align:center;font-size:11px;color:#475569}.ic-device-meta i{margin-right:4px;color:#0e7066}.ic-device-status{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.ic-device-location{font-size:12px;color:#64748b;border-top:1px solid #f1f5f9;padding-top:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ic-device-location i{color:#ef4444;margin-right:5px}.ic-device-actions{display:flex;gap:6px;margin-top:12px}.ic-device-actions button{flex:1;border:0;background:#ecfdf5;color:#0e7066;border-radius:10px;padding:8px;font-weight:800;cursor:pointer}.ic-device-actions button:hover{background:#d1fae5}@media(max-width:1180px){.ic-hero-v2,.ic-overview-v2{grid-template-columns:1fr}.ic-orbit-card{max-width:420px}.ic-board-tools{max-width:none}}

.ic-hero{background:radial-gradient(circle at top right,rgba(59,130,246,.24),transparent 28%),linear-gradient(135deg,#083f3a,#0e7066);color:#fff;border-radius:20px;padding:24px;margin-bottom:14px;display:grid;grid-template-columns:1fr 260px;gap:18px;align-items:center;box-shadow:0 16px 40px rgba(12,94,84,.20)}
.ic-hero h1{font-size:28px;margin-bottom:8px}.ic-hero p{color:rgba(255,255,255,.82);line-height:1.55;font-size:13px}.ic-hero.refined{background:radial-gradient(circle at 88% 18%,rgba(126,200,80,.32),transparent 24%),linear-gradient(135deg,#073f3a,#0d6d63 58%,#062d29);border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 44px rgba(6,45,41,.24)}.ic-hero-mini{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.ic-hero-mini span{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:7px 10px;color:rgba(255,255,255,.86);font-size:12px;font-weight:700}.ic-hero-score{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:18px;text-align:center}.ic-hero-score span,.ic-hero-score em{display:block;color:rgba(255,255,255,.8);font-size:12px}.ic-hero-score b{display:block;font-size:46px;line-height:1;margin:8px 0;color:#fff}
.ic-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:14px}.ic-kpi-grid.refined{grid-template-columns:repeat(5,minmax(150px,1fr))}.ic-kpi{background:#fff;border-radius:16px;padding:16px;box-shadow:0 8px 24px rgba(15,23,42,.06);border:1px solid #edf2f7;position:relative;overflow:hidden}.ic-kpi:before{content:'';position:absolute;inset:0 0 auto 0;height:4px;background:var(--primary)}.ic-kpi.ok:before{background:#16a34a}.ic-kpi.warn:before{background:#f59e0b}.ic-kpi.danger:before{background:#dc2626}.ic-kpi.info:before{background:#2563eb}.ic-kpi.muted:before{background:#64748b}.ic-kpi{display:block;text-align:left;cursor:pointer;transition:.16s}.ic-kpi:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(15,23,42,.10);border-color:#d7efe7}.ic-kpi.active{box-shadow:0 0 0 3px rgba(14,112,102,.14),0 14px 30px rgba(15,23,42,.10);border-color:var(--primary)}.ic-kpi.active:after{content:'Đang lọc';position:absolute;top:10px;right:12px;background:#ecfdf5;color:var(--primary);border-radius:999px;padding:3px 8px;font-size:10px;font-weight:800}.ic-kpi i{position:absolute;right:14px;bottom:12px;font-size:34px;color:rgba(12,94,84,.10)}.ic-kpi span{display:block;color:var(--text-light);font-size:12px;font-weight:700;margin-bottom:8px}.ic-kpi b{font-size:28px;color:var(--text)}.ic-kpi em{display:block;font-style:normal;color:var(--text-light);font-size:11px;margin-top:6px}
.ic-layout{display:grid;grid-template-columns:250px minmax(0,1fr);gap:14px;align-items:start}.ic-layout.refined{grid-template-columns:238px minmax(0,1fr)}.ic-side{position:sticky;top:70px;padding:10px}.ic-side-title{font-weight:800;color:var(--primary);padding:8px 10px 12px}.ic-side button{width:100%;display:flex;align-items:center;justify-content:space-between;border:0;background:transparent;padding:10px 12px;border-radius:10px;color:var(--text);font-weight:600;cursor:pointer}.ic-side button:hover,.ic-side button.active{background:#ecfdf5;color:var(--primary)}.ic-side button b{background:#f1f5f9;border-radius:999px;padding:2px 8px;font-size:11px;color:inherit}.ic-main{min-width:0}.ic-risk-queue{margin-bottom:14px}.ic-risk-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;padding:14px}.ic-risk-card{border:1px solid #edf2f7;background:linear-gradient(180deg,#fff,#fbfdfc);border-radius:14px;padding:14px;cursor:pointer;box-shadow:0 4px 14px rgba(15,23,42,.04);border-left:5px solid #94a3b8}.ic-risk-card.high{border-left-color:#f59e0b}.ic-risk-card.critical{border-left-color:#dc2626}.ic-risk-card:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(15,23,42,.09)}.ic-risk-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.ic-risk-top b{font-size:14px;color:var(--text)}.ic-risk-meta{font-size:12px;color:var(--text-light);margin:6px 0}.ic-risk-tags{display:flex;gap:6px;flex-wrap:wrap}.ic-risk-tags span{background:#f8fafc;border-radius:999px;padding:3px 8px;font-size:11px;color:var(--text-light)}.ic-risk-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.ic-risk{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:800;white-space:nowrap}.ic-risk b{font-size:12px}.ic-risk.safe{background:#dcfce7;color:#15803d}.ic-risk.watch{background:#fef3c7;color:#a16207}.ic-risk.high{background:#ffedd5;color:#c2410c}.ic-risk.critical{background:#fee2e2;color:#b91c1c}
.ic-tools{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px;border-bottom:1px solid var(--border);flex-wrap:wrap;background:linear-gradient(180deg,#fff,#fbfdfc)}.ic-tools h3{color:var(--primary);font-size:16px}.ic-tools p{color:var(--text-light);font-size:12px}.ic-tools input{min-width:320px;flex:1;border:1px solid var(--border);border-radius:10px;padding:10px 12px}.ic-table-panel{border-radius:16px;overflow:hidden}.ic-table thead th{background:#f8fafc;color:#475569;font-size:11px;text-transform:uppercase;letter-spacing:.35px}.ic-table tbody tr{cursor:pointer}.ic-table tbody tr:hover{background:#f8fffc}.mono{font-family:Consolas,monospace}.danger-text{color:var(--danger)!important}.warn-text{color:var(--warning)!important}.ic-detail-head{display:flex;align-items:center;justify-content:space-between;gap:14px;background:linear-gradient(135deg,#ecfdf5,#fff);border-radius:14px;padding:16px;margin-bottom:14px}.ic-detail-head h2{color:var(--primary);font-size:22px}.ic-detail-head p{color:var(--text-light);font-size:12px;margin-top:4px}.ic-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px}.ic-detail-grid div{background:#f8fafc;border-radius:12px;padding:14px}.ic-detail-grid span{display:block;color:var(--text-light);font-size:12px;margin-bottom:7px}.ic-detail-grid b{font-size:16px;color:var(--text)}
@media(max-width:1100px){.ic-hero,.ic-layout{grid-template-columns:1fr}.ic-side{position:static}.ic-tools input{min-width:220px}}

/* iCloud monitor */
.icloud-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:14px 16px}
.ic-stat-cell{background:#f7fafc;border-radius:8px;padding:14px;text-align:center;cursor:pointer;border:2px solid transparent;transition:.15s}
.ic-stat-cell:hover{border-color:var(--primary)}
.ic-stat-cell.normal{background:#dcfce7;color:#15803d}
.ic-stat-cell.offline{background:#fef3c7;color:#a16207}
.ic-stat-cell.location-anomaly{background:#ffedd5;color:#c2410c}
.ic-stat-cell.locked{background:#fee2e2;color:#b91c1c}
.ic-stat-cell .ic-n{font-size:24px;font-weight:700;margin-bottom:4px}
.ic-stat-cell .ic-l{font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}

.ic-tabs{display:flex;gap:6px;padding:12px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.ic-tab{padding:6px 14px;border-radius:16px;background:#f1f5f9;color:var(--text);font-size:12px;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:6px}
.ic-tab:hover{background:#e2e8f0}
.ic-tab.active{background:var(--primary);color:#fff}
.ic-tab .ic-dot{width:8px;height:8px;border-radius:50%}
.ic-tab .ic-dot.normal{background:#16a34a}
.ic-tab .ic-dot.offline{background:#f59e0b}
.ic-tab .ic-dot.location-anomaly{background:#ea580c}
.ic-tab .ic-dot.locked{background:#dc2626}

.batt{display:inline-flex;align-items:center;gap:4px;font-size:12px}
.batt-bar{width:28px;height:10px;border:1px solid var(--text-light);border-radius:2px;position:relative;overflow:hidden}
.batt-bar::after{content:'';position:absolute;right:-3px;top:2px;width:2px;height:4px;background:var(--text-light)}
.batt-bar i{display:block;height:100%;background:#16a34a}
.batt-bar.low i{background:#dc2626}
.batt-bar.mid i{background:#f59e0b}

/* Alert cards (Pháp lý / cảnh báo) */
.alert-banner{padding:14px 16px;border-radius:8px;margin-bottom:12px;display:flex;align-items:center;gap:12px;font-size:13px}
.alert-banner.danger{background:#fee2e2;color:#991b1b;border-left:4px solid #dc2626}
.alert-banner.warn{background:#fef3c7;color:#92400e;border-left:4px solid #f59e0b}
.alert-banner.info{background:#dbeafe;color:#1e40af;border-left:4px solid #2563eb}
.alert-banner i{font-size:20px}
.alert-card{background:#fff;border-radius:8px;padding:14px;box-shadow:0 1px 3px rgba(0,0,0,.04);margin-bottom:10px;border-left:4px solid var(--warning);display:flex;gap:12px;align-items:flex-start}
.alert-card.danger{border-left-color:var(--danger)}
.alert-card.info{border-left-color:var(--info)}
.alert-card .ac-ic{width:36px;height:36px;border-radius:50%;background:#fef3c7;color:var(--warning);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.alert-card.danger .ac-ic{background:#fee2e2;color:var(--danger)}
.alert-card.info .ac-ic{background:#dbeafe;color:var(--info)}
.alert-card .ac-body{flex:1}
.alert-card .ac-title{font-weight:600;margin-bottom:3px}
.alert-card .ac-sub{font-size:12px;color:var(--text-light);line-height:1.5}
.alert-card .ac-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}

/* Dossier grid (19 mục) */
.doss-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.doss-cell{background:#f7fafc;border:1px solid var(--border);border-radius:6px;padding:10px;position:relative;min-height:80px;display:flex;flex-direction:column;gap:6px}
.doss-cell.done{background:#dcfce7;border-color:#86efac}
.doss-cell.done::after{content:'✓';position:absolute;top:6px;right:8px;color:#15803d;font-weight:700}
.doss-cell .d-lbl{font-size:11px;color:var(--text-light);font-weight:500}
.doss-cell .d-name{font-size:12.5px;font-weight:500;color:var(--text)}
.doss-cell .d-up{margin-top:auto;font-size:11px}
.doss-cell input[type=file]{font-size:10px;width:100%}

.dp-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-top:4px}
.dp-fill{height:100%;background:linear-gradient(90deg,var(--success),var(--primary));transition:width .3s}

/* SMS templates */
.sms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.sms-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:14px;display:flex;flex-direction:column;gap:8px}
.sms-card:hover{border-color:var(--primary);box-shadow:0 2px 6px rgba(0,0,0,.06)}
.sms-card .sms-head{display:flex;justify-content:space-between;align-items:center}
.sms-card .sms-head h4{font-size:13px;font-weight:600;color:var(--primary)}
.sms-card .sms-body{font-size:12px;color:var(--text);line-height:1.6;background:#f7fafc;padding:10px;border-radius:5px;white-space:pre-wrap;font-family:Consolas,monospace;min-height:80px}
.sms-card .sms-foot{display:flex;gap:6px}

/* Pháp lý step bar (5 bước) */
.step-bar{display:flex;gap:4px;margin:6px 0}
.step-bar .sb-seg{flex:1;height:6px;border-radius:3px;background:#e2e8f0}
.step-bar .sb-seg.done{background:var(--success)}
.step-bar .sb-seg.current{background:var(--warning);animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
.step-label{font-size:11px;color:var(--text-light);margin-top:2px}

/* Customer detail header */
.cust-head{display:flex;gap:14px;align-items:center;padding:14px;background:linear-gradient(135deg,#f0fdf4,#fff);border-radius:8px;margin-bottom:12px}
.cust-avatar{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;flex-shrink:0}
.cust-head .cust-name{font-size:16px;font-weight:600;color:var(--text)}
.cust-head .cust-meta{font-size:12px;color:var(--text-light);margin-top:3px}

/* KPI staff cards */
.kpi-card{background:#fff;border-radius:8px;padding:14px;box-shadow:0 1px 3px rgba(0,0,0,.04);display:flex;flex-direction:column;gap:8px}
.kpi-card .kc-row{display:flex;justify-content:space-between;align-items:center;font-size:12px}
.kpi-card .kc-name{font-weight:600;color:var(--text)}
.kpi-card .kc-role{font-size:11px;color:var(--text-light)}
.kpi-card .kc-score{font-size:26px;font-weight:700;color:var(--primary)}
.kpi-card .kc-score.low{color:var(--danger)}
.kpi-card .kc-score.mid{color:var(--warning)}
.kpi-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;font-size:11px;text-align:center}
.kpi-mini > div{background:#f7fafc;padding:6px;border-radius:4px}
.kpi-mini .km-n{font-weight:700;color:var(--text);font-size:13px;display:block}
.kpi-mini .km-l{color:var(--text-light)}

/* KPI dashboard */
.kpi-toolbar{padding:18px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.kpi-toolbar h3{font-size:18px;color:var(--primary);margin-bottom:4px}
.kpi-toolbar p{color:var(--text-light);font-size:12px}
.kpi-filter-row{display:flex;gap:10px;align-items:end;flex-wrap:wrap}
.kpi-filter-row .field{min-width:130px}
.kpi-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:14px}
.kpi-sum-card{background:#fff;border-radius:10px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.04);position:relative;overflow:hidden;border-left:4px solid var(--primary)}
.kpi-sum-card.warn{border-left-color:var(--warning)}
.kpi-sum-card span{display:block;color:var(--text-light);font-size:12px;margin-bottom:8px}
.kpi-sum-card b{font-size:24px;color:var(--text)}
.kpi-sum-card i{position:absolute;right:14px;bottom:12px;font-size:30px;color:rgba(12,94,84,.12)}
.kpi-rank-list{padding:12px 16px;display:flex;flex-direction:column;gap:8px}
.rank-mini{display:grid;grid-template-columns:44px 1fr 80px;align-items:center;padding:10px;border-radius:8px;background:#f7fafc;cursor:pointer}
.rank-mini:hover{background:#ecfdf5}
.rank-mini b{color:var(--primary)}
.rank-mini em{font-style:normal;text-align:right;font-weight:700;color:var(--primary)}
.kpi-role-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;padding:14px 16px}
.kpi-role-grid div{background:#f7fafc;border-radius:8px;padding:12px}
.kpi-role-grid b,.kpi-role-grid span,.kpi-role-grid em{display:block}
.kpi-role-grid span{color:var(--text-light);font-size:12px;margin:4px 0}
.kpi-role-grid em{font-style:normal;color:var(--primary);font-weight:700}
.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:38px;height:28px;border-radius:14px;background:#ecfdf5;color:var(--primary);font-weight:700}
.score-pill{display:inline-flex;align-items:center;justify-content:center;min-width:52px;padding:6px 10px;border-radius:18px;font-weight:800;background:#f1f5f9;color:var(--text)}
.score-pill.good{background:#dcfce7;color:#15803d}.score-pill.ok{background:#dbeafe;color:#1d4ed8}.score-pill.warn{background:#fef3c7;color:#a16207}.score-pill.bad{background:#fee2e2;color:#b91c1c}
.kpi-table tbody tr:hover{background:#f8fffc}
.kpi-detail-head{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#ecfdf5,#fff);border-radius:10px;padding:16px;margin-bottom:14px}
.kpi-detail-head h2{color:var(--primary);font-size:20px;margin-bottom:4px}
.kpi-detail-head p{color:var(--text-light)}
.kpi-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
.kpi-detail-grid div{background:#f7fafc;border-radius:8px;padding:14px}
.kpi-detail-grid span{display:block;color:var(--text-light);font-size:12px;margin-bottom:6px}
.kpi-detail-grid b{font-size:20px;color:var(--primary)}

/* Config grid */
.cfg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}
.cfg-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #edf0f4;gap:10px}
.cfg-row:last-child{border-bottom:none}
.cfg-row .cfg-lbl{font-size:12.5px;color:var(--text)}
.cfg-row .cfg-sub{font-size:11px;color:var(--text-light);margin-top:2px}
.cfg-row .cfg-ctl{flex-shrink:0}
.cfg-row input[type=number],.cfg-row select,.cfg-row input[type=text]{width:120px;padding:6px 8px;border:1px solid var(--border);border-radius:4px}

/* Legal doc (đơn tố giác) */
.legal-doc{background:#fff;padding:30px 40px;max-width:800px;margin:0 auto;font-family:'Times New Roman',serif;font-size:14px;line-height:1.8;color:#000;box-shadow:0 2px 8px rgba(0,0,0,.08);border-radius:4px}
.legal-doc h2,.legal-doc h3{text-align:center;font-weight:700;margin:10px 0}
.legal-doc h2{font-size:16px;text-transform:uppercase}
.legal-doc h3{font-size:18px;text-decoration:underline;margin:20px 0}
.legal-doc .ld-head{text-align:center;margin-bottom:20px}
.legal-doc .ld-row{display:flex;gap:20px;margin-bottom:6px}
.legal-doc .ld-sign{display:flex;justify-content:space-between;margin-top:30px;font-style:italic}
.legal-doc p{margin:6px 0;text-align:justify;text-indent:2em}
.legal-doc .nb{font-weight:700}

/* Import khách hàng */
.import-box{display:flex;flex-direction:column;gap:14px}
.import-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.import-file-btn{position:relative;overflow:hidden}
.import-file-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}
.import-note{background:#f7fafc;border:1px dashed var(--border);border-radius:8px;padding:12px 14px;color:var(--text);font-size:12px;line-height:1.7}
.import-review{display:flex;flex-direction:column;gap:12px}
.import-bulk{display:flex;gap:8px;flex-wrap:wrap;align-items:center;background:#f7fafc;border:1px solid var(--border);border-radius:8px;padding:10px}
.import-table{max-height:58vh;border:1px solid var(--border);border-radius:8px}
.import-table .tbl thead th{position:sticky;top:0;z-index:2}
.import-table tr.imp-exact{background:#fff7f7}
.import-table tr.imp-suspect{background:#fffbeb}
.import-table tr.imp-error{background:#f8fafc;color:#64748b}
.match-chip{display:inline-block;background:#eef2ff;color:#3730a3;border-radius:12px;padding:3px 8px;font-size:11px;margin:2px 2px 0 0;white-space:nowrap}
.imp-action{min-width:140px;padding:6px 8px;border:1px solid var(--border);border-radius:5px;background:#fff}
.modal.xl{max-width:1280px}



/* Branch executive dashboard */
.branch-hero,.branch-detail-hero{background:radial-gradient(circle at 82% 18%,rgba(126,200,80,.28),transparent 26%),linear-gradient(135deg,#073f3a,#0e7066 60%,#092f2b);color:#fff;border-radius:22px;padding:24px;margin-bottom:14px;display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,460px);gap:18px;align-items:center;box-shadow:0 18px 44px rgba(6,45,41,.22);overflow:hidden}
.branch-hero h1,.branch-detail-hero h1{font-size:29px;margin-bottom:8px}.branch-hero p,.branch-detail-hero p{color:rgba(255,255,255,.82);line-height:1.6}.branch-hero-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.branch-hero-tags span{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:7px 10px;font-size:12px;font-weight:700}.branch-filter-card,.branch-detail-filter{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:14px;backdrop-filter:blur(10px)}.branch-filter-row,.branch-detail-filter{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.branch-filter-row .field,.branch-detail-filter .field{min-width:120px;flex:1}.branch-filter-row label,.branch-detail-filter label{color:rgba(255,255,255,.78)}.branch-filter-row select,.branch-detail-filter select{border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.96);border-radius:10px;padding:9px 10px}.branch-filter-row .hide{display:none}
.branch-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-bottom:14px}.branch-summary>div{background:#fff;border:1px solid #edf2f7;border-radius:16px;padding:16px;box-shadow:0 8px 22px rgba(15,23,42,.05);border-left:4px solid var(--primary)}.branch-summary>div.warn{border-left-color:var(--warning)}.branch-summary span{display:block;color:var(--text-light);font-size:12px;font-weight:700;margin-bottom:8px}.branch-summary b{display:block;font-size:24px;color:var(--text);line-height:1.15}.branch-summary em{display:block;font-style:normal;color:var(--text-light);font-size:11.5px;margin-top:7px}.branch-summary.detail{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}
.branch-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:14px;margin-bottom:14px}.branch-card{background:#fff;border:1px solid #edf2f7;border-radius:18px;padding:16px;box-shadow:0 10px 26px rgba(15,23,42,.05);cursor:pointer;transition:.15s}.branch-card:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(15,23,42,.1);border-color:#ccefe4}.branch-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.branch-card-head b{font-size:16px;color:var(--primary)}.branch-card-head span{display:block;color:var(--text-light);font-size:11.5px;margin-top:4px}.branch-health{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:800;white-space:nowrap}.branch-health b{font-size:13px;color:inherit}.branch-health.good{background:#dcfce7;color:#15803d}.branch-health.warn{background:#fef3c7;color:#a16207}.branch-health.bad{background:#fee2e2;color:#b91c1c}.branch-money{background:linear-gradient(135deg,#f8fffc,#f4fbf8);border:1px solid #e4f4ed;border-radius:14px;padding:14px;margin-bottom:12px}.branch-money span,.branch-money em{display:block;color:var(--text-light);font-size:11.5px}.branch-money b{display:block;font-size:24px;color:var(--text);margin:5px 0}.branch-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.branch-metrics div{background:#f8fafc;border-radius:12px;padding:10px;text-align:center}.branch-metrics b{display:block;font-size:20px;color:var(--text)}.branch-metrics span{font-size:11px;color:var(--text-light)}.branch-flow{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:center}.branch-flow>div{background:#f8fafc;border-radius:12px;padding:10px}.branch-flow span{display:block;color:var(--text-light);font-size:11px}.branch-flow b{font-size:13px}.branch-table-panel{border-radius:16px}
.branch-detail-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.75fr);gap:14px;margin-bottom:14px}.branch-detail-grid.three{grid-template-columns:repeat(3,1fr)}.branch-risk-list,.branch-list{display:flex;flex-direction:column;gap:8px;padding:14px}.branch-risk-item,.branch-list>div{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;background:#f8fafc;border-radius:12px;padding:11px 12px;border-left:4px solid var(--warning);cursor:pointer}.branch-risk-item:hover,.branch-list>div:hover{background:#ecfdf5}.branch-risk-item b,.branch-list b{display:block;color:var(--text);font-size:13px}.branch-risk-item span,.branch-list span{display:block;color:var(--text-light);font-size:11.5px;margin-top:3px}.branch-risk-item em,.branch-list em{font-style:normal;font-weight:700;color:var(--primary);white-space:nowrap}.branch-list.cash>div{border-left-color:var(--primary)}
@media(max-width:1100px){.branch-hero,.branch-detail-hero,.branch-detail-grid,.branch-detail-grid.three{grid-template-columns:1fr}.branch-flow{grid-template-columns:1fr 1fr}.branch-flow .btn{grid-column:1/-1;justify-content:center}}


/* Branch picker and branch list actions */
.branch-title{justify-content:space-between}.branch-title .btn{margin-left:auto}.branch-picker-list{display:flex;flex-direction:column;gap:8px}.branch-picker-list button{display:grid;grid-template-columns:1fr auto;gap:6px 12px;text-align:left;background:#f8fafc;border:1px solid #edf2f7;border-radius:12px;padding:12px;cursor:pointer}.branch-picker-list button:hover,.branch-picker-list button.active{background:#ecfdf5;border-color:var(--primary)}.branch-picker-list b{font-size:14px;color:var(--primary)}.branch-picker-list span{grid-column:1/-1;color:var(--text-light);font-size:12px}.branch-picker-list em{grid-column:2;grid-row:1;font-style:normal;font-weight:800;color:var(--primary);font-size:12px}


/* Bad debt control center */
.baddebt-hero{background:radial-gradient(circle at 84% 18%,rgba(239,68,68,.24),transparent 28%),linear-gradient(135deg,#3b1212,#7f1d1d 55%,#0f302d);color:#fff;border-radius:22px;padding:24px;margin-bottom:14px;display:grid;grid-template-columns:minmax(0,1fr) minmax(520px,720px);gap:18px;align-items:center;box-shadow:0 18px 44px rgba(70,10,10,.2)}.baddebt-hero h1{font-size:29px;margin-bottom:8px}.baddebt-hero p{color:rgba(255,255,255,.82);line-height:1.6}.baddebt-filter-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:14px;display:grid;grid-template-columns:1.3fr repeat(5,minmax(100px,1fr));gap:10px;align-items:end;backdrop-filter:blur(10px)}.baddebt-filter-card label{color:rgba(255,255,255,.78)}.baddebt-filter-card input,.baddebt-filter-card select{border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.96);border-radius:10px;padding:9px 10px;width:100%}.baddebt-filter-actions{grid-column:1/-1;display:flex;gap:8px;justify-content:flex-end}.baddebt-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:12px;margin-bottom:14px}.baddebt-card{background:#fff;border:1px solid #edf2f7;border-radius:16px;padding:16px;box-shadow:0 8px 22px rgba(15,23,42,.05);border-left:4px solid var(--primary);position:relative;overflow:hidden}.baddebt-card.danger{border-left-color:var(--danger)}.baddebt-card.warn{border-left-color:var(--warning)}.baddebt-card.success{border-left-color:var(--success)}.baddebt-card.critical{background:linear-gradient(135deg,#fff7f7,#fff);border-left-color:#991b1b}.baddebt-card span{display:block;color:var(--text-light);font-size:12px;font-weight:700;margin-bottom:8px}.baddebt-card b{display:block;font-size:24px;color:var(--text);line-height:1.15}.baddebt-card em{display:block;font-style:normal;color:var(--text-light);font-size:11.5px;margin-top:7px}.baddebt-card i{position:absolute;right:14px;bottom:12px;font-size:32px;color:rgba(127,29,29,.1)}.baddebt-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(360px,.85fr);gap:14px;margin-bottom:14px}.baddebt-priority-list{padding:14px;display:flex;flex-direction:column;gap:10px}.baddebt-priority-item{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:#f8fafc;border-radius:14px;padding:12px;border-left:4px solid var(--warning);cursor:pointer}.baddebt-priority-item:hover{background:#fff7ed}.baddebt-priority-item.critical{border-left-color:#991b1b}.baddebt-priority-item.high{border-left-color:var(--danger)}.baddebt-priority-item.medium{border-left-color:var(--warning)}.baddebt-priority-item b,.baddebt-priority-item span,.baddebt-priority-item small{display:block}.baddebt-priority-item span{color:var(--text-light);font-size:11.5px;margin-top:3px}.baddebt-priority-item small{color:#b45309;font-size:11px;margin-top:4px}.baddebt-priority-item em{font-style:normal;font-weight:800;color:#991b1b;white-space:nowrap}.baddebt-risk-pill,.baddebt-bucket{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:800;white-space:nowrap}.baddebt-risk-pill.critical{background:#fee2e2;color:#991b1b}.baddebt-risk-pill.high{background:#ffedd5;color:#c2410c}.baddebt-risk-pill.medium{background:#fef3c7;color:#a16207}.baddebt-risk-pill.watch{background:#dbeafe;color:#1d4ed8}.baddebt-bucket{background:#fff7ed;color:#c2410c}.baddebt-table-panel{border-radius:16px}.baddebt-table-panel tbody tr:hover{background:#fffafa}.baddebt-control-plan .plan-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;background:linear-gradient(135deg,#fff7f7,#fff);border-radius:14px;padding:16px;margin-bottom:12px}.baddebt-control-plan .plan-head h2{color:#991b1b;font-size:22px}.baddebt-control-plan .plan-head p{color:var(--text-light);margin-top:4px}.plan-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:12px}.plan-metrics div{background:#f8fafc;border-radius:12px;padding:12px}.plan-metrics span{display:block;color:var(--text-light);font-size:12px;margin-bottom:5px}.plan-metrics b{font-size:18px;color:var(--text)}.plan-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0}.plan-steps div{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px}.plan-steps b,.plan-steps span{display:block}.plan-steps span{color:var(--text-light);font-size:12px;margin-top:5px;line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}@media(max-width:1200px){.baddebt-hero,.baddebt-grid{grid-template-columns:1fr}.baddebt-filter-card{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){.baddebt-filter-card,.plan-steps{grid-template-columns:1fr}.baddebt-filter-actions{justify-content:stretch}.baddebt-filter-actions .btn{flex:1}}

/* Capital command center */
.capital-hero{background:radial-gradient(circle at 86% 18%,rgba(245,158,11,.22),transparent 26%),linear-gradient(135deg,#073f3a,#0e7066 58%,#122d2a);color:#fff;border-radius:22px;padding:24px;margin-bottom:14px;display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,560px);gap:18px;align-items:center;box-shadow:0 18px 44px rgba(6,45,41,.22)}.capital-hero h1{font-size:29px;margin-bottom:8px}.capital-hero p{color:rgba(255,255,255,.82);line-height:1.6}.capital-hero-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.capital-hero-tags span{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:7px 10px;font-size:12px;font-weight:700}.capital-filter-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:14px;backdrop-filter:blur(10px)}.capital-filter-row{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.capital-filter-row .field{min-width:116px;flex:1}.capital-filter-row label{color:rgba(255,255,255,.78)}.capital-filter-row input,.capital-filter-row select{border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.96);border-radius:10px;padding:9px 10px}.cap-day,.cap-month,.cap-quarter{display:none}.cap-day.show,.cap-month.show,.cap-quarter.show{display:block}.capital-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-bottom:14px}.capital-summary>div{background:#fff;border:1px solid #edf2f7;border-radius:16px;padding:16px;box-shadow:0 8px 22px rgba(15,23,42,.05);border-left:4px solid var(--primary)}.capital-summary>div.warn{border-left-color:var(--warning)}.capital-summary>div.danger{border-left-color:var(--danger)}.capital-summary>div.success{border-left-color:var(--success)}.capital-summary span{display:block;color:var(--text-light);font-size:12px;font-weight:700;margin-bottom:8px}.capital-summary b{display:block;font-size:24px;color:var(--text);line-height:1.15}.capital-summary em{display:block;font-style:normal;color:var(--text-light);font-size:11.5px;margin-top:7px}.capital-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(320px,.8fr);gap:14px;margin-bottom:14px}.capital-flow-panel{border-radius:16px}.capital-flow-panel .chart-host{height:340px;padding:14px}.capital-alert-list{display:flex;flex-direction:column;gap:10px;padding:14px}.capital-alert{display:grid;grid-template-columns:38px 1fr;gap:10px;align-items:start;background:#f8fafc;border-radius:12px;padding:12px;border-left:4px solid var(--info)}.capital-alert.warn{border-left-color:var(--warning)}.capital-alert.danger{border-left-color:var(--danger)}.capital-alert.success{border-left-color:var(--success)}.capital-alert i{width:34px;height:34px;border-radius:10px;background:#ecfdf5;color:var(--primary);display:flex;align-items:center;justify-content:center}.capital-alert.warn i{background:#fef3c7;color:var(--warning)}.capital-alert.danger i{background:#fee2e2;color:var(--danger)}.capital-alert b{display:block;font-size:13px}.capital-alert span{display:block;color:var(--text-light);font-size:11.5px;margin-top:3px;line-height:1.45}.capital-table-panel{border-radius:16px}.capital-roi{display:inline-flex;border-radius:999px;padding:4px 8px;font-weight:800;font-size:11px}.capital-roi.good{background:#dcfce7;color:#15803d}.capital-roi.bad{background:#fee2e2;color:#b91c1c}.capital-detail-head{display:flex;align-items:center;justify-content:space-between;gap:14px;background:linear-gradient(135deg,#ecfdf5,#fff);border-radius:14px;padding:16px;margin-bottom:14px}.capital-detail-head h2{color:var(--primary);font-size:22px}.capital-detail-head p{color:var(--text-light);font-size:12px;margin-top:4px}@media(max-width:1100px){.capital-hero,.capital-grid{grid-template-columns:1fr}}
