/* Reform Society — Offert (skärm). Profil: Formula Condensed (rubriker),
   Inter (brödtext), Space Mono (fakta). Orange i stora block, off-white grund,
   mörkblå text. Skarpa hörn (brand), mjuka skuggor, generös luft. */

@font-face {
  font-family: "Formula Condensed";
  src: url("/static/fonts/FormulaCondensed-Bold.otf") format("opentype");
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Inter";
  src: url("/static/fonts/Inter-Variable.ttf") format("truetype");
  font-weight: 100 900; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Space Mono";
  src: url("/static/fonts/SpaceMono-Regular.ttf") format("truetype");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Space Mono";
  src: url("/static/fonts/SpaceMono-Bold.ttf") format("truetype");
  font-weight: 700; font-style: normal; font-display: swap;
}

:root {
  --orange: #fb531a;
  --orange-dark: #d94512;
  --morkrod: #610000;
  --rosa: #ffa59d;
  --morkbla: #210051;
  --offwhite: #f7f5e4;
  --offwhite2: #efeada;
  --ink: #161320;
  --muted: #7c7868;
  --white: #ffffff;
  --line: rgba(33, 0, 81, .14);
  --line-soft: rgba(22, 19, 32, .1);
  --shadow: 0 24px 60px -28px rgba(33, 0, 81, .28), 0 2px 10px -4px rgba(33, 0, 81, .1);
  --shadow-sm: 0 10px 30px -16px rgba(33, 0, 81, .25);
  --serif-head: "Formula Condensed", "Arial Narrow", sans-serif;
  --sans: "Inter", "Helvetica Neue", Arial, sans-serif;
  --mono: "Space Mono", "Courier New", monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--offwhite);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ---------- Ram ---------- */
.wrap { max-width: 980px; margin: 0 auto; padding: 0 28px; }
.mono-label {
  font-family: var(--mono); font-weight: 700; font-size: 11px;
  letter-spacing: .15em; text-transform: uppercase; color: var(--muted);
}
:focus-visible { outline: 3px solid rgba(251, 83, 26, .75); outline-offset: 2px; }

/* ---------- Hero ---------- */
.hero {
  background: var(--orange);
  color: var(--offwhite);
  padding: 60px 0 52px 0;
  position: relative;
  overflow: hidden;
}
.hero .wrap { position: relative; z-index: 1; }
.hero-logo { width: 188px; height: auto; display: block; margin-bottom: 48px; }
.hero-eyebrow {
  font-family: var(--mono); font-weight: 700; font-size: 12px;
  letter-spacing: .36em; text-transform: uppercase; color: rgba(255, 255, 255, .92);
  margin: 0 0 16px 0;
}
.hero h1 {
  font-family: var(--serif-head); font-weight: 700; text-transform: uppercase;
  font-size: clamp(44px, 7vw, 78px); line-height: .94; margin: 0 0 20px 0;
  color: var(--offwhite); max-width: 18ch;
}
.hero-summary { max-width: 58ch; font-size: 17px; line-height: 1.55; color: rgba(255, 255, 255, .94); margin: 0; }

.hero-meta {
  border-top: 1px solid rgba(247, 245, 228, .42);
  margin-top: 36px; padding-top: 26px;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 18px 32px;
}
.hero-meta dl { margin: 0; }
.hero-meta dt {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase; color: rgba(247, 245, 228, .68);
  margin: 0 0 4px 0;
}
.hero-meta dd { margin: 0; font-weight: 600; font-size: 16.5px; color: var(--white); }

/* ---------- Dokument ---------- */
.doc { padding-top: 56px; padding-bottom: 88px; }
.doc h2 {
  font-family: var(--serif-head); font-weight: 700; text-transform: uppercase;
  font-size: 42px; line-height: .98; color: var(--ink);
  margin: 56px 0 16px 0;
}
.doc > :first-child h2, .doc h2:first-child { margin-top: 0; }
.doc h3 {
  font-family: var(--sans); font-weight: 700; font-size: 20px;
  color: var(--ink); margin: 30px 0 8px 0;
}
.doc p { margin: 0 0 13px 0; }
.doc strong { color: var(--morkbla); }
.doc s { color: var(--muted); }
.doc a { color: var(--orange-dark); text-decoration: none; border-bottom: 1px solid rgba(251, 83, 26, .4); transition: border-color .15s; }
.doc a:hover { border-bottom-color: var(--orange-dark); }
.doc ul, .doc ol { margin: 0 0 18px 0; padding-left: 26px; }
.doc li { margin: 0 0 7px 0; }
.doc ul li::marker { color: var(--orange); }
.doc ol li::marker { font-family: var(--mono); font-size: 14px; color: var(--orange); }
.doc hr { border: 0; border-top: 1px solid var(--line-soft); margin: 36px 0; }
.doc blockquote {
  margin: 18px 0; padding: 16px 22px; background: var(--offwhite2);
  border-left: 3px solid var(--orange);
  font-family: var(--mono); font-size: 14.5px; line-height: 1.55;
}
.doc table {
  width: 100%; border-collapse: collapse; margin: 18px 0 26px 0; font-size: 15px;
  background: var(--white); border: 1px solid var(--line-soft);
}
.doc th {
  background: var(--morkbla); color: var(--white);
  font-family: var(--mono); font-weight: 700; font-size: 11px;
  letter-spacing: .1em; text-transform: uppercase;
  text-align: left; padding: 12px 14px;
}
.doc td { padding: 11px 14px; border-bottom: 1px solid var(--line-soft); vertical-align: top; }
.doc tr:last-child td { border-bottom: 0; }
.doc tr:nth-child(even) td { background: rgba(247, 245, 228, .55); }

.terms-divider { margin: 60px 0 0 0; }

/* ---------- Paneler ---------- */
.panel {
  background: var(--white);
  border: 1px solid var(--line);
  border-top: 3px solid var(--ink);
  padding: 36px 38px;
  margin: 44px 0;
}
.panel h2 {
  font-family: var(--serif-head); font-weight: 700; text-transform: uppercase;
  font-size: 32px; line-height: 1.02; color: var(--ink); margin: 0 0 12px 0;
}
.panel p { margin: 0 0 18px 0; font-size: 15.5px; line-height: 1.6; }

/* ---------- Formulär ---------- */
label { display: block; margin: 16px 0 4px 0; }
label .mono-label { display: block; margin-bottom: 5px; }
input[type=text], input[type=email], textarea {
  width: 100%; padding: 13px 14px;
  font-family: var(--sans); font-size: 16px; color: var(--ink);
  border: 1.5px solid rgba(22, 19, 32, .35); border-radius: 0; background: var(--white);
  transition: border-color .15s, box-shadow .15s;
}
input:focus, textarea:focus {
  outline: none; border-color: var(--morkbla);
  box-shadow: 0 0 0 3px rgba(251, 83, 26, .25);
}
::placeholder { color: rgba(124, 120, 104, .75); }

.btn {
  display: inline-block; cursor: pointer;
  font-family: var(--serif-head); font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; font-size: 19px; line-height: 1.15;
  padding: 15px 28px 13px 28px; border: 0; border-radius: 0;
  background: var(--orange); color: var(--white);
  text-decoration: none; text-align: center;
  transition: background .15s ease, transform .06s ease;
}
.btn:hover { background: var(--orange-dark); }
.btn:active { transform: translateY(1px); }
.btn-secondary { background: var(--morkbla); }
.btn-secondary:hover { background: #321266; }
.btn-ghost {
  background: transparent; color: var(--ink);
  border: 1.5px solid rgba(22, 19, 32, .55); padding: 13px 26px 11px 26px;
  box-shadow: none;
}
.btn-ghost:hover { background: var(--ink); border-color: var(--ink); color: var(--offwhite); }
/* länkar som knappar måste slå .doc a i specificitet */
.doc a.btn { color: var(--white); border-bottom: 0; }
.doc a.btn:hover { color: var(--white); }
.doc a.btn-ghost { color: var(--ink); }
.doc a.btn-ghost:hover { color: var(--offwhite); }
.btn-sm { font-size: 15px; padding: 10px 18px 8px 18px; line-height: 1.25; box-shadow: none; white-space: nowrap; }
.btn-ghost.btn-sm { padding: 9px 16px 7px 16px; }
.intern-table td:last-child { text-align: right; white-space: nowrap; }
.btn-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; margin-top: 20px; }
button[disabled] { opacity: .65; cursor: default; }

/* ---------- Statusboxar ---------- */
.error-box {
  background: rgba(255, 165, 157, .35); border: 1px solid rgba(97, 0, 0, .35);
  border-left: 3px solid var(--morkrod); color: var(--morkrod);
  padding: 14px 18px; margin: 18px 0; font-size: 15px;
}
.warn-box {
  background: var(--offwhite2); border-left: 3px solid var(--orange);
  padding: 14px 18px; margin: 18px 0; font-size: 14.5px;
}
.ok-box {
  background: rgba(211, 239, 200, .6); border: 1px solid rgba(3, 58, 35, .3);
  border-left: 3px solid #033a23; color: #033a23;
  padding: 14px 18px; margin: 18px 0; font-size: 15px;
}

/* ---------- Steg-kort (om-sidan) ---------- */
.steps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
  margin: 8px 0 40px 0;
}
.step-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-top: 3px solid var(--orange);
  box-shadow: var(--shadow-sm);
  padding: 28px 30px 24px 30px;
}
.step-top {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 16px;
}
.step-num {
  font-family: var(--serif-head); font-weight: 700;
  font-size: 46px; line-height: 1; color: var(--orange);
}
.step-icon { width: 44px; height: 44px; color: var(--morkbla); }
.step-card h3 {
  font-family: var(--serif-head); font-weight: 700; text-transform: uppercase;
  font-size: 24px; line-height: 1.04; color: var(--morkbla); margin: 0 0 9px 0;
}
.step-card p { margin: 0; font-size: 15px; line-height: 1.55; }
.step-card strong { color: var(--morkbla); }

/* ---------- Flikar ---------- */
.tabs {
  display: flex; gap: 28px; flex-wrap: wrap;
  border-bottom: 1px solid rgba(22, 19, 32, .18);
  margin: 0 0 34px 0;
}
.tab {
  font-family: var(--mono); font-weight: 700; font-size: 12.5px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--muted); text-decoration: none;
  padding: 12px 2px 14px 2px; margin-bottom: -1px;
  border-bottom: 3px solid transparent;
  display: flex; align-items: center; gap: 8px;
  transition: color .15s, border-color .15s;
}
.tab:hover { color: var(--ink); }
.tab-active { color: var(--morkbla); border-bottom-color: var(--orange); }
.tab-count {
  font-size: 10.5px; background: rgba(33, 0, 81, .08); color: inherit;
  padding: 2px 8px; border-radius: 999px;
}
.tab-active .tab-count { background: var(--morkbla); color: var(--white); }

/* ---------- Interna listor ---------- */
.intern-table {
  width: 100%; border-collapse: collapse; margin: 12px 0 36px 0; font-size: 15px;
  background: var(--white); border: 1px solid var(--line-soft);
}
.intern-table th {
  font-family: var(--mono); font-weight: 700; font-size: 10.5px;
  letter-spacing: .12em; text-transform: uppercase;
  background: var(--morkbla); color: var(--white);
  text-align: left; padding: 12px 14px;
}
.intern-table td { padding: 13px 14px 14px; border-bottom: 1px solid var(--line-soft); vertical-align: middle; }
.intern-table tr:last-child td { border-bottom: 0; }
.intern-table tr:hover td { background: rgba(247, 245, 228, .6); }

.badge {
  display: inline-block; font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; padding: 4px 9px;
  vertical-align: middle;
}
.badge-published { background: rgba(33, 0, 81, .1); color: var(--morkbla); box-shadow: inset 0 0 0 1px rgba(33, 0, 81, .35); }
.badge-approved { background: rgba(101, 239, 111, .25); color: #033a23; box-shadow: inset 0 0 0 1px rgba(3, 58, 35, .4); }
.badge-declined { background: rgba(255, 165, 157, .35); color: var(--morkrod); box-shadow: inset 0 0 0 1px rgba(97, 0, 0, .35); }
.badge-mine { background: var(--orange); color: var(--white); margin-left: 7px; }

.linkbox {
  display: flex; gap: 12px; align-items: center;
  background: var(--offwhite);
  border: 1px dashed rgba(124, 120, 104, .8);
  padding: 14px 16px; margin: 14px 0;
}
.linkbox input {
  flex: 1; min-width: 0; border: 0; background: transparent;
  font-family: var(--mono); font-size: 13px; padding: 0; color: var(--ink);
}
.linkbox input:focus { box-shadow: none; }

.preview-banner {
  background: var(--morkbla); color: rgba(255, 255, 255, .95);
  font-family: var(--mono); font-size: 12px; letter-spacing: .07em;
  padding: 10px 16px; text-align: center; line-height: 1.5;
}
.preview-banner a { color: var(--rosa); }

.footer {
  border-top: 1px solid var(--line-soft);
  padding: 26px 0 56px 0; margin-top: 40px;
  font-family: var(--mono); font-size: 12px; color: var(--muted);
  display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap;
}
.footer a { color: var(--muted); }
.footer a:hover { color: var(--orange-dark); }

details > summary { cursor: pointer; }
details > summary:not(.btn):hover { color: var(--orange-dark); }

/* ---------- Annotationer ---------- */
.ann-kommentar { background: rgba(251, 83, 26, .16); box-shadow: inset 0 -2px 0 rgba(251, 83, 26, .5); cursor: pointer; }
.ann-stryk, .ann-ersatt {
  text-decoration: line-through; text-decoration-color: rgba(97, 0, 0, .8);
  background: rgba(255, 165, 157, .35);
}
.ann-ins {
  background: rgba(211, 239, 200, .9); text-decoration: none; font-weight: 600; padding: 0 3px;
  white-space: pre-wrap; /* radbrytningar och kantmellanslag i förslag ska synas */
}
.ann-stryk { white-space: pre-wrap; }

/* Docs-affordance för kunden: texten ska KÄNNAS skrivbar */
.suggest-mode { cursor: text; transition: box-shadow .12s; }
.suggest-mode:hover { box-shadow: -10px 0 0 -7px rgba(33, 0, 81, .25); }
.suggest-mode:focus { outline: none; box-shadow: -10px 0 0 -7px var(--orange); }
body.suggesting ::selection { background: rgba(251, 83, 26, .25); }

/* statuspill — kundens sparkvitto (Docs: "Saving…/Saved") */
.doc-status {
  position: fixed; top: 14px; right: 14px; z-index: 60;
  font-family: var(--mono); font-size: 11.5px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  background: var(--morkbla); color: rgba(255, 255, 255, .92);
  padding: 9px 14px; box-shadow: var(--shadow-sm);
  max-width: min(320px, calc(100vw - 28px));
  transition: background .2s;
}
.doc-status.saving { background: var(--orange-dark); }
.doc-status.saved { background: #033a23; }
.doc-status.error { background: var(--morkrod); }
.doc-status.toggle {
  cursor: pointer; background: var(--orange); color: var(--white);
  border: 2px solid var(--offwhite);   /* syns även mot orange hero */
  box-shadow: 0 6px 18px -6px rgba(33, 0, 81, .45);
}
.doc-status.toggle:active { transform: translateY(1px); }

/* introduktionsraden överst i dokumentet — copyn följer interaktionsläget:
   pekare = skriv direkt, touch = via Föreslå ändringar-växeln */
.doc-hint {
  font-size: 14.5px; color: var(--muted);
  border-left: 3px solid var(--orange);
  background: var(--offwhite2);
  padding: 12px 16px; margin: 0 0 34px 0;
}
.hint-coarse { display: none; }
@media (pointer: coarse) {
  .hint-fine { display: none; }
  .hint-coarse { display: inline; }
}

/* toppbanner när offerten är avgjord */
.state-banner {
  font-family: var(--mono); font-size: 12px; letter-spacing: .07em;
  padding: 10px 16px; text-align: center; line-height: 1.5;
}
.state-approved { background: #033a23; color: #d3efc8; }
.state-declined { background: var(--morkrod); color: var(--rosa); }

/* blink när kort ↔ markering kopplas */
@keyframes annflash { 0% { outline: 3px solid var(--orange); outline-offset: 2px; } 100% { outline: 3px solid transparent; outline-offset: 2px; } }
.ann-flash { animation: annflash 1.6s ease-out; }

/* versionsdiff */
.diff-body .diff-same { color: rgba(22, 19, 32, .45); }
.diff-body .diff-changed, .diff-body .diff-added, .diff-body .diff-removed { color: var(--ink); }
.diff-body h2.diff-same, .diff-body h3.diff-same { color: rgba(22, 19, 32, .35); }
.diff-body p, .diff-body blockquote { margin: 0 0 13px 0; }

/* svarstrådar under synpunkterna */
.ann-reply {
  margin: 10px 0 0 14px; padding: 8px 12px;
  border-left: 2px solid var(--line);
  background: rgba(247, 245, 228, .55);
}
.ann-reply p { margin: 3px 0 0 0; font-size: 14.5px; }
.ann-reply-konsult { border-left-color: var(--orange); }
.ann-reply-form {
  display: flex; gap: 8px; align-items: center; margin: 10px 0 0 14px;
}
.ann-reply-form input {
  flex: 1; min-width: 0; padding: 9px 12px; font-size: 14.5px;
  border: 1.5px solid rgba(22, 19, 32, .25);
}
.ann-reply-form .btn { flex-shrink: 0; }
.ann-card {
  background: var(--white);
  border: 1px solid var(--line); border-left: 3px solid var(--orange);
  padding: 16px 20px; margin: 14px 0;
}
.ann-card-closed { opacity: .62; border-left-color: var(--muted); }
.ann-quote { margin: 7px 0 0 0; font-size: 14.5px; color: var(--muted); font-style: italic; }
.ann-pop {
  display: none; position: absolute; z-index: 50;
  background: var(--white); border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.ann-pop button {
  border: 0; background: var(--white); cursor: pointer;
  font-family: var(--sans); font-size: 14px; font-weight: 600; color: var(--ink);
  padding: 11px 15px; border-right: 1px solid var(--line-soft);
  transition: background .12s, color .12s;
}
.ann-pop button:last-child { border-right: 0; }
.ann-pop button:hover { background: var(--orange); color: var(--white); }
.ann-form {
  display: none; position: absolute; z-index: 50; width: min(400px, calc(100vw - 24px));
  background: var(--white); border: 1px solid var(--line);
  box-shadow: var(--shadow); padding: 18px 20px;
}
.ann-form label { margin: 8px 0 2px 0; }

/* ---------- Surfplatta ---------- */
@media (min-width: 1440px) {
  .wrap { max-width: 1060px; }
}
@media (max-width: 900px) {
  .panel { padding: 30px 28px; }
}

/* ---------- Mobil ---------- */
@media (max-width: 640px) {
  body { font-size: 16px; }
  .wrap { padding: 0 18px; }
  .hero { padding: 30px 0 28px 0; }
  .hero-logo { width: 120px; margin-bottom: 24px; }
  .hero h1 { font-size: clamp(30px, 9vw, 42px); }
  .hero-summary { font-size: 15px; }
  .hero-eyebrow { font-size: 11px; margin-bottom: 12px; }
  .hero-meta { grid-template-columns: repeat(2, 1fr); gap: 12px 16px; margin-top: 20px; padding-top: 16px; }
  .hero-meta dt { font-size: 9.5px; }
  .hero-meta dd { font-size: 14.5px; }
  .doc { padding-top: 32px; padding-bottom: 56px; }
  .doc h2 { font-size: 28px; margin-top: 38px; }
  .doc h3 { font-size: 16.5px; }
  .panel { padding: 22px 18px; margin: 28px 0; }
  .panel h2 { font-size: 24px; }
  .btn { font-size: 15px; padding: 12px 16px 10px 16px; }
  .btn-sm { font-size: 12.5px; padding: 8px 12px 6px 12px; }
  .btn-row { gap: 10px; }
  .btn-row .btn, .btn-row form { flex: 1 1 auto; }
  .btn-row form .btn { width: 100%; }
  .linkbox { flex-direction: column; align-items: stretch; gap: 10px; }
  .linkbox .btn { width: 100%; }
  .linkbox input { font-size: 12px; }
  .tabs { gap: 14px; }
  .tab { font-size: 11px; padding-bottom: 11px; }
  .doc table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; font-size: 14px; }
  /* Interna listor: ALDRIG sidledes-scroll — sekundära kolumner döljs,
     layouten är låst till skärmbredden och allt innehåll bryter rad.
     Allt klickbart ligger alltid inom skärmen. */
  .intern-table { font-size: 13.5px; }
  .intern-table th, .intern-table td { padding: 10px 8px; }
  /* .doc table-regeln ovan gör tabeller till block — interntabellerna ska
     förbli riktiga tabeller med låst layout inom skärmbredden */
  .doc .intern-table-rows { display: table; table-layout: fixed; width: 100%; min-width: 0; overflow-x: visible; }
  .intern-table-rows .col-kund, .intern-table-rows .col-senast { display: none; }
  .intern-table-rows th, .intern-table-rows td { white-space: normal; word-break: break-word; }
  .tbl-offerter th:nth-child(3) { width: 104px; }
  .tbl-offerter th:last-child { width: 30px; }
  .tbl-utkast th:last-child { width: 116px; }
  .intern-table-rows .btn { white-space: normal; }
  .intern-table-rows .badge { margin-top: 4px; }
  .table-scroll { overflow-x: visible; }
  .table-scroll .intern-table { min-width: 0; width: 100%; }
  .fas-sub { font-size: 10.5px; }
  .badge { font-size: 9px; padding: 3px 7px; }
  .mono-label { font-size: 10px; }
  .doc-hint { font-size: 13px; padding: 10px 14px; margin-bottom: 26px; }
  .doc-status { font-size: 10px; padding: 7px 11px; top: 10px; right: 10px; max-width: 230px; }
  .ann-card { padding: 13px 14px; }
  .ann-quote { font-size: 13.5px; }
  .ann-reply { margin-left: 8px; padding: 7px 10px; }
  .ann-reply p { font-size: 13.5px; }
  .ann-reply-form { margin-left: 8px; }
  .ann-reply-form input { font-size: 13.5px; padding: 8px 10px; }
  .step-num { font-size: 40px; }
  .step-icon { width: 38px; height: 38px; }
  .step-card { padding: 24px 22px 20px 22px; }
  .ann-pop button { padding: 13px 16px; font-size: 14.5px; }
  .identity-bar-text { font-size: 12.5px; }
  .footer { flex-direction: column; gap: 8px; padding-bottom: 44px; font-size: 11px; }
}

/* ---------- Konsult-verktygsrad ---------- */
/* sticky: sparstatus och verktyg ska finnas kvar mitt i ett långt dokument */
.toolbar { background: var(--ink); color: var(--white); position: sticky; top: 0; z-index: 80; }
.toolbar-inner {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding-top: 12px; padding-bottom: 12px; flex-wrap: wrap;
}
.toolbar-status { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.toolbar-sub { font-size: 13.5px; color: rgba(255,255,255,.85); }
.toolbar-sub a { color: var(--rosa); }
.toolbar-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.toolbar-link { font-family: var(--mono); font-size: 12px; letter-spacing: .06em; color: rgba(255,255,255,.85); text-decoration: none; }
.toolbar-link:hover { color: var(--white); }
.toolbar .badge-published, .toolbar .badge-ready { background: rgba(255,255,255,.14); color: var(--white); box-shadow: inset 0 0 0 1px rgba(255,255,255,.4); }
.toolbar .badge-approved { background: #65ef6f; color: #033a23; box-shadow: none; }
.toolbar .badge-declined { background: var(--rosa); color: var(--morkrod); box-shadow: none; }
.badge-ready { background: rgba(251,83,26,.12); color: var(--orange-dark); box-shadow: inset 0 0 0 1px rgba(251,83,26,.5); }
.badge-attn { background: var(--orange); color: var(--white); margin-left: 7px; }
.toolbar-send { position: relative; }
.toolbar-send summary { list-style: none; display: inline-block; }
.toolbar-send summary::-webkit-details-marker { display: none; }
.toolbar-pop {
  position: absolute; right: 0; top: calc(100% + 8px); z-index: 60;
  width: min(360px, calc(100vw - 32px));
  background: var(--white); color: var(--ink);
  border: 1px solid var(--line); box-shadow: var(--shadow); padding: 16px 18px;
}
.toolbar-syncrow {
  font-family: var(--mono); font-size: 11.5px; color: rgba(255,255,255,.65);
  padding-bottom: 10px;
}
.toolbar-syncrow a { color: rgba(255,255,255,.75); }
.linklike {
  background: none; border: 0; padding: 0; cursor: pointer;
  font-family: var(--mono); font-size: 11.5px; color: rgba(255,255,255,.75);
  text-decoration: underline;
}
.row-link { color: var(--ink); text-decoration: none; }
.row-link:hover strong { color: var(--orange-dark); }
.fas-sub { font-size: 12px; color: var(--muted); margin-top: 3px; }
.row-clickable { cursor: pointer; }
.row-arrow { color: var(--orange); font-weight: 700; font-size: 17px; width: 1%; }
.row-clickable:hover .row-arrow { color: var(--orange-dark); }
@media (max-width: 640px) {
  /* mobil: verktygsraden ska inte äta halva skärmen — kompakt, och INTE
     sticky (ett litet viewport tål inte en fastnaglad flervalsrad) */
  .toolbar { position: static; }
  .toolbar-inner { gap: 8px; padding-top: 9px; padding-bottom: 9px; }
  .toolbar-status { gap: 8px; }
  .toolbar-sub { font-size: 11.5px; }
  .toolbar-actions { gap: 8px; }
  .toolbar .btn-sm { font-size: 12px; padding: 7px 11px 5px 11px; }
  .toolbar-link { font-size: 10.5px; }
  .toolbar-syncrow { font-size: 10px; padding-bottom: 8px; }
  .toolbar-pop { right: auto; left: 0; }
  .save-status { font-size: 10px; margin-right: 8px; }
}

/* toasts + synkbesked i interna vyn */
.intern-toast {
  position: fixed; bottom: 22px; left: 50%; transform: translate(-50%, 16px); opacity: 0;
  z-index: 90; max-width: min(560px, calc(100vw - 32px));
  font-size: 14.5px; padding: 13px 20px; box-shadow: var(--shadow);
  transition: transform .25s ease, opacity .25s ease;
}
.intern-toast.visible { transform: translate(-50%, 0); opacity: 1; }
.intern-toast.ok { background: #033a23; color: #d3efc8; }
.intern-toast.err { background: var(--morkrod); color: var(--rosa); }
.sync-flash { font-weight: 700; margin-right: 10px; }
.sync-ok { color: #8be78b; }
.sync-err { color: var(--rosa); }

/* utskrift: dokumentet, inget verktyg */
@media print {
  .toolbar, .identity-bar, .ann-pop, .ann-form, .doc-status, .preview-banner,
  .doc-hint, .intern-toast { display: none !important; }
  body { background: #fff; }
}

.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
@media (min-width: 641px) {
  .table-scroll .intern-table { min-width: 720px; }
}
.toolbar .btn-ghost { color: var(--white); border-color: rgba(255,255,255,.55); }
.toolbar .btn-ghost:hover { background: rgba(255,255,255,.12); color: var(--white); border-color: var(--white); }

/* ---------- Inline-redigering (konsult) ---------- */
.editable { cursor: text; transition: box-shadow .12s; border-radius: 0; }
.editable:hover { box-shadow: -10px 0 0 -7px rgba(251,83,26,.55); }
.editable:focus { outline: none; box-shadow: -10px 0 0 -7px var(--orange); background: rgba(255,255,255,.6); }
.save-status { font-family: var(--mono); font-size: 11.5px; margin-right: 14px; }
.save-status.saving, .save-status.typing { color: var(--rosa); }
.save-status.saved { color: #8be78b; }
.save-status.error { color: var(--rosa); font-weight: 700; }

/* ---------- Identitetslist (kund, icke-blockerande) ---------- */
.identity-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 70;
  display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap;
  background: var(--morkbla); color: var(--white);
  padding: 14px 18px;
  transform: translateY(110%); transition: transform .25s ease;
  box-shadow: 0 -12px 40px -12px rgba(33,0,81,.4);
}
.identity-bar.visible { transform: translateY(0); }
.identity-bar-text { font-size: 14.5px; }
.identity-bar input {
  width: 200px; padding: 10px 12px; font-size: 15px;
  border: 0; background: var(--white);
}
.identity-bar input:focus { box-shadow: 0 0 0 3px rgba(251,83,26,.6); }
.identity-bar.shake { animation: ibshake .35s; }
@keyframes ibshake { 25% { transform: translateX(-6px); } 75% { transform: translateX(6px); } }
@media (max-width: 640px) {
  .identity-bar { gap: 8px; padding: 12px 14px; }
  .identity-bar-text { font-size: 13px; width: 100%; text-align: center; }
  .identity-bar input { flex: 1; min-width: 0; width: auto; }
}
