
:root {
  --teal:    #0E7EA3;
  --teal-d:  #0a6585;
  --green:   #0D9E6A;
  --red:     #D94040;
  --amber:   #D97706;
  --blue:    #1E40AF;
  --bg:      #F0F4F8;
  --surface: #FFFFFF;
  --surf2:   #F7F9FC;
  --border:  #E2E8F0;
  --text-h:  #0F172A;
  --text-1:  #1E293B;
  --text-2:  #475569;
  --text-3:  #94A3B8;
  --font:    'DM Sans', sans-serif;
  --mono:    'DM Mono', monospace;
  --radius:  10px;
  --shadow:  0 1px 3px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.06);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text-1);
  min-height: 100vh;
  font-size: 14px;
}

/* ── LOGIN ── */
#loginScreen {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #0F172A 0%, #1E3A5F 50%, #0E4D6E 100%);
}
.login-card {
  background: var(--surface);
  border-radius: 18px;
  padding: 36px 40px 32px;
  width: 380px;
  max-width: 92vw;
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
}
.login-logo {
  font-family: var(--font);
  font-size: 22px;
  font-weight: 700;
  color: var(--text-h);
  margin-bottom: 4px;
  letter-spacing: -0.5px;
}
.login-logo sup { font-size: 11px; color: var(--teal); font-weight: 700; }
.login-sub { font-size: 12px; color: var(--text-3); margin-bottom: 28px; }
.login-label { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--text-2); margin-bottom: 5px; }
.login-input {
  width: 100%; padding: 10px 13px; border: 1.5px solid var(--border);
  border-radius: 8px; font-family: var(--font); font-size: 13px;
  background: var(--surf2); color: var(--text-h); outline: none;
  transition: border-color .15s;
}
.login-input:focus { border-color: var(--teal); }
.login-field { margin-bottom: 14px; }
.login-btn {
  width: 100%; padding: 11px; background: var(--teal); color: #fff;
  border: none; border-radius: 8px; font-family: var(--font);
  font-size: 13.5px; font-weight: 700; cursor: pointer; transition: all .15s;
  margin-top: 6px;
}
.login-btn:hover { background: var(--teal-d); transform: translateY(-1px); }
.login-err { font-size: 12px; color: var(--red); margin-top: 8px; text-align: center; display: none; }
.login-err.show { display: block; }

/* ── APP SHELL ── */
#app { display: none; }
.top-bar {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 0 28px;
  height: 56px;
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; z-index: 100;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.bar-brand {
  font-size: 15px; font-weight: 700; color: var(--text-h); letter-spacing: -.3px;
  display: flex; align-items: center; gap: 10px;
}
.bar-brand sup { font-size: 9px; color: var(--teal); font-weight: 700; }
.bar-badge {
  font-size: 10px; font-weight: 700; background: rgba(14,126,163,.1);
  color: var(--teal); padding: 2px 8px; border-radius: 20px;
  letter-spacing: .3px; text-transform: uppercase;
}
.bar-right { display: flex; gap: 10px; align-items: center; }
.bar-btn {
  padding: 6px 14px; border-radius: 7px; font-size: 12.5px; font-weight: 600;
  cursor: pointer; transition: all .15s; border: 1.5px solid var(--border);
  background: var(--surf2); color: var(--text-2); font-family: var(--font);
}
.bar-btn:hover { border-color: var(--teal); color: var(--teal); }
.bar-btn.danger:hover { border-color: var(--red); color: var(--red); }

/* ── NAV TABS ── */
.nav-tabs {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 0 28px;
  display: flex; gap: 2px;
}
.nav-tab {
  padding: 12px 16px; font-size: 13px; font-weight: 600;
  color: var(--text-3); cursor: pointer; border-bottom: 2.5px solid transparent;
  transition: all .15s; white-space: nowrap;
  position: relative;
}
.nav-tab:hover { color: var(--text-1); }
.nav-tab.active { color: var(--teal); border-color: var(--teal); }
.nav-badge {
  position: absolute; top: 8px; right: 4px;
  background: var(--red); color: #fff;
  font-size: 9px; font-weight: 800; min-width: 16px; height: 16px;
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  padding: 0 4px;
}

/* ── MAIN CONTENT ── */
.main { padding: 28px; max-width: 1200px; margin: 0 auto; }

/* ── STATS ROW ── */
.stats-row { display: grid; grid-template-columns: repeat(auto-fit,minmax(160px,1fr)); gap: 14px; margin-bottom: 24px; }
.stat-card {
  background: var(--surface); border-radius: var(--radius);
  padding: 18px 20px; border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.stat-val { font-size: 28px; font-weight: 700; color: var(--text-h); font-family: var(--mono); line-height: 1; }
.stat-lbl { font-size: 11px; text-transform: uppercase; letter-spacing: .5px; color: var(--text-3); font-weight: 700; margin-top: 4px; }
.stat-val.teal  { color: var(--teal); }
.stat-val.green { color: var(--green); }
.stat-val.amber { color: var(--amber); }
.stat-val.red   { color: var(--red); }

/* ── SECTION CARD ── */
.card {
  background: var(--surface); border-radius: var(--radius);
  border: 1px solid var(--border); box-shadow: var(--shadow);
  margin-bottom: 20px; overflow: hidden;
}
.card-head {
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.card-title { font-size: 13.5px; font-weight: 700; color: var(--text-h); }
.card-actions { display: flex; gap: 8px; }

/* ── TABLE ── */
.tbl { width: 100%; border-collapse: collapse; }
.tbl th {
  font-size: 10.5px; text-transform: uppercase; letter-spacing: .5px;
  font-weight: 700; color: var(--text-3); padding: 10px 16px;
  background: var(--surf2); border-bottom: 1px solid var(--border);
  text-align: left; white-space: nowrap;
}
.tbl td {
  padding: 11px 16px; font-size: 13px; color: var(--text-1);
  border-bottom: 1px solid var(--border); vertical-align: middle;
}
.tbl tr:last-child td { border-bottom: none; }
.tbl tr:hover td { background: var(--surf2); }
.mono { font-family: var(--mono); font-size: 12px; letter-spacing: .5px; }

/* ── BADGES ── */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10.5px; font-weight: 700; padding: 2px 8px;
  border-radius: 20px; white-space: nowrap;
}
.badge-green  { background: rgba(13,158,106,.1); color: #0a7d54; }
.badge-red    { background: rgba(217,64,64,.1);  color: var(--red); }
.badge-amber  { background: rgba(217,119,6,.12); color: var(--amber); }
.badge-blue   { background: rgba(30,64,175,.1);  color: var(--blue); }
.badge-gray   { background: #F1F5F9; color: var(--text-3); }

/* ── ACTION BUTTONS IN TABLE ── */
.act-btn {
  padding: 4px 10px; border-radius: 6px; font-size: 11.5px; font-weight: 600;
  cursor: pointer; transition: all .12s; border: 1px solid;
  font-family: var(--font);
}
.act-btn.approve { background: rgba(13,158,106,.08); color: var(--green); border-color: rgba(13,158,106,.25); }
.act-btn.approve:hover { background: var(--green); color: #fff; }
.act-btn.reject  { background: rgba(217,64,64,.08);  color: var(--red);   border-color: rgba(217,64,64,.2); }
.act-btn.reject:hover  { background: var(--red);  color: #fff; }
.act-btn.suspend { background: rgba(217,119,6,.08); color: var(--amber); border-color: rgba(217,119,6,.2); }
.act-btn.suspend:hover { background: var(--amber); color: #fff; }
.act-btn.reinstate { background: rgba(14,126,163,.08); color: var(--teal); border-color: rgba(14,126,163,.2); }
.act-btn.reinstate:hover { background: var(--teal); color: #fff; }

/* ── EMPTY STATE ── */
.empty { padding: 48px; text-align: center; color: var(--text-3); }
.empty-icon { font-size: 36px; margin-bottom: 12px; }
.empty-msg { font-size: 13px; }

/* ── MODAL ── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(15,23,42,.5); backdrop-filter: blur(3px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity .2s;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal-box {
  background: var(--surface); border-radius: 14px;
  padding: 28px; width: 460px; max-width: 94vw;
  box-shadow: 0 25px 60px rgba(0,0,0,.25);
  transform: translateY(12px); transition: transform .2s;
}
.modal-overlay.open .modal-box { transform: none; }
.modal-title { font-size: 16px; font-weight: 700; color: var(--text-h); margin-bottom: 4px; }
.modal-sub   { font-size: 12.5px; color: var(--text-2); margin-bottom: 20px; }
.modal-field { margin-bottom: 12px; }
.modal-label { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--text-2); margin-bottom: 4px; }
.modal-input {
  width: 100%; padding: 9px 12px; border: 1.5px solid var(--border);
  border-radius: 8px; font-family: var(--font); font-size: 13px;
  background: var(--surf2); color: var(--text-h); outline: none;
  transition: border-color .15s;
}
.modal-input:focus { border-color: var(--teal); }
.modal-check { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.modal-check input { width: 16px; height: 16px; accent-color: var(--teal); cursor: pointer; }
.modal-check span { font-size: 13px; color: var(--text-1); font-weight: 500; }
.modal-footer { display: flex; gap: 8px; justify-content: flex-end; margin-top: 20px; }
.modal-cancel {
  padding: 9px 18px; background: var(--surf2); border: 1.5px solid var(--border);
  border-radius: 8px; font-family: var(--font); font-size: 13px;
  font-weight: 600; color: var(--text-2); cursor: pointer;
}
.modal-ok {
  padding: 9px 20px; border: none; border-radius: 8px;
  font-family: var(--font); font-size: 13px; font-weight: 700;
  cursor: pointer; background: var(--teal); color: #fff;
  transition: all .15s;
}
.modal-ok:hover { background: var(--teal-d); }
.modal-ok.green { background: var(--green); }
.modal-ok.red   { background: var(--red); }
.code-display {
  font-family: var(--mono); font-size: 22px; font-weight: 700; letter-spacing: 2px;
  color: var(--teal); background: rgba(14,126,163,.06);
  border: 2px dashed rgba(14,126,163,.3); border-radius: 10px;
  padding: 16px; text-align: center; margin: 16px 0; cursor: pointer;
}
.code-display:hover { background: rgba(14,126,163,.1); }

/* ── ISSUE CODE PANEL ── */
/* ── ISSUE PAGE LAYOUT ── */
.ip-page { display: flex; flex-direction: column; gap: 16px; max-width: 860px; margin: 0 auto; }
.ip-page-hd {
  display: flex; align-items: flex-start; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; margin-bottom: 4px;
}
.ip-page-title { font-size: 18px; font-weight: 700; color: var(--text-h); }
.ip-page-sub   { font-size: 12px; color: var(--text-2); margin-top: 2px; }

/* ── ISSUE CARDS ── */
.ip-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
  overflow: hidden;
}
.ip-card-hd {
  display: flex; align-items: center; gap: 9px;
  padding: 13px 18px;
  background: rgba(14,126,163,.05);
  border-bottom: 1.5px solid var(--border);
}
.ip-card-icon  { font-size: 15px; }
.ip-card-title { font-size: 13px; font-weight: 700; color: var(--text-h); }
.ip-card-body  { padding: 18px; }

.ip-card-results { display: none; border-color: rgba(13,158,106,.35); }
.ip-card-results .ip-card-hd { background: rgba(13,158,106,.07); border-color: rgba(13,158,106,.25); }
.ip-card-results .ip-card-title { color: var(--green); }

.issue-panel {
  background: linear-gradient(135deg, rgba(14,126,163,.06), rgba(13,158,106,.06));
  border: 1px solid rgba(14,126,163,.2); border-radius: var(--radius);
  padding: 20px; margin-bottom: 20px;
}

.issue-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.issue-label { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--text-2); margin-bottom: 4px; display: block; }
.issue-input {
  width: 100%; padding: 8px 11px; border: 1.5px solid var(--border);
  border-radius: 7px; font-family: var(--font); font-size: 13px;
  background: var(--surface); color: var(--text-h); outline: none;
  transition: border-color .15s;
}
.issue-input:focus { border-color: var(--teal); }
.issue-btn {
  padding: 9px 20px; background: var(--teal); color: #fff; border: none;
  border-radius: 8px; font-family: var(--font); font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .15s; white-space: nowrap;
}
.issue-btn:hover { background: var(--teal-d); }

/* ── AI CHART ── */
.chart-bar-wrap { padding: 16px 20px 20px; }
.chart-day { display: flex; align-items: center; gap: 10px; margin-bottom: 7px; }
.chart-day-lbl { font-size: 11px; color: var(--text-3); font-family: var(--mono); width: 80px; flex-shrink: 0; }
.chart-bar-bg { flex: 1; background: var(--surf2); border-radius: 4px; height: 20px; overflow: hidden; }
.chart-bar-fill { height: 100%; background: linear-gradient(90deg,var(--teal),#22d3ee); border-radius: 4px; transition: width .4s; min-width: 2px; }
.chart-day-val { font-size: 11.5px; font-family: var(--mono); color: var(--text-2); width: 30px; text-align: right; flex-shrink: 0; }

/* ── TOAST ── */
.toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(70px);
  background: var(--text-h); color: #fff;
  padding: 10px 22px; border-radius: 30px;
  font-size: 13px; font-weight: 600; z-index: 99999;
  pointer-events: none; transition: transform .3s cubic-bezier(.34,1.56,.64,1);
  white-space: nowrap;
}
.toast.show { transform: translateX(-50%) translateY(0); }
.toast.ok  { background: var(--green); }
.toast.err { background: var(--red); }

/* ── RESPONSIVE ── */
@media(max-width:640px) {
  .main { padding: 16px; }
  .stats-row { grid-template-columns: 1fr 1fr; }
  .issue-grid { grid-template-columns: 1fr; }
  .top-bar { padding: 0 16px; }
  .nav-tabs { padding: 0 16px; overflow-x: auto; }
}

/* Modern confirm modal */
.dm-overlay {
  position:fixed;inset:0;z-index:9999;
  background:rgba(10,18,30,.55);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.dm-overlay.show{opacity:1;pointer-events:all;}
.dm-box {
  background:#fff;border-radius:16px;padding:32px 28px 24px;
  max-width:380px;width:90%;box-shadow:0 24px 60px rgba(0,0,0,.18);
  transform:scale(.96);transition:transform .2s;
  border:1px solid #e5e7eb;
}
.dm-overlay.show .dm-box{transform:scale(1);}
.dm-icon{font-size:36px;margin-bottom:12px;text-align:center;}
.dm-title{font-size:17px;font-weight:800;color:#111;margin-bottom:8px;text-align:center;}
.dm-body{font-size:13px;color:#6b7280;text-align:center;line-height:1.6;margin-bottom:24px;}
.dm-code{font-family:monospace;font-size:13px;font-weight:700;color:#0f766e;
  background:#f0fdfb;padding:4px 10px;border-radius:6px;display:inline-block;margin-bottom:4px;}
.dm-footer{display:flex;gap:10px;justify-content:center;}
.dm-btn{padding:10px 22px;border-radius:10px;font-size:13px;font-weight:700;
  border:none;cursor:pointer;transition:all .15s;}
.dm-btn-cancel{background:#f3f4f6;color:#374151;}
.dm-btn-cancel:hover{background:#e5e7eb;}
.dm-btn-danger{background:#dc2626;color:#fff;}
.dm-btn-danger:hover{background:#b91c1c;}
.dm-btn-ok{background:#0d9488;color:#fff;}
.dm-btn-ok:hover{background:#0f766e;}

/* ── ACCORDION TREE (Licenses) ───────────────────────────── */
.acc-inst {
  border: 1px solid var(--border); border-radius: 10px;
  margin-bottom: 10px; overflow: hidden;
  background: var(--surface); box-shadow: var(--shadow);
}
.acc-inst-hd {
  padding: 13px 18px; display: flex; align-items: center;
  justify-content: space-between; cursor: pointer;
  background: var(--surf2); transition: background .15s;
  user-select: none;
}
.acc-inst-hd:hover { background: rgba(14,126,163,.06); }
.acc-inst-name { font-size: 14px; font-weight: 700; color: var(--text-h); }
.acc-inst-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.acc-arrow { font-size: 11px; color: var(--text-3); transition: transform .2s; margin-left: 8px; }
.acc-arrow.open { transform: rotate(90deg); }
.acc-inst-body { display: none; }
.acc-inst-body.open { display: block; }

.acc-dept {
  border-top: 1px solid var(--border);
}
.acc-dept-hd {
  padding: 10px 18px 10px 32px; display: flex; align-items: center;
  justify-content: space-between; cursor: pointer;
  background: #fff; transition: background .15s;
  user-select: none;
}
.acc-dept-hd:hover { background: rgba(14,126,163,.04); }
.acc-dept-name { font-size: 13px; font-weight: 600; color: var(--text-1); }
.acc-dept-body { display: none; padding: 0 0 0 32px; }
.acc-dept-body.open { display: block; }
.acc-dept-body .tbl th:first-child,
.acc-dept-body .tbl td:first-child { padding-left: 16px; }

/* ── ISSUE BATCH PANEL ───────────────────────────────────── */
.ib-mode-bar { display: flex; gap: 0; margin-bottom: 18px; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; width: fit-content; }
.ib-mode-btn {
  padding: 8px 20px; font-size: 13px; font-weight: 700; cursor: pointer;
  background: var(--surf2); color: var(--text-2); border: none;
  font-family: var(--font); transition: all .15s;
}
.ib-mode-btn.active { background: var(--teal); color: #fff; }

.ib-section { margin-bottom: 16px; }
.ib-inst-row { display: grid; grid-template-columns: 2fr 1fr; gap: 10px; margin-bottom: 14px; }

.ib-dept-block {
  border: 1.5px solid var(--border); border-radius: 9px;
  margin-bottom: 10px; overflow: hidden;
}
.ib-dept-hd {
  padding: 9px 14px; background: var(--surf2); display: flex;
  align-items: center; gap: 8px;
}
.ib-dept-input {
  flex: 1; padding: 6px 10px; border: 1.5px solid var(--border);
  border-radius: 6px; font-family: var(--font); font-size: 13px;
  background: var(--surface); color: var(--text-h); outline: none;
}
.ib-dept-input:focus { border-color: var(--teal); }
.ib-dept-body { padding: 10px 14px; }
.ib-dept-rm { background: none; border: none; color: var(--red); cursor: pointer; font-size: 16px; padding: 2px 6px; border-radius: 5px; }
.ib-dept-rm:hover { background: rgba(217,64,64,.1); }

.ib-code-row {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 0; border-bottom: 1px solid var(--border);
}
.ib-code-row:last-child { border-bottom: none; }
.ib-code-num { font-size: 11px; font-weight: 700; color: var(--text-3); width: 20px; flex-shrink: 0; }

.ib-type-toggle { display: flex; border: 1.5px solid var(--border); border-radius: 6px; overflow: hidden; flex-shrink: 0; }
.ib-type-btn { padding: 5px 10px; font-size: 11.5px; font-weight: 700; cursor: pointer; border: none; background: var(--surf2); color: var(--text-2); font-family: var(--font); transition: all .12s; }
.ib-type-btn.ai.active  { background: rgba(109,40,217,0.15); color: #5B21B6; }
.ib-type-btn.std.active { background: rgba(14,126,163,.15); color: var(--teal); }

.ib-mini-input { padding: 5px 8px; border: 1.5px solid var(--border); border-radius: 6px; font-family: var(--font); font-size: 12.5px; background: var(--surface); color: var(--text-h); outline: none; width: 90px; }
.ib-mini-input:focus { border-color: var(--teal); }
.ib-code-rm { background: none; border: none; color: var(--text-3); cursor: pointer; font-size: 15px; padding: 2px 5px; }
.ib-code-rm:hover { color: var(--red); }

.ib-add-code-btn {
  margin-top: 8px; padding: 5px 12px; font-size: 12px; font-weight: 700;
  border: 1.5px dashed var(--border); border-radius: 6px; cursor: pointer;
  background: none; color: var(--text-2); font-family: var(--font); transition: all .15s;
}
.ib-add-code-btn:hover { border-color: var(--teal); color: var(--teal); }

.ib-add-dept-btn {
  padding: 8px 16px; font-size: 13px; font-weight: 700;
  border: 1.5px dashed rgba(14,126,163,.4); border-radius: 8px; cursor: pointer;
  background: rgba(14,126,163,.04); color: var(--teal); font-family: var(--font); transition: all .15s;
  width: 100%;
}
.ib-add-dept-btn:hover { background: rgba(14,126,163,.1); border-style: solid; }

.ib-generate-btn {
  width: 100%; padding: 12px; background: var(--teal); color: #fff; border: none;
  border-radius: 9px; font-family: var(--font); font-size: 14px; font-weight: 700;
  cursor: pointer; margin-top: 16px; transition: all .15s;
}
.ib-generate-btn:hover { background: var(--teal-d); transform: translateY(-1px); }
.ib-generate-btn:disabled { background: var(--text-3); cursor: not-allowed; transform: none; }

.ib-results {
  margin-top: 18px; border: 1.5px solid rgba(13,158,106,.3);
  border-radius: 10px; overflow: hidden; display: none;
}
.ib-results-hd {
  padding: 12px 16px; background: rgba(13,158,106,.07);
  font-size: 13px; font-weight: 700; color: var(--green);
  border-bottom: 1px solid rgba(13,158,106,.2);
}
.ib-result-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 16px; border-bottom: 1px solid var(--border);
}
.ib-result-row:last-child { border-bottom: none; }
.ib-result-dept { font-size: 11px; color: var(--text-3); font-weight: 600; width: 160px; flex-shrink: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ib-result-code { font-family: var(--mono); font-size: 13px; font-weight: 700; color: var(--teal); flex: 1; letter-spacing: .5px; cursor: pointer; }
.ib-result-code:hover { color: var(--teal-d); text-decoration: underline; }
.ib-result-type { flex-shrink: 0; }
.ib-result-err { color: var(--red); font-size: 12px; flex: 1; }


/* === Generated from inline style="" attributes === */
.s1c3d11 { font-size:11px;color:var(--text-3) }
.scb4589 { display:none }
.s35f64e { padding:5px 10px;border:1.5px solid var(--border);border-radius:7px;font-family:var(--font);font-size:12.5px;background:var(--surf2);color:var(--text-1);outline:none;cursor:pointer }
.sdf74e8 { overflow-x:auto }
.sbe2540 { margin-bottom:18px }
.sf41bf6 { flex-wrap:wrap;gap:8px }
.s94d4ab { display:flex;gap:8px;flex-wrap:wrap;align-items:center }
.s7fc163 { display:flex;gap:4px }
.s40e86f { padding:4px 10px;border-radius:6px;border:1.5px solid var(--teal);background:var(--teal);color:#fff;font-size:12px;font-weight:700;cursor:pointer }
.s3bea47 { padding:4px 10px;border-radius:6px;border:1.5px solid var(--border);background:transparent;color:var(--text-2);font-size:12px;font-weight:600;cursor:pointer }
.s8cb58b { display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px }
.sf3e2d1 { font-size:14px;font-weight:700;color:var(--text-h) }
.s1ef31f { font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-2);margin-bottom:8px }
.s6b2b82 { display:none;background:var(--text-2);margin-top:6px }
.s130b4d { background:linear-gradient(135deg,rgba(14,126,163,.08),rgba(109,40,217,.06));border:1.5px solid rgba(14,126,163,.2);border-radius:10px;padding:14px 18px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px }
.s800744 { font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-2);margin-bottom:3px }
.s3580e5 { font-size:13.5px;font-weight:700;color:var(--text-h);font-family:var(--mono) }
.s04a5c2 { font-size:11.5px;color:var(--text-3);margin-top:2px }
.s334f3d { display:inline-flex;align-items:center;gap:7px;padding:10px 18px;background:var(--teal);color:#fff;border-radius:8px;font-family:var(--font);font-size:13px;font-weight:700;text-decoration:none;transition:background .15s;white-space:nowrap }
.sbf885d { font-weight:400;text-transform:none;letter-spacing:0 }
.s9e3c4c { margin-top:6px }
.se6fa50 { display:flex;gap:8px;margin-top:6px }
.s299dac { display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1.5px solid #6D28D9;background:rgba(109,40,217,0.08);cursor:pointer;font-size:13px;font-weight:700;color:#5B21B6 }
.s817228 { accent-color:#6D28D9 }
.s8c4d8b { display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1.5px solid var(--border);background:var(--surf2);cursor:pointer;font-size:13px;font-weight:600;color:var(--text-2) }
.sddc021 { accent-color:var(--teal) }
.s13076d { text-align:center }
.s279407 { font-size:32px;margin-bottom:10px }
.sfd21cc { font-size:11.5px;color:var(--text-3);margin-bottom:16px }
.s9b54a3 { justify-content:center }
/* ═══════════════════════════════════════════════════════════
   VAULT UI — convenience PIN gate styles
═══════════════════════════════════════════════════════════ */
#vault-setup,#vault-reset{
  display:none;position:fixed;inset:0;
  background:var(--bg,#f8fafc);
  align-items:flex-start;justify-content:center;z-index:9999;
  overflow-y:auto;
}
#vault-pin{
  display:none;position:fixed;inset:0;
  background:var(--bg,#f8fafc);
  align-items:center;justify-content:center;z-index:9999;
  overflow-y:auto;
}
#vault-setup .login-card,#vault-pin .login-card,#vault-reset .login-card{
  margin:auto;margin-top:32px;margin-bottom:32px;
}
.vault-err{
  background:#fef2f2;border:1px solid #fca5a5;color:#dc2626;
  border-radius:6px;padding:10px 14px;font-size:0.82rem;margin-bottom:8px;
}
.vault-lockbanner{
  background:#fef3c7;border:1px solid #fbbf24;color:#92400e;
  border-radius:6px;padding:10px 14px;font-size:0.83rem;
  text-align:center;margin-bottom:12px;
}
.vault-sel{
  width:100%;padding:8px 12px;
  border:1px solid var(--border,#d1d5db);
  border-radius:6px;font-size:0.9rem;
  background:#fff;color:#1e293b;
}
.vault-ghost-btn{
  background:transparent!important;
  border:1px solid var(--border,#d1d5db)!important;
  color:var(--text-2,#64748b)!important;
  margin-top:8px;
}
.vault-ghost-btn:hover{background:#f1f5f9!important;}
.vault-danger-btn{background:#dc2626!important;}
.vault-danger-btn:hover{background:#b91c1c!important;}

/* Dashboard page header */
.dash-header{
  text-align:center;
  padding:28px 20px 4px;
  background:var(--bg,#f8fafc);
}
.dash-header-title{
  font-size:1.6rem;font-weight:800;
  color:var(--text-h,#0f172a);letter-spacing:-0.5px;
}
.dash-header-sub{
  font-size:0.82rem;color:var(--text-3,#94a3b8);
  margin-top:2px;font-weight:500;
}
