/* ============================================================
   Purview Baseline — app styles. Tokens only (var(--…)).
   Vanilla, no framework. Pairs with js/render.js class names.
============================================================ */
* { box-sizing: border-box; }
html, body { height: 100%; }
body { margin: 0; }

.app { display: flex; flex-direction: column; height: 100vh; background: var(--bg-base); color: var(--fg-1); }
.app-body { flex: 1; display: grid; grid-template-columns: var(--shell-sidebar) 1fr 340px; min-height: 0; }
.ic { flex: none; }

/* ---------- Footer (compact, muted; mirrors N7 shell §4) ---------- */
.footer { flex: none; height: var(--shell-footer); display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: 0 var(--space-4); border-top: 1px solid var(--border-1); background: var(--bg-surface); font-size: var(--text-xs); }
.footer-brand { font-weight: var(--fw-med); color: var(--fg-2); }
.footer-meta { color: var(--fg-3); }

/* ---------- Header ---------- */
.header { height: var(--shell-header); display: flex; align-items: center; gap: var(--space-4); padding: 0 var(--space-4); border-bottom: 1px solid var(--border-1); background: var(--bg-surface); }
.brand { display: flex; align-items: center; gap: var(--space-2); }
.brand-mark { display: grid; place-items: center; width: 30px; height: 30px; background: var(--primary); color: var(--primary-on); border-radius: var(--radius-sm); font-weight: var(--fw-bold); font-size: var(--text-sm); }
.brand-name { font-weight: var(--fw-sb); font-size: var(--text-md); }
.search { display: flex; align-items: center; gap: var(--space-2); background: var(--bg-sunken); border: 1px solid var(--border-1); border-radius: var(--radius-sm); padding: 0 var(--space-3); color: var(--fg-3); flex: 0 1 340px; }
.search input { border: 0; background: transparent; outline: none; color: var(--fg-1); font-family: var(--font-sans); font-size: var(--text-sm); padding: var(--space-2) 0; width: 100%; }
.header-right { margin-left: auto; display: flex; align-items: center; gap: var(--space-3); }

/* ---------- Buttons + segmented ---------- */
.btn { display: inline-flex; align-items: center; gap: var(--space-2); border: 1px solid var(--border-1); background: var(--bg-surface); color: var(--fg-1); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3); font-size: var(--text-sm); font-family: var(--font-sans); cursor: pointer; transition: background var(--dur-fast) var(--ease-out); }
.btn:hover { background: var(--bg-sunken); }
.btn-ghost { border-color: transparent; background: transparent; }
.btn-primary { background: var(--primary); color: var(--primary-on); border-color: var(--primary); }
.btn-primary:hover { background: var(--primary-hover); }
.cap { text-transform: capitalize; }
.segmented { display: inline-flex; background: var(--bg-sunken); border: 1px solid var(--border-1); border-radius: var(--radius-sm); padding: 2px; }
.seg { border: 0; background: transparent; color: var(--fg-2); padding: var(--space-1) var(--space-3); font-size: var(--text-sm); font-family: var(--font-sans); border-radius: var(--radius-xs); cursor: pointer; }
.seg-active { background: var(--bg-surface); color: var(--fg-1); box-shadow: var(--shadow-xs); }
.seg-default { color: var(--fg-3); margin-left: 2px; }

/* ---------- Sidebar ---------- */
.sidebar { border-right: 1px solid var(--border-1); background: var(--bg-surface); overflow-y: auto; padding: var(--space-3); display: flex; flex-direction: column; gap: var(--space-1); }
.sidebar-home-link { display: flex; align-items: center; gap: var(--space-2); width: 100%; border: 0; background: transparent; cursor: pointer; color: var(--fg-1); font-family: var(--font-sans); font-size: var(--text-sm); font-weight: var(--fw-med); padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); margin-bottom: var(--space-2); }
.sidebar-home-link:hover { background: var(--bg-sunken); }
.sidebar-home-link.active { background: var(--primary-soft); color: var(--primary); }
.sidebar-section { margin-bottom: var(--space-1); }
.sidebar-section-head { display: flex; align-items: center; gap: var(--space-2); width: 100%; border: 0; background: transparent; cursor: pointer; color: var(--section-color, var(--fg-2)); font-family: var(--font-sans); font-size: var(--text-xs); font-weight: var(--fw-sb); text-transform: uppercase; letter-spacing: var(--tracking-wide); padding: var(--space-2); }
.sidebar-count { margin-left: auto; color: var(--fg-3); font-weight: var(--fw-reg); }
.sidebar-items { list-style: none; margin: 0; padding: 0 0 0 var(--space-2); }
.sidebar-item { display: flex; align-items: center; gap: var(--space-2); width: 100%; border: 0; background: transparent; cursor: pointer; color: var(--fg-2); font-family: var(--font-sans); font-size: var(--text-sm); padding: var(--space-1) var(--space-2); border-radius: var(--radius-sm); text-align: left; }
.sidebar-item:hover { background: var(--bg-sunken); color: var(--fg-1); }
.sidebar-item.active { background: var(--primary-soft); color: var(--primary); }
.sidebar-item-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
.sidebar-item .ic { color: var(--section-color, var(--fg-3)); }
/* sub-labels indent under their parent group, with a guide rail */
.sidebar-item-sub { margin-left: var(--space-4); border-left: 1px solid var(--border-1); border-top-left-radius: 0; border-bottom-left-radius: 0; padding-left: var(--space-3); }
.sidebar-item-sub .ic { opacity: .8; }
.sidebar-item-group { font-weight: var(--fw-sb); }
.sidebar-item-tag { font-size: 9px; text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--fg-3); background: var(--bg-sunken); padding: 1px 5px; border-radius: var(--radius-pill); }
.sidebar-empty { color: var(--fg-3); font-size: var(--text-xs); padding: var(--space-1) var(--space-2); }

/* ---------- Canvas ---------- */
.canvas { overflow: auto; padding: var(--space-6); min-width: 0; }
.canvas-empty { display: grid; place-items: center; }
.empty { max-width: 30rem; text-align: center; }
.empty h2 { margin-bottom: var(--space-3); }
.view-pad { padding: var(--space-6); color: var(--fg-2); }

/* ---------- Chips ---------- */
.chip { display: inline-flex; align-items: center; gap: 4px; background: var(--bg-sunken); border: 1px solid var(--border-1); border-radius: var(--radius-pill); padding: 2px var(--space-2); font-size: var(--text-xs); color: var(--fg-2); white-space: nowrap; }
.chip-xs { font-size: 11px; padding: 1px 7px; }
.chip-ok { background: var(--success-soft); color: var(--success); border-color: transparent; }
.chip-warn { background: var(--warning-soft); color: var(--warning); border-color: transparent; }
.chip-danger { background: var(--danger-soft); color: var(--danger); border-color: transparent; }
.chip-soft { background: var(--primary-soft); color: var(--primary); border-color: transparent; }
.chip-muted { background: transparent; color: var(--fg-3); }
.chip-loc { background: transparent; }
.chip-ref { cursor: pointer; background: var(--accent-soft); color: var(--accent); border-color: transparent; font-family: var(--font-sans); }
.chips { display: flex; flex-wrap: wrap; gap: var(--space-2); }

/* ---------- Flow board ---------- */
.flow { max-width: 60rem; }
/* Per-policy scripting note (callout) */
.callout { display: flex; gap: var(--space-3); align-items: flex-start; margin: var(--space-4) 0; padding: var(--space-3) var(--space-4); border: 1px solid var(--border-1); border-left: 3px solid var(--accent); border-radius: var(--radius-md); background: color-mix(in srgb, var(--accent) 7%, var(--bg-surface)); }
.callout .ic { color: var(--accent); margin-top: 2px; }
.callout-title { font-weight: var(--fw-sb); font-size: var(--text-sm); margin-bottom: 4px; }
.callout p { margin: 0 0 var(--space-2); font-size: var(--text-sm); color: var(--fg-2); line-height: 1.45; }
.callout p:last-child { margin-bottom: 0; }
.callout-eg { color: var(--fg-1); }
.callout code { font-family: var(--font-mono); font-size: 0.92em; background: var(--bg-sunken); padding: 1px 5px; border-radius: var(--radius-xs); }
.flow-entry { background: var(--bg-surface); border: 1px solid var(--border-2); border-radius: var(--radius-md); padding: var(--space-4); box-shadow: var(--shadow-sm); }
.flow-entry-head { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-3); }
.flow-entry-head .ic { color: var(--primary); }
.flow-entry-title { font-weight: var(--fw-sb); font-size: var(--text-md); }
.flow-entry-sub { color: var(--fg-3); font-size: var(--text-xs); }
.flow-spine { display: flex; flex-direction: column; }
.flow-connector-wrap { display: flex; flex-direction: column; }
.flow-connector { width: 2px; height: var(--space-5); background: var(--border-2); margin-left: var(--space-8); }
.flow-rule { background: var(--bg-surface); border: 1px solid var(--border-1); border-radius: var(--radius-md); overflow: hidden; }
.flow-rule-focus { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-soft); }
.flow-rule-head { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3); background: var(--bg-sunken); border-bottom: 1px solid var(--border-1); }
.flow-rule-name { font-weight: var(--fw-med); font-size: var(--text-sm); margin-right: auto; }
.prio-badge { background: var(--primary); color: var(--primary-on); font-size: 11px; padding: 1px 7px; border-radius: var(--radius-pill); font-weight: var(--fw-sb); }
.flow-lanes { display: grid; grid-template-columns: 1fr auto 1fr; }
.flow-lane { padding: var(--space-3); display: flex; flex-direction: column; gap: var(--space-2); }
/* subtle accent tint that adapts per theme (avoids the muddy brown of a fixed soft token in dark) */
.flow-lane.then { background: color-mix(in srgb, var(--accent) 12%, var(--bg-surface)); box-shadow: inset 1px 0 0 color-mix(in srgb, var(--accent) 28%, transparent); }
.lane-label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--fg-3); font-weight: var(--fw-sb); }
.flow-arrow { display: grid; place-items: center; color: var(--fg-3); }
.cond-item, .action-item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--fg-1); }
.cond-item .ic, .action-item .ic { color: var(--fg-3); }
.cond-op { display: flex; align-items: center; gap: var(--space-2); margin: 1px 0 1px 7px; }
.cond-op::before { content: ""; width: 2px; align-self: stretch; min-height: 12px; background: var(--border-2); border-radius: 1px; }
.cond-op span { font-size: 10px; font-weight: var(--fw-sb); letter-spacing: var(--tracking-wide); color: var(--fg-3); text-transform: uppercase; }
.action-detail { color: var(--fg-3); font-size: var(--text-xs); }
.retention-timeline { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-3); }
.rt-node { display: flex; align-items: center; gap: 6px; font-size: var(--text-sm); }
.rt-meta { color: var(--fg-3); font-size: var(--text-xs); }
.rt-bar { flex: 1; height: 8px; border-radius: var(--radius-pill); background: linear-gradient(90deg, var(--primary-soft), var(--primary)); position: relative; min-width: 80px; }
.rt-duration { position: absolute; top: -18px; left: 50%; transform: translateX(-50%); font-size: var(--text-xs); color: var(--fg-2); white-space: nowrap; }

/* ---------- Retention policies (combined list) ---------- */
.ret-list { display: flex; flex-direction: column; gap: var(--space-3); }
.ret-policy { border: 1px solid var(--border-1); background: var(--bg-surface); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4) var(--space-4); cursor: pointer; }
.ret-policy:hover { background: var(--bg-sunken); }
.ret-policy-active { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-soft); }
.ret-policy-head { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-2); }
.ret-policy-head .ic { color: var(--moss); }
.ret-policy-name { font-weight: var(--fw-sb); font-size: var(--text-sm); }
.ret-policy-chips { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-left: auto; }
.ret-policy-meta { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3); font-size: var(--text-xs); color: var(--fg-3); }
.rpm-item { display: inline-flex; align-items: center; gap: 6px; }
.rpm-item:not(:last-child)::after { content: "·"; margin-left: var(--space-2); color: var(--border-2); }
.rpm-key { color: var(--fg-3); }
.rpm-val { font-family: var(--font-mono); font-size: 0.92em; background: var(--bg-sunken); color: var(--fg-2); padding: 1px 6px; border-radius: var(--radius-xs); }
/* flatten the inner rule timeline so it reads as part of the policy card */
.ret-policy .flow-rule { border: 0; background: transparent; border-radius: 0; }
.ret-policy .flow-rule + .flow-rule { border-top: 1px solid var(--border-1); }

/* ---------- Taxonomy ---------- */
.taxonomy { max-width: 52rem; }
.taxonomy-head, .matrix-head h2 { font-weight: var(--fw-sb); margin: 0 0 var(--space-4); }
.taxo-mode { color: var(--fg-3); font-weight: var(--fw-reg); text-transform: capitalize; }
.pub-meta { display: flex; flex-wrap: wrap; gap: var(--space-2); margin: 0 0 var(--space-4); }
.tree { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.tree-children { margin-top: var(--space-2); padding-left: var(--space-6); border-left: 2px solid var(--border-1); }
.tree-node { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); width: 100%; border: 1px solid var(--border-1); background: var(--bg-surface); color: var(--fg-1); border-radius: var(--radius-md); padding: var(--space-2) var(--space-3); cursor: pointer; font-family: var(--font-sans); text-align: left; }
.tree-node:hover { background: var(--bg-sunken); }
.tree-node-active { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-soft); }
.tree-node-main { display: flex; align-items: center; gap: var(--space-2); min-width: 0; }
.tree-node-name { font-weight: var(--fw-med); font-size: var(--text-sm); }
.tree-node-badges { display: flex; flex-wrap: wrap; gap: 4px; justify-content: flex-end; }

/* ---------- JSON graph (native <details>) ---------- */
.jsongraph { font-family: var(--font-mono); font-size: var(--text-sm); max-width: 52rem; }
.jsongraph-head { font-family: var(--font-sans); color: var(--fg-2); margin-bottom: var(--space-3); }
.jsongraph-body { background: var(--bg-surface); border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: var(--space-3); }
.json-branch { border-left: 1px dashed var(--border-2); padding-left: var(--space-3); }
.json-branch > summary { cursor: pointer; list-style: none; display: flex; align-items: center; gap: 6px; padding: 2px 0; color: var(--fg-1); }
.json-branch > summary::-webkit-details-marker { display: none; }
.json-branch > summary::before { content: "▸"; color: var(--fg-3); font-size: 10px; }
.json-branch[open] > summary::before { content: "▾"; }
.json-children { padding-left: var(--space-3); }
.json-row { display: flex; align-items: center; gap: 6px; padding: 1px 0 1px var(--space-4); }
.json-key { color: var(--primary); }
.json-sep { color: var(--fg-3); }
.json-meta { color: var(--fg-3); font-size: var(--text-xs); }
.json-string { color: var(--success); }
.json-number { color: var(--accent); }
.json-boolean { color: var(--info); }

/* ---------- Relationship (hand-rolled SVG) ---------- */
.relgraph { overflow: auto; border: 1px solid var(--border-1); border-radius: var(--radius-md); background: var(--bg-surface); height: calc(100vh - var(--shell-header) - var(--space-6) * 2); }
.rel-legend { position: sticky; top: 0; z-index: 2; display: flex; flex-wrap: wrap; gap: var(--space-3); padding: var(--space-2) var(--space-3); background: var(--bg-sunken); border-bottom: 1px solid var(--border-1); }
.rel-leg { display: flex; align-items: center; gap: 6px; font-size: var(--text-xs); color: var(--fg-2); text-transform: capitalize; }
.rel-leg-swatch { width: 14px; height: 3px; border-radius: 2px; }
.rel-leg-hint { margin-left: auto; font-size: var(--text-xs); color: var(--fg-3); font-style: italic; }
.rel-canvas { position: relative; }
.rel-edges { position: absolute; top: 0; left: 0; pointer-events: none; }
.rel-edge { fill: none; stroke-width: 1.75; opacity: .75; }
.rel-colhead { position: absolute; top: 12px; text-align: center; font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--fg-3); font-weight: var(--fw-sb); }
.rel-node { position: absolute; display: flex; align-items: center; gap: 6px; padding: 0 var(--space-2); border: 1px solid var(--border-2); border-radius: var(--radius-sm); background: var(--bg-surface); color: var(--fg-1); font-size: var(--text-xs); box-shadow: var(--shadow-xs); overflow: hidden; }
.rel-node[data-goto] { cursor: pointer; }
.rel-node[data-goto]:hover { background: var(--bg-sunken); }
.rel-node span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rel-node .ic { color: var(--fg-3); }
.rel-dlpPolicy, .rel-retentionPolicy, .rel-dlpRule, .rel-retentionRule { border-left: 3px solid var(--accent); }
.rel-label, .rel-labelPolicy { border-left: 3px solid var(--primary); }
.rel-sit { border-left: 3px solid var(--sky); }
.rel-retentionLabel { border-left: 3px solid var(--moss); }
.rel-location { background: var(--bg-sunken); color: var(--fg-2); }
.rel-focus { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-soft); }

/* ---------- Coverage matrix ---------- */
.matrix-wrap { max-width: 60rem; }
.matrix-scroll { overflow-x: auto; }
.matrix { border-collapse: separate; border-spacing: 6px; }
.matrix th { font-size: var(--text-sm); color: var(--fg-2); font-weight: var(--fw-med); padding: var(--space-2); }
.matrix-row-head { text-align: right; white-space: nowrap; }
.cell { width: 130px; height: 56px; border: 1px solid var(--border-1); border-radius: var(--radius-sm); cursor: pointer; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; gap: 2px; padding: var(--space-2); font-family: var(--font-sans); position: relative; }
.cell-state { font-size: var(--text-sm); font-weight: var(--fw-med); }
.cell-count { font-size: var(--text-xs); color: var(--fg-3); }
.cell-flags { position: absolute; top: 4px; right: 6px; display: flex; gap: 3px; }
.flag { font-size: 10px; font-weight: var(--fw-bold); padding: 0 4px; border-radius: var(--radius-xs); }
.flag-broad { background: var(--warning-soft); color: var(--warning); }
.flag-overlap { background: var(--info-soft); color: var(--info); }
.cell-enforced { background: var(--success-soft); color: var(--success); border-color: transparent; }
.cell-test { background: var(--warning-soft); color: var(--warning); border-color: transparent; }
.cell-covered { background: var(--primary-soft); color: var(--primary); border-color: transparent; }
.cell-gap { background: var(--danger-soft); color: var(--danger); border-color: transparent; }
.cell-na { background: transparent; color: var(--fg-3); cursor: default; }
.cell-active { outline: 2px solid var(--primary); }
.matrix-legend { display: flex; flex-wrap: wrap; gap: var(--space-3); margin: var(--space-4) 0; align-items: center; }
.lg { font-size: var(--text-xs); padding: 2px var(--space-2); border-radius: var(--radius-xs); }
.lg-enforced { background: var(--success-soft); color: var(--success); }
.lg-test { background: var(--warning-soft); color: var(--warning); }
.lg-covered { background: var(--primary-soft); color: var(--primary); }
.lg-gap { background: var(--danger-soft); color: var(--danger); }
.lg-na { background: var(--bg-sunken); color: var(--fg-3); }
.lg-note { color: var(--fg-3); font-size: var(--text-xs); }
.matrix-detail { background: var(--bg-surface); border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: var(--space-4); }
.matrix-detail-head { font-weight: var(--fw-sb); margin-bottom: var(--space-2); }
.ref-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-1); }
.ref-row { border: 0; background: transparent; color: var(--primary); cursor: pointer; font-family: var(--font-sans); text-align: left; padding: 2px 0; }
.ref-row:hover { text-decoration: underline; }

/* ---------- SIT table ---------- */
.sit-table { width: 100%; border-collapse: collapse; }
.sit-table th { text-align: left; font-size: var(--text-xs); color: var(--fg-3); text-transform: uppercase; padding: var(--space-2); border-bottom: 1px solid var(--border-1); }
.sit-table td { padding: var(--space-2); border-bottom: 1px solid var(--border-1); font-size: var(--text-sm); }
.sit-table tbody tr { cursor: pointer; }
.sit-table tbody tr:hover { background: var(--bg-sunken); }

/* ---------- Inspector ---------- */
.inspector { border-left: 1px solid var(--border-1); background: var(--bg-surface); overflow-y: auto; display: flex; flex-direction: column; }
.inspector-empty { padding: var(--space-4); color: var(--fg-3); }
.inspector-head { padding: var(--space-4); border-bottom: 1px solid var(--border-1); }
.inspector-title { font-weight: var(--fw-sb); font-size: var(--text-md); margin-bottom: var(--space-2); }
.inspector-sub { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.inspector-tabs { display: flex; gap: var(--space-1); padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--border-1); flex-wrap: wrap; }
.inspector-tabs button { border: 0; background: transparent; cursor: pointer; color: var(--fg-2); font-family: var(--font-sans); font-size: var(--text-sm); padding: var(--space-1) var(--space-2); border-radius: var(--radius-xs); }
.inspector-tabs .tab-active { background: var(--primary-soft); color: var(--primary); }
.inspector-body { padding: var(--space-4); overflow-y: auto; }
.kv { margin: 0; }
.kv-row { display: grid; grid-template-columns: 38% 1fr; gap: var(--space-2); padding: var(--space-2) 0; border-bottom: 1px solid var(--border-1); }
.kv-row dt { color: var(--fg-3); font-size: var(--text-xs); }
.kv-row dd { margin: 0; font-size: var(--text-sm); word-break: break-word; }
.findings { display: flex; flex-direction: column; gap: var(--space-3); }
.finding { border: 1px solid var(--border-1); border-radius: var(--radius-sm); padding: var(--space-3); }
.finding-head { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-1); }
.finding-rule { color: var(--fg-3); font-size: var(--text-xs); font-family: var(--font-mono); }
.finding-msg { font-size: var(--text-sm); }
.finding-fix { color: var(--fg-2); margin-top: var(--space-1); }

/* ---------- Builder forms + export ---------- */
.form { display: flex; flex-direction: column; gap: var(--space-3); }
.field { display: flex; flex-direction: column; gap: var(--space-1); }
.field-label { font-size: var(--text-xs); color: var(--fg-3); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
.field input, .field select, .field textarea { border: 1px solid var(--border-1); background: var(--bg-sunken); color: var(--fg-1); border-radius: var(--radius-sm); padding: var(--space-2); font-family: var(--font-sans); font-size: var(--text-sm); }
.field textarea { min-height: 56px; resize: vertical; }
.toggle { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); }
.toggle input { width: auto; }
.toggle-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-1); }
.export { display: flex; flex-direction: column; gap: var(--space-3); }
.export-actions { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.export-status { color: var(--success); min-height: 1em; }
.export-label { font-size: var(--text-xs); color: var(--fg-3); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-1); }
.export-code { font-family: var(--font-mono); font-size: 12px; max-height: 240px; overflow: auto; white-space: pre; background: var(--bg-sunken); border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: var(--space-3); }
.export-note code { font-size: 11px; }
