/* ── Reset & Base ───────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal-50:#E0F5F1;--teal-100:#B2EBE6;--teal-200:#7DD4C8;
  --teal-400:#1D9E8F;--teal-600:#0F6E62;--teal-800:#094F46;
  --bg-primary:#ffffff;--bg-secondary:#f5f7f6;--bg-tertiary:#eef1f0;
  --text-primary:#0d1c1a;--text-secondary:#4a6560;--text-tertiary:#8aa09b;
  --border-light:rgba(15,110,98,0.12);--border-med:rgba(15,110,98,0.22);
  --red-50:#FCEBEB;--red-400:#E24B4A;--red-600:#A32D2D;--red-800:#791F1F;
  --amber-50:#FAEEDA;--amber-400:#EF9F27;--amber-600:#854F0B;--amber-800:#633806;
  --blue-50:#E6F1FB;--blue-400:#378ADD;--blue-600:#185FA5;--blue-800:#0C447C;
  --green-50:#EAF3DE;--green-400:#639922;--green-600:#3B6D11;--green-800:#27500A;
  --r:8px;--rl:12px;
  --shadow:0 1px 4px rgba(15,110,98,0.08);
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;line-height:1.5}

/* ── Layout ─────────────────────────────────────────────────── */
.app-shell{display:flex;height:100vh;overflow:hidden}
.sidebar{width:220px;min-width:220px;background:var(--bg-primary);border-right:1px solid var(--border-light);display:flex;flex-direction:column;height:100vh;overflow-y:auto;flex-shrink:0}
.main{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;min-width:0}
.content{flex:1;overflow-y:auto;padding:20px 22px}

/* ── Sidebar ────────────────────────────────────────────────── */
.sb-logo{padding:14px 16px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:10px}
.sb-logo img{width:34px;height:34px;object-fit:contain;flex-shrink:0}
.sb-logo-text{font-size:13px;font-weight:600;color:var(--teal-600);line-height:1.2}
.sb-logo-sub{font-size:11px;color:var(--text-secondary)}
.nav-section{padding:14px 14px 4px;font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;margin:1px 6px;border-radius:var(--r);cursor:pointer;font-size:13px;color:var(--text-secondary);transition:background .12s;user-select:none}
.nav-item:hover{background:var(--teal-50)}
.nav-item.active{background:var(--teal-50);color:var(--teal-600);font-weight:600}
.nav-item i{font-size:16px;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--red-400);color:#fff;font-size:10px;padding:1px 6px;border-radius:9px;font-weight:600}

/* ── Topbar ─────────────────────────────────────────────────── */
.topbar{background:var(--bg-primary);border-bottom:1px solid var(--border-light);padding:0 20px;height:50px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.topbar-logo{height:26px;object-fit:contain;flex-shrink:0}
.topbar-divider{width:1px;height:22px;background:var(--border-med)}
.topbar-title{font-size:15px;font-weight:600;flex:1;color:var(--text-primary)}
.tb-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid var(--border-med);border-radius:var(--r);font-size:12px;color:var(--text-secondary);cursor:pointer;background:transparent;transition:background .1s;white-space:nowrap}
.tb-btn:hover{background:var(--teal-50)}
.tb-btn.primary{background:var(--teal-400);color:#fff;border-color:var(--teal-400)}
.tb-btn.primary:hover{background:var(--teal-600)}
.tb-user{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}
.tb-user .avatar{width:28px;height:28px;border-radius:50%;background:var(--teal-50);color:var(--teal-800);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.tb-user .logout{cursor:pointer;color:var(--teal-600);font-size:13px;padding:4px 8px;border-radius:var(--r);transition:background .1s}
.tb-user .logout:hover{background:var(--teal-50)}

/* ── Pages ──────────────────────────────────────────────────── */
.page{display:none}.page.active{display:block}

/* ── Metrics ────────────────────────────────────────────────── */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}
.metric{background:var(--bg-secondary);border-radius:var(--r);padding:14px 16px;border:1px solid var(--border-light)}
.metric-label{font-size:11px;color:var(--text-secondary);margin-bottom:5px;font-weight:500}
.metric-val{font-size:22px;font-weight:700;color:var(--text-primary)}
.metric-sub{font-size:11px;margin-top:3px;color:var(--text-tertiary)}
.metric-sub.g{color:var(--green-600)}.metric-sub.r{color:var(--red-600)}.metric-sub.a{color:var(--amber-600)}

/* ── Panels ─────────────────────────────────────────────────── */
.panels-2{display:grid;grid-template-columns:1.5fr 1fr;gap:14px;margin-bottom:14px}
.panels-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
.panels-full{margin-bottom:14px}
.panel{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--rl);overflow:hidden;box-shadow:var(--shadow)}
.ph{padding:12px 16px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.ph h3{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;color:var(--text-primary)}
.ph h3 i{font-size:14px;color:var(--teal-400)}
.ph-act{font-size:12px;color:var(--teal-600);cursor:pointer;font-weight:500}
.ph-act:hover{text-decoration:underline}
.pb{padding:14px 16px}

/* ── Badges ─────────────────────────────────────────────────── */
.badge{font-size:10px;padding:2px 8px;border-radius:9px;font-weight:600;display:inline-block;white-space:nowrap}
.b-crit{background:var(--red-50);color:var(--red-800)}
.b-high{background:var(--amber-50);color:var(--amber-800)}
.b-med{background:var(--blue-50);color:var(--blue-800)}
.b-low{background:var(--green-50);color:var(--green-800)}
.b-open{background:var(--amber-50);color:var(--amber-800)}
.b-prog{background:var(--blue-50);color:var(--blue-800)}
.b-closed{background:var(--green-50);color:var(--green-800)}
.b-overdue{background:var(--red-50);color:var(--red-800)}
.b-submitted{background:var(--green-50);color:var(--green-800)}
.b-pending{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-light)}
.b-teal{background:var(--teal-50);color:var(--teal-800)}

/* ── Table ──────────────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto}
table.data{width:100%;border-collapse:collapse;font-size:12px}
table.data th{padding:8px 12px;text-align:left;font-size:11px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-light);background:var(--bg-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
table.data td{padding:9px 12px;border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle}
table.data tr:last-child td{border-bottom:none}
table.data tr:hover td{background:var(--teal-50)}
.td-name{font-weight:600;font-size:13px}
.td-sub{font-size:11px;color:var(--text-secondary);margin-top:1px}

/* ── Avatar ─────────────────────────────────────────────────── */
.av{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.av-teal{background:var(--teal-50);color:var(--teal-800)}
.av-blue{background:var(--blue-50);color:var(--blue-800)}
.av-amber{background:var(--amber-50);color:var(--amber-800)}
.av-green{background:var(--green-50);color:var(--green-800)}
.av-row{display:flex;align-items:center;gap:7px}

/* ── Heat Map ───────────────────────────────────────────────── */
.hm-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}
.hm-cell{aspect-ratio:1;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;cursor:default}
.hm-none{background:var(--bg-secondary);color:var(--text-tertiary)}
.hm-low{background:#C0DD97;color:var(--green-800)}
.hm-med{background:#FAC775;color:var(--amber-800)}
.hm-high{background:#F0997B;color:#712B13}
.hm-crit{background:#F09595;color:var(--red-800)}

/* ── Progress ───────────────────────────────────────────────── */
.prog-bar{height:5px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width .3s}

/* ── Filters ────────────────────────────────────────────────── */
.filters{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.filter-btn{padding:5px 12px;border:1px solid var(--border-med);border-radius:var(--r);font-size:12px;cursor:pointer;background:var(--bg-primary);color:var(--text-secondary);transition:all .1s;font-family:inherit}
.filter-btn:hover{background:var(--teal-50)}
.filter-btn.active{background:var(--teal-50);color:var(--teal-600);border-color:var(--teal-200);font-weight:600}
.search-box{display:flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--border-med);border-radius:var(--r);background:var(--bg-primary);flex:1;max-width:240px}
.search-box input{border:none;background:transparent;font-size:12px;color:var(--text-primary);outline:none;width:100%;font-family:inherit}
.search-box i{color:var(--text-tertiary);font-size:14px}

/* ── Section header ─────────────────────────────────────────── */
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sec-head h2{font-size:16px;font-weight:700;color:var(--text-primary)}

/* ── Quick row items ────────────────────────────────────────── */
.rr{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border-light)}
.rr:last-child{border-bottom:none}
.rr-name{font-size:13px;flex:1;min-width:0;font-weight:500}
.rr-sub{font-size:11px;color:var(--text-secondary);font-weight:400}
.ci{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border-light)}
.ci:last-child{border-bottom:none}
.ci-icon{width:30px;height:30px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.ci-icon.ok{background:var(--green-50);color:var(--green-600)}
.ci-icon.warn{background:var(--amber-50);color:var(--amber-600)}
.ci-icon.fail{background:var(--red-50);color:var(--red-600)}
.ci-name{font-size:12px;font-weight:600}
.ci-due{font-size:11px;color:var(--text-secondary);margin-top:1px}
.ii{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--border-light)}
.ii:last-child{border-bottom:none}
.ii-dot{width:8px;height:8px;border-radius:50%;margin-top:4px;flex-shrink:0}
.ii-title{font-size:12px;font-weight:600}
.ii-meta{font-size:11px;color:var(--text-secondary);margin-top:2px}
.ki{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border-light)}
.ki:last-child{border-bottom:none}
.ki-name{font-size:12px;font-weight:500;flex:1;min-width:0}
.ki-sub{font-size:11px;color:var(--text-secondary)}
.mini-bar{width:64px;flex-shrink:0}

/* ── BCM cards ──────────────────────────────────────────────── */
.bcm-card{background:var(--bg-secondary);border-radius:var(--r);padding:12px;margin-bottom:8px;border:1px solid var(--border-light)}
.bcm-card:last-child{margin-bottom:0}
.bcm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.bcm-title{font-size:13px;font-weight:600}
.bcm-row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0;color:var(--text-secondary)}
.bcm-row span:last-child{font-weight:600;color:var(--text-primary)}

/* ── Report cards ───────────────────────────────────────────── */
.report-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
.report-card{border:1px solid var(--border-light);border-radius:var(--rl);padding:16px;background:var(--bg-primary);cursor:pointer;transition:background .1s;box-shadow:var(--shadow)}
.report-card:hover{background:var(--teal-50)}
.rc-icon{width:40px;height:40px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:10px;font-size:20px}
.rc-title{font-size:13px;font-weight:600;margin-bottom:4px}
.rc-sub{font-size:11px;color:var(--text-secondary)}
.rc-meta{font-size:11px;color:var(--text-tertiary);margin-top:8px}

/* ── Modal ──────────────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.35);z-index:200;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--bg-primary);border-radius:var(--rl);width:560px;max-height:88vh;overflow-y:auto;border:1px solid var(--border-med);box-shadow:0 8px 32px rgba(0,0,0,0.18)}
.modal-head{padding:16px 18px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg-primary);z-index:1}
.modal-head h3{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}
.modal-close{cursor:pointer;color:var(--text-secondary);font-size:20px;padding:2px 6px;border-radius:var(--r)}
.modal-close:hover{background:var(--teal-50);color:var(--teal-600)}
.modal-body{padding:18px}
.modal-foot{padding:12px 18px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:8px}

/* ── Forms ──────────────────────────────────────────────────── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px}
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:0}
.form-group label{font-size:12px;font-weight:600;color:var(--text-secondary)}
.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-med);border-radius:var(--r);padding:8px 10px;font-size:13px;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;transition:border-color .15s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--teal-400);box-shadow:0 0 0 3px rgba(29,158,143,0.12)}
.form-group textarea{resize:vertical;min-height:68px}
.form-section{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--teal-600);margin:16px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--teal-50)}

/* ── Settings toggles ───────────────────────────────────────── */
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-light)}
.setting-row:last-child{border-bottom:none}
.setting-label{font-size:13px;font-weight:500}
.setting-desc{font-size:11px;color:var(--text-secondary);margin-top:2px}
.toggle{width:38px;height:20px;border-radius:10px;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.toggle.on{background:var(--teal-400)}.toggle.off{background:var(--border-med)}
.toggle-knob{width:16px;height:16px;border-radius:50%;background:#fff;position:absolute;top:2px;transition:left .2s}
.toggle.on .toggle-knob{left:20px}.toggle.off .toggle-knob{left:2px}
.sdot{width:8px;height:8px;border-radius:50%;display:inline-block}
.sdot-g{background:var(--green-400)}.sdot-a{background:var(--amber-400)}.sdot-r{background:var(--red-400)}

/* ── Login Page ─────────────────────────────────────────────── */
.login-page{min-height:100vh;background:linear-gradient(135deg,var(--teal-800) 0%,var(--teal-600) 50%,var(--teal-400) 100%);display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:#fff;border-radius:16px;width:420px;padding:40px;box-shadow:0 20px 60px rgba(0,0,0,0.25)}
.login-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:28px;gap:8px}
.login-logo img{height:40px;object-fit:contain}
.login-logo p{font-size:13px;color:var(--text-secondary)}
.login-title{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:6px;text-align:center}
.login-sub{font-size:13px;color:var(--text-secondary);text-align:center;margin-bottom:24px}
.login-field{margin-bottom:16px}
.login-field label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.login-field input{width:100%;border:1px solid var(--border-med);border-radius:var(--r);padding:10px 12px;font-size:14px;font-family:inherit;transition:border-color .15s;color:var(--text-primary)}
.login-field input:focus{outline:none;border-color:var(--teal-400);box-shadow:0 0 0 3px rgba(29,158,143,0.12)}
.login-btn{width:100%;background:var(--teal-400);color:#fff;border:none;border-radius:var(--r);padding:12px;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s;font-family:inherit;margin-top:8px}
.login-btn:hover{background:var(--teal-600)}
.login-err{background:var(--red-50);color:var(--red-800);border:1px solid var(--red-400);border-radius:var(--r);padding:10px 12px;font-size:13px;margin-bottom:14px;display:none}
.login-err.show{display:block}
.login-hint{margin-top:20px;background:var(--teal-50);border-radius:var(--r);padding:12px;font-size:12px;color:var(--text-secondary)}
.login-hint strong{color:var(--teal-600)}

/* ── Toast ──────────────────────────────────────────────────── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--teal-800);color:#fff;padding:12px 18px;border-radius:var(--r);font-size:13px;font-weight:500;box-shadow:0 4px 16px rgba(0,0,0,0.25);z-index:999;transform:translateY(80px);opacity:0;transition:all .3s;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
.toast.error{background:var(--red-600)}

/* ── Donut ──────────────────────────────────────────────────── */
.donut-wrap{display:flex;align-items:center;gap:20px}
.donut-legend{flex:1}
.donut-leg-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12px}
.leg-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}

/* ── Action btn in table ────────────────────────────────────── */
.act-btn{padding:3px 9px;border:1px solid var(--border-med);border-radius:var(--r);font-size:11px;cursor:pointer;background:transparent;font-family:inherit;transition:background .1s;color:var(--text-secondary)}
.act-btn:hover{background:var(--teal-50);color:var(--teal-600);border-color:var(--teal-200)}
.act-btn.danger:hover{background:var(--red-50);color:var(--red-600);border-color:var(--red-400)}

/* ── RCSA ───────────────────────────────────────────────────── */
.rcsa-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light)}
.rcsa-row:last-child{border-bottom:none}
