/* USX Cyber — CMMC Assured · Base layout & components */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  color: var(--color-ink);
  background: var(--color-bg);
  font-size: 15px;
  line-height: 1.5;
}
a { color: var(--color-brand); }

/* Shell */
.shell { display: grid; grid-template-columns: 256px minmax(0, 1fr); min-height: 100vh; }
.sidebar {
  background: var(--color-brand-deep);
  color: #dce6f2;
  padding: 20px 14px;
  display: flex; flex-direction: column; gap: 2px;
  position: sticky; top: 0; align-self: start; height: 100vh; overflow-y: auto;
}
/* sidebar journey progress block */
.side-progress { margin: 6px 6px 10px; padding: 12px; background: rgba(255,255,255,.05); border-radius: var(--radius-sm); }
.side-progress .sp-label { font-size: 11px; text-transform: uppercase; letter-spacing: .07em; color: #8aa0bd; }
.side-progress .sp-score { font-size: 26px; font-weight: 800; color: #fff; line-height: 1.1; margin-top: 2px; }
.side-progress .sp-score span { font-size: 13px; font-weight: 500; color: #8aa0bd; }
.side-progress .bar { background: rgba(255,255,255,.12); margin-top: 8px; }
.nav-step-no { display:inline-grid; place-items:center; width:18px; height:18px; border-radius:50%; background:rgba(255,255,255,.12); color:#cfe0f2; font-size:11px; font-weight:700; flex:none; }
.nav-link.active .nav-step-no { background: var(--color-brand-deep); color:#fff; }
.nav-step-no.done { background: var(--color-accent); color: var(--color-brand-deep); }
.nav-badge { margin-left: auto; background: var(--color-warn); color: #fff; border-radius: 99px; font-size: 11px; font-weight: 700; padding: 1px 7px; min-width: 18px; text-align: center; }

/* collapsible nav categories */
.nav-cat { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border-radius: var(--radius-sm); cursor: pointer; color: #c3d2e6; font-size: 14px; user-select: none; }
.nav-cat:hover { background: rgba(255,255,255,.06); color: #fff; }
.nav-cat.has-active { color: #fff; }
.nav-cat-label { font-weight: 600; }
.nav-cat .nav-badge { margin-left: auto; }
.nav-caret { margin-left: auto; font-size: 11px; color: #7e93b0; transition: transform .15s; }
.nav-cat .nav-badge + .nav-caret { margin-left: 6px; }
.nav-cat.open .nav-caret { transform: rotate(90deg); }
.nav-link.nav-child { padding-left: 34px; font-size: 13.5px; }
.nav-divider { height: 1px; background: rgba(255,255,255,.12); margin: 10px 8px; }
.side-foot { margin-top: auto; padding: 12px 10px 4px; font-size: 11px; line-height: 1.45; color: #8aa0bd; border-top: 1px solid rgba(255,255,255,.1); }
.side-foot b { color: #d7e3f2; }

/* mobile / narrow-screen sidebar (off-canvas) */
.nav-toggle { display: none; border: none; background: transparent; color: var(--color-ink); font-size: 20px; cursor: pointer; padding: 2px 6px; line-height: 1; flex: none; }
.nav-scrim { display: none; }
@media (max-width: 860px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { position: fixed; top: 0; left: 0; bottom: 0; width: 256px; transform: translateX(-100%); transition: transform .2s ease; z-index: 70; }
  .shell.nav-open .sidebar { transform: translateX(0); box-shadow: 8px 0 30px rgba(15,34,56,.3); }
  .nav-toggle { display: inline-flex; }
  .shell.nav-open .nav-scrim { display: block; position: fixed; inset: 0; background: rgba(15,34,56,.45); z-index: 60; }
  .topbar { flex-wrap: wrap; }
  .role-switch { flex-wrap: wrap; }
  .main { padding: 18px 18px 50px; }
}

/* long unbroken strings never blow out table cells */
td { overflow-wrap: anywhere; }

/* ===== Policy Builder generated document ===== */
.policy-doc { background: var(--color-bg-panel); border: 1px solid var(--color-line); border-radius: var(--radius); padding: 22px 26px; box-shadow: var(--shadow); }
.policy-doc h2 { margin: 0 0 4px; font-size: 20px; }
.policy-doc h3 { font-size: 14px; color: var(--color-brand); margin: 18px 0 6px; }
.policy-doc p { font-size: 13.5px; margin: 0 0 6px; }
.policy-doc ul { margin: 6px 0; padding-left: 22px; }
.policy-doc li { margin: 4px 0; font-size: 13.5px; }
.pol-meta { border-collapse: collapse; margin: 8px 0 14px; font-size: 12px; }
.pol-meta td { border: 1px solid var(--color-line); padding: 4px 9px; }
.pol-meta td:nth-child(odd) { color: var(--color-ink-muted); background: var(--color-bg-soft); font-weight: 600; white-space: nowrap; }
.pol-practices li > div { color: var(--color-ink-2); margin-top: 2px; }
/* Policy Builder fill-in-the-blank fields */
.pb-fill { padding: 9px 0; border-bottom: 1px solid var(--color-line); }
.pb-fill:last-of-type { border-bottom: none; }
.pb-context { font-size: 12.5px; color: var(--color-ink-2); margin-bottom: 5px; line-height: 1.5; }
.pb-context mark { background: var(--color-warn-soft); color: var(--color-warn); padding: 0 3px; border-radius: 3px; font-style: normal; font-weight: 600; }
.brand { display: flex; align-items: center; gap: 10px; padding: 4px 8px 18px; }
.brand .mark {
  width: 30px; height: 30px; border-radius: 7px;
  background: var(--color-accent); color: var(--color-brand-deep);
  display: grid; place-items: center; font-weight: 800;
}
.brand .name { font-weight: 700; color: #fff; line-height: 1.1; }
.brand .name small { display: block; font-weight: 500; font-size: 11px; color: #9fb3cc; }

.nav-link {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 11px; border-radius: var(--radius-sm);
  color: #c3d2e6; text-decoration: none; font-size: 14px; cursor: pointer;
}
.nav-link:hover { background: rgba(255,255,255,.06); color: #fff; }
.nav-link.active { background: var(--color-accent); color: var(--color-brand-deep); font-weight: 600; }
.nav-group-label { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: #6f86a3; padding: 14px 11px 4px; }

/* Main — fills the available width (no dead space on the right) */
.main { padding: 22px 34px 60px; min-width: 0; }
.topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; gap: 20px; }
.topbar h1 { font-size: 22px; margin: 0; }
.role-switch { display: flex; gap: 6px; align-items: center; font-size: 13px; color: var(--color-ink-muted); }
.role-switch select { padding: 6px 8px; border-radius: var(--radius-sm); border: 1px solid var(--color-line-strong); }

/* Cards */
.grid { display: grid; gap: 16px; }
.grid.cols-4 { grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); }
.grid.cols-3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.grid.cols-2 { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
.card { background: var(--color-bg-panel); border: 1px solid var(--color-line); border-radius: var(--radius); box-shadow: var(--shadow); padding: 18px; }
.stat .label { font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: var(--color-ink-muted); }
.stat .value { font-size: 30px; font-weight: 700; margin-top: 4px; }
.stat .value.accent { color: var(--color-accent-strong); }

/* Progress bar */
.bar { height: 8px; background: var(--color-bg-soft); border-radius: 99px; overflow: hidden; margin-top: 10px; }
.bar > span { display: block; height: 100%; background: var(--color-accent); }

/* Table */
table { width: 100%; border-collapse: collapse; background: var(--color-bg-panel); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
th, td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--color-line); font-size: 14px; vertical-align: top; }
th { background: var(--color-bg-soft); font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--color-ink-muted); }
tr:last-child td { border-bottom: none; }
tr.clickable { cursor: pointer; }
tr.clickable:hover td { background: var(--color-accent-soft); }

/* Pills */
.pill { display: inline-block; padding: 2px 9px; border-radius: 99px; font-size: 12px; font-weight: 600; }
.pill.met      { background: var(--color-success-soft); color: var(--color-success); }
.pill.partial  { background: var(--color-warn-soft);    color: var(--color-warn); }
.pill.notmet   { background: var(--color-danger-soft);  color: var(--color-danger); }
.pill.na       { background: var(--color-bg-soft);      color: var(--color-ink-muted); }
.pill.level    { background: var(--color-brand); color: #fff; }

/* Drawer */
.drawer-backdrop { position: fixed; inset: 0; background: rgba(15,34,56,.45); display: none; }
.drawer-backdrop.open { display: block; }
.drawer { position: fixed; top: 0; right: 0; width: min(560px, 92vw); height: 100vh; background: var(--color-bg-panel); box-shadow: -8px 0 30px rgba(15,34,56,.2); padding: 22px 24px; overflow-y: auto; transform: translateX(100%); transition: transform .18s ease; }
.drawer.open { transform: translateX(0); }
.drawer h2 { margin: 0 0 2px; font-size: 19px; }
.dvp { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin: 14px 0; }
.dvp > div { background: var(--color-bg-soft); border-radius: var(--radius-sm); padding: 10px; font-size: 12.5px; }
.dvp b { display: block; color: var(--color-brand); margin-bottom: 3px; }
.obj { border: 1px solid var(--color-line); border-radius: var(--radius-sm); padding: 10px 12px; margin-bottom: 8px; }
.obj .oid { font-weight: 700; color: var(--color-brand); font-size: 13px; }

/* Plain-English vs formal NIST language toggle (drawer) */
.drawer .formal { display: none; }
.drawer.show-formal .formal { display: block; }
.drawer.show-formal .formal.dvp { display: grid; }

.muted { color: var(--color-ink-muted); }
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: var(--radius-sm); border: 1px solid var(--color-brand); background: var(--color-brand); color: #fff; font-size: 14px; cursor: pointer; }
.btn.ghost { background: transparent; color: var(--color-brand); }
.btn.accent { background: var(--color-accent-strong); border-color: var(--color-accent-strong); }
.btn.sm { padding: 5px 10px; font-size: 13px; }
.btn.danger { background: transparent; color: var(--color-danger); border-color: var(--color-danger); }
.section-title { font-size: 13px; text-transform: uppercase; letter-spacing: .05em; color: var(--color-ink-muted); margin: 26px 0 10px; }

/* ---- shared module components (used by src/modules/*.js via window.UI) ---- */
.mod-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 14px; }
.mod-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* form controls */
.inp { width: 100%; padding: 8px 10px; border: 1px solid var(--color-line-strong); border-radius: var(--radius-sm); font: inherit; font-size: 14px; background: #fff; color: var(--color-ink); }
textarea.inp { min-height: 84px; resize: vertical; }
.inp:focus { outline: 2px solid var(--color-focus); outline-offset: 1px; border-color: var(--color-accent); }
.field { display: block; margin-bottom: 14px; }
.field-label { display: block; font-size: 13px; font-weight: 600; color: var(--color-ink-2); margin-bottom: 5px; }
.field-hint { display: block; font-size: 12px; color: var(--color-ink-muted); margin-top: 4px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 16px; }
.form-grid .full { grid-column: 1 / -1; }

/* extra status pills for modules (risk, evidence, poam) */
.pill.open     { background: var(--color-warn-soft);    color: var(--color-warn); }
.pill.progress { background: var(--color-accent-soft);  color: var(--color-accent-strong); }
.pill.done,
.pill.approved { background: var(--color-success-soft); color: var(--color-success); }
.pill.high,
.pill.critical { background: var(--color-danger-soft);  color: var(--color-danger); }
.pill.medium   { background: var(--color-warn-soft);    color: var(--color-warn); }
.pill.low      { background: var(--color-success-soft); color: var(--color-success); }
.pill.review   { background: var(--color-bg-soft);      color: var(--color-ink-muted); }

/* tabs */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--color-line); margin-bottom: 16px; }
.tab { padding: 9px 14px; cursor: pointer; border-bottom: 2px solid transparent; color: var(--color-ink-muted); font-size: 14px; }
.tab.active { color: var(--color-brand); border-bottom-color: var(--color-accent); font-weight: 600; }

/* toast */
#ui-toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--color-brand-deep); color: #fff; padding: 10px 18px; border-radius: var(--radius); box-shadow: var(--shadow); opacity: 0; pointer-events: none; transition: opacity .15s, transform .15s; z-index: 50; }
#ui-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* link tags (chips showing linked control ids) */
.chip { display: inline-block; padding: 2px 8px; border-radius: 99px; font-size: 12px; background: var(--color-bg-soft); color: var(--color-brand); margin: 2px 3px 2px 0; border: 1px solid var(--color-line); }
.chip.suggest { background: #fff; border-style: dashed; color: var(--color-ink-2); }

/* ===== Journey home (guided flow) ===== */
.journey-hero { display: grid; grid-template-columns: 1.4fr 1fr; gap: 18px; margin-bottom: 22px; }
@media (max-width: 980px){ .journey-hero { grid-template-columns: 1fr; } }
.journey-hero .hero-card { background: linear-gradient(135deg, var(--color-brand-deep), var(--color-brand)); color:#fff; border-radius: var(--radius); padding: 24px; }
.journey-hero .hero-card h2 { margin: 0 0 6px; font-size: 24px; }
.journey-hero .hero-card p { margin: 0; color: #c3d2e6; max-width: 52ch; }
.journey-next { margin-top: 16px; display:inline-flex; gap:10px; align-items:center; background: var(--color-accent); color: var(--color-brand-deep); padding: 10px 16px; border-radius: var(--radius-sm); font-weight: 700; cursor:pointer; border:none; font-size:14px; }

.steps { display: grid; gap: 12px; }
.step { display: grid; grid-template-columns: 44px 1fr auto; gap: 14px; align-items: center; background: var(--color-bg-panel); border: 1px solid var(--color-line); border-radius: var(--radius); padding: 16px 18px; box-shadow: var(--shadow); }
.step.is-next { border-color: var(--color-accent); box-shadow: 0 0 0 2px var(--color-accent-soft), var(--shadow); }
.step.is-done { opacity: .82; }
.step .num { width: 40px; height: 40px; border-radius: 50%; display:grid; place-items:center; font-weight: 800; font-size: 16px; background: var(--color-bg-soft); color: var(--color-ink-muted); }
.step.is-done .num { background: var(--color-success-soft); color: var(--color-success); }
.step.is-next .num { background: var(--color-accent); color: #fff; }
.step .s-body h3 { margin: 0 0 3px; font-size: 16px; }
.step .s-body p { margin: 0; font-size: 13.5px; color: var(--color-ink-muted); }
.step .s-body .bar { max-width: 320px; margin-top: 8px; }
.step .s-side { text-align: right; display:flex; flex-direction:column; gap:6px; align-items:flex-end; }

/* ===== Controls & Objectives — denser, more visual ===== */
.ctrl-toolbar { display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-bottom:16px; }
.ctrl-toolbar .inp { max-width: 240px; }
.fam-block { background: var(--color-bg-panel); border: 1px solid var(--color-line); border-radius: var(--radius); box-shadow: var(--shadow); margin-bottom: 14px; overflow: hidden; }
.fam-head { display:flex; align-items:center; gap:14px; padding: 14px 18px; cursor:pointer; user-select:none; }
.fam-head:hover { background: var(--color-bg-soft); }
.fam-head .fam-id { width:38px; height:38px; border-radius:9px; background:var(--color-brand); color:#fff; display:grid; place-items:center; font-weight:800; font-size:14px; flex:none; }
.fam-head .fam-name { font-weight:700; }
.fam-head .fam-meta { margin-left:auto; display:flex; align-items:center; gap:16px; }
.fam-head .fam-bar { width:160px; }
.fam-head .caret { transition: transform .15s; color: var(--color-ink-muted); }
.fam-block.open .caret { transform: rotate(90deg); }
.fam-rows { display:none; border-top:1px solid var(--color-line); }
.fam-block.open .fam-rows { display:block; }
.cgrid { display:grid; grid-template-columns: 120px 1fr 150px 110px; gap:12px; align-items:center; padding: 11px 18px; border-bottom:1px solid var(--color-line); cursor:pointer; }
.cgrid:last-child { border-bottom:none; }
.cgrid:hover { background: var(--color-accent-soft); }
.cgrid .cid { font-weight:700; font-size:13px; }
.cgrid .cname { font-weight:600; font-size:14px; }
.cgrid .cdesc { color:var(--color-ink-muted); font-size:12.5px; }
.cov { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--color-ink-muted); }
.cov .bar { width:80px; }

/* evidence integration */
.ev-line { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:8px 10px; border:1px solid var(--color-line); border-radius:var(--radius-sm); margin-bottom:6px; font-size:13.5px; }
.ev-line .ev-t { font-weight:600; }
.add-ev-form { background: var(--color-bg-soft); border-radius: var(--radius-sm); padding: 12px; margin-top: 8px; }

/* controls overview row tweaks */
.cgrid { grid-template-columns: 132px 1fr 120px 190px; }
.cov { justify-content:flex-end; }
.cov-n { white-space:nowrap; }
.open-btn { white-space:nowrap; margin-left:4px; }
.form-hint { font-size:12px; color: var(--color-accent-strong); margin-top:5px; font-weight:600; }

/* ===== single-control full-page workspace ===== */
.ctrl-page .ctrl-topbar { display:flex; align-items:center; gap:16px; margin-bottom:14px; }
.ctrl-page .ctrl-topbar .muted { margin-left:auto; font-size:13px; }
.ctrl-page-head h2 { margin:0 0 2px; font-size:23px; }
.ctrl-cols { display:grid; grid-template-columns: minmax(0,1fr) 330px; gap:22px; align-items:start; margin-top:16px; }
@media (max-width: 960px){ .ctrl-cols { grid-template-columns:1fr; } }
.ctrl-side { display:flex; flex-direction:column; gap:14px; position:sticky; top:16px; }
.ctrl-side .card { padding:14px 16px; }
.ctrl-main .obj { background:var(--color-bg-panel); }
.accent-card { background: var(--color-accent-soft); border-color: var(--color-accent); }
.ctrl-foot { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:26px; padding-top:18px; border-top:1px solid var(--color-line); }
.continue-cta { font-size:15px; padding:12px 24px; box-shadow: 0 4px 14px rgba(46,184,154,.28); }
/* plain ⟷ NIST segmented toggle (swaps in place; no page growth) */
.lang-toggle { display:inline-flex; background:var(--color-bg-soft); border:1px solid var(--color-line); border-radius:9px; padding:3px; margin-bottom:14px; gap:2px; }
.lang-toggle .seg { border:none; background:transparent; padding:7px 16px; border-radius:6px; cursor:pointer; font:inherit; font-size:13.5px; color:var(--color-ink-muted); }
.lang-toggle .seg.active { background:#fff; color:var(--color-brand); font-weight:600; box-shadow:var(--shadow); }
.methods { display:flex; flex-direction:column; gap:9px; }
.methods > div { display:grid; grid-template-columns:80px 1fr; gap:10px; font-size:12.5px; align-items:start; line-height:1.5; }
.methods b { color:var(--color-brand); }
.methods span { color:var(--color-ink-2); }

/* tasks on the control page */
.task-row { display:flex; align-items:flex-start; gap:8px; padding:7px 0; border-bottom:1px solid var(--color-line); }
.task-row:last-of-type { border-bottom:none; }
.task-row .task-body { flex:1; font-size:13.5px; }
.task-done-txt { text-decoration:line-through; color:var(--color-ink-muted); }
.task-del { border:none; background:transparent; color:var(--color-ink-muted); cursor:pointer; font-size:13px; line-height:1; padding:2px 4px; }
.task-del:hover { color:var(--color-danger); }
.task-done { margin-top:3px; accent-color: var(--color-accent-strong); }

/* form detail popup metadata */
.form-meta { display:grid; grid-template-columns:120px 1fr; gap:8px 12px; font-size:13.5px; margin:10px 0; }
.form-meta .k { color:var(--color-ink-muted); font-size:12.5px; }

/* pagination bar */
.pager { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:12px; flex-wrap:wrap; }
.pager-ctrl { display:flex; align-items:center; gap:10px; }
.pager-ctrl .inp { width:auto; display:inline-block; padding:4px 8px; }
.pager-ctrl .btn[disabled] { opacity:.45; cursor:default; }

/* gap assessment answer buttons */
.gap-ans { display:flex; gap:6px; flex-wrap:wrap; }
.gapbtn { border:1px solid var(--color-line-strong); background:#fff; padding:6px 16px; border-radius:var(--radius-sm); cursor:pointer; font:inherit; font-size:13px; color:var(--color-ink-2); }
.gapbtn:hover { border-color:var(--color-accent); }
.gapbtn.on.met     { background:var(--color-success-soft); border-color:var(--color-success); color:var(--color-success); font-weight:700; }
.gapbtn.on.partial { background:var(--color-warn-soft);    border-color:var(--color-warn);    color:var(--color-warn);    font-weight:700; }
.gapbtn.on.notmet  { background:var(--color-danger-soft);  border-color:var(--color-danger);  color:var(--color-danger);  font-weight:700; }
.gapbtn.on.na      { background:var(--color-bg-soft);      border-color:var(--color-line-strong); color:var(--color-ink-muted); font-weight:700; }

/* caution banner (e.g. unmapped docs) */
.caution-banner { display:flex; align-items:center; justify-content:space-between; gap:12px; background:var(--color-warn-soft); border:1px solid var(--color-warn); color:var(--color-warn); border-radius:var(--radius); padding:11px 16px; margin-bottom:16px; font-size:14px; }
.caution-banner b { color:var(--color-warn); }

/* ===== Guardient overlay ===== */
.g-card { background: linear-gradient(135deg, var(--color-brand-deep), var(--color-brand)); color:#eaf2fb; border-color: var(--color-brand-deep); }
.g-card .g-head { font-weight:700; color:#fff; display:flex; align-items:center; gap:8px; font-size:14px; }
.g-sub { color:#aebfd4; font-size:12.5px; }
.g-obj { background: rgba(255,255,255,.06); border-radius: var(--radius-sm); padding:9px 11px; margin-bottom:7px; }
.g-obj b { color:#fff; }
.g-badge { display:inline-block; background: var(--color-brand); color:#fff; border-radius:99px; font-size:11px; font-weight:700; padding:2px 9px; white-space:nowrap; vertical-align:middle; }
.g-pill { font-size:11px; font-weight:700; border-radius:99px; padding:1px 8px; white-space:nowrap; flex:none; }
.g-pill-usx { background: var(--color-accent); color: var(--color-brand-deep); }
.g-pill-shared { background:#9fb3cc; color: var(--color-brand-deep); }
.g-pill-client { background: rgba(255,255,255,.15); color:#eaf2fb; }
.g-hint { font-size:12px; color: var(--color-accent-strong); margin-top:6px; font-weight:600; }

/* ===== guided tour card ===== */
#tour-card { position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%); width: min(560px, 92vw); background: var(--color-bg-panel); border: 1px solid var(--color-line); border-top: 3px solid var(--color-accent); border-radius: var(--radius); box-shadow: 0 12px 40px rgba(15,34,56,.35); padding: 16px 20px 18px; z-index: 100; }
#tour-card h3 { margin: 8px 0 6px; font-size: 17px; color: var(--color-brand); }
#tour-card p { margin: 0 0 14px; font-size: 14px; line-height: 1.55; }
.tour-top { display:flex; justify-content:space-between; align-items:center; }
.tour-step { font-size:12px; text-transform:uppercase; letter-spacing:.05em; color:var(--color-ink-muted); font-weight:600; }
.tour-x { border:none; background:transparent; cursor:pointer; color:var(--color-ink-muted); font-size:14px; }
.tour-btns { display:flex; align-items:center; gap:8px; }

/* ===== custom neon-battery scrollbars ===== */
* { scrollbar-width: thin; scrollbar-color: var(--color-accent) var(--color-bg-soft); }
::-webkit-scrollbar { width: 12px; height: 12px; }
::-webkit-scrollbar-track { background: var(--color-bg-soft); border-radius: 10px; }
::-webkit-scrollbar-thumb {
  border-radius: 10px;
  border: 3px solid var(--color-bg-soft);
  background: linear-gradient(180deg, #3fd9b6 0%, #2eb89a 55%, #22a084 100%);
  box-shadow: inset 0 0 6px rgba(46,184,154,.65);
}
::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #54e6c6, #2bc6a4); box-shadow: inset 0 0 8px rgba(46,184,154,.9); }
::-webkit-scrollbar-corner { background: transparent; }
/* dark sidebar variant */
.sidebar::-webkit-scrollbar-track { background: transparent; }
.sidebar::-webkit-scrollbar-thumb { border-color: var(--color-brand-deep); box-shadow: inset 0 0 7px rgba(63,217,182,.55); }

/* ===== Learn CMMC readability ===== */
.learn-wrap { max-width: 920px; }
.learn-layout { display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: 22px; align-items: start; margin-top: 8px; }
@media (max-width: 820px) { .learn-layout { grid-template-columns: 1fr; } }
.learn-nav { display: flex; flex-direction: column; gap: 2px; position: sticky; top: 16px; }
.learn-nav a { padding: 9px 12px; border-radius: var(--radius-sm); cursor: pointer; font-size: 13.5px; color: var(--color-ink-2); border-left: 3px solid transparent; }
.learn-nav a:hover { background: var(--color-bg-soft); }
.learn-nav a.active { background: var(--color-accent-soft); color: var(--color-brand); font-weight: 600; border-left-color: var(--color-accent); }
.learn-content .learn-wrap { max-width: none; }
.learn-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--color-line); }
.learn-card { background:var(--color-bg-panel); border:1px solid var(--color-line); border-radius:var(--radius); box-shadow:var(--shadow); padding:20px 22px; margin-bottom:14px; }
.learn-card h3 { margin:0 0 8px; font-size:18px; color:var(--color-brand); display:flex; align-items:center; gap:9px; }
.learn-card h3 .lc-ico { width:26px;height:26px;border-radius:7px;background:var(--color-accent-soft);color:var(--color-accent-strong);display:grid;place-items:center;font-size:14px;flex:none; }
.learn-card p { margin:0 0 10px; line-height:1.6; }
.learn-card p:last-child { margin-bottom:0; }
.learn-steps { counter-reset: ls; list-style:none; margin:0; padding:0; }
.learn-steps li { position:relative; padding:8px 0 8px 40px; border-bottom:1px dashed var(--color-line); }
.learn-steps li:last-child { border-bottom:none; }
.learn-steps li::before { counter-increment: ls; content: counter(ls); position:absolute; left:0; top:6px; width:26px;height:26px;border-radius:50%; background:var(--color-brand); color:#fff; display:grid; place-items:center; font-weight:700; font-size:13px; }
.gloss-term { padding:11px 0; border-bottom:1px solid var(--color-line); }
.gloss-term:last-child { border-bottom:none; }
.gloss-term b { color:var(--color-brand); }
.gloss-term .abbr { display:inline-block; min-width:0; }

/* ----- In-tool form fill (forms.js + form-fill.js) ----- */
/* fill page uses the open width on wide screens; falls back to full width below */
.fill-page { max-width: 1320px; }
.fill-sec { margin-bottom: 16px; }
.fill-header { border-left: 3px solid var(--color-accent); }
.fill-guide { background: var(--color-bg-soft, #f6f8fa); border:1px solid var(--color-line); margin-bottom:16px; font-size:14px; }
.fill-guide p { line-height:1.5; }
/* info-block fields pack responsively so single fields never get over-wide */
.fill-page .form-grid { grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 0 18px; }
.fill-page .form-grid .fill-wide { grid-column: 1 / -1; }
/* fixed layout = columns share the page width instead of overflowing (no side-scroll) */
.fill-table-wrap { overflow-x:auto; }
.fill-grid { width:100%; border-collapse:collapse; font-size:13px; table-layout:fixed; }
.fill-grid th { text-align:left; font-size:12px; color:var(--color-ink-muted); padding:5px 6px; white-space:normal; overflow-wrap:anywhere; line-height:1.25; border-bottom:1px solid var(--color-line); vertical-align:bottom; }
.fill-grid td { padding:3px 4px; vertical-align:top; }
.fill-grid td .inp { overflow-wrap:anywhere; }
.inp.sm { padding:5px 7px; font-size:13px; }
.row-del { color:var(--color-ink-muted); padding:3px 7px; }
.fill-foot { position:sticky; bottom:0; display:flex; align-items:center; gap:10px; padding:14px 0 4px; margin-top:8px; background:linear-gradient(transparent, var(--color-bg) 30%); }
.chk-cell { text-align:center; vertical-align:middle; }
.fill-chk { width:17px; height:17px; accent-color: var(--color-accent); cursor:pointer; }
.fill-bool { display:flex; align-items:center; margin-bottom:14px; }
.fill-bool input { width:17px; height:17px; accent-color: var(--color-accent); cursor:pointer; }

/* ----- CMMC Variables registry (registry.js) + control-page parameter card ----- */
.reg-row { display:flex; gap:16px; justify-content:space-between; align-items:flex-start; padding:12px 0; border-top:1px solid var(--color-line); }
.reg-row:first-of-type { border-top:none; }
.reg-row-main { min-width:0; flex:1; }
.reg-label { font-weight:600; font-size:14px; }
.reg-usage { font-size:12px; color:var(--color-ink-muted); margin-top:6px; display:flex; flex-wrap:wrap; gap:4px; align-items:center; }
.reg-row-edit { flex:none; display:flex; flex-direction:column; align-items:flex-end; gap:4px; min-width:175px; }
.reg-exp { font-size:11.5px; max-width:240px; text-align:right; }
.reg-bool { display:inline-flex; align-items:center; gap:8px; cursor:pointer; }
.reg-bool input { width:17px; height:17px; accent-color:var(--color-accent); cursor:pointer; }
.reg-num { display:inline-flex; align-items:center; gap:6px; }
.cp-param-row { display:flex; justify-content:space-between; align-items:center; gap:10px; padding:8px 0; border-top:1px solid var(--color-line); }
.cp-param-row:first-of-type { border-top:none; }
@media (max-width:720px){ .reg-row{ flex-direction:column; } .reg-row-edit{ align-items:flex-start; min-width:0; } .reg-exp{ text-align:left; } }

/* ----- No-CUI banner (shown on every page, incl. all submission/upload pages) ----- */
.cui-banner { background:#fff4e5; color:#8a4b00; border-bottom:1px solid #f0b46a; padding:9px 20px; font-size:13px; line-height:1.45; text-align:center; }
.cui-banner b { color:#a85800; }
@media (max-width:700px){ .cui-banner{ font-size:12px; padding:8px 12px; } }

/* ----- Sign-in screen (API mode) ----- */
.login-overlay { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 20px;
  background: linear-gradient(135deg, var(--color-brand-deep), var(--color-brand)); }
.login-card { width: 100%; max-width: 380px; background: var(--color-surface); border-radius: var(--radius); box-shadow: 0 10px 40px rgba(15,34,56,.35); padding: 28px 26px; display: flex; flex-direction: column; gap: 12px; }
.login-brand { display: flex; align-items: center; gap: 11px; }
.login-brand .mark { width: 38px; height: 38px; border-radius: 9px; background: var(--color-brand); color: #fff; display: grid; place-items: center; font-weight: 700; font-size: 19px; }
.login-brand-txt b { display: block; color: var(--color-ink); font-size: 16px; line-height: 1.1; }
.login-brand-txt small { color: var(--color-ink-muted); font-size: 12px; }
.login-card h2 { margin: 6px 0 2px; font-size: 18px; color: var(--color-ink); }
.login-field { display: flex; flex-direction: column; gap: 5px; font-size: 13px; color: var(--color-ink-2); }
.login-field input { padding: 10px 11px; border: 1px solid var(--color-line-strong); border-radius: var(--radius-sm); font-size: 14px; }
.login-field input:focus { outline: 2px solid var(--color-focus); outline-offset: 1px; border-color: var(--color-focus); }
.login-remember { display: flex; align-items: center; gap: 7px; font-size: 13px; color: var(--color-ink-muted); }
.login-error { background: var(--color-danger-soft); color: var(--color-danger); border-radius: var(--radius-sm); padding: 8px 11px; font-size: 13px; }
.login-submit { width: 100%; justify-content: center; padding: 11px; font-size: 15px; margin-top: 2px; }
.login-submit[disabled] { opacity: .65; cursor: default; }
.login-note { font-size: 11.5px; color: var(--color-ink-muted); line-height: 1.5; margin-top: 4px; }
.user-chip { display: inline-block; font-size: 13px; color: var(--color-ink-2); background: var(--color-bg-soft); border: 1px solid var(--color-line); border-radius: 999px; padding: 4px 10px; max-width: 180px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; vertical-align: middle; }

/* ----- Administration (RBAC management) ----- */
.admin-tabs { display: flex; gap: 6px; margin: 4px 0 14px; border-bottom: 1px solid var(--color-line); }
.admin-tabs .tab { background: none; border: none; border-bottom: 2px solid transparent; padding: 8px 12px; font-size: 14px; color: var(--color-ink-muted); cursor: pointer; }
.admin-tabs .tab.active { color: var(--color-brand); border-bottom-color: var(--color-brand); font-weight: 600; }
.admin-form { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.admin-form input, .admin-form select { padding: 8px 10px; border: 1px solid var(--color-line-strong); border-radius: var(--radius-sm); font-size: 14px; }
.admin-form input[type=email], .admin-form input[type=text] { min-width: 210px; }
.admin-table { width: 100%; border-collapse: collapse; margin-top: 14px; font-size: 14px; }
.admin-table th { text-align: left; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--color-ink-muted); padding: 8px 10px; border-bottom: 1px solid var(--color-line); }
.admin-table td { padding: 9px 10px; border-bottom: 1px solid var(--color-line); vertical-align: middle; }
.admin-actions { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.pill { display: inline-block; font-size: 12px; padding: 2px 8px; border-radius: 999px; background: var(--color-bg-soft); border: 1px solid var(--color-line); color: var(--color-ink-2); }
.pill-admin { background: var(--color-accent-soft); border-color: var(--color-accent); color: var(--color-accent-strong); }
.pill-ok { background: var(--color-success-soft); border-color: var(--color-success); color: var(--color-success); }
.pill-off { background: var(--color-bg-soft); color: var(--color-ink-muted); }
.pill-warn { background: var(--color-warn-soft); border-color: var(--color-warn); color: var(--color-warn); }
.secret-card { border-left: 3px solid var(--color-accent); }
.secret { background: var(--color-bg-soft); padding: 3px 8px; border-radius: var(--radius-sm); font-family: ui-monospace, Consolas, monospace; font-size: 14px; }
.access-panel { border-left: 3px solid var(--color-brand); }
.card.error { border-left: 3px solid var(--color-danger); color: var(--color-danger); }
.muted { color: var(--color-ink-muted); }

/* ----- Per-objective attestation (Controls page) ----- */
.obj-attest .obj-count { float: right; font-size: 12px; font-weight: 600; padding: 2px 9px; border-radius: 999px; background: var(--color-warn-soft); color: var(--color-warn); border: 1px solid var(--color-warn); }
.obj-attest .obj-count.done { background: var(--color-success-soft); color: var(--color-success); border-color: var(--color-success); }
.obj-att { border: 1px solid var(--color-line); border-left: 3px solid var(--color-line-strong); border-radius: var(--radius-sm); padding: 10px 12px; margin-bottom: 10px; background: var(--color-bg-soft); }
.obj-att.attested { border-left-color: var(--color-success); background: var(--color-surface); }
.obj-att-top { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
.obj-att-top .oid { flex: 0 0 auto; font-weight: 700; font-size: 13px; background: var(--color-brand); color: #fff; border-radius: var(--radius-sm); padding: 2px 8px; }
.obj-att-text { flex: 1 1 auto; min-width: 0; font-size: 13.5px; }
.obj-att-text .obj-nist { font-size: 11.5px; margin-top: 3px; }
.obj-att-top .obj-status { flex: 0 0 auto; width: auto; min-width: 96px; }
.obj-att-text > div:first-child { overflow-wrap: anywhere; }
.obj-att .obj-statement { width: 100%; resize: vertical; font-family: inherit; font-size: 13.5px; }
/* SSP per-objective implementation detail */
.ssp-ctrl { margin: 12px 0 18px; }
.ssp-ctrl h5 { margin: 0 0 2px; font-size: 14px; }
.ssp-todo { color: var(--color-warn); }

/* ----- Evidence files card (Controls page, api mode) ----- */
.files-card .cui-note { background:#fff4e5; color:#8a4b00; border:1px solid #f0b46a; border-radius: var(--radius-sm); padding:7px 10px; font-size:12px; line-height:1.45; margin-bottom:10px; }
.files-up { display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.files-up input[type=file] { flex:1 1 200px; min-width:0; }
.files-up .cui-check { display:flex; align-items:center; gap:6px; font-size:12.5px; color:var(--color-ink-2); }
.files-list { margin-top:12px; }
.file-row { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid var(--color-line); }
.file-row:last-child { border-bottom:0; }
.file-meta { flex:1 1 auto; min-width:0; display:flex; flex-direction:column; }
.file-name { font-size:13.5px; font-weight:600; overflow-wrap:anywhere; color:var(--color-brand); }
