/* workbench.css — Governance Workbench UI.
   Layers on top of index.css (reuses its design tokens / CSS variables). */

* { box-sizing: border-box; }
body {
  margin: 0;
  background:
    radial-gradient(1200px 600px at 80% -10%, var(--accent-primary-alpha-10), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, var(--accent-secondary-alpha-10), transparent 55%),
    var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-body);
  min-height: 100vh;
  padding-top: 70px; /* clears the fixed site header */
}
a { color: var(--accent-primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---------------- Header ----------------
   The workbench reuses the main site header (#main-header / .navbar / .nav-links
   / .theme-toggle from index.css). Only the workbench-specific buttons are
   styled here. */
.wb-ghost-btn, .wb-primary-btn { font-family: var(--font-body); cursor: pointer; border-radius: var(--radius-pill); transition: all var(--transition-fast); }
.wb-ghost-btn { padding: 0.5rem 1rem; border: 1px solid var(--border-color); background: var(--white-alpha-03); color: var(--text-secondary); font-weight: 600; font-size: 0.85rem; }
.wb-ghost-btn:hover { background: var(--bg-card-hover); color: var(--text-primary); text-decoration: none; }
.wb-primary-btn { padding: 0.7rem 1.4rem; border: none; background: var(--accent-primary); color: var(--color-white); font-weight: 700; font-size: 0.92rem; box-shadow: var(--shadow-primary-button); }
.wb-primary-btn:hover { box-shadow: var(--shadow-primary-button-hover); transform: translateY(-1px); }
.wb-primary-btn:disabled { opacity: 0.5; cursor: not-allowed; box-shadow: none; }

/* ---------------- Shell layout ---------------- */
/* width:100% keeps the shell a fixed width regardless of panel content.
   body is a flex column, so the `margin: … auto` would otherwise shrink the
   shell to its content (narrow panels rendered narrower and re-centered). */
.wb-shell { display: grid; grid-template-columns: 320px 1fr; gap: 1.5rem; width: 100%; max-width: 1320px; margin: 1.5rem auto; padding: 0 1.5rem; align-items: start; }
.glass { background: var(--bg-card); backdrop-filter: var(--glass-blur); border: 1px solid var(--border-color); border-radius: var(--radius-md); }

/* ---------------- Left rail ---------------- */
.wb-rail { position: sticky; top: 84px; display: flex; flex-direction: column; gap: 1rem; }
.wb-score-card { padding: 1.25rem; display: flex; align-items: center; gap: 1.1rem; }
.wb-gauge { position: relative; width: 96px; height: 96px; flex-shrink: 0; }
.wb-gauge svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.wb-gauge-track { fill: none; stroke: var(--white-alpha-03); stroke-width: 9; }
.wb-gauge-fill { fill: none; stroke: var(--text-muted); stroke-width: 9; stroke-linecap: round; transition: stroke-dashoffset var(--transition-slow), stroke var(--transition-normal); }
.wb-gauge-fill.g-good { stroke: var(--color-success); }
.wb-gauge-fill.g-mid { stroke: var(--color-warning); }
.wb-gauge-fill.g-bad { stroke: var(--color-danger); }
.wb-gauge-label { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.wb-gauge-label strong { font-family: var(--font-heading); font-size: 1.7rem; line-height: 1; }
.wb-gauge-label small { font-size: 0.6rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.wb-score-meta { display: flex; flex-direction: column; gap: 0.4rem; }
.wb-band { font-family: var(--font-heading); font-weight: 700; font-size: 1.05rem; }

.wb-tier-chip { display: inline-block; font-size: 0.72rem; font-weight: 700; padding: 0.2rem 0.6rem; border-radius: var(--radius-pill); background: var(--white-alpha-03); color: var(--text-secondary); width: fit-content; }
.tier-prohibited { background: var(--color-danger-bg); color: var(--color-danger); }
.tier-high { background: var(--color-danger-bg); color: var(--color-danger); }
.tier-limited { background: var(--color-warning-bg); color: var(--color-warning); }
.tier-minimal { background: var(--color-success-bg); color: var(--color-success); }

.wb-steps { display: flex; flex-direction: column; gap: 0.4rem; }
.wb-step { display: flex; align-items: center; gap: 0.75rem; text-align: left; padding: 0.7rem 0.8rem; border-radius: var(--radius-sm); border: 1px solid transparent; background: transparent; color: var(--text-secondary); cursor: pointer; transition: all var(--transition-fast); font-family: var(--font-body); }
.wb-step:hover { background: var(--white-alpha-03); }
.wb-step.active { background: var(--accent-primary-alpha-10); border-color: var(--accent-primary-alpha-25); color: var(--text-primary); }
.wb-step-num { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; font-weight: 700; font-size: 0.85rem; background: var(--white-alpha-03); color: var(--text-muted); }
.wb-step.active .wb-step-num { background: var(--accent-primary); color: var(--color-white); }
.wb-step-text { display: flex; flex-direction: column; flex: 1; }
.wb-step-text strong { font-size: 0.92rem; font-family: var(--font-heading); font-weight: 600; }
.wb-step-text small { font-size: 0.74rem; color: var(--text-muted); }
.wb-step-flag { width: 20px; height: 20px; border-radius: 50%; display: grid; place-items: center; font-size: 0.7rem; font-weight: 800; }
.wb-flag-pass { background: var(--color-success-bg); color: var(--color-success); }
.wb-flag-warn { background: var(--color-warning-bg); color: var(--color-warning); }
.wb-flag-fail { background: var(--color-danger-bg); color: var(--color-danger); }

.wb-privacy { padding: 1rem; font-size: 0.8rem; }
.wb-privacy strong { display: block; margin-bottom: 0.3rem; }
.wb-privacy p { margin: 0; color: var(--text-muted); line-height: 1.5; }

/* ---------------- Main panels ---------------- */
.wb-main { min-width: 0; }
.wb-panel { display: none; animation: wbfade 0.25s ease; }
.wb-panel.active { display: block; }
@keyframes wbfade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.wb-panel-head { margin-bottom: 1.5rem; }
.wb-panel-head h1 { font-family: var(--font-heading); font-size: 1.85rem; margin: 0 0 0.4rem; }
.wb-panel-head p { color: var(--text-secondary); margin: 0; max-width: 70ch; line-height: 1.6; }

/* ---------------- Forms ---------------- */
.wb-form { display: flex; flex-direction: column; gap: 1rem; }
.wb-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.wb-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1rem; }
.wb-field { display: flex; flex-direction: column; gap: 0.35rem; font-size: 0.85rem; font-weight: 600; color: var(--text-secondary); }
.wb-field small { font-weight: 400; color: var(--text-muted); }
.wb-field input, .wb-field select, .wb-field textarea, .wb-doc-input {
  font-family: var(--font-body); font-size: 0.92rem; padding: 0.65rem 0.8rem;
  background: var(--bg-secondary); color: var(--text-primary);
  border: 1px solid var(--border-color); border-radius: var(--radius-sm); transition: border var(--transition-fast), box-shadow var(--transition-fast);
}
.wb-field input:focus, .wb-field select:focus, .wb-field textarea:focus, .wb-doc-input:focus {
  outline: none; border-color: var(--accent-primary); box-shadow: var(--shadow-select-focus);
}
.wb-fieldset { border: 1px solid var(--border-color); border-radius: var(--radius-sm); padding: 1rem; }
.wb-fieldset legend { font-size: 0.85rem; font-weight: 600; padding: 0 0.5rem; color: var(--text-secondary); }
.wb-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem; }
.wb-checks label { display: flex; align-items: center; gap: 0.5rem; font-size: 0.85rem; color: var(--text-secondary); font-weight: 400; }

/* ---------------- Upload ---------------- */
.wb-upload { display: flex; align-items: center; gap: 0.8rem; padding: 1rem; border: 1.5px dashed var(--border-color); border-radius: var(--radius-md); background: var(--white-alpha-02); flex-wrap: wrap; }
.wb-upload-btn { padding: 0.6rem 1.1rem; border: 1px solid var(--accent-primary-alpha-35); background: var(--accent-primary-alpha-10); color: var(--accent-primary); font-weight: 700; border-radius: var(--radius-sm); cursor: pointer; font-family: var(--font-body); }
.wb-upload-btn:hover { background: var(--accent-primary-alpha-15); }
.wb-upload-hint, .wb-filename { font-size: 0.82rem; color: var(--text-muted); }
.wb-filename { font-weight: 600; color: var(--text-secondary); }
.wb-upload-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: 1rem; flex-wrap: wrap; }
.wb-config { margin-top: 1.2rem; display: flex; flex-direction: column; gap: 1rem; }
.wb-doc-input { width: 100%; resize: vertical; line-height: 1.5; }

/* ---------------- Results ---------------- */
.wb-result { margin-top: 1.5rem; display: flex; flex-direction: column; gap: 1.1rem; }
.wb-banner { display: flex; align-items: center; gap: 0.6rem; padding: 0.85rem 1.1rem; border-radius: var(--radius-sm); font-weight: 600; font-size: 0.92rem; }
.wb-banner span { font-size: 1.1rem; }
.wb-banner-pass { background: var(--color-success-bg); color: var(--color-success); border: 1px solid var(--color-success-alpha-30); }
.wb-banner-fail { background: var(--color-danger-bg); color: var(--color-danger); border: 1px solid var(--color-danger-alpha-30); }

.wb-metric-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 0.8rem; }
.wb-metric { display: flex; flex-direction: column; gap: 0.2rem; padding: 0.9rem 1rem; border-radius: var(--radius-sm); background: var(--bg-card); border: 1px solid var(--border-color); border-left-width: 3px; }
.wb-metric small { font-size: 0.74rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; }
.wb-metric strong { font-family: var(--font-heading); font-size: 1.35rem; }
.wb-metric-hint { font-size: 0.72rem; color: var(--text-muted); }
.wb-metric-pass { border-left-color: var(--color-success); }
.wb-metric-warn { border-left-color: var(--color-warning); }
.wb-metric-fail { border-left-color: var(--color-danger); }
.wb-metric-muted { border-left-color: var(--text-muted); }

.wb-table { width: 100%; border-collapse: collapse; font-size: 0.88rem; overflow: hidden; border-radius: var(--radius-sm); }
.wb-table th, .wb-table td { padding: 0.6rem 0.8rem; text-align: left; border-bottom: 1px solid var(--border-color); }
.wb-table th { background: var(--white-alpha-03); font-weight: 600; color: var(--text-secondary); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.03em; }
.wb-ref { font-size: 0.68rem; background: var(--accent-primary-alpha-15); color: var(--accent-primary); padding: 0.05rem 0.35rem; border-radius: var(--radius-pill); }
.wb-sev { font-size: 0.74rem; font-weight: 700; padding: 0.15rem 0.55rem; border-radius: var(--radius-pill); text-transform: capitalize; }
.wb-sev-significant, .wb-sev-critical { background: var(--color-danger-bg); color: var(--color-danger); }
.wb-sev-moderate, .wb-sev-high { background: var(--color-warning-bg); color: var(--color-warning); }
.wb-sev-stable, .wb-sev-low { background: var(--color-success-bg); color: var(--color-success); }
.wb-sev-medium { background: var(--color-info-bg); color: var(--color-info); }

.wb-flags { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.45rem; }
.wb-flags li { padding: 0.6rem 0.9rem; background: var(--color-warning-bg); border-left: 3px solid var(--color-warning); border-radius: var(--radius-sm); font-size: 0.86rem; color: var(--text-primary); }

/* Charts */
.wb-chart { padding: 1rem 1.1rem; background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-sm); }
.wb-chart-title { font-size: 0.8rem; font-weight: 600; color: var(--text-secondary); margin-bottom: 0.8rem; text-transform: uppercase; letter-spacing: 0.04em; }
.wb-bar-row { display: grid; grid-template-columns: 120px 1fr 56px; align-items: center; gap: 0.7rem; margin-bottom: 0.55rem; font-size: 0.84rem; }
.wb-bar-label { color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wb-bar-track { height: 14px; background: var(--white-alpha-03); border-radius: var(--radius-pill); overflow: hidden; }
.wb-bar-fill { display: block; height: 100%; background: linear-gradient(90deg, var(--accent-primary), var(--accent-secondary)); border-radius: var(--radius-pill); transition: width var(--transition-slow); }
.wb-bar-val { text-align: right; font-weight: 600; color: var(--text-primary); }

/* Verdict (intake) */
.wb-verdict { display: flex; gap: 1.2rem; padding: 1.4rem; border-radius: var(--radius-md); border: 1px solid var(--border-color); background: var(--bg-card); align-items: flex-start; }
.wb-verdict-badge { flex-shrink: 0; padding: 0.6rem 1rem; border-radius: var(--radius-sm); font-family: var(--font-heading); font-weight: 800; font-size: 1.05rem; }
.tier-prohibited .wb-verdict-badge, .wb-verdict.tier-prohibited .wb-verdict-badge { background: var(--color-danger); color: var(--color-white); }
.wb-verdict.tier-high .wb-verdict-badge { background: var(--color-danger-bg); color: var(--color-danger); }
.wb-verdict.tier-limited .wb-verdict-badge { background: var(--color-warning-bg); color: var(--color-warning); }
.wb-verdict.tier-minimal .wb-verdict-badge { background: var(--color-success-bg); color: var(--color-success); }
.wb-verdict-body h3 { margin: 0 0 0.3rem; font-family: var(--font-heading); }
.wb-annex { font-size: 0.85rem; color: var(--accent-primary); font-weight: 600; margin: 0 0 0.5rem; }
.wb-reasons { margin: 0; padding-left: 1.1rem; color: var(--text-secondary); font-size: 0.88rem; line-height: 1.55; }

.wb-framework-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; }
.wb-fw { padding: 0.8rem 1rem; background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-sm); font-size: 0.85rem; color: var(--text-secondary); }
.wb-fw-k { display: block; font-weight: 700; color: var(--text-primary); margin-bottom: 0.2rem; font-family: var(--font-heading); }

.wb-sub { font-family: var(--font-heading); font-size: 1.05rem; margin: 0.5rem 0 0; }
.wb-checklist { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.wb-checklist li { display: flex; gap: 0.6rem; padding: 0.6rem 0.8rem; background: var(--white-alpha-02); border: 1px solid var(--border-color); border-radius: var(--radius-sm); }
.wb-checklist small { display: block; color: var(--text-muted); font-size: 0.76rem; margin-top: 0.1rem; }
.wb-check { color: var(--accent-primary); }
.wb-next-hint { font-size: 0.86rem; color: var(--text-muted); padding: 0.8rem 1rem; background: var(--accent-primary-alpha-10); border-radius: var(--radius-sm); }
.wb-note { color: var(--text-muted); font-size: 0.88rem; }

/* Doc control grid */
.wb-progress { height: 10px; background: var(--white-alpha-03); border-radius: var(--radius-pill); overflow: hidden; }
.wb-progress-fill { height: 100%; background: linear-gradient(90deg, var(--color-danger), var(--color-warning), var(--color-success)); border-radius: var(--radius-pill); transition: width var(--transition-slow); }
.wb-control-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 0.5rem; }
.wb-control { display: flex; align-items: center; gap: 0.55rem; padding: 0.6rem 0.8rem; border-radius: var(--radius-sm); font-size: 0.85rem; border: 1px solid var(--border-color); }
.wb-control-ic { font-weight: 800; }
.wb-control-present { background: var(--color-success-bg); color: var(--text-primary); border-color: var(--color-success-alpha-30); }
.wb-control-present .wb-control-ic { color: var(--color-success); }
.wb-control-weak { background: var(--color-warning-bg); color: var(--text-primary); border-color: var(--color-warning-alpha-30); }
.wb-control-weak .wb-control-ic { color: var(--color-warning); }
.wb-control-missing { background: var(--color-danger-bg); color: var(--text-primary); border-color: var(--color-danger-alpha-30); }
.wb-control-missing .wb-control-ic { color: var(--color-danger); }

/* ---------------- Chat ---------------- */
.wb-chat { display: flex; flex-direction: column; height: 62vh; min-height: 440px; overflow: hidden; }
.wb-chat-messages { flex: 1; overflow-y: auto; padding: 1.2rem; display: flex; flex-direction: column; gap: 0.9rem; }
.wb-msg { max-width: 85%; padding: 0.8rem 1rem; border-radius: var(--radius-md); font-size: 0.9rem; line-height: 1.55; }
.wb-msg-user { align-self: flex-end; background: var(--accent-primary); color: var(--color-white); border-bottom-right-radius: 4px; }
.wb-msg-agent { align-self: flex-start; background: var(--bg-secondary); border: 1px solid var(--border-color); border-bottom-left-radius: 4px; }
.wb-msg-agent p { margin: 0 0 0.6rem; } .wb-msg-agent p:last-child { margin-bottom: 0; }
.wb-msg-agent ul { margin: 0.3rem 0 0.6rem; padding-left: 1.2rem; }
.wb-msg-agent li { margin-bottom: 0.25rem; }
.wb-msg-agent code { background: var(--white-alpha-03); padding: 0.05rem 0.35rem; border-radius: 4px; font-size: 0.85em; }
.wb-md-h { display: block; margin-bottom: 0.3rem; color: var(--accent-primary); }
.wb-msg-pending { opacity: 0.6; font-style: italic; }
.wb-chat-suggest { display: flex; gap: 0.5rem; padding: 0 1.2rem 0.6rem; flex-wrap: wrap; }
.wb-chip { padding: 0.4rem 0.8rem; border-radius: var(--radius-pill); border: 1px solid var(--border-color); background: var(--white-alpha-03); color: var(--text-secondary); font-size: 0.8rem; cursor: pointer; font-family: var(--font-body); }
.wb-chip:hover { background: var(--accent-primary-alpha-10); color: var(--accent-primary); border-color: var(--accent-primary-alpha-25); }
.wb-chat-input { display: flex; gap: 0.6rem; padding: 0.9rem 1.2rem; border-top: 1px solid var(--border-color); background: var(--bg-secondary); }
.wb-chat-input input { flex: 1; padding: 0.7rem 1rem; border-radius: var(--radius-pill); border: 1px solid var(--border-color); background: var(--bg-primary); color: var(--text-primary); font-family: var(--font-body); }
.wb-chat-input input:focus { outline: none; border-color: var(--accent-primary); }

/* ---------------- Dossier ---------------- */
.wb-dossier-actions { display: flex; gap: 0.6rem; margin-top: 1rem; flex-wrap: wrap; }
.wb-sharelink { margin-top: 0.9rem; padding: 0.7rem 1rem; background: var(--color-success-bg); border-radius: var(--radius-sm); font-size: 0.86rem; word-break: break-all; }
.wb-dossier { background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: 1.6rem; }
.wb-empty { text-align: center; color: var(--text-muted); padding: 3rem 1rem; }
.wb-doc-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; padding-bottom: 1.2rem; border-bottom: 2px solid var(--border-color); margin-bottom: 1.4rem; flex-wrap: wrap; }
.wb-doc-head h2 { font-family: var(--font-heading); margin: 0; font-size: 1.5rem; }
.wb-doc-meta { color: var(--text-muted); font-size: 0.82rem; margin: 0.3rem 0 0; }
.wb-doc-score { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 0.3rem; }
.wb-doc-score strong { font-family: var(--font-heading); font-size: 2.2rem; line-height: 1; }
.wb-doc-score small { color: var(--text-muted); font-size: 0.8rem; }
.wb-doc-sec { margin-bottom: 1.6rem; }
.wb-doc-sec h3 { font-family: var(--font-heading); font-size: 1.2rem; border-bottom: 1px solid var(--border-color); padding-bottom: 0.4rem; margin: 0 0 0.9rem; }
.wb-road-sev { font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.05em; margin: 1.2rem 0 0.6rem; padding: 0.25rem 0.6rem; border-radius: var(--radius-sm); display: inline-block; }
.wb-road-card { border: 1px solid var(--border-color); border-radius: var(--radius-sm); padding: 1rem 1.1rem; margin-bottom: 0.7rem; background: var(--white-alpha-02); }
.wb-road-top { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.4rem; }
.wb-road-i { width: 24px; height: 24px; flex-shrink: 0; border-radius: 50%; background: var(--accent-primary); color: var(--color-white); display: grid; place-items: center; font-size: 0.8rem; font-weight: 700; }
.wb-road-top strong { font-family: var(--font-heading); flex: 1; }
.wb-effort { font-size: 0.72rem; color: var(--text-muted); border: 1px solid var(--border-color); padding: 0.15rem 0.5rem; border-radius: var(--radius-pill); }
.wb-road-why { font-size: 0.86rem; color: var(--text-secondary); margin: 0 0 0.6rem; }
.wb-road-steps { margin: 0 0 0.7rem; padding-left: 1.3rem; font-size: 0.86rem; color: var(--text-secondary); }
.wb-road-steps li { margin-bottom: 0.2rem; }
.wb-road-foot { display: flex; gap: 1rem; flex-wrap: wrap; font-size: 0.78rem; color: var(--text-muted); }
.wb-accept { color: var(--color-success); }
.wb-disclaimer { font-size: 0.78rem; color: var(--text-muted); font-style: italic; border-top: 1px solid var(--border-color); padding-top: 1rem; }

/* ---------------- Help blocks ---------------- */
.wb-help { margin-bottom: 1.5rem; border: 1px solid var(--accent-primary-alpha-25); background: var(--accent-primary-alpha-10); border-radius: var(--radius-md); overflow: hidden; }
.wb-help > summary { cursor: pointer; padding: 0.85rem 1.1rem; font-weight: 600; font-size: 0.92rem; color: var(--accent-primary); list-style: none; display: flex; align-items: center; gap: 0.4rem; }
.wb-help > summary::-webkit-details-marker { display: none; }
.wb-help > summary::after { content: '▾'; margin-left: auto; transition: transform var(--transition-fast); }
.wb-help[open] > summary::after { transform: rotate(180deg); }
.wb-help-body { padding: 0 1.1rem 1.1rem; font-size: 0.88rem; color: var(--text-secondary); line-height: 1.6; }
.wb-help-body p { margin: 0.5rem 0; }
.wb-help-body ul { margin: 0.5rem 0; padding-left: 1.2rem; }
.wb-help-body li { margin-bottom: 0.3rem; }
.wb-help-body code { background: var(--white-alpha-03); padding: 0.1rem 0.35rem; border-radius: 4px; font-size: 0.85em; color: var(--text-primary); }
.wb-help-table { border-collapse: collapse; margin: 0.6rem 0; font-size: 0.82rem; }
.wb-help-table th, .wb-help-table td { border: 1px solid var(--border-color); padding: 0.3rem 0.7rem; text-align: left; }
.wb-help-table th { background: var(--white-alpha-03); font-weight: 600; }

/* ---------------- Applicable regulations ---------------- */
.wb-compliance { margin-top: 1.5rem; }
.wb-compliance:empty { display: none; }
.wb-reg-list { display: flex; flex-direction: column; gap: 0.5rem; }
.wb-reg { border: 1px solid var(--border-color); border-radius: var(--radius-sm); background: var(--bg-card); overflow: hidden; }
.wb-reg > summary { cursor: pointer; padding: 0.7rem 0.9rem; display: flex; flex-direction: column; gap: 0.15rem; list-style: none; }
.wb-reg > summary::-webkit-details-marker { display: none; }
.wb-reg-name { font-weight: 600; font-family: var(--font-heading); color: var(--text-primary); }
.wb-reg-meta { font-size: 0.76rem; color: var(--text-muted); }
.wb-reg-body { padding: 0 0.9rem 0.9rem; }
.wb-reg-status { font-size: 0.78rem; color: var(--text-muted); margin: 0.3rem 0; }
.wb-reg-penalty { font-size: 0.78rem; color: var(--color-warning); margin: 0.2rem 0 0.5rem; }
.wb-reg-rules { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.45rem; }
.wb-reg-rules li { display: flex; gap: 0.6rem; align-items: flex-start; }
.wb-reg-rules small { display: block; color: var(--text-muted); font-size: 0.78rem; margin-top: 0.1rem; }
.wb-reg-ref { flex-shrink: 0; font-size: 0.7rem; font-weight: 700; padding: 0.15rem 0.5rem; border-radius: var(--radius-pill); white-space: nowrap; }

/* ---------------- Responsive ---------------- */
@media (max-width: 980px) {
  .wb-shell { grid-template-columns: 1fr; }
  .wb-rail { position: static; }
  .wb-grid-2, .wb-grid-3, .wb-checks, .wb-framework-grid { grid-template-columns: 1fr; }
  .wb-brand-sub { display: none; }
}

/* ---------------- Print (dossier as PDF) ---------------- */
@media print {
  #main-header, #mobile-nav-drawer, .wb-rail, .wb-steps, .wb-panel-head p, .wb-dossier-actions, .wb-sharelink { display: none !important; }
  body { padding-top: 0 !important; }
  body { background: #fff; color: #000; }
  .wb-shell { display: block; margin: 0; padding: 0; max-width: none; }
  .wb-panel { display: none !important; }
  #panel-dossier { display: block !important; }
  .wb-dossier { border: none; padding: 0; background: #fff; }
  .wb-road-card, .wb-fw, .wb-metric { break-inside: avoid; }
  a { color: #000; text-decoration: none; }
}
