/* ═══════════════════════════════════════════════════════════════════════════
   index.css — Styles specific to the Supervisory Portal (index.html)
   Depends on: shared.css
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Load screen ────────────────────────────────────────────────────────────── */
#load-screen { position: fixed; inset: 0; background: var(--bg); overflow-y: auto; z-index: 300; }
.load-inner  { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 24px; gap: 32px; }
.load-header { text-align: center; }
.load-logo   { font-family: var(--mono); font-size: clamp(1.4rem, 4vw, 1.8rem); font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.load-title  { font-size: 0.9rem; font-weight: 500; color: var(--t2); margin-bottom: 4px; line-height: 1; }
.load-desc   { font-size: 13px; color: var(--t2); line-height: 1.6; }
.wordmark      { font-size: clamp(0.75rem, 2vw, 0.9rem); font-weight: 500; letter-spacing: -0.02em; color: var(--t1); margin: 0; line-height: 1; }
.wordmark span { color: #d4d6da; font-weight: 400; }

.load-clusters { display: flex; flex-direction: column; gap: 20px; width: 100%; max-width: 680px; }
.cluster-block  { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r3); overflow: hidden; }
.cluster-title  { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--t3); padding: 12px 18px; border-bottom: 1px solid var(--border); background: var(--bg2); }
.cluster-teams  { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; }
.team-btn       { background: none; border: none; border-right: 1px solid var(--border); cursor: pointer; padding: 18px 16px; text-align: left; transition: background .15s; display: flex; flex-direction: column; gap: 5px; position: relative; }
.team-btn:last-child { border-right: none; }
.team-btn:hover { background: var(--bg4); }
.team-btn:hover .team-arrow { opacity: 1; transform: translateX(0); }
.team-name  { font-size: 14px; font-weight: 600; color: var(--t1); }
.team-file  { font-family: var(--mono); font-size: 10px; color: var(--t3); }
.team-arrow { font-size: 14px; color: var(--accent); opacity: 0; transform: translateX(-4px); transition: all .15s; margin-top: 4px; }

.cluster-block-btn { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r3); overflow: hidden; width: 100%; text-align: left; cursor: pointer; display: block; padding: 0; }
.cluster-nav-row { display: flex; justify-content: space-between; align-items: center; padding: 16px 18px; transition: background .15s; }
.cluster-nav-row:hover { background: var(--bg4); }
.cluster-nav-arrow { font-size: 14px; color: var(--accent); }
.sc-top-right { display: flex; align-items: center; gap: 8px; }
.chart-footnote { font-size: 11px; color: var(--t3); text-align: center; margin-top: -8px; }
.dev-empty { font-size: 12px; color: var(--t3); padding: 6px 0; }
.hist-del-btn { color: var(--red); border-color: rgba(255,82,82,.25); }

.load-status  { font-size: 12px; color: var(--t2); text-align: center; min-height: 18px; }
.load-status.err { color: var(--red); }
.load-footer  { display: flex; flex-direction: column; align-items: center; gap: 8px; width: 100%; max-width: 680px; }
.load-restore { background: var(--amber-bg); border: 1px solid rgba(245,158,11,.25); border-radius: var(--r); padding: 10px 14px; font-size: 12px; color: var(--amber); width: 100%; display: none; text-align: center; }
.load-div     { display: flex; align-items: center; gap: 10px; color: var(--t3); font-size: 11px; width: 100%; }
.load-div::before, .load-div::after { content: ''; flex: 1; height: 1px; background: var(--border); }

/* ── Header ─────────────────────────────────────────────────────────────────── */
header { background: var(--bg2); border-bottom: 1px solid var(--border); height: 58px; display: flex; align-items: center; justify-content: space-between; padding: 0 24px; position: sticky; top: 0; z-index: 100; }
.h-left  { display: flex; align-items: center; gap: 14px; }
.h-logo  { font-family: var(--mono); font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--accent2); background: rgba(99,102,241,0.15); border: 1px solid rgba(99,102,241,0.3); border-radius: 4px; padding: 3px 10px; }
.h-logo span { color: var(--accent2); }
.h-sep   { width: 1px; height: 18px; background: var(--border2); }
.nav     { display: flex; gap: 2px; }
.nav-btn { font-size: 13px; font-weight: 500; color: var(--t2); background: none; border: none; cursor: pointer; padding: 5px 12px; border-radius: var(--r); transition: all .15s; }
.nav-btn:hover  { color: var(--t1); background: var(--bg4); }
.nav-btn.active { color: var(--t1); background: var(--bg3); }
.h-right { display: flex; align-items: center; gap: 8px; }
#unsaved-pill { display: none; font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--amber); background: var(--amber-bg); border: 1px solid rgba(245,158,11,.3); padding: 3px 10px; border-radius: 9999px; animation: blink 2.2s infinite; }
#lock-banner  { display: none; font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--red); background: var(--red-bg); border: 1px solid rgba(239,68,68,.3); padding: 3px 10px; border-radius: 9999px; }
#user-pill    { display: none; font-size: 13px; font-weight: 500; color: var(--t2); background: var(--bg3); border: 1px solid var(--border2); border-radius: 20px; padding: 4px 14px; }

/* ── Layout ─────────────────────────────────────────────────────────────────── */
main { padding: 22px; max-width: 1440px; margin: 0 auto; width: 100%; }
.view { display: none; }
.view.active { display: block; animation: fadeIn .18s ease; }

/* ── Command bar ─────────────────────────────────────────────────────────────── */
.cmd-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 10px; margin-bottom: 14px; }
.cmd-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r2); padding: 1.5rem; box-shadow: var(--shadow); display: flex; flex-direction: column; gap: 5px; transition: border-color .15s; }
.cmd-card:hover { border-color: var(--t3); }
.cmd-card.c-red    { border-left: 3px solid var(--red);    }
.cmd-card.c-amber  { border-left: 3px solid var(--amber);  }
.cmd-card.c-green  { border-left: 3px solid var(--green);  }
.cmd-card.c-accent { border-left: 3px solid var(--accent); }
.cmd-label { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--t3); }
.cmd-val   { font-family: var(--mono); font-size: 30px; font-weight: 600; line-height: 1; }
.cmd-sub   { font-size: 12px; color: var(--t2); }
.cmd-card.c-red    .cmd-val { color: var(--red);    }
.cmd-card.c-amber  .cmd-val { color: var(--amber);  }
.cmd-card.c-green  .cmd-val { color: var(--green);  }
.cmd-card.c-accent .cmd-val { color: var(--accent); }

/* ── Compliance row ──────────────────────────────────────────────────────────── */
.comp-dash-row  { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 22px; }
.comp-dash-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r2); padding: 1.5rem; box-shadow: var(--shadow); display: flex; align-items: center; gap: 20px; }
.cdc-ring-wrap  { flex-shrink: 0; position: relative; width: 90px; height: 90px; }
.cdc-ring-wrap svg { width: 90px; height: 90px; }
.cdc-ring-center { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 0; }
.cdc-ring-pct   { font-family: var(--mono); font-size: 17px; font-weight: 600; line-height: 1; }
.cdc-ring-pct.green { color: var(--green); } .cdc-ring-pct.amber { color: var(--amber); } .cdc-ring-pct.red { color: var(--red); }
.cdc-info  { flex: 1; min-width: 0; }
.cdc-label { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--t3); margin-bottom: 8px; }
.cdc-stats { display: flex; flex-direction: column; gap: 4px; }
.cdc-stat  { display: flex; align-items: center; justify-content: space-between; gap: 6px; }
.cdc-stat-val { font-family: var(--mono); font-size: 15px; font-weight: 600; min-width: 20px; text-align: right; }
.cdc-stat-val.red { color: var(--red); } .cdc-stat-val.amber { color: var(--amber); } .cdc-stat-val.green { color: var(--green); }
.cdc-stat-lbl { font-size: 11px; color: var(--t3); }

/* ── Section header ──────────────────────────────────────────────────────────── */
.sec-hdr   { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.sec-title { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--t3); }

/* ── Staff grid ──────────────────────────────────────────────────────────────── */
.staff-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(308px,1fr)); gap: 11px; margin-bottom: 30px; }
.sc { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r2); padding: 1.5rem; box-shadow: var(--shadow); cursor: pointer; transition: all .15s; position: relative; overflow: hidden; }
.sc::after { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; }
.sc.green::after { background: var(--green); } .sc.amber::after { background: var(--amber); } .sc.red::after { background: var(--red); }
.sc:hover { background: var(--bg4); border-color: var(--t3); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(0,0,0,.3); }
.sc[draggable] { cursor: grab; } .sc[draggable]:active { cursor: grabbing; }
.sc.drag-over { border-color: var(--accent); background: var(--bg5); transform: scale(1.01); }
.sc.dragging  { opacity: 0.4; transform: scale(0.97); }
.drag-hint { font-family: var(--mono); font-size: 9px; text-transform: uppercase; letter-spacing: .1em; color: var(--t3); margin-left: auto; }
.sc-top  { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 11px; }
.sc-name { font-weight: 600; font-size: 15px; }
.sc-role { font-family: var(--mono); font-size: 11px; color: var(--t2); margin-top: 2px; }
.rag       { font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 3px 10px; border-radius: 9999px; flex-shrink: 0; }
.rag.green { background: rgba(16,185,129,.1);  color: var(--green); border: 1px solid rgba(16,185,129,.3);  }
.rag.amber { background: rgba(245,158,11,.1);  color: var(--amber); border: 1px solid rgba(245,158,11,.3);  }
.rag.red   { background: rgba(239,68,68,.1);   color: var(--red);   border: 1px solid rgba(239,68,68,.3);   }

/* Compliance strips */
.sc-strips { display: flex; flex-direction: column; gap: 5px; padding-top: 11px; border-top: 1px solid var(--border2); }
.sc-strip  { display: flex; align-items: center; gap: 8px; font-size: 11px; }
.sc-strip-label { color: var(--t3); font-family: var(--mono); font-size: 9px; text-transform: uppercase; letter-spacing: .08em; width: 32px; flex-shrink: 0; }
.sc-strip-bar   { flex: 1; height: 3px; background: var(--border); border-radius: 2px; overflow: hidden; }
.sc-strip-fill  { height: 100%; border-radius: 2px; transition: width .4s ease; }
.sc-strip-fill.green { background: var(--green); } .sc-strip-fill.amber { background: var(--amber); } .sc-strip-fill.red { background: var(--red); }
.sc-strip-val   { font-family: var(--mono); font-size: 11px; width: 80px; text-align: right; flex-shrink: 0; }
.sc-strip-val.green { color: var(--green); } .sc-strip-val.amber { color: var(--amber); } .sc-strip-val.red { color: var(--red); }

/* Skills/training on card */
.sc-dev        { padding-top: 10px; border-top: 1px solid var(--border2); margin-top: 10px; display: flex; flex-direction: column; gap: 8px; }
.sc-dev-row    { display: flex; flex-direction: column; gap: 4px; }
.sc-dev-label  { font-family: var(--mono); font-size: 9px; text-transform: uppercase; letter-spacing: .08em; color: var(--t3); margin-bottom: 2px; }
.sc-dev-list   { display: flex; flex-direction: column; gap: 3px; }
.sc-dev-item   { font-size: 11px; color: var(--t2); display: flex; align-items: center; gap: 4px; }
.sc-dev-item-title { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sc-dev-more   { color: var(--t3); font-style: italic; }

/* ── Modal ──────────────────────────────────────────────────────────────────── */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,.75); backdrop-filter: blur(3px); z-index: 200; display: none; align-items: center; justify-content: center; padding: 20px; }
.overlay.open { display: flex; animation: fadeIn .15s ease; }
.modal    { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r3); box-shadow: var(--shadow); width: 100%; max-height: 92vh; display: flex; flex-direction: column; animation: slideUp .2s ease; }
.modal-hdr     { padding: 1.5rem; border-bottom: 1px solid var(--border); display: flex; align-items: flex-start; justify-content: space-between; flex-shrink: 0; gap: 12px; }
.modal-hdr-left { flex: 1; min-width: 0; }
.modal-title   { font-size: 17px; font-weight: 700; }
.modal-sub     { font-size: 12px; color: var(--t2); margin-top: 2px; }
.modal-body    { padding: 1.5rem; overflow-y: auto; flex: 1; }
.modal-ftr     { padding: 1rem 1.5rem; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: 8px; flex-shrink: 0; }
.modal-close   { background: none; border: none; cursor: pointer; color: var(--t3); font-size: 18px; line-height: 1; padding: 2px 6px; border-radius: 4px; transition: color .12s; }
.modal-close:hover { color: var(--t1); }

/* ── Record tabs ─────────────────────────────────────────────────────────────── */
.rec-tabs { display: flex; gap: 2px; margin-bottom: 18px; border-bottom: 1px solid var(--border); padding-bottom: 0; }
.rec-tab  { font-size: 13px; font-weight: 500; color: var(--t2); background: none; border: none; cursor: pointer; padding: 8px 14px; border-radius: var(--r) var(--r) 0 0; transition: all .15s; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.rec-tab:hover  { color: var(--t1); }
.rec-tab.active { color: var(--t1); border-bottom-color: var(--accent); }
.rec-panel        { display: none; }
.rec-panel.active { display: block; }

/* ── Compliance blocks ───────────────────────────────────────────────────────── */
.comp-row         { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 14px; }
.comp-block       { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r2); padding: 1.5rem; box-shadow: var(--shadow); }
.comp-block-label { font-family: var(--mono); font-size: 9px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--t3); margin-bottom: 6px; }
.comp-block-val   { font-family: var(--mono); font-size: 18px; font-weight: 600; }
.comp-block-sub   { font-size: 11px; color: var(--t2); margin-top: 3px; }

/* ── History ─────────────────────────────────────────────────────────────────── */
.hist-list { display: flex; flex-direction: column; gap: 8px; }
.hist-item { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r2); box-shadow: var(--shadow); overflow: hidden; }
.hist-hdr  { display: flex; align-items: center; justify-content: space-between; padding: 11px 14px; cursor: pointer; transition: background .12s; gap: 10px; }
.hist-hdr:hover { background: var(--bg4); }
.hist-hdr-left  { display: flex; align-items: center; gap: 10px; min-width: 0; flex: 1; }
.hist-hdr-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.hist-date { font-family: var(--mono); font-size: 12px; font-weight: 600; }
.hist-by   { font-size: 12px; color: var(--t2); }
.hist-chev { color: var(--t3); font-size: 9px; transition: transform .15s; }
.hist-item.open .hist-chev { transform: rotate(180deg); }
.hist-body { display: none; padding: 0 14px 14px; border-top: 1px solid var(--border2); }
.hist-item.open .hist-body { display: block; }
.hist-edit-btn { font-family: var(--mono); font-size: 9px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; padding: 3px 8px; border-radius: 4px; border: 1px solid var(--border); background: none; color: var(--t3); cursor: pointer; transition: all .12s; }
.hist-edit-btn:hover { color: var(--accent); border-color: var(--accent); background: var(--accent-bg); }

.metric-chips { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
.metric-chip  { background: var(--bg4); border: 1px solid var(--border); border-radius: var(--r); padding: 8px 12px; min-width: 100px; }
.mc-label { font-family: var(--mono); font-size: 9px; text-transform: uppercase; letter-spacing: .1em; color: var(--t3); margin-bottom: 4px; }
.mc-val   { font-family: var(--mono); font-size: 16px; font-weight: 600; color: var(--t1); }

.qual-list { display: flex; flex-direction: column; gap: 10px; }
.qual-lbl  { font-size: 11px; font-weight: 600; color: var(--t3); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 3px; }
.qual-txt  { font-size: 13px; color: var(--t2); line-height: 1.6; }

/* ── BWV badges ──────────────────────────────────────────────────────────────── */
.bwv-type    { font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: .05em; padding: 3px 10px; border-radius: 9999px; text-transform: uppercase; border: 1px solid; }
.bwv-arrest  { background: rgba(239,68,68,.1);   color: var(--red);       border-color: rgba(239,68,68,.3);   }
.bwv-force   { background: rgba(245,158,11,.1);  color: var(--amber);     border-color: rgba(245,158,11,.3);  }
.bwv-search  { background: rgba(99,102,241,.1);  color: var(--accent2);   border-color: rgba(99,102,241,.3);  }
.bwv-general { background: rgba(16,185,129,.1);  color: var(--green);     border-color: rgba(16,185,129,.3);  }

/* ── Chart ───────────────────────────────────────────────────────────────────── */
.chart-wrap    { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r2); padding: 1.5rem; margin-bottom: 16px; box-shadow: var(--shadow); }
.chart-toggles { display: flex; gap: 6px; margin-bottom: 14px; flex-wrap: wrap; }
.chart-toggle  { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; padding: 4px 10px; border-radius: 4px; border: 1px solid var(--border); cursor: pointer; transition: all .15s; color: var(--t3); background: none; }
.chart-toggle[data-key="stopSearches"].on         { border-color: var(--accent); color: var(--accent); background: var(--accent-bg); }
.chart-toggle[data-key="positiveOutcomeRate"].on  { border-color: var(--purple); color: var(--purple); background: var(--purple-bg); }
.chart-toggle[data-key="intelligenceSubmissions"].on { border-color: var(--amber); color: var(--amber); background: var(--amber-bg); }
.chart-toggle[data-key="totalCrimes"].on          { border-color: var(--green);  color: var(--green);  background: var(--green-bg);  }
.chart-canvas-wrap { position: relative; width: 100%; height: 180px; }
canvas#perf-chart  { width: 100%; height: 100%; }
.chart-empty       { text-align: center; color: var(--t3); font-size: 12px; padding: 40px 0; }

/* ── Development (skills / training) ────────────────────────────────────────── */
.dev-section       { margin-bottom: 24px; }
.dev-section-title { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--t3); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--border2); display: flex; align-items: center; justify-content: space-between; }
.skill-list  { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.skill-item  { display: flex; align-items: center; justify-content: space-between; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r); padding: 9px 12px; gap: 8px; }
.skill-name  { font-size: 13px; color: var(--t1); }
.skill-del   { background: none; border: none; cursor: pointer; color: var(--t3); font-size: 14px; padding: 0 2px; line-height: 1; transition: color .12s; flex-shrink: 0; }
.skill-del:hover { color: var(--red); }
.skill-add-row      { display: flex; gap: 8px; }
.skill-add-row input { flex: 1; }

.training-list   { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.training-item   { display: flex; align-items: center; justify-content: space-between; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r); padding: 9px 12px; gap: 10px; }
.training-title  { font-size: 13px; color: var(--t1); flex: 1; min-width: 0; }
.training-status { font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 3px 10px; border-radius: 9999px; border: 1px solid; flex-shrink: 0; }
.training-status.approved { background: rgba(16,185,129,.1);  color: var(--green); border-color: rgba(16,185,129,.3);  }
.training-status.denied   { background: var(--red-bg);        color: var(--red);   border-color: rgba(239,68,68,.3);   }
.training-status.pending  { background: var(--amber-bg);      color: var(--amber); border-color: rgba(245,158,11,.3);  }
.training-del    { background: none; border: none; cursor: pointer; color: var(--t3); font-size: 14px; padding: 0 2px; line-height: 1; transition: color .12s; }
.training-del:hover { color: var(--red); }
.training-add-row        { display: flex; gap: 8px; align-items: flex-start; }
.training-add-row input  { flex: 1; }
.training-add-row select { width: 140px; flex-shrink: 0; }

/* ── Forms ───────────────────────────────────────────────────────────────────── */
.form-sec       { margin-bottom: 22px; }
.form-sec-title { font-family: var(--mono); font-size: 9px; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--t3); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--border2); }
.form-grid  { display: grid; gap: 12px; }
.fg-2 { grid-template-columns: 1fr 1fr; }
.fg-3 { grid-template-columns: 1fr 1fr 1fr; }
.fg-1 { grid-template-columns: 1fr; }
.form-group { display: flex; flex-direction: column; gap: 5px; }
.span2 { grid-column: span 2; } .span3 { grid-column: span 3; }
label { font-size: 12px; font-weight: 500; color: var(--t2); }
input[type="text"], input[type="number"], input[type="date"], select, textarea {
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--r);
  color: var(--t1); font-family: var(--sans); font-size: 13px;
  padding: 8px 11px; width: 100%; transition: border-color .15s; outline: none;
}
input:focus, select:focus, textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(99,102,241,.08); }
input::placeholder, textarea::placeholder { color: var(--t3); }
textarea { resize: vertical; min-height: 72px; line-height: 1.5; }
select option { background: var(--bg3); }
.ferr { font-size: 11px; color: var(--red); display: none; }
.form-group.err input, .form-group.err textarea, .form-group.err select { border-color: var(--red); }
.form-group.err .ferr { display: block; }

/* ── Role picker ─────────────────────────────────────────────────────────────── */
.role-opts { display: flex; gap: 8px; }
.role-opt  { flex: 1; background: var(--bg); border: 2px solid var(--border); border-radius: var(--r); padding: 10px; cursor: pointer; text-align: center; transition: all .15s; }
.role-opt:hover { border-color: var(--t3); }
.role-opt.sel   { border-color: var(--accent); background: var(--accent-bg); }
.role-opt .rt   { font-weight: 600; font-size: 14px; }
.role-opt .rc   { font-size: 10px; color: var(--t3); margin-top: 2px; font-family: var(--mono); }
.role-opt.sel .rc { color: var(--accent); }

/* ── Archive table ───────────────────────────────────────────────────────────── */
.arch-wrap { overflow-x: auto; }
table      { width: 100%; border-collapse: collapse; font-size: 13px; }
thead th   { font-family: var(--mono); font-size: 9px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--t3); text-align: left; padding: 9px 13px; border-bottom: 1px solid var(--border); }
tbody tr   { border-bottom: 1px solid var(--border2); transition: background .1s; cursor: pointer; }
tbody tr:hover { background: var(--bg3); }
tbody td   { padding: 10px 13px; color: var(--t2); }
tbody td:first-child { color: var(--t1); font-weight: 500; }

/* ── Misc ────────────────────────────────────────────────────────────────────── */
.chip      { display: inline-block; font-family: var(--mono); font-size: 9px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; padding: 2px 7px; border-radius: 4px; border: 1px solid; }
.chip-pc   { background: var(--accent-bg); color: var(--accent); border-color: rgba(99,102,241,.2); }
.chip-pcso { background: var(--purple-bg); color: var(--purple); border-color: rgba(167,139,250,.2); }
.empty       { text-align: center; padding: 50px 20px; color: var(--t3); }
.empty-icon  { font-size: 32px; margin-bottom: 10px; }
.empty-title { font-size: 14px; color: var(--t2); margin-bottom: 4px; font-weight: 500; }
.empty-sub   { font-size: 12px; }
.divider   { height: 1px; background: var(--border); margin: 20px 0; }
.info-note { font-size: 11px; color: var(--t3); margin-top: 5px; line-height: 1.5; }

/* ── Responsive ──────────────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .cmd-grid      { grid-template-columns: repeat(3,1fr); }
  .comp-dash-row { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 700px) {
  .cmd-grid      { grid-template-columns: repeat(2,1fr); }
  .comp-dash-row { grid-template-columns: 1fr 1fr; }
  .fg-2, .fg-3   { grid-template-columns: 1fr; }
  .span2, .span3 { grid-column: span 1; }
  main           { padding: 14px; }
}
