:root {
  --bg: #f4f6f8;
  --panel: #ffffff;
  --ink: #1f2933;
  --muted: #5f6b75;
  --line: #d8dee3;
  --line-strong: #b9c2ca;
  --brand: #005aa0;
  --brand-dark: #003b6f;
  --brand-soft: #e8f1f8;
  --good: #1f7a3f;
  --good-soft: #e7f3eb;
  --warn: #8a5a00;
  --warn-soft: #fff4d8;
  --bad: #a3312d;
  --bad-soft: #fbe7e5;
  --focus: #ffcc33;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink); font-family: Arial, Helvetica, sans-serif; font-size: 13px; line-height: 1.42; }
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }
.header { min-height: 54px; display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 8px 20px; background: #fff; border-bottom: 1px solid var(--line-strong); position: sticky; top: 0; z-index: 20; }
.logo, .brand-logo { display: inline-flex; align-items: center; gap: 10px; font-weight: 700; color: var(--ink); }
.brand-logo img { height: 30px; width: auto; display: block; }
.logo-mark { width: 26px; height: 26px; display: grid; place-items: center; background: var(--brand); color: #fff; border-radius: 3px; font-weight: 700; }
.nav { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.nav a, .nav button { min-height: 32px; border: 1px solid var(--line-strong); background: #fff; color: var(--ink); padding: 6px 10px; border-radius: 3px; font: inherit; cursor: pointer; }
.nav a.active, .nav button.active { background: var(--brand); border-color: var(--brand); color: #fff; text-decoration: none; }
.shell { max-width: 1380px; margin: 0 auto; padding: 18px 20px 32px; }
.app-title { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 14px; }
h1 { font-size: 22px; line-height: 1.2; margin: 0 0 6px; font-weight: 700; letter-spacing: -.01em; }
h2 { font-size: 17px; line-height: 1.25; margin: 0 0 10px; font-weight: 700; }
h3 { font-size: 14px; line-height: 1.25; margin: 0 0 8px; font-weight: 700; }
p { margin: 0 0 10px; color: var(--muted); }
.lead { font-size: 14px; max-width: 850px; color: var(--muted); }
.card { background: var(--panel); border: 1px solid var(--line); border-radius: 4px; padding: 14px; box-shadow: none; }
.card.flat { box-shadow: none; }
.grid { display: grid; gap: 12px; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.split { display: grid; grid-template-columns: 340px minmax(0, 1fr); gap: 14px; align-items: start; }
.sidebar { display: grid; gap: 10px; position: sticky; top: 70px; }
.kpi { padding: 10px 12px; border: 1px solid var(--line); background: #fff; border-radius: 4px; }
.kpi strong { display: block; font-size: 22px; color: var(--brand-dark); margin-top: 2px; }
.small { font-size: 12px; color: var(--muted); }
.badge { display: inline-flex; align-items: center; gap: 5px; border: 1px solid var(--line-strong); border-radius: 3px; padding: 2px 7px; background: #fff; color: var(--muted); font-size: 12px; font-weight: 600; vertical-align: middle; }
.badge.good { background: var(--good-soft); border-color: #b6d7c2; color: var(--good); }
.badge.warn { background: var(--warn-soft); border-color: #efd28b; color: var(--warn); }
.badge.bad { background: var(--bad-soft); border-color: #e7b6b3; color: var(--bad); }
button, .btn { min-height: 34px; border: 1px solid var(--brand); background: var(--brand); color: #fff; border-radius: 3px; padding: 7px 12px; font: inherit; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 6px; }
button:hover, .btn:hover { background: var(--brand-dark); text-decoration: none; }
button:disabled, .btn.disabled { opacity: .55; cursor: not-allowed; background: #94a3b8; border-color: #94a3b8; }
button.secondary, .btn.secondary { background: #fff; color: var(--brand); border-color: var(--brand); }
button.secondary:hover, .btn.secondary:hover { background: var(--brand-soft); }
button.danger { background: var(--bad); border-color: var(--bad); }
button:disabled { opacity: .55; cursor: not-allowed; }
.global-loading {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 3000;
  height: 3px;
  background: rgba(11, 55, 109, .12);
}
.global-loading[hidden] { display: none; }
.global-loading span {
  display: block;
  width: 42%;
  height: 100%;
  background: var(--ak-blue, var(--brand));
  animation: ak-loading-sweep 1.05s ease-in-out infinite;
}
.global-loading strong {
  position: fixed;
  right: 16px;
  top: 8px;
  border: 1px solid var(--ak-line, var(--line));
  border-radius: 4px;
  padding: 5px 8px;
  background: #fff;
  color: var(--ak-blue, var(--brand));
  font-size: 12px;
  box-shadow: 0 8px 22px rgba(15, 35, 55, .14);
}
button.is-loading,
.btn.is-loading,
.side-link.is-loading {
  pointer-events: none;
}
.button-spinner {
  width: 13px;
  height: 13px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 999px;
  animation: ak-spin .7s linear infinite;
}
@keyframes ak-loading-sweep {
  0% { transform: translateX(-110%); }
  50% { transform: translateX(90%); }
  100% { transform: translateX(260%); }
}
@keyframes ak-spin {
  to { transform: rotate(360deg); }
}
.link-button {
  min-height: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--brand);
  font-weight: 700;
  text-align: left;
  justify-content: flex-start;
}
.link-button:hover { background: transparent; color: var(--brand-dark); text-decoration: underline; }
.actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
label, .field-group { display: grid; gap: 5px; font-weight: 700; color: var(--ink); }
.field-label { display: block; font-weight: 700; color: inherit; }
input, textarea, select { width: 100%; min-height: 34px; border: 1px solid var(--line-strong); border-radius: 3px; background: #fff; padding: 7px 9px; color: var(--ink); font: inherit; }
textarea { min-height: 86px; resize: vertical; }
input:focus, textarea:focus, select:focus, button:focus, a:focus { outline: 3px solid var(--focus); outline-offset: 1px; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.form-grid .full { grid-column: 1 / -1; }
.form-row { display: flex; align-items: end; gap: 10px; }
table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); font-size: 12px; }
th, td { padding: 8px 9px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
th { background: #eef1f4; color: #34404a; font-size: 11px; text-transform: uppercase; letter-spacing: .03em; font-weight: 700; }
tr:last-child td { border-bottom: 0; }
hr { border: 0; border-top: 1px solid var(--line); margin: 14px 0; }
pre { margin: 0; background: #102033; color: #f3f7fb; padding: 12px; border-radius: 4px; overflow: auto; font-size: 12px; }
.message { border: 1px solid var(--line); border-left-width: 4px; background: #fff; padding: 9px 10px; border-radius: 3px; margin: 10px 0; }
.message.ok { border-color: #b6d7c2; border-left-color: var(--good); background: var(--good-soft); color: #174d2c; }
.message.err { border-color: #e7b6b3; border-left-color: var(--bad); background: var(--bad-soft); color: #681d1a; }
.list-button { width: 100%; text-align: left; background: #fff; color: var(--ink); border: 1px solid var(--line); border-radius: 4px; padding: 10px; justify-content: flex-start; display: block; font-weight: 400; }
.list-button:hover, .list-button.active { background: var(--brand-soft); border-color: var(--brand); text-decoration: none; }
.proc-list { display: grid; gap: 6px; }
.proc-list-title { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 4px; }
.process-map { display: grid; grid-template-columns: repeat(10, minmax(0, 1fr)); gap: 6px; margin: 12px 0 14px; }
.process-step { min-height: 72px; border: 1px solid var(--line-strong); background: #fff; border-radius: 4px; padding: 7px; color: var(--ink); cursor: pointer; text-align: left; overflow: hidden; align-items: flex-start; justify-content: flex-start; appearance: none; font: inherit; }
.process-step span { display: block; font-size: 11px; color: var(--muted); }
.process-step strong { display: block; font-size: 12px; line-height: 1.2; margin-top: 2px; overflow-wrap: anywhere; hyphens: auto; }
.process-step.complete { background: var(--good-soft); border-color: #90c7a2; }
.process-step.active { border-color: var(--brand); box-shadow: inset 0 0 0 2px var(--brand); }
.process-step.incomplete { background: #fff; }
.process-step:hover,
.process-step:focus-visible { border-color: var(--brand); background: #f6fbff; box-shadow: inset 0 0 0 1px var(--brand); outline: none; }
.process-step.complete:hover,
.process-step.complete:focus-visible { background: #effaf2; }
.step-panel { border-top: 3px solid var(--brand); }
.step-help { background: #f8fafc; border: 1px solid var(--line); padding: 10px; border-radius: 4px; margin-bottom: 10px; }
.validation-list { margin: 8px 0 0; padding-left: 18px; color: var(--bad); }
.validation-list.warn { color: var(--warn); }
.validation-list button { background: transparent; border: 0; color: inherit; min-height: 0; padding: 0; display: inline; font-weight: 700; text-align: left; text-decoration: underline; }
.workspace-tools details { border: 1px solid var(--line); border-radius: 4px; background: #fff; margin-bottom: 8px; }
.workspace-tools summary { cursor: pointer; padding: 10px; font-weight: 700; }
.workspace-tools details > div { padding: 0 10px 10px; }
.multi-picker { display: grid; gap: 7px; }
.multi-picker-panel { border: 1px solid var(--line); background: #fff; border-radius: 4px; padding: 8px; max-height: 280px; overflow: auto; }
.multi-picker-options { display: grid; gap: 4px; margin-top: 7px; }
.multi-picker-chips { display: flex; flex-wrap: wrap; gap: 6px; min-height: 26px; align-items: center; }
.chip { min-height: 24px; padding: 3px 7px; background: var(--brand-soft); border-color: var(--brand); color: var(--brand-dark); border-radius: 999px; font-weight: 700; }
.uploaded-doc-list { display: grid; gap: 8px; }
.uploaded-doc-item { display: flex; justify-content: space-between; gap: 8px; align-items: center; border: 1px solid var(--line); border-radius: 4px; padding: 8px; background: #fff; }
.eforms-grid { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 12px; }
.eform-field-ok { color: var(--good); font-weight: 700; }
.eform-field-missing { color: var(--bad); font-weight: 700; }
.progress { height: 8px; background: #e3e7eb; border-radius: 999px; overflow: hidden; }
.progress > span { display: block; height: 100%; background: var(--brand); }
.notice-item { display: grid; gap: 8px; padding: 12px; border: 1px solid var(--line); border-radius: 4px; background: #fff; }
.meta { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: 20px; background: var(--bg); }
.login-card { width: min(480px, 100%); }
footer { padding: 20px; color: var(--muted); text-align: center; }
@media (max-width: 1100px) { .process-map { grid-template-columns: repeat(5, minmax(0, 1fr)); } .eforms-grid { grid-template-columns: 1fr; } }
@media (max-width: 850px) { .split, .grid.two, .grid.three, .form-grid { grid-template-columns: 1fr; } .header { align-items: flex-start; flex-direction: column; } .sidebar { position: static; } .process-map { grid-template-columns: repeat(2, minmax(0, 1fr)); } .shell { padding: 12px; } }

/* V1.5 dynamic documents */
.dynamic-doc-shell { display: grid; gap: 12px; }
.dynamic-builder { border-top: 3px solid var(--brand-dark); }
.compact-panel { max-height: 420px; overflow: auto; }
.doc-preview-section, .supplier-section { border: 1px solid var(--line); background: #fff; border-radius: 4px; padding: 10px; margin: 10px 0; }
.doc-block.info_box { border-left: 4px solid var(--brand); background: var(--brand-soft); padding: 8px; color: var(--ink); }
.field-head { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 4px; }
.dyn-answer-form { border-top: 1px solid var(--line); padding: 10px 0; display: grid; gap: 7px; }
.supplier-doc + .supplier-doc { margin-top: 12px; }
.dynamic-supplier-docs { display: grid; gap: 12px; }

/* V1.5 dynamiska dokument */
.dense-shell { max-width: 1500px; }
.document-workbench { grid-template-columns: 360px minmax(0, 1fr); align-items: start; }
.builder-sidebar { position: sticky; top: 70px; }
.compact-form { gap: 8px; }
.check-row { display: flex; align-items: center; gap: 7px; font-weight: 600; }
.check-row input { width: auto; min-height: auto; }
.section-bar { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.document-canvas, .supplier-response-canvas { display: grid; gap: 10px; }
.doc-section { border: 1px solid var(--line); background: #fff; border-radius: 4px; padding: 12px; }
.doc-section h2, .doc-section h3 { margin-bottom: 6px; }
.doc-block { border-left: 3px solid var(--line-strong); padding: 7px 9px; margin: 6px 0; background: #f8fafc; }
.doc-block.info_box { border-left-color: var(--brand); background: var(--brand-soft); }
.field-row, .answer-field { border: 1px solid var(--line); border-radius: 4px; background: #fff; padding: 9px; margin: 7px 0; }
.answer-field label { display: block; margin-bottom: 6px; }
.field-row { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; }
@media (max-width: 1000px) { .document-workbench { grid-template-columns: 1fr; } .builder-sidebar { position: static; } .section-bar, .field-row { flex-direction: column; } }


/* Aktera V1.6.1, stram myndighetsnära applayout */
:root {
  --ak-blue: #0b376d;
  --ak-blue-2: #0d4f8b;
  --ak-sky: #d9ecfb;
  --ak-bg: #f5f7fa;
  --ak-panel: #ffffff;
  --ak-line: #d8e0ea;
  --ak-line-2: #e7edf4;
  --ak-text: #12263f;
  --ak-muted: #5d6b7a;
  --ak-green: #0b7a50;
  --ak-yellow: #b7791f;
  --ak-red: #b42318;
  --ak-shadow: 0 10px 26px rgba(15, 35, 55, .08);
}
body {
  background: var(--ak-bg);
  color: var(--ak-text);
  font-size: 13px;
  line-height: 1.42;
}
.header {
  min-height: 56px;
  padding: 10px 24px;
  border-bottom: 1px solid var(--ak-line);
  background: #fff;
  box-shadow: 0 1px 4px rgba(15, 35, 55, .04);
}
.brand-logo img { height: 28px; }
.brand-logo span { font-size: 13px; color: var(--ak-blue); }
.nav { gap: 8px; }
.nav a, .nav button {
  border-radius: 3px;
  padding: 7px 10px;
  font-size: 12px;
  border-color: var(--ak-line);
}
.nav a.active, .nav button.primary { background: var(--ak-blue); color: #fff; }
.shell { max-width: 100%; padding: 22px 24px; }
h1 { font-size: 22px; letter-spacing: -.02em; line-height: 1.2; }
h2 { font-size: 16px; }
h3 { font-size: 13px; }
p, .lead { font-size: 13px; color: var(--ak-muted); }
.card {
  border-radius: 4px;
  border: 1px solid var(--ak-line);
  box-shadow: none;
  background: var(--ak-panel);
  padding: 18px;
}
.card.flat { border: 1px solid var(--ak-line); }
button, .btn { border-radius: 3px; background: var(--ak-blue); font-size: 12px; padding: 8px 12px; }
button.secondary, .btn.secondary { border: 1px solid var(--ak-line); color: var(--ak-blue); }
input, textarea, select { border-radius: 3px; padding: 8px 9px; font-size: 12px; border-color: var(--ak-line); }
label, .field-group { gap: 5px; font-size: 12px; color: var(--ak-text); }
table { font-size: 12px; }
th { background: #f4f7fb; color: #4b5c70; font-weight: 700; letter-spacing: .04em; }
th, td { padding: 9px 10px; }
.badge { border-radius: 3px; padding: 3px 7px; font-size: 11px; }
.kpi { border-radius: 4px; box-shadow: none; border-color: var(--ak-line); padding: 14px; }
.kpi strong { font-size: 24px; color: var(--ak-blue); }
.app-frame { display: grid; grid-template-columns: 238px 1fr; min-height: calc(100vh - 56px); }
.app-sidebar { background: #fff; border-right: 1px solid var(--ak-line); padding: 14px 10px; }
.app-sidebar .side-section { margin: 10px 0 16px; }
.app-sidebar .side-label { color: #748395; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; padding: 7px 10px; }
.side-link { display: flex; align-items: center; gap: 8px; color: var(--ak-text); padding: 8px 10px; border-radius: 3px; font-size: 12px; text-decoration: none; margin: 1px 0; }
.side-link:hover { background: #f0f5fa; text-decoration: none; }
.side-link.active { background: #eaf3fb; color: var(--ak-blue); border-left: 3px solid var(--ak-blue); padding-left: 7px; }
.side-details { margin: 8px 0 12px; border-top: 1px solid var(--ak-line-2); padding-top: 8px; }
.side-details summary { cursor: pointer; color: #748395; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0; padding: 7px 10px; }
.side-details .side-link { margin-left: 4px; font-size: 11px; }
.test-account-switcher { margin-top: 18px; border-top: 1px solid var(--ak-line-2); padding-top: 8px; }
.test-account-panel { display: grid; gap: 8px; padding: 0 8px 8px; }
.test-account-panel label { font-size: 11px; }
.test-account-panel select { font-size: 11px; min-height: 32px; }
.test-account-panel button { width: 100%; min-height: 30px; font-size: 11px; }
.app-main { min-width: 0; padding: 22px 24px; }
.app-topbar { height: 56px; background: #fff; border-bottom: 1px solid var(--ak-line); display: flex; align-items: center; justify-content: space-between; padding: 0 22px; }
.mobile-menu-toggle,
.mobile-menu-backdrop { display: none; }
.app-page-title { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-bottom: 16px; }
.app-page-title h1 { margin: 0 0 4px; }
.app-page-title p { margin: 0; max-width: 760px; }
.gov-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
.gov-card-title { font-size: 12px; color: var(--ak-muted); margin-bottom: 8px; }
.gov-card-value { font-size: 26px; font-weight: 800; color: var(--ak-text); }
.focus-summary-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}
.focus-pill {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  min-height: 58px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--ak-text);
  text-decoration: none;
}
.focus-pill:hover { border-color: var(--ak-blue); background: #f7fbff; text-decoration: none; }
.focus-pill strong {
  min-width: 34px;
  height: 34px;
  border-radius: 4px;
  background: var(--ak-blue);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 16px;
}
.focus-pill span { font-weight: 700; }
.focus-pill.muted strong { background: #6b7a8a; }
.procurement-focus-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
  gap: 14px;
  align-items: end;
  margin-bottom: 12px;
}
.completed-procurements summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  gap: 12px;
}
.completed-procurements summary::-webkit-details-marker { display: none; }
.completed-procurements summary::after {
  content: 'Visa';
  align-self: start;
  border: 1px solid var(--ak-blue);
  border-radius: 3px;
  color: var(--ak-blue);
  padding: 5px 9px;
  font-weight: 800;
}
.completed-procurements[open] summary { margin-bottom: 12px; }
.completed-procurements[open] summary::after { content: 'Dölj'; }
.list-button { border-radius: 4px; padding: 11px; border-color: var(--ak-line); }
.list-button.active { border-color: var(--ak-blue); background: #eef6fd; }
.doc-workspace { display: grid; grid-template-columns: 300px minmax(680px, 1fr) 340px; gap: 14px; min-height: calc(100vh - 112px); }
.doc-panel { background: #fff; border: 1px solid var(--ak-line); border-radius: 4px; min-height: 0; overflow: hidden; }
.doc-panel-head { border-bottom: 1px solid var(--ak-line); padding: 12px; display:flex; align-items:center; justify-content:space-between; gap: 8px; background: #f8fafc; }
.save-state { cursor: default; user-select: none; }
.doc-panel-body { padding: 12px; overflow: auto; max-height: calc(100vh - 172px); }
.field-palette-sticky { position: sticky; top: 0; z-index: 2; background: #fff; padding-bottom: 10px; border-bottom: 1px solid var(--ak-line); }
.field-palette-sticky summary { cursor:pointer; list-style:none; border:1px solid var(--ak-line); border-radius:4px; padding:8px 10px; font-weight:800; background:#f8fafc; }
.field-palette-sticky summary::-webkit-details-marker { display:none; }
.field-palette-sticky[open] summary { margin-bottom:8px; border-color:#b9d6ee; background:#eef6fd; }
.field-palette-sticky:not([open]) { padding-bottom: 8px; }
.document-card { border: 1px solid var(--ak-line); background: #fff; border-radius: 4px; padding: 10px; margin-bottom: 8px; cursor: pointer; }
.document-card.active { border-color: var(--ak-blue); background: #eef6fd; }
.document-card strong { display:block; font-size: 12px; }
.document-card .small { display:block; margin-top:4px; }
.document-profile-panel { display:grid; grid-template-columns:180px minmax(0,1fr); gap:18px; align-items:start; }
.document-profile-logo { min-height:116px; border:1px solid var(--ak-line); background:#f8fafc; border-radius:4px; display:grid; place-items:center; text-align:center; padding:12px; color:var(--ak-muted); font-size:12px; }
.document-profile-logo strong { display:block; color:#536274; letter-spacing:.04em; }
.document-profile-logo span { display:block; margin-top:6px; overflow-wrap:anywhere; }
.document-profile-logo img { max-width:150px; max-height:82px; object-fit:contain; display:block; margin:0 auto 8px; }
.template-dialog {
  width: min(1120px, 96vw);
}
.template-fullscreen-editor {
  min-height: calc(100vh - 100px);
}
.template-editor-shell {
  display: grid;
  gap: 12px;
}
.template-editor-layout {
  grid-template-columns: minmax(0, 1fr) 330px;
  align-items: start;
}
.template-fullscreen-editor .editor-title {
  position: sticky;
  top: 0;
  z-index: 8;
  background: var(--ak-bg);
  padding: 0 0 10px;
}
.template-word-stage {
  max-height: calc(100vh - 184px);
}
.template-word-page {
  min-height: 980px;
  padding: 44px 54px;
}
.template-word-designer {
  max-height: none;
  overflow: visible;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}
.template-fullscreen-editor .template-doc-section {
  width: 100%;
  box-shadow: none;
  border: 0;
  padding: 0 0 24px;
}
.template-properties-panel .doc-panel-body {
  max-height: calc(100vh - 184px);
}
.template-wysiwyg-panel {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #f8fafc;
  padding: 12px;
}
.template-designer {
  display: grid;
  gap: 12px;
  max-height: min(62vh, 720px);
  overflow: auto;
  margin-top: 10px;
  padding: 18px;
  background: #e9eef4;
  border: 1px solid var(--ak-line);
  border-radius: 4px;
}
.template-doc-section {
  width: min(820px, 100%);
  margin: 0 auto;
  background: #fff;
  border: 1px solid #d4dce6;
  box-shadow: 0 6px 18px rgba(15, 35, 55, .08);
  padding: 28px 38px;
  display: grid;
  gap: 10px;
}
.template-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid var(--ak-line);
  padding-bottom: 8px;
}
.template-section-head h2 {
  margin: 0;
  outline: none;
}
.template-doc-block {
  border-left: 3px solid var(--ak-line);
  padding: 8px 10px;
  background: #fbfcfe;
}
.template-doc-block div[contenteditable="true"],
.template-doc-field strong[contenteditable="true"] {
  outline: none;
}
.template-doc-block div[contenteditable="true"]:focus,
.template-doc-field strong[contenteditable="true"]:focus,
.template-section-head h2[contenteditable="true"]:focus {
  outline: 3px solid var(--focus);
  outline-offset: 2px;
}
.template-doc-field {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fbfcfe;
  padding: 10px;
}
.template-field-line {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}
.editor-chrome { display: grid; grid-template-rows: auto 1fr; min-height: calc(100vh - 112px); }
.editor-toolbar { background: #fff; border: 1px solid var(--ak-line); border-radius: 4px 4px 0 0; display:flex; align-items:center; justify-content:space-between; gap: 10px; padding: 9px 12px; }
.document-validation-panel { background:#fff; border:1px solid var(--ak-line); border-top:0; padding:12px; position:relative; }
.validation-close { position:absolute; right:8px; top:8px; min-width:30px; min-height:30px; padding:0; border-radius:999px; background:#fff; color:var(--ak-muted); border-color:var(--ak-line); }
.validation-summary { display:flex; align-items:center; justify-content:space-between; gap:12px; border-left:4px solid var(--ak-blue); background:#f7fbff; padding:9px 11px; }
.validation-summary.blocked { border-left-color: var(--ak-red); background:#fff7f6; }
.validation-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:8px; margin-top:10px; }
.validation-grid div { border:1px solid var(--ak-line); border-radius:4px; padding:8px; font-size:12px; display:flex; gap:7px; align-items:center; }
.validation-grid span { width:20px; height:20px; border-radius:999px; display:inline-grid; place-items:center; font-weight:800; background:#e8f5ee; color:#17663a; }
.validation-grid .warn span { background:#fff4e5; color:#8a5200; }
.toolbar-group { display:flex; gap: 6px; flex-wrap: wrap; align-items:center; }
.toolbar-group button, .toolbar-group .btn { padding: 6px 9px; }
.process-step-select-label { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:700; color:var(--ak-muted); }
.process-step-select-label select { min-height:34px; max-width:280px; }
.word-stage { background: #e9eef4; border: 1px solid var(--ak-line); border-top: 0; border-radius: 0 0 4px 4px; overflow: auto; padding: 28px 18px 60px; max-height: calc(100vh - 165px); }
.word-page { width: min(900px, 100%); min-height: 1120px; margin: 0 auto; background: #fff; box-shadow: 0 8px 24px rgba(15, 35, 55, .14); border: 1px solid #d4dce6; padding: 54px 64px; }
.word-page.drag-over { outline: 2px dashed #0b5cab; outline-offset: 8px; background: #fbfdff; }
.word-page h1 { font-size: 26px; border-bottom: 2px solid var(--ak-blue); padding-bottom: 12px; margin-bottom: 24px; }
.authority-editor-strip { border: 1px solid #cbd8e6; border-left: 4px solid #0b5cab; background: #f7fbff; padding: 10px 12px; margin: -22px 0 22px; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.authority-editor-strip strong { display:block; color:#102a43; font-size:13px; }
.authority-editor-strip span { color:#5d6d80; font-size:12px; }
.authority-editor-symbols, .authority-inline-symbols { display:inline-flex; gap:4px; flex-wrap:wrap; align-items:center; }
.authority-editor-symbols span, .authority-inline-symbols span { width:22px; height:22px; border-radius:999px; display:inline-grid; place-items:center; background:#eef5fb; border:1px solid #bfd3e7; color:#063b73; font-size:11px; font-weight:800; }
.editor-print-preview { margin: 0 0 18px; padding-bottom: 4px; border-bottom: 1px solid #eef2f7; }
.editor-pdf-header { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; border-bottom:1px solid #c9d6e2; padding-bottom:7px; margin-bottom:6px; color:#5b697a; font-size:11px; }
.editor-pdf-header span:nth-child(2) { text-align:center; }
.editor-pdf-header span:nth-child(3) { text-align:right; }
.editor-front-head { display:grid; grid-template-columns:1fr auto; gap:18px; align-items:start; margin-bottom:12px; }
.editor-print-preview h1 { border:0; padding:0; margin:0 0 14px; color:#1f2933; font-size:28px; line-height:1.16; letter-spacing:0; outline:none; }
.editor-front-date { color:#536274; font-size:13px; }
.editor-logo { max-height:44px; max-width:156px; object-fit:contain; }
.editor-logo-dummy { width:148px; min-height:64px; border:1px solid #a9b7c7; display:grid; place-items:center; color:#526274; font-size:11px; font-weight:800; text-align:center; line-height:1.05; background:#f8fafc; padding:7px; box-sizing:border-box; }
.editor-logo-dummy small { display:block; margin-top:5px; font-size:9px; font-weight:700; }
.editor-cover-meta { margin: 0 0 14px; display:grid; grid-template-columns:220px 1fr; gap:6px 12px; font-size:14px; }
.editor-cover-meta dt { color:#566579; font-weight:800; }
.editor-cover-meta dd { margin:0; color:#102033; }
.editor-legend-title { margin:16px 0 9px; font-size:16px; color:#1f2933; }
.editor-legend { display:grid; grid-template-columns:1fr 1fr; gap:8px 18px; margin:0 0 12px; font-size:12px; }
.editor-legend-item { display:grid; grid-template-columns:24px 1fr; gap:7px; align-items:start; }
.editor-legend-item > span { width:22px; height:22px; border-radius:999px; display:inline-grid; place-items:center; background:#eef5fb; border:1px solid #bfd3e7; color:#063b73; font-size:11px; font-weight:800; }
.editor-legend-item small { color:#334155; }
.doc-meta-line { font-size: 11px; color: var(--ak-muted); margin-bottom: 24px; display:flex; gap: 8px; flex-wrap: wrap; }
.doc-section { border: 1px solid transparent; padding: 10px 8px; margin: 10px -8px 16px; border-radius: 3px; }
.doc-section:hover, .doc-section.selected { border-color: #b9d6ee; background: #f8fbfe; }
.doc-section.drop-target { border-color: #0b5cab; background: #f1f7fe; box-shadow: inset 0 0 0 1px rgba(11, 92, 171, .18); }
.doc-section-title { font-size: 18px; font-weight: 700; margin: 0 0 12px; outline: none; }
.doc-block { color: #23364b; min-height: 26px; outline: none; padding: 5px 0; margin: 4px 0; }
.doc-block.selected, .doc-image-block.selected, .doc-page-break.selected { outline:2px solid rgba(11,92,171,.35); outline-offset:3px; }
.doc-block.info_box { background: #eef6fd; border-left: 4px solid var(--ak-blue); padding: 10px 12px; }
.doc-image-block { margin: 12px 0; border: 1px solid var(--ak-line); padding: 8px; background: #fff; }
.doc-image-block img { max-width: 100%; display: block; }
.doc-image-block figcaption { color: var(--ak-muted); font-size: 11px; margin-top: 5px; }
.doc-page-break { margin: 18px 0; border-top: 1px dashed #9fb1c3; color: #64748b; text-align: center; font-size: 11px; }
.doc-page-break span { background:#fff; padding:0 8px; position:relative; top:-8px; }
.doc-field { border: 1px solid var(--ak-line); border-radius: 4px; margin: 10px 0; padding: 10px; background: #fbfcfe; }
.doc-field.selected { border-color: var(--ak-blue); box-shadow: 0 0 0 2px rgba(11, 55, 109, .08); }
.doc-field-label { display:flex; align-items:center; justify-content:space-between; gap: 8px; margin-bottom: 6px; }
.doc-field-label strong { font-size: 12px; }
.fake-input { border: 1px solid var(--ak-line); background: #fff; border-radius: 3px; min-height: 34px; padding: 8px; color: #8190a2; font-size: 12px; }
.fake-input.long { min-height: 86px; }
.fake-input.table { min-height: 120px; display:grid; place-items:center; }
.doc-price-table, .price-matrix-editor table { width:100%; border-collapse:collapse; font-size:12px; }
.doc-price-table th, .doc-price-table td, .price-matrix-editor th, .price-matrix-editor td { border:1px solid var(--ak-line); padding:6px; text-align:left; }
.doc-price-table tfoot th,
.price-matrix-editor tfoot th { background:#eef6fd; font-weight:800; }
.price-matrix-editor { border:1px solid var(--ak-line); border-radius:4px; padding:10px; background:#f8fafc; display:grid; gap:10px; }
.price-matrix-head { display:grid; grid-template-columns:minmax(0, 1fr) 90px auto; align-items:end; gap:8px; margin-bottom:0; }
.price-matrix-head strong,
.price-matrix-head span { display:block; }
.price-matrix-head span { color:var(--ak-muted); font-size:12px; line-height:1.35; }
.price-matrix-head label { margin:0; }
.price-matrix-head input { max-width:90px; }
.price-matrix-summary { border:1px solid var(--ak-line); background:#fff; border-radius:4px; padding:8px 10px; display:flex; justify-content:space-between; gap:10px; align-items:center; }
.matrix-column-settings { display:grid; gap:8px; }
.matrix-column-card { border:1px solid var(--ak-line); background:#fff; border-radius:4px; padding:8px; display:grid; grid-template-columns:minmax(120px, 1.2fr) minmax(110px, .9fr) minmax(100px, .8fr) minmax(120px, .9fr); gap:8px; align-items:end; }
.matrix-column-card label { margin:0; }
.price-matrix-scroll { overflow:auto; max-height:420px; background:#fff; border:1px solid var(--ak-line); border-radius:4px; }
.price-matrix-editor input,
.price-matrix-editor select { width:100%; min-width:92px; }
.price-matrix-editor th { background:#f4f8fc; position:sticky; top:0; z-index:1; }
.price-matrix-editor th span { display:inline-flex; margin-left:4px; font-size:10px; color:var(--ak-muted); }
.matrix-actions { display:flex; gap:6px; flex-wrap:wrap; margin-top:8px; }
.property-form { display:grid; gap: 10px; }
.check-row { display:flex; align-items:center; gap:8px; min-height:28px; font-weight:600; }
.check-row input[type="checkbox"] { width:16px; height:16px; margin:0; flex:0 0 auto; accent-color: var(--ak-blue); }
.field-palette { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; }
.palette-button { background: #fff; border: 1px solid var(--ak-line); color: var(--ak-text); border-radius: 3px; justify-content: flex-start; padding: 8px; font-weight: 600; }
.palette-button:hover { background: #eef6fd; text-decoration:none; }
.palette-button[draggable="true"], .editor-toolbar [draggable="true"] { cursor: grab; }
.palette-button[draggable="true"]:active, .editor-toolbar [draggable="true"]:active { cursor: grabbing; }
.empty-editor { min-height: 420px; display:grid; place-items:center; color: var(--ak-muted); text-align:center; }
.fullscreen-editor { position: fixed; inset: 0; background: var(--ak-bg); z-index: 1000; display: grid; grid-template-rows: 56px 1fr; }
.fullscreen-editor .app-topbar { height: 56px; }
.fullscreen-editor .doc-workspace { min-height: calc(100vh - 56px); grid-template-columns: 280px minmax(680px, 1fr) 340px; padding: 14px; }
.fullscreen-editor .word-stage { max-height: calc(100vh - 113px); }
.fullscreen-editor .doc-panel-body { max-height: calc(100vh - 125px); }
@media (max-width: 1100px) {
  .app-frame { grid-template-columns: 1fr; }
  .app-sidebar {
    display:block;
    position:fixed;
    inset:0 auto 0 0;
    width:min(318px, 88vw);
    transform:translateX(-105%);
    transition:transform .18s ease;
    z-index:1001;
    overflow-y:auto;
    box-shadow:0 18px 42px rgba(15, 35, 55, .24);
  }
  .app-frame.mobile-menu-open .app-sidebar { transform:translateX(0); }
  .mobile-menu-toggle {
    display:inline-flex;
    min-width:72px;
    margin-left:8px;
  }
  .mobile-menu-backdrop {
    position:fixed;
    inset:0;
    background:rgba(15, 35, 55, .38);
    z-index:1000;
  }
  body.mobile-menu-open .mobile-menu-backdrop { display:block; }
  body.mobile-menu-open { overflow:hidden; }
  .app-frame.menu-collapsed { grid-template-columns:1fr; }
  .app-frame.menu-collapsed .app-sidebar { padding:14px 10px; }
  .app-frame.menu-collapsed .side-head { padding:8px 10px 12px; justify-content:space-between; }
  .app-frame.menu-collapsed .side-head strong,
  .app-frame.menu-collapsed .side-label,
  .app-frame.menu-collapsed .side-details summary,
  .app-frame.menu-collapsed .side-link { font-size:12px; justify-content:flex-start; padding:8px 10px; }
  .app-frame.menu-collapsed .side-label,
  .app-frame.menu-collapsed .side-details summary { font-size:11px; }
  .app-frame.menu-collapsed .side-link::before { content:none; }
  .app-frame.menu-collapsed .test-account-switcher { display:block; }
  .doc-workspace { grid-template-columns: 1fr; }
  .doc-panel-body, .word-stage { max-height: none; }
  .word-page { padding: 30px 22px; min-height: 700px; }
  .gov-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}


/* V1.6.3 shell refinements */
.side-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:8px 10px 12px;
  border-bottom:1px solid var(--ak-line);
  margin-bottom:8px;
}
.side-head strong {
  color:var(--ak-blue);
  font-size:13px;
}
.sidebar-toggle {
  background:#fff;
  color:var(--ak-blue);
  border:1px solid var(--ak-line);
  border-radius:3px;
  padding:4px 7px;
  line-height:1;
}
.app-frame.menu-collapsed { grid-template-columns: 52px 1fr; }
.app-frame.menu-collapsed .app-sidebar { padding: 10px 6px; }
.app-frame.menu-collapsed .side-head strong,
.app-frame.menu-collapsed .side-label,
.app-frame.menu-collapsed .side-details summary,
.app-frame.menu-collapsed .side-link { font-size:0; justify-content:center; padding:9px 6px; }
.app-frame.menu-collapsed .side-link::before { content:'•'; font-size:18px; color:var(--ak-blue); }
.app-frame.menu-collapsed .side-head { padding:6px 0 10px; justify-content:center; }
.app-frame.menu-collapsed .sidebar-toggle { font-size:12px; }
.app-frame.menu-collapsed .test-account-switcher { display:none; }
.espd-workspace { display:grid; gap:16px; }
.espd-picker { border:1px solid var(--ak-line-2); border-radius:6px; padding:14px; background:#fff; }
.espd-picker h3, .espd-preview h3, .espd-validation h3 { margin:0 0 10px; }
.espd-chip-grid { display:flex; flex-wrap:wrap; gap:8px; }
.espd-chip { display:inline-flex; align-items:center; gap:8px; border:1px solid var(--ak-line-2); border-radius:999px; padding:7px 10px; background:#f8fafc; font-size:13px; }
.espd-chip input { width:16px; height:16px; }
.espd-criteria-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:10px; }
.espd-criterion-card { display:flex; align-items:flex-start; gap:10px; border:1px solid var(--ak-line-2); border-radius:6px; padding:12px; background:#fbfdff; min-height:84px; }
.espd-criterion-card input { width:18px; height:18px; margin-top:2px; }
.espd-criterion-card span { display:grid; gap:4px; }
.espd-criterion-card small { color:var(--ak-muted); }
.espd-validation { border:1px solid var(--ak-line-2); border-radius:6px; padding:14px; }
.espd-validation.ok { border-color:#87c79d; background:#f4fbf6; }
.espd-validation.err { border-color:#e29a9a; background:#fff7f7; }
.espd-preview { border:1px solid var(--ak-line-2); border-radius:6px; padding:14px; background:#f8fafc; }
.espd-preview-groups { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:12px; }
.espd-preview-groups section { background:#fff; border:1px solid var(--ak-line-2); border-radius:6px; padding:12px; }
.espd-preview-groups h4 { margin:0 0 8px; }
.espd-workbench { border:1px solid var(--ak-line-2); border-radius:6px; padding:14px; background:#fff; display:grid; gap:14px; }
.espd-workbench .table-actions { min-width:240px; }
.espd-workbench .table-actions button { margin:2px 3px 2px 0; }
.espd-mini-panel { border:1px solid var(--ak-line-2); border-radius:6px; background:#f8fafc; padding:12px; min-height:130px; }
.espd-mini-panel h4 { margin:0 0 8px; }
.espd-supplier-workspace { display:grid; gap:16px; }
.espd-response-groups { display:grid; gap:16px; }
.espd-response-group { display:grid; gap:12px; }
.espd-answer-form,
.espd-operator-panel,
.espd-import-panel { border:1px solid var(--ak-line-2); border-radius:6px; padding:14px; background:#fff; }
.espd-answer-form.saved { border-color:#87c79d; box-shadow:inset 4px 0 0 #87c79d; }
.espd-operator-panel,
.espd-import-panel { display:grid; gap:12px; }
.editor-only-frame {
  min-height: calc(100vh - 56px);
  display:grid;
  grid-template-columns: 1fr;
}
.document-overview-grid {
  display:grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap:14px;
}
.document-overview-list {
  display:grid;
  gap:10px;
}
.editor-page-shell {
  display:grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap:14px;
  min-height: calc(100vh - 112px);
}
.price-matrix-expanded .editor-page-shell {
  grid-template-columns: minmax(420px, .8fr) minmax(680px, 1.2fr);
}
.price-matrix-expanded .doc-panel-body {
  max-height: calc(100vh - 150px);
}
.editor-page-shell .word-stage { max-height: calc(100vh - 165px); }
.editor-fullscreen-active {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: #e9eef4;
  display: grid;
  grid-template-rows: 48px 1fr;
}
.editor-fullscreen-active .app-topbar,
.editor-fullscreen-active .app-sidebar,
.editor-fullscreen-active .doc-list-panel,
.editor-fullscreen-active .preview-hidden-in-fullscreen {
  display:none !important;
}
.editor-fullscreen-active .editor-page-shell {
  min-height: calc(100vh - 48px);
  grid-template-columns: minmax(0, 1fr) 320px;
  padding:0;
  gap:0;
}
.editor-fullscreen-active .editor-toolbar {
  border-radius:0;
  border-left:0;
  border-right:0;
}
.editor-fullscreen-active .word-stage {
  max-height: calc(100vh - 48px);
  border:0;
  border-radius:0;
  padding:24px;
}
.editor-fullscreen-active .doc-panel {
  border-radius:0;
  border-top:0;
  border-right:0;
  border-bottom:0;
}
.preview-page {
  background:#e9eef4;
  min-height:100vh;
  padding:26px;
}
.preview-toolbar {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:#fff;
  border:1px solid var(--ak-line);
  padding:10px 14px;
  margin:0 auto 18px;
  max-width:900px;
}
.supplier-live-answer { margin-top: 7px; }
.supplier-live-answer input,
.supplier-live-answer textarea,
.supplier-live-answer select { border:1px solid var(--ak-line); border-radius:3px; padding:7px; font: inherit; font-size:12px; background:#fff; }
.supplier-live-answer input[type="text"],
.supplier-live-answer input[type="number"],
.supplier-live-answer input[type="date"],
.supplier-live-answer textarea,
.supplier-live-answer select { width:100%; box-sizing:border-box; }
.supplier-live-answer textarea { min-height:84px; resize:vertical; }
.choice-row { display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
.choice-row label { display:flex; gap:6px; align-items:center; font-weight:600; }
.choice-row input[type="radio"],
.choice-row input[type="checkbox"] { width:15px; height:15px; accent-color:var(--ak-blue); }
.file-preview-note { margin-top:5px; font-size:11px; color:var(--ak-muted); }
.supplier-price-input { width:100%; border-collapse:collapse; font-size:12px; }
.supplier-price-input th, .supplier-price-input td { border:1px solid var(--ak-line); padding:5px; }
.supplier-price-input input { width:100%; box-sizing:border-box; min-width:78px; }
.supplier-preview-field {
  border:1px solid var(--ak-line);
  background:#fbfcfe;
  padding:10px;
  border-radius:4px;
  margin:10px 0;
}
.supplier-preview-field label {
  font-weight:700;
  display:block;
  margin-bottom:6px;
}
.supplier-preview-field .supplier-input-preview {
  border:1px solid var(--ak-line);
  min-height:34px;
  background:#fff;
  padding:8px;
  color:#758399;
}
.supplier-answer-workbench {
  display: grid;
  grid-template-columns: 290px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.supplier-answer-rail {
  position: sticky;
  top: 78px;
  display: grid;
  gap: 10px;
  background: #fff;
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  padding: 12px;
}
.supplier-doc-picker {
  display: grid;
  gap: 6px;
}
.supplier-doc-picker button {
  background: #fff;
  color: var(--ak-text);
  border: 1px solid var(--ak-line);
  justify-content: flex-start;
  text-align: left;
  display: grid;
  gap: 3px;
}
.supplier-doc-picker button.active {
  border-color: var(--ak-blue);
  background: #eef6fd;
  color: var(--ak-blue);
}
.supplier-doc-picker button span {
  color: var(--ak-muted);
  font-size: 11px;
}
.supplier-answer-stage {
  background: #e9eef4;
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  padding: 22px 14px 44px;
  overflow: auto;
}
.supplier-answer-page {
  width: min(920px, 100%);
  min-height: 1050px;
  margin: 0 auto;
  background: #fff;
  box-shadow: 0 10px 28px rgba(15, 35, 55, .14);
  border: 1px solid #d4dce6;
  padding: 54px 64px;
}
.doc-meta-line {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: var(--ak-muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.supplier-answer-page h1 {
  font-size: 26px;
  border-bottom: 2px solid var(--ak-blue);
  padding-bottom: 12px;
  margin-bottom: 20px;
}
.supplier-answer-section {
  margin: 22px 0 28px;
}
.supplier-answer-section h2 {
  font-size: 18px;
  margin-bottom: 10px;
}
.supplier-answer-block {
  color: #23364b;
  margin: 8px 0;
}
blockquote.supplier-answer-block {
  border-left: 3px solid var(--ak-blue);
  padding-left: 12px;
  color: #40566d;
}
.supplier-answer-field {
  border: 1px solid #c9d5e2;
  background: #fbfdff;
  border-radius: 4px;
  padding: 12px;
  margin: 14px 0;
}
.supplier-answer-field.saved {
  border-color: #9bc9aa;
  background: #f7fcf8;
}
.supplier-answer-field.unsaved {
  border-color: #efd28b;
  background: #fffdf4;
}
.supplier-answer-field-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.supplier-answer-field-title {
  display: grid;
  gap: 4px;
}
.supplier-answer-control {
  width: 100%;
  border-color: #b7c6d6;
  background: #fff;
  font-size: 13px;
}
textarea.supplier-answer-control {
  min-height: 120px;
  line-height: 1.5;
}
.supplier-answer-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 8px;
}
.supplier-choice-list {
  display: grid;
  gap: 7px;
  margin-top: 8px;
}
.supplier-choice-list label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}
.supplier-choice-list input {
  width: auto;
  min-height: auto;
}
.supplier-save-state {
  min-height: 24px;
  color: var(--ak-muted);
}
.supplier-answer-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 12px;
}
.supplier-answer-progress {
  display: grid;
  gap: 6px;
}
@media (max-width: 1050px) {
  .supplier-answer-workbench {
    grid-template-columns: 1fr;
  }
  .supplier-answer-rail {
    position: static;
  }
  .supplier-answer-page {
    padding: 30px 22px;
    min-height: auto;
  }
}
.admin-subnav,
.module-tabs,
.pager {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.admin-subnav {
  border: 1px solid var(--ak-line);
  background: #fff;
  border-radius: 4px;
  padding: 8px;
  margin: 12px 0 16px;
}
.tab-button {
  min-height: 32px;
  border: 1px solid var(--ak-line);
  background: #fff;
  color: var(--ak-blue);
  border-radius: 3px;
  padding: 6px 10px;
  font-weight: 700;
}
.tab-button.active {
  background: var(--ak-blue);
  border-color: var(--ak-blue);
  color: #fff;
}
.data-toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) repeat(3, minmax(130px, 180px)) auto;
  gap: 10px;
  align-items: end;
}
.search-first-layout {
  display: grid;
  gap: 14px;
}
.focused-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  flex-wrap: wrap;
}
.click-row {
  cursor: pointer;
}
.click-row:hover td {
  background: #f4f9fd;
}
.record-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.record-detail-grid .wide {
  grid-column: 1 / -1;
}
.inline-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.inline-edit-grid .full {
  grid-column: 1 / -1;
}
@media (max-width: 1000px) {
  .data-toolbar,
  .record-detail-grid,
  .inline-edit-grid {
    grid-template-columns: 1fr;
  }
  .record-detail-grid .wide,
  .inline-edit-grid .full {
    grid-column: auto;
  }
}
@media print {
  .preview-toolbar { display:none; }
  html, body, .preview-page, #previewRoot, .authority-render, .word-stage { overflow:visible !important; }
  ::-webkit-scrollbar { display:none; width:0; height:0; }
  .preview-page { background:#fff; padding:0; }
  .word-page { box-shadow:none; border:0; width:auto; min-height:auto; padding:24mm 20mm; overflow:visible !important; }
}


/* V1.6.3 editor fullscreen body mode */
.editor-fullscreen-active .app-frame { display:block; min-height:100vh; }
.editor-fullscreen-active .app-main { padding:0; }
.editor-fullscreen-active .editor-title { display:none; }
.editor-fullscreen-active .editor-page-shell { height:100vh; min-height:100vh; }
.editor-fullscreen-active .editor-toolbar { position:sticky; top:0; z-index:5; }
.document-overview-item {
  display:grid;
  grid-template-columns: 1fr auto;
  gap:12px;
  align-items:center;
  border:1px solid var(--ak-line);
  background:#fff;
  border-radius:4px;
  padding:12px;
}
.document-overview-item h3 { margin:0 0 4px; font-size:14px; }
.document-overview-item p { margin:0; }
.preview-hidden-in-fullscreen { display: initial; }

/* V2.3.5 focused procurement workspace */
.workspace-main { max-width: 1680px; width: 100%; }
.workspace-detail { gap: 14px; }
.workspace-step-wide,
.workspace-tools-wide { width: 100%; }
.empty-workspace { max-width: 760px; }
.compact-process-map {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 6px;
  margin: 12px 0 4px;
}
.process-phase-shell { display: grid; gap: 12px; margin-top: 12px; }
.workspace-process-compact {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.workspace-header-card {
  display: grid;
  gap: 10px;
}
.workspace-title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: start;
}
.workspace-title-row h1 {
  margin-bottom: 4px;
}
.workspace-title-row p {
  margin-bottom: 0;
}
.workspace-header-actions {
  min-width: 300px;
  display: flex;
  align-items: stretch;
  justify-content: flex-end;
  gap: 10px;
}
.workspace-progress {
  min-width: 150px;
  display: grid;
  align-content: center;
  gap: 4px;
}
.workspace-control-button {
  min-width: 150px;
  border-radius: 4px;
  padding: 8px 10px;
  justify-content: flex-start;
  text-align: left;
}
.workspace-control-button.good {
  background: var(--ak-green);
  border-color: var(--ak-green);
}
.workspace-control-button.warn {
  background: var(--ak-yellow);
  border-color: var(--ak-yellow);
  color: #fff;
}
.workspace-control-button.bad {
  background: var(--ak-red);
  border-color: var(--ak-red);
}
.workspace-control-button small,
.workspace-control-button strong {
  display: block;
  line-height: 1.2;
}
.workspace-control-button small {
  font-size: 11px;
  font-weight: 700;
  opacity: .92;
}
.hamburger-icon {
  font-size: 18px;
  line-height: 1;
}
.workspace-step-bar {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  padding: 8px 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}
.workspace-step-main {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}
.workspace-step-main strong,
.workspace-step-main span {
  display: block;
}
.workspace-step-main strong {
  font-size: 13px;
}
.workspace-step-main span {
  font-size: 12px;
  color: var(--ak-muted);
}
.workspace-step-actions {
  justify-content: flex-end;
}
.workspace-step-actions select {
  min-width: 190px;
}
.process-view-page {
  display: grid;
  gap: 14px;
}
.process-view-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: start;
  border-bottom: 1px solid var(--ak-line);
  padding-bottom: 12px;
}
.process-view-head h1 {
  margin-bottom: 4px;
}
.process-view-head p {
  margin-bottom: 0;
}
.process-view-active {
  border: 1px solid var(--ak-line);
  border-left: 5px solid var(--ak-blue);
  border-radius: 4px;
  background: #f8fbfe;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.process-view-active strong,
.process-view-active span {
  display: block;
}
.process-view-active span {
  font-size: 12px;
  color: var(--ak-muted);
}
.process-view-page .process-phase-shell {
  gap: 16px;
}
.process-view-page .process-phase {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  padding: 12px;
}
.process-view-page .compact-process-map {
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  margin-bottom: 0;
}
.workspace-control-drawer[hidden] {
  display: none;
}
.workspace-control-drawer {
  position: fixed;
  inset: 0;
  z-index: 2500;
}
.workspace-control-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 22, 34, .36);
}
.workspace-control-panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(620px, calc(100vw - 24px));
  height: 100%;
  overflow: auto;
  background: #fff;
  border-left: 1px solid var(--ak-line);
  box-shadow: -20px 0 40px rgba(15, 35, 55, .22);
  padding: 16px;
}
.workspace-control-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  border-bottom: 1px solid var(--ak-line);
  padding-bottom: 12px;
  margin-bottom: 12px;
}
.workspace-control-head h2 {
  margin: 0 0 4px;
}
.workspace-control-status {
  border: 1px solid var(--ak-line);
  border-left-width: 5px;
  border-radius: 4px;
  padding: 10px 12px;
  margin-bottom: 12px;
  display: grid;
  gap: 2px;
}
.workspace-control-status.good {
  border-left-color: var(--ak-green);
  background: #f3fbf6;
}
.workspace-control-status.warn {
  border-left-color: var(--ak-yellow);
  background: #fff9ea;
}
.workspace-control-status.bad {
  border-left-color: var(--ak-red);
  background: #fff4f3;
}
.workspace-control-status span {
  color: var(--ak-muted);
  font-size: 12px;
}
.workspace-tools-drawer details {
  margin-bottom: 10px;
}
.workspace-tools-drawer .process-phase-shell {
  margin-top: 8px;
}
.workspace-tools-drawer .compact-process-map {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}
.process-focus-row {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  padding: 10px 12px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.process-focus-row strong,
.process-focus-row span {
  display: block;
}
.process-full-map {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
}
.process-full-map summary {
  cursor: pointer;
  padding: 10px 12px;
  font-weight: 800;
}
.process-full-map[open] {
  padding-bottom: 12px;
}
.process-full-map[open] summary {
  border-bottom: 1px solid var(--ak-line);
}
.process-full-map .process-phase-shell {
  padding: 0 12px;
}
.publication-gate-compact {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}
.gate-issue-details {
  min-width: min(420px, 42vw);
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 4px;
  background: rgba(255,255,255,.72);
}
.gate-issue-details summary {
  cursor: pointer;
  padding: 8px 10px;
  font-weight: 800;
}
.gate-issue-details[open] {
  grid-column: 1 / -1;
  padding-bottom: 10px;
}
.gate-issue-details[open] summary {
  border-bottom: 1px solid rgba(0,0,0,.12);
  margin-bottom: 8px;
}
.gate-issue-details > :not(summary) {
  margin-left: 10px;
  margin-right: 10px;
}
.process-phase h3 {
  margin: 0 0 6px;
  color: var(--ak-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0;
}
.compact-process-map .process-step {
  min-height: 44px;
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  grid-template-rows: auto auto;
  gap: 1px 7px;
  align-items: center;
  padding: 6px 8px;
}
.compact-process-map .process-step .step-index {
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #eef3f8;
  color: var(--ak-blue);
  font-weight: 800;
  font-size: 11px;
}
.compact-process-map .process-step strong {
  margin: 0;
  font-size: 11px;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.compact-process-map .process-step .step-state {
  font-size: 10px;
  line-height: 1.1;
}
.compact-process-map .process-step.complete .step-index {
  background: var(--good-soft);
  color: var(--good);
}
.compact-process-map .process-step.warning {
  background: var(--warn-soft);
  border-color: #efd28b;
}
.compact-process-map .process-step.warning .step-index {
  background: #f6dfa0;
  color: var(--warn);
}
.compact-process-map .process-step.active {
  background: #f6fbff;
}
.compact-process-map .process-step.active .step-index {
  background: var(--ak-blue);
  color: #fff;
}
.process-step-status-form .message {
  grid-column: 1 / -1;
}
.workspace-tools-wide details[open] { background: #fbfdff; }
.workspace-tools-wide .validation-list { max-width: 980px; }
.document-step-shell { gap: 14px; }
.document-kind-picker {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 12px;
}
.document-kind-card {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  display: flex;
  gap: 9px;
  align-items: flex-start;
  padding: 10px;
  cursor: pointer;
}
.document-kind-card.active { border-color: var(--ak-blue); background: #eef6fd; }
.document-kind-card input,
.toggle-row input {
  width: auto;
  min-height: auto;
  margin-top: 3px;
}
.document-kind-card span,
.toggle-row span { display: grid; gap: 2px; }
.document-kind-card small,
.toggle-row small { color: var(--ak-muted); font-weight: 400; line-height: 1.35; }
.toggle-row {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fbfdff;
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 9px 10px;
}
.document-create-tools {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
}
.document-create-tools summary {
  cursor: pointer;
  padding: 11px 12px;
  font-weight: 800;
}
.document-create-tools[open] { padding-bottom: 12px; }
.document-create-tools[open] summary { border-bottom: 1px solid var(--ak-line); margin-bottom: 12px; }
.document-create-tools [data-document-kind-panel] { padding: 0 12px; }
.document-list-panel {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  padding: 12px;
  overflow: auto;
}
.document-combined-table td:first-child { white-space: nowrap; }
.document-source-badge { background: #eef6fd; color: var(--ak-blue); }
.bid-phase-panel { display: grid; gap: 14px; }
.question-list { display: grid; gap: 10px; }
.question-item {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  padding: 12px;
}
.question-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 10px;
}
.supplier-search-panel { margin-bottom: 14px; }
.inline-search {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 10px;
  align-items: end;
}
.supplier-procurement-list {
  display: grid;
  gap: 10px;
}
.supplier-procurement-card.active {
  border-color: var(--ak-blue);
  background: #f6fbff;
}
.pager {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  margin: 12px 0;
}
.supplier-detail { margin-top: 14px; }
.supplier-bid-layout {
  display: grid;
  grid-template-columns: minmax(240px, 330px) minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.supplier-bid-list {
  position: sticky;
  top: 86px;
  display: grid;
  gap: 8px;
}
.supplier-bid-workspace {
  display: grid;
  gap: 14px;
  min-width: 0;
}
.supplier-process {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
  margin: 14px 0;
}
.supplier-process-step {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  padding: 9px;
  display: grid;
  gap: 4px;
  min-height: 68px;
}
.supplier-process-step span {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #edf2f7;
  font-weight: 800;
}
.supplier-process-step.done {
  border-color: #71b48d;
  background: #f4fbf6;
}
.supplier-process-step.done span {
  background: #dff3e6;
  color: #17633c;
}
.dynamic-supplier-docs,
.supplier-doc,
.supplier-section {
  display: grid;
  gap: 10px;
}
.supplier-doc {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
  padding: 12px;
}
.answer-field {
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fbfdff;
  padding: 10px;
  margin: 8px 0;
}
.template-dialog {
  width: min(860px, calc(100vw - 28px));
  border: 1px solid var(--ak-line);
  border-radius: 6px;
  padding: 18px;
}
.template-dialog::backdrop { background: rgba(12, 24, 40, .34); }
.template-dialog textarea[name="sections"] {
  min-height: 220px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 12px;
}
@media (min-width: 1200px) {
  .workspace-step-wide .form-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .workspace-step-wide .form-grid .full { grid-column: 1 / -1; }
  .workspace-step-wide textarea { min-height: 120px; }
}
@media (max-width: 850px) {
  .compact-process-map { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .compact-process-map .process-step strong { white-space: normal; }
  .focus-summary-strip,
  .procurement-focus-head,
  .template-editor-layout,
  .workspace-title-row,
  .workspace-step-bar,
  .process-view-head { grid-template-columns: 1fr; }
  .workspace-header-actions { min-width: 0; justify-content: stretch; flex-wrap: wrap; }
  .workspace-progress,
  .workspace-control-button { flex: 1 1 180px; }
  .workspace-step-actions { justify-content: flex-start; }
  .workspace-step-actions select { min-width: 0; }
  .template-word-stage,
  .template-properties-panel .doc-panel-body { max-height: none; }
  .template-word-page { padding: 26px 20px; min-height: 640px; }
  .process-focus-row,
  .publication-gate-compact { display: grid; grid-template-columns: 1fr; }
  .gate-issue-details { min-width: 0; }
  .inline-search,
  .supplier-bid-layout,
  .bid-viewer-grid { grid-template-columns: 1fr; }
  .supplier-bid-list { position: static; }
}

/* V2.3.9 supplier workspace and admin feedback */
.loading-panel {
  border: 1px solid var(--ak-line);
  background: #f8fafc;
  border-radius: 4px;
  padding: 14px;
  color: var(--ak-muted);
  font-weight: 700;
}
.supplier-bid-main { max-width: 1720px; }
.supplier-bid-workspace-full {
  display: grid;
  gap: 14px;
  width: 100%;
}
.supplier-workspace-head .app-title { align-items: flex-start; }
.supplier-clickable-process {
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
}
.supplier-step-panel { min-height: 360px; }
.step-help-text {
  background: #f8fafc;
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  padding: 10px;
  margin-bottom: 12px;
}
.dynamic-preview-slot { margin-top: 12px; }
.dynamic-preview-frame {
  width: 100%;
  min-height: 720px;
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
}
.bid-package-dialog {
  width: min(1180px, calc(100vw - 24px));
  max-height: min(880px, calc(100vh - 24px));
  overflow: auto;
}
.bid-viewer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(340px, .8fr);
  gap: 14px;
  align-items: start;
}
.bid-viewer-main,
.bid-preview-pane {
  display: grid;
  gap: 12px;
}
.bid-preview-frame {
  width: 100%;
  min-height: 620px;
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  background: #fff;
}
.bid-answer-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 20px;
}
.bid-answer-list p {
  margin: 4px 0 0;
  white-space: pre-wrap;
}
@media (max-width: 850px) {
  .bid-viewer-grid { grid-template-columns: 1fr; }
}
.admin-control-grid { align-items: start; }
.admin-form-panel { gap: 10px; }
.admin-status-panel { margin-top: 12px; }
.org-card-list {
  display: grid;
  gap: 8px;
}
.org-card {
  width: 100%;
  display: grid;
  gap: 4px;
  justify-items: start;
  text-align: left;
  background: #fff;
  color: var(--ak-text);
  border: 1px solid var(--ak-line);
  border-radius: 4px;
  padding: 10px;
}
.org-card:hover {
  border-color: var(--ak-blue);
  background: #eef6fd;
}
.org-card span {
  color: var(--ak-muted);
  font-weight: 600;
}
.org-detail-head {
  display: grid;
  gap: 6px;
  margin-bottom: 12px;
}

/* V2.3.22 Sprint 37 focused direct procurement */
.direct-focused-main {
  max-width: 1760px;
}
.direct-focused-shell {
  display: grid;
  grid-template-columns: minmax(230px, 300px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}
.direct-list-panel {
  border: 1px solid var(--ak-line);
  border-radius: 6px;
  background: #fff;
  padding: 12px;
  position: sticky;
  top: 82px;
  max-height: calc(100vh - 110px);
  overflow: auto;
}
.direct-workspace {
  display: grid;
  gap: 14px;
  min-width: 0;
}
.direct-workspace-head {
  border: 1px solid var(--ak-line);
  border-radius: 6px;
  background: #fff;
  padding: 14px;
  display: flex;
  gap: 14px;
  justify-content: space-between;
  align-items: flex-start;
}
.direct-workspace-head h1 {
  margin: 4px 0;
  font-size: clamp(1.35rem, 1.8vw, 2rem);
}
.focused-process-strip {
  display: grid;
  grid-template-columns: repeat(9, minmax(0, 1fr));
  gap: 6px;
}
.focused-step {
  min-height: 62px;
  border: 1px solid var(--ak-line);
  border-radius: 6px;
  background: #fff;
  color: var(--ak-text);
  padding: 8px;
  display: grid;
  gap: 5px;
  justify-items: start;
  text-align: left;
}
.focused-step span {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: #edf2f7;
  display: grid;
  place-items: center;
  font-weight: 800;
}
.focused-step strong {
  font-size: .82rem;
  line-height: 1.18;
}
.focused-step.completed {
  border-color: #84bf9a;
  background: #f2fbf5;
}
.focused-step.completed span {
  background: #dff3e6;
  color: #17633c;
}
.focused-step.active {
  border-color: var(--ak-blue);
  background: #eef6fd;
  box-shadow: inset 0 0 0 1px var(--ak-blue);
}
.focused-step.locked {
  color: #64748b;
  background: #f8fafc;
}
.focused-step-card {
  border: 1px solid var(--ak-line);
  border-radius: 6px;
  background: #fff;
  padding: 16px;
  min-height: 520px;
}
.step-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 14px;
}
.step-panel-head h2 {
  margin: 2px 0 6px;
}
.save-state {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 2px 8px;
  border: 1px solid var(--ak-line);
  border-radius: 999px;
  background: #f8fafc;
  color: var(--ak-muted);
  font-size: .82rem;
  font-weight: 800;
}
.callout {
  border: 1px solid var(--ak-line);
  border-left: 4px solid var(--ak-blue);
  border-radius: 4px;
  background: #f8fafc;
  padding: 10px 12px;
  margin: 10px 0;
}
.callout ul {
  margin: 6px 0 0;
  padding-left: 20px;
}
.callout.danger {
  border-left-color: var(--ak-red);
  background: #fff7f6;
}
.callout.success {
  border-left-color: var(--ak-green);
  background: #f2fbf5;
}
.contract-control-grid {
  display: grid;
  grid-template-columns: minmax(300px, .85fr) minmax(0, 1.15fr);
  gap: 14px;
  align-items: start;
}
.contract-search-results,
.preview-panel,
.supplier-editor {
  border: 1px solid var(--ak-line);
  border-radius: 6px;
  background: #fbfdff;
  padding: 12px;
  display: grid;
  gap: 10px;
}
.result-row {
  width: 100%;
  display: grid;
  justify-items: start;
  text-align: left;
  gap: 4px;
  border: 1px solid var(--ak-line);
  border-radius: 6px;
  background: #fff;
  color: var(--ak-text);
  padding: 10px;
}
.result-row:hover {
  border-color: var(--ak-blue);
  background: #eef6fd;
}
.result-row span {
  color: var(--ak-muted);
  font-weight: 600;
}
.supplier-editor table input {
  min-width: 130px;
}
.protocol-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.protocol-preview {
  max-height: 520px;
  overflow: auto;
  white-space: pre-wrap;
}
.button {
  min-height: 34px;
  border: 1px solid var(--brand);
  background: var(--brand);
  color: #fff;
  border-radius: 3px;
  padding: 7px 12px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.button:hover {
  background: var(--brand-dark);
  color: #fff;
  text-decoration: none;
}
.button.secondary {
  background: #fff;
  color: var(--brand);
}
.button.secondary:hover {
  background: var(--brand-soft);
  color: var(--brand);
}
@media (max-width: 1120px) {
  .focused-process-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .contract-control-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 850px) {
  .price-matrix-expanded .editor-page-shell,
  .matrix-column-card {
    grid-template-columns: 1fr;
  }
  .direct-focused-shell {
    grid-template-columns: 1fr;
  }
  .direct-list-panel {
    position: static;
    max-height: none;
  }
  .direct-workspace-head,
  .step-panel-head {
    display: grid;
  }
  .focused-process-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
