/* ============================================================================
   ProspectFlow — Dealdesk design tokens & shell
   ----------------------------------------------------------------------------
   Geladen door app/templates/_shell.html (de nieuwe sidebar-layout). Tailwind
   CDN levert de utilities; dit bestand levert de huisstijl-tokens, de shell-
   chrome (sidebar/topbar), en de herbruikbare card/pill/btn-primitives uit het
   goedgekeurde Dealdesk-ontwerp.

   WHITE-LABEL: alle kleur hangt aan --acc*. De default is de ProspectFlow-
   indigo (matcht brand/prospectflow-logo.svg). Een tenant overschrijft via
   app_config.theme -> _shell.html schrijft de overrides als inline custom
   properties op <html data-... style="--acc:...">. Geen enkele andere kleur is
   hard-coded aan een merk.
   ========================================================================== */

:root {
  /* Accent — ProspectFlow indigo→violet (default). Tenant-overschrijfbaar. */
  --acc: #6366f1;
  --acc-d: #4f46e5;
  --acc-l: #818cf8;
  --acc-bg: #eef0fe;
  --acc-ink: #3730a3;

  /* Chrome — vast fundament */
  --sidebar: #0e1014;
  --sidebar-2: #16181f;
  --sidebar-border: #23252e;
  --sidebar-text: #9b9ba6;

  --body: #f6f8fb;
  --surface: #ffffff;
  --ink: #0e1014;
  --ink-2: #4a4a5a;
  /* WCAG AA: #6b6b7a ≈ 5.2:1 op wit (was #8a8a98 ≈ 3.4:1, faalde 4.5:1). */
  --ink-3: #6b6b7a;
  --divider: #e6e9f0;
  /* Alias zodat losse templates die var(--border)/var(--line) verwachten
     (o.a. catalog.html zoek-/filterveld) hun rand wél krijgen — anders viel
     de border-declaratie ongeldig weg en stonden de velden randloos. */
  --border: #e6e9f0;
  --line: #e6e9f0;

  --green: #0f9d58;
  --green-bg: #e7f7ee;
  --amber: #c77700;
  --amber-bg: #fdf3e0;
  --red: #d92d20;
  --red-bg: #feeceb;
  --blue: #1f6feb;
  --blue-bg: #e8f0fe;
  --purple: #7c3aed;
  --purple-bg: #f1eafe;
}

/* ---- base ---- */
.dd-body {
  background: var(--body);
  color: var(--ink);
  font-family: "Inter", ui-sans-serif, system-ui, sans-serif;
  font-feature-settings: "cv11", "ss01";
}
.dd-tn {
  font-variant-numeric: tabular-nums;
}
.dd-brandbar {
  height: 3px;
  background: linear-gradient(
    90deg,
    var(--acc),
    var(--acc-l) 55%,
    #5b6478 55.2%,
    #5b6478 72%,
    var(--acc-l) 72.2%
  );
}

/* ---- shell layout ---- */
.dd-shell {
  display: flex;
  height: calc(100vh - 3px);
  overflow: hidden;
}
.dd-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.dd-content {
  flex: 1;
  overflow-y: auto;
}

/* ---- sidebar ---- */
.dd-sidebar {
  width: 232px;
  flex: none;
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, var(--sidebar) 0%, var(--sidebar-2) 100%);
  transition: width 0.22s cubic-bezier(0.4, 0, 0.2, 1);
  /* overflow visible: anders knipt de sidebar de op right:-14px zwevende
     inklap-toggle af. Verticaal scrollen wordt door .dd-nav zelf afgehandeld;
     ingeklapte tekst is display:none, dus er spilt niets horizontaal. */
  overflow: visible;
}

/* collapsed state — iconen-only rail */
.dd-shell.sidebar-collapsed .dd-sidebar {
  width: 52px;
}
.dd-shell.sidebar-collapsed .dd-brand-name,
.dd-shell.sidebar-collapsed .dd-brand-sub,
.dd-shell.sidebar-collapsed .dd-nav-label,
.dd-shell.sidebar-collapsed .dd-navlink > span:not(.dd-ico):not(.dd-count),
.dd-shell.sidebar-collapsed .dd-me-name,
.dd-shell.sidebar-collapsed .dd-me-role,
.dd-shell.sidebar-collapsed .dd-sidebar-foot > span[style*="flex: 1"] {
  display: none;
}
.dd-shell.sidebar-collapsed .dd-navlink {
  justify-content: center;
  padding: 10px 0;
}
.dd-shell.sidebar-collapsed .dd-sidebar-foot {
  justify-content: center;
}
.dd-shell.sidebar-collapsed .dd-sidebar-toggle {
  justify-content: center;
}

/* toggle button */
.dd-sidebar-toggle {
  position: absolute;
  top: 14px;
  right: -14px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--sidebar-border);
  background: var(--sidebar-2);
  color: var(--sidebar-text);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10;
  transition:
    background 0.12s,
    color 0.12s,
    opacity 0.12s;
  /* Zichtbaar in rust (was 0): touch-gebruikers kunnen niet hoveren om de
     affordance te ontdekken. */
  opacity: 0.55;
}
.dd-sidebar:hover .dd-sidebar-toggle,
.dd-sidebar-toggle:focus-visible {
  opacity: 1;
}
.dd-sidebar-toggle:hover {
  background: var(--acc);
  color: #fff;
  border-color: transparent;
}
.dd-sidebar-toggle .dd-ico {
  width: 14px;
  height: 14px;
}
/* sidebar needs relative positioning for the toggle button */
.dd-sidebar {
  position: relative;
}
.dd-brand {
  height: 58px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  border-bottom: 1px solid var(--sidebar-border);
}
.dd-brand-mark {
  width: 28px;
  height: 28px;
  border-radius: 9px;
  flex: none;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--acc-l), var(--acc-d));
  box-shadow: 0 2px 8px color-mix(in srgb, var(--acc) 45%, transparent);
  color: #fff;
  font-weight: 800;
  font-size: 13px;
}
.dd-brand-name {
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.dd-brand-sub {
  font-size: 9.5px;
  letter-spacing: 0.08em;
  color: var(--sidebar-text);
}

.dd-nav {
  flex: 1;
  padding: 12px 10px;
  overflow-y: auto;
}
.dd-nav-label {
  padding: 12px 12px 4px;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  /* WCAG AA: #83838f ≈ 4.8:1 op --sidebar #0e1014 (was #5a5a66 ≈ 2.8:1). */
  color: #83838f;
}
.dd-navlink {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 12px;
  border-radius: 12px;
  cursor: pointer;
  color: var(--sidebar-text);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  transition:
    background 0.14s,
    color 0.14s;
}
.dd-navlink:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.04);
}
.dd-navlink.on {
  color: #fff;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--acc) 16%, transparent),
    color-mix(in srgb, var(--acc) 3%, transparent)
  );
}
.dd-navlink .dd-navdot {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 18px;
  border-radius: 0 4px 4px 0;
  background: var(--acc);
}
.dd-navlink .dd-ico {
  width: 17px;
  height: 17px;
  flex: none;
}
.dd-navlink .dd-count {
  margin-left: auto;
  font-size: 11px;
  font-weight: 700;
  color: #d6d6e0;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 99px;
  padding: 1px 7px;
}
.dd-navlink .dd-count.acc {
  color: #fff;
  background: var(--acc);
  box-shadow: 0 2px 6px color-mix(in srgb, var(--acc) 50%, transparent);
}

.dd-sidebar-foot {
  padding: 12px 14px;
  border-top: 1px solid var(--sidebar-border);
  display: flex;
  align-items: center;
  gap: 10px;
}
.dd-me-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  flex: none;
  display: grid;
  place-items: center;
  font-size: 10.5px;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, #3d4250, #23252e);
}
.dd-me-name {
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.2;
}
.dd-me-role {
  color: var(--sidebar-text);
  font-size: 9.5px;
}

/* ---- topbar ---- */
.dd-topbar {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 26px;
  border-bottom: 1px solid var(--divider);
  background: color-mix(in srgb, var(--surface) 72%, transparent);
  backdrop-filter: blur(8px);
}
.dd-search {
  display: flex;
  align-items: center;
  gap: 9px;
  cursor: text;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 10px;
  padding: 7px 12px;
  width: clamp(180px, 22vw, 340px);
  color: var(--ink-3);
  font-size: 13px;
}
.dd-search kbd {
  margin-left: auto;
  font-size: 10.5px;
  border: 1px solid var(--divider);
  border-bottom-width: 2px;
  border-radius: 5px;
  padding: 1px 5px;
  color: var(--ink-3);
  background: var(--body);
}

/* ---- primitives: card / pill / btn ---- */
.dd-card {
  background: var(--surface);
  border-radius: 18px;
  box-shadow:
    0 0 0 1px rgba(14, 16, 20, 0.05),
    0 1px 2px rgba(14, 16, 20, 0.04),
    0 8px 24px -12px rgba(14, 16, 20, 0.08);
}
.dd-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  /* ≥11px voor leesbaarheid (was 10.5px). */
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  padding: 3px 8px;
  border-radius: 99px;
  white-space: nowrap;
}
.dd-pill .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.dd-pill.concept {
  background: #f1f0ec;
  color: #5b5b66;
}
.dd-pill.verstuurd {
  background: var(--blue-bg);
  color: var(--blue);
}
.dd-pill.akkoord {
  background: var(--green-bg);
  color: var(--green);
}
.dd-pill.verlopen {
  background: var(--red-bg);
  color: var(--red);
}
.dd-pill.wacht {
  background: var(--amber-bg);
  /* #c77700 op #fdf3e0 ≈ 4.0:1 (faalt AA). Donkerder amber-ink ≈ 5.4:1. */
  color: #9a5b00;
}
.dd-pill.acc {
  background: var(--acc-bg);
  color: var(--acc-ink);
}
/* pipeline-stage varianten (lead/prospect/klant/verloren) */
.dd-pill.lead {
  background: #f1f0ec;
  color: #5b5b66;
}
.dd-pill.prospect {
  background: var(--blue-bg);
  color: var(--blue);
}
.dd-pill.klant {
  background: var(--green-bg);
  color: var(--green);
}
.dd-pill.verloren {
  background: var(--red-bg);
  color: var(--red);
}
/* verkleind in sidebar-rij — leesbaar (≥11px) en geen tracked caps */
.dd-cust-stage {
  font-size: 11px;
  text-transform: none;
  letter-spacing: 0;
  padding: 2px 6px;
  flex-shrink: 0;
}
/* in studio-eyebrow: passende verticale uitlijning */
.dd-studio-stage {
  font-size: 9.5px;
  padding: 1px 6px;
  vertical-align: middle;
}

.dd-btn {
  font: inherit;
  font-weight: 600;
  font-size: 13px;
  border-radius: 10px;
  padding: 8px 14px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid rgba(14, 16, 20, 0.1);
  background: var(--surface);
  color: var(--ink);
  transition:
    filter 0.14s,
    box-shadow 0.14s,
    transform 0.12s;
}
.dd-btn:hover {
  box-shadow:
    0 1px 2px rgba(14, 16, 20, 0.06),
    0 6px 16px -8px rgba(14, 16, 20, 0.2);
}
.dd-btn:active {
  transform: translateY(1px);
}
.dd-btn.primary {
  background: linear-gradient(180deg, var(--acc), var(--acc-d));
  border-color: transparent;
  color: #fff;
  box-shadow:
    0 1px 2px color-mix(in srgb, var(--acc-d) 45%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.dd-btn.primary:hover {
  filter: brightness(1.06);
}
.dd-btn.ghost {
  border-color: transparent;
  background: transparent;
  color: var(--ink-2);
}
.dd-btn.ghost:hover {
  background: var(--divider);
  box-shadow: none;
}
.dd-btn.sm {
  padding: 5px 10px;
  font-size: 12px;
  border-radius: 8px;
}
.dd-btn.danger {
  background: var(--red);
  border-color: transparent;
  color: #fff;
}
.dd-btn.danger:hover {
  filter: brightness(1.06);
}
.dd-btn.lg {
  padding: 11px 18px;
  font-size: 14px;
  border-radius: 12px;
}
.dd-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* editor: "Exporteren ▾" split-menu — native <details>, no JS for open/close */
.dd-export {
  position: relative;
  display: inline-block;
}
.dd-export > summary {
  list-style: none;
  cursor: pointer;
}
.dd-export > summary::-webkit-details-marker {
  display: none;
}
.dd-export-menu {
  position: absolute;
  right: 0;
  margin-top: 6px;
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 6px;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 12px;
  box-shadow: 0 8px 24px -12px rgba(14, 16, 20, 0.18);
}
.dd-export-menu .dd-btn {
  justify-content: flex-start;
}

/* editor canvas: visible keyboard focus ring (replaces Tailwind focus:outline-none) */
#editorCanvas:focus-visible {
  outline: 2px solid var(--acc);
  outline-offset: 2px;
  border-radius: 8px;
}

/* ---- toegankelijkheid: één zichtbare focus-ring voor alle interactieve
   dealdesk-elementen (de "blauwe focus-ring" uit PRODUCT.md). :where() houdt
   de specificiteit op 0 zodat input-:focus-stijlen blijven gelden. Outline
   volgt automatisch de border-radius van het element. ---- */
:where(
  .dd-shell a,
  .dd-shell button,
  .dd-shell [role="button"],
  .dd-shell [tabindex]
):focus-visible {
  outline: 2px solid var(--acc);
  outline-offset: 2px;
}
/* topbar-zoekveld heeft inline outline:0 — toon de ring op de wrapper */
.dd-search:focus-within {
  border-color: var(--acc);
  box-shadow: 0 0 0 3px var(--acc-bg);
}

/* Expliciete focus-ring per interactief element. Tailwind preflight strip de
   UA-outline, dus de generieke :where()-regel hierboven dekt niet alles (chips,
   rijen en tabs hebben class-specifieke achtergronden). Deze regel garandeert
   een zichtbare toetsenbord-focus op elk van die controls. */
.dd-ck-item:focus-visible,
.dd-cust-row:focus-visible,
.dd-ck-tab:focus-visible,
.dd-ag-chip:focus-visible,
.dd-ag-chipmain:focus-visible,
.dd-ag-check:focus-visible,
.dd-ag-dayadd:focus-visible,
.dd-navlink:focus-visible {
  outline: 2px solid var(--acc);
  outline-offset: 2px;
}

/* ============================================================================
   Cockpit (Fase 2) — werklijst / maanddoel-ring / preview / digest
   ========================================================================== */
[x-cloak] {
  display: none !important;
}

.dd-cockpit {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

/* ---- header + ring ---- */
.dd-ck-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  padding: 24px 32px 16px;
  flex: none;
}
.dd-ck-eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--acc-d);
}
.dd-ck-title {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 2px;
}
.dd-ck-sub {
  font-size: 13.5px;
  color: var(--ink-2);
  margin-top: 3px;
}
.dd-ck-sub strong {
  color: var(--ink);
  font-weight: 600;
}
.dd-ck-headright {
  display: flex;
  align-items: center;
  gap: 20px;
}
.dd-ck-kbdhint {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--ink-3);
}
.dd-ck-kbdhint span {
  margin: 0 2px;
}
.dd-ck-kbdhint kbd,
.dd-ck-head kbd {
  font-size: 10.5px;
  border: 1px solid var(--divider);
  border-bottom-width: 2px;
  border-radius: 5px;
  padding: 1px 5px;
  color: var(--ink-2);
  background: var(--surface);
}
@media (max-width: 1279px) {
  .dd-ck-kbdhint {
    display: none;
  }
}
.dd-ring {
  position: relative;
  width: 64px;
  height: 64px;
  flex: none;
}
.dd-ring-track {
  stroke: #e9edf3;
}
.dd-ring-val {
  stroke: url(#ddrg);
  stroke-linecap: round;
  transition: stroke-dashoffset 0.6s ease;
}
.dd-ring-label {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.dd-ring-pct {
  font-size: 14px;
  font-weight: 700;
}
.dd-ring-cap {
  font-size: 7.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  margin-top: 2px;
  color: var(--ink-3);
}

/* ---- body grid ---- */
.dd-ck-body {
  flex: 1;
  display: flex;
  gap: 20px;
  padding: 0 32px 22px;
  min-height: 0;
}
.dd-ck-listcol {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.dd-ck-listcard {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

/* ---- filter-tabs ---- */
.dd-ck-tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 18px;
  height: 48px;
  flex: none;
  border-bottom: 1px solid var(--divider);
  overflow-x: auto;
}
.dd-ck-tab {
  font: inherit;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-2);
  padding: 6px 12px;
  border-radius: 10px;
  border: 0;
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
  flex: none;
}
.dd-ck-tab:hover {
  background: #f2f4f8;
}
.dd-ck-tab.on {
  color: #fff;
  background: var(--ink);
  font-weight: 600;
}
.dd-ck-tab.on .dd-ck-tabn {
  color: rgba(255, 255, 255, 0.7) !important;
}
.dd-ck-tabn {
  font-size: 11px;
  font-weight: 700;
  margin-left: 2px;
}
.dd-ck-sortnote {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--ink-3);
  white-space: nowrap;
  flex: none;
}

/* ---- werklijst-items ---- */
.dd-ck-list {
  flex: 1;
  overflow-y: auto;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.dd-ck-item {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  text-align: left;
  font: inherit;
  padding: 11px 14px 11px 16px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  transition:
    background 0.12s,
    box-shadow 0.12s;
}
.dd-ck-item:hover {
  background: #fafbfd;
}
.dd-ck-item.sel {
  background: var(--surface);
  border-color: var(--divider);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--acc) 35%, transparent),
    0 8px 22px -14px rgba(14, 16, 20, 0.4);
}
.dd-ck-catpill {
  flex: none;
  width: 78px;
  justify-content: center;
}
.dd-ck-itmain {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.dd-ck-ittitle {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dd-ck-itsub {
  font-size: 12px;
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dd-ck-itright {
  flex: none;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 1px;
}
.dd-ck-itamt {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
}
.dd-ck-itmeta {
  font-size: 11px;
  color: var(--ink-3);
}
.dd-ck-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 10px;
  padding: 40px;
  color: var(--ink-2);
}
.dd-ck-empty p {
  font-size: 13.5px;
  max-width: 42ch;
  line-height: 1.55;
}

/* ---- digest ---- */
.dd-ck-digest {
  margin-top: 16px;
  padding: 0 6px;
  flex: none;
}
.dd-ck-digest-h {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 8px;
}
.dd-ck-digest-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 20px;
  font-size: 12.5px;
  color: var(--ink-2);
}
.dd-ck-digest-item {
  display: flex;
  align-items: center;
  gap: 6px;
}
.dd-ck-digest-item b {
  color: var(--ink);
}
.dd-ck-digest-dot {
  width: 5px;
  height: 5px;
  border-radius: 99px;
  flex: none;
}

/* ---- preview ---- */
.dd-ck-preview {
  flex: 0 1 400px;
  min-width: 300px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
@media (max-width: 1023px) {
  .dd-ck-preview {
    display: none !important;
  }
}
.dd-pv-hero {
  position: relative;
  height: 138px;
  flex: none;
  /* Licht i.p.v. donkere --sidebar-gradient (AI-dark tell): kalme accent-tint. */
  background: var(--acc-bg);
  border-bottom: 1px solid var(--divider);
}
.dd-pv-hero-overlay {
  position: absolute;
  inset: 0;
  opacity: 0.5;
  background-image: radial-gradient(
    circle at 78% 22%,
    color-mix(in srgb, var(--acc) 14%, transparent),
    transparent 55%
  );
}
.dd-pv-hero-top {
  position: absolute;
  top: 16px;
  left: 16px;
  right: 16px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.dd-pv-num {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--ink-3);
}
.dd-pv-amt {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-top: 2px;
}
.dd-pv-hero-bottom {
  position: absolute;
  bottom: 12px;
  left: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.dd-pv-client {
  background: color-mix(in srgb, var(--acc) 16%, var(--surface));
  color: var(--acc-ink);
}
.dd-pv-owner {
  font-size: 11px;
  color: var(--ink-2);
}
.dd-pv-body {
  padding: 20px;
  flex: 1;
  overflow-y: auto;
}
.dd-pv-title {
  font-size: 16.5px;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.35;
}
.dd-pv-meta {
  font-size: 12px;
  color: var(--ink-3);
  margin-top: 6px;
}
.dd-pv-reason {
  margin-top: 16px;
  border-radius: 12px;
  padding: 14px;
  background: #f7f8fb;
  border: 1px solid var(--divider);
}
.dd-pv-reason-h,
.dd-pv-trail-h {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 6px;
}
.dd-pv-reason-p {
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
.dd-pv-trail-wrap {
  margin-top: 16px;
}
.dd-pv-trail {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dd-pv-trail-row {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 12.5px;
  color: var(--ink-2);
}
.dd-pv-trail-dot {
  width: 7px;
  height: 7px;
  border-radius: 99px;
  flex: none;
}
.dd-pv-trail-when {
  margin-left: auto;
  color: var(--ink-3);
  font-size: 12px;
}
.dd-pv-actions {
  padding: 14px;
  flex: none;
  display: flex;
  gap: 8px;
  border-top: 1px solid var(--divider);
}
.dd-pv-actions .dd-btn {
  flex: 1;
  justify-content: center;
}

/* scrollbar */
.dd-content::-webkit-scrollbar,
.dd-nav::-webkit-scrollbar,
.dd-ck-list::-webkit-scrollbar,
.dd-pv-body::-webkit-scrollbar,
.dd-studio-build-scroll::-webkit-scrollbar,
.dd-studio-paper-scroll::-webkit-scrollbar,
.dd-studio-copilot-body::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}
.dd-content::-webkit-scrollbar-thumb,
.dd-nav::-webkit-scrollbar-thumb,
.dd-ck-list::-webkit-scrollbar-thumb,
.dd-pv-body::-webkit-scrollbar-thumb,
.dd-studio-build-scroll::-webkit-scrollbar-thumb,
.dd-studio-paper-scroll::-webkit-scrollbar-thumb,
.dd-studio-copilot-body::-webkit-scrollbar-thumb {
  background: #d3d9e3;
  border-radius: 8px;
}
.dd-nav::-webkit-scrollbar-thumb {
  background: #2a2d36;
}
.dd-studio-build-scroll::-webkit-scrollbar-thumb,
.dd-studio-paper-scroll::-webkit-scrollbar-thumb {
  background: #e2e6ef;
}

/* =========================================================================
   Dealdesk Fase 3 — Pijplijn (kanban-board)
   ========================================================================= */
.dd-pl {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  /* inset gelijk aan cockpit (.dd-ck-head 32px) zodat de pijplijn niet strak
     tegen sidebar/rand plakt; box-sizing:border-box (Tailwind preflight). */
  padding: 22px 32px 18px;
}
.dd-pl-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.dd-pl-eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--acc-d);
}
.dd-pl-title {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 2px 0 2px;
}
.dd-pl-sub {
  font-size: 13.5px;
  color: var(--ink-2);
}
.dd-pl-tools {
  display: flex;
  align-items: center;
  gap: 8px;
}
.dd-selbtn {
  font: inherit;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink-2);
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid rgba(14, 16, 20, 0.1);
  border-radius: 10px;
  padding: 7px 12px;
  cursor: pointer;
  transition: background 0.12s;
}
.dd-selbtn:hover {
  background: #fff;
}
.dd-seg {
  display: inline-flex;
  background: #eef1f6;
  border-radius: 10px;
  padding: 3px;
  gap: 2px;
}
.dd-seg button {
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-2);
  padding: 5px 12px;
  border-radius: 8px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.dd-seg button.on {
  background: #fff;
  color: var(--ink);
  box-shadow: 0 1px 2px rgba(14, 16, 20, 0.12);
}

/* board grid: auto-fit kolommen, horizontaal scrollen bij veel statussen */
.dd-board {
  flex: 1;
  min-height: 0;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(248px, 1fr);
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 8px;
}
.dd-pcol {
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: rgba(255, 255, 255, 0.55);
  border-radius: 16px;
  padding: 10px;
  box-shadow: 0 0 0 1px rgba(14, 16, 20, 0.05);
  transition:
    background 0.15s,
    box-shadow 0.15s;
}
.dd-pcol.over {
  background: var(--acc-bg);
  box-shadow: inset 0 0 0 2px var(--acc);
}
.dd-pcol-head {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 2px 4px 8px;
  flex-shrink: 0;
}
.dd-pcol-dot {
  width: 9px;
  height: 9px;
  border-radius: 99px;
  flex-shrink: 0;
}
.dd-pcol-name {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--ink);
}
.dd-pcol-n {
  font-size: 10.5px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 99px;
  background: #eef1f6;
  color: var(--ink-3);
}
.dd-pcol-sum {
  margin-left: auto;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--ink-2);
}
.dd-pcol-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 2px;
}
.dd-ocard {
  cursor: grab;
  background: #fff;
  border-radius: 12px;
  padding: 11px 12px;
  text-align: left;
  text-decoration: none;
  color: inherit;
  display: block;
  box-shadow:
    0 0 0 1px rgba(14, 16, 20, 0.07),
    0 1px 2px rgba(14, 16, 20, 0.05);
  transition:
    transform 0.12s,
    box-shadow 0.12s;
}
.dd-ocard:hover {
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(14, 16, 20, 0.09),
    0 6px 16px -6px rgba(14, 16, 20, 0.18);
}
.dd-ocard.dragging {
  opacity: 0.45;
  transform: rotate(1.5deg) scale(0.98);
}
.dd-ocard.is-sel {
  box-shadow:
    0 0 0 2px var(--acc),
    0 6px 16px -6px rgba(14, 16, 20, 0.18);
}
.dd-ocard-check,
.dd-pcol-check {
  width: 15px;
  height: 15px;
  accent-color: var(--acc);
  cursor: pointer;
  flex-shrink: 0;
  margin: 0;
}
.dd-ocard-check {
  margin-right: 1px;
}
.dd-ocard-top {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--ink-3);
}
.dd-ocard-eye {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.dd-ocard-age {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10.5px;
  font-weight: 600;
  color: var(--ink-3);
}
.dd-ocard-agedot {
  width: 7px;
  height: 7px;
  border-radius: 99px;
}
.dd-ocard-title {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.3;
  margin-top: 6px;
  color: var(--ink);
}
.dd-ocard-client {
  font-size: 11.5px;
  margin-top: 1px;
  color: var(--ink-3);
}
.dd-ocard-amt {
  font-size: 13.5px;
  font-weight: 700;
  margin-top: 8px;
  color: var(--ink);
}
.dd-pl-drop {
  height: 88px;
  border-radius: 12px;
  border: 1.5px dashed #d3d9e3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 500;
  color: var(--ink-3);
}

/* =========================================================================
   STUDIO (Fase 4) — editor-drieluik: Opbouw | A4-preview | Copiloot
   ========================================================================= */
.dd-studio {
  height: 100%;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 12px 20px 14px;
}
.dd-studio-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 10px;
  flex-shrink: 0;
}
.dd-studio-eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--acc-d);
}
.dd-studio-title {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 1px;
  color: var(--ink);
}
.dd-studio-client {
  font-weight: 500;
  font-size: 15px;
  color: var(--ink-3);
}
.dd-studio-headright {
  display: flex;
  align-items: center;
  gap: 18px;
}
.dd-studio-amt {
  font-variant-numeric: tabular-nums;
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
  white-space: nowrap;
}
.dd-studio-amt:empty {
  display: none;
}
.dd-studio-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.dd-studio-dirty {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  color: var(--amber);
}
.dd-studio-dirty-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--amber);
}

/* ---- panes ---- */
.dd-studio-panes {
  flex: 1;
  min-height: 0;
  display: flex;
  gap: 18px;
}
.dd-studio-build {
  /* Flexibel i.p.v. hard 460px: mag krimpen tot 400, groeien als de copiloot
     is ingeklapt, zodat de regels-editor genoeg werkruimte houdt. */
  flex: 1 1 480px;
  min-width: 340px;
  max-width: 720px;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 16px;
  box-shadow: 0 1px 2px rgba(14, 16, 20, 0.04);
  overflow: hidden;
}
/* Regels-tab heeft de meeste kolommen → geef de opbouw-kolom extra ruimte,
   maar alleen als de copiloot is ingeklapt (anders zou de preview te smal
   worden). Met open copiloot houdt de preview zo zijn eerlijke breedte. */
.dd-studio.tab-regels.copilot-collapsed .dd-studio-build {
  flex-grow: 2;
  max-width: 760px;
}
.dd-studio-tabs {
  display: flex;
  flex-shrink: 0;
  border-bottom: 1px solid var(--divider);
  background: var(--surface);
  padding: 0 8px;
}
.dd-studio-tab {
  flex: 1;
  padding: 8px 4px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-3);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition:
    color 0.12s,
    border-color 0.12s;
}
.dd-studio-tab:hover {
  color: var(--ink);
}
.dd-studio-tab.on {
  color: var(--acc-ink, var(--ink));
  border-bottom-color: var(--acc);
}
.dd-studio-build-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 10px 14px;
}
.dd-studio-section {
  padding: 8px 0;
  border-bottom: 1px solid var(--divider);
}
.dd-studio-section:last-child {
  border-bottom: 0;
}
.dd-studio-section-h {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  /* margin-top: 0 zodat de class veilig op <h2> kan zonder UA-marge. */
  margin-top: 0;
  margin-bottom: 7px;
}

/* catalogus-zoekbalk sticky boven regelposten */
.dd-studio-section--catalog-sticky {
  position: sticky;
  top: -10px;
  z-index: 2;
  background: var(--surface);
  margin: -10px -14px 0;
  padding: 10px 14px 8px;
  border-bottom: 1px solid var(--divider);
}
/* G-07: geselecteerde catalogus-doelregel visueel markeren */
#line-items-body tr.dd-catalog-active {
  background: color-mix(in srgb, var(--acc) 10%, transparent);
  outline: 2px solid var(--acc);
  outline-offset: -2px;
}
.dd-studio-form {
  display: block;
}
.dd-studio-build-foot {
  flex-shrink: 0;
  border-top: 1px solid var(--divider);
  background: #fafbfd;
  padding: 12px 16px;
}
.dd-studio-marge {
  margin-top: 12px;
}
.dd-studio-marge-row {
  display: flex;
  justify-content: space-between;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 5px;
}
.dd-studio-marge-track {
  height: 6px;
  border-radius: 999px;
  background: #e9edf3;
  overflow: hidden;
}
.dd-studio-marge-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #34d399, var(--green));
  transition: width 0.2s ease;
}

/* ---- Rekenen-indicator (HTMX htmx-indicator) ---- */
.dd-rekenen {
  opacity: 0;
  transition: opacity 200ms ease-in;
  font-size: 11px;
  color: var(--ink-3);
  margin-right: 8px;
  flex-shrink: 0;
  pointer-events: none;
}
.htmx-request .dd-rekenen,
.htmx-request.dd-rekenen {
  opacity: 1;
}

/* ---- Responsief detail-grid voor regelrij-velden ---- */
.dd-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}

/* ---- A4 paper (live preview) ---- */
/* Reopen-rail: zichtbaar als preview ingeklapt is */
.dd-studio-paper-reopen {
  display: none;
  width: 28px;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--ink-3);
  border: 1px solid var(--divider);
  border-radius: 10px;
  background: var(--surface);
  transition:
    color 0.14s,
    background 0.14s;
}
.dd-studio-paper-reopen:hover {
  color: var(--ink);
  background: var(--body);
}
.dd-studio.paper-collapsed .dd-studio-paper-reopen {
  display: flex;
}
/* Ingeklapte preview — geeft de build-kolom meer breedte */
.dd-studio.paper-collapsed .dd-studio-paper {
  display: none;
}
.dd-studio.paper-collapsed .dd-studio-build {
  max-width: none;
  flex-grow: 2;
}
/* Collapse-knop in de paper-bar */
.dd-studio-paper-collapse {
  margin-left: 4px;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 7px;
  border: 1px solid var(--divider);
  background: var(--surface);
  color: var(--ink-3);
  cursor: pointer;
  transition:
    color 0.14s,
    background 0.14s;
}
.dd-studio-paper-collapse:hover {
  color: var(--ink);
  background: var(--body);
}

.dd-studio-paper {
  flex: 1;
  /* Min-breedte zodat de live-preview niet door build + copiloot wordt
     platgedrukt op de laptop-band (was min-width:0 → kromp tot ~166px op 1440). */
  min-width: 360px;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.dd-studio-paper-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  flex-shrink: 0;
}
.dd-studio-paper-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-2);
}
.dd-studio-paper-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  justify-content: center;
  padding-top: 2px;
}
.dd-studio-paper-empty {
  padding: 28px;
  font-size: 13px;
  color: var(--ink-3);
}
.dd-paper {
  width: 100%;
  max-width: 600px;
  height: fit-content;
}
/* paper rendering of _build_offer_html (.offer-doc) */
.dd-paper .offer-doc {
  position: relative;
  background: #fff;
  border-radius: 10px;
  box-shadow:
    0 1px 2px rgba(14, 16, 20, 0.06),
    0 18px 50px -28px rgba(14, 16, 20, 0.4);
  padding: 40px 44px;
  color: #2a2a33;
  font-size: 12.5px;
  line-height: 1.6;
  overflow: hidden;
}
.dd-paper .offer-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}
.dd-paper .offer-doc > *:not(.offer-bg) {
  position: relative;
  z-index: 1;
}
.dd-paper .company-info {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 22px;
}
.dd-paper .company-info__name {
  font-weight: 700;
  font-size: 15px;
  color: var(--ink);
}
.dd-paper .company-info__addr {
  font-size: 10.5px;
  color: #8a8a96;
  white-space: pre-line;
  text-align: right;
}
.dd-paper .offer-client-block {
  margin-bottom: 16px;
  font-size: 12px;
}
.dd-paper .offer-client-block strong {
  font-weight: 700;
}
.dd-paper .fallback-simple-table {
  width: 100%;
  border-collapse: collapse;
  margin: 14px 0;
  font-size: 11.5px;
}
.dd-paper .fallback-simple-table td {
  padding: 6px 4px;
  border-bottom: 1px solid #eeece7;
  vertical-align: top;
}
.dd-paper .fallback-simple-table img {
  border-radius: 6px;
}
.dd-paper .offer-totals {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
}
.dd-paper .offer-totals > div {
  display: flex;
  justify-content: space-between;
  gap: 22px;
  min-width: 200px;
  font-size: 12px;
}
.dd-paper .offer-totals > div:last-child {
  font-weight: 700;
  border-top: 1.5px solid #2a2a33;
  padding-top: 6px;
  margin-top: 3px;
}
.dd-studio-prev-err {
  padding: 18px;
  border-radius: 10px;
  background: var(--red-bg);
  color: var(--red);
  font-size: 12.5px;
  font-weight: 500;
}

/* ---- copilot ---- */
.dd-studio-copilot {
  flex: 0 1 320px;
  min-width: 260px;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 16px;
  box-shadow: 0 1px 2px rgba(14, 16, 20, 0.04);
  overflow: hidden;
}
/* Ingeklapte copiloot — geeft de live-preview zijn breedte terug. */
.dd-studio.copilot-collapsed .dd-studio-copilot {
  display: none;
}
.dd-studio-copilot-collapse {
  margin-left: auto;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 7px;
  border: 1px solid var(--divider);
  background: var(--surface);
  color: var(--ink-3);
  cursor: pointer;
  transition:
    color 0.14s,
    background 0.14s;
}
.dd-studio-copilot-collapse:hover {
  color: var(--ink);
  background: var(--body);
}
/* "Copiloot tonen"-knop in de studio-acties (alleen zichtbaar bij ingeklapt). */
.dd-studio-copilot-show {
  display: none;
}
.dd-studio.copilot-collapsed .dd-studio-copilot-show {
  display: inline-flex;
}
.dd-studio-copilot-h {
  display: flex;
  align-items: center;
  gap: 9px;
  height: 50px;
  padding: 0 14px;
  flex-shrink: 0;
  border-bottom: 1px solid var(--divider);
}
.dd-studio-copilot-orb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--acc-l), var(--acc-d));
  box-shadow: 0 0 0 3px var(--acc-bg);
}
.dd-studio-copilot-title {
  font-size: 13.5px;
  font-weight: 700;
  flex: 1;
  color: var(--ink);
}
.dd-studio-copilot-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 12px;
}
.dd-studio-copilot-off {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 24px;
  text-align: center;
  font-size: 12.5px;
  color: var(--ink-3);
}
.dd-studio-cop-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.dd-studio-cop-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 11px;
  border-radius: 10px;
  border: 1px solid var(--divider);
  background: #f7f8fb;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink-2);
  cursor: pointer;
  transition:
    background 0.12s ease,
    border-color 0.12s ease;
  text-align: left;
}
.dd-studio-cop-btn:hover:not(:disabled) {
  background: #fff;
  border-color: color-mix(in srgb, var(--acc) 40%, var(--divider));
}
.dd-studio-cop-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.dd-studio-cop-spin {
  width: 13px;
  height: 13px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: dd-spin 0.7s linear infinite;
}
@keyframes dd-spin {
  to {
    transform: rotate(360deg);
  }
}
.dd-studio-cop-card {
  border-radius: 12px;
  border: 1px solid var(--divider);
  background: #f7f8fb;
  padding: 12px;
}
.dd-studio-cop-card-h {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 6px;
}
.dd-studio-cop-lbl {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--ink-3);
  margin: 8px 0 3px;
}
.dd-studio-cop-text {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--ink-2);
  white-space: pre-wrap;
  word-break: break-word;
  background: #fff;
  border-radius: 6px;
  padding: 7px 9px;
}
.dd-studio-cop-row {
  display: flex;
  gap: 6px;
  margin-top: 10px;
}
.dd-studio-cop-prevrow {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  border-radius: 10px;
  border: 1px solid var(--divider);
  background: #fff;
  padding: 9px 10px;
}
.dd-studio-cop-prevlabel {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dd-studio-cop-prevmeta {
  font-size: 11px;
  color: var(--ink-3);
  margin-top: 2px;
}

/* Tussen-breakpoint: op laptops (≤1400px) zou de vaste copiloot de A4-preview
   platdrukken. Wanneer de copiloot dan toch open staat, toont hij als een
   rechter off-canvas lade boven de preview i.p.v. een derde inline-kolom. De
   Alpine x-init klapt hem op dit formaat standaard in (zie build.html). */
@media (min-width: 1081px) and (max-width: 1400px) {
  .dd-studio:not(.copilot-collapsed) .dd-studio-copilot {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 360px;
    max-width: 86vw;
    z-index: 60;
    border-radius: 0;
    border-left: 1px solid var(--divider);
    box-shadow: -10px 0 34px rgba(14, 16, 20, 0.2);
  }
}

@media (max-width: 1080px) {
  .dd-studio {
    height: auto;
    padding: 16px;
  }
  .dd-studio-panes {
    flex-direction: column;
  }
  .dd-studio-build,
  .dd-studio-copilot {
    width: 100%;
    max-width: none;
  }
  .dd-studio-build {
    flex: 1 1 auto;
  }
  .dd-studio-build-scroll {
    overflow-y: visible;
  }
  .dd-studio-paper {
    min-height: 70vh;
    /* Reset de laptop-min-breedte zodra de panes stacken (volle breedte),
       anders forceert min-width:360px overflow op telefoons <360px. */
    min-width: 0;
  }
}

/* Compacte laptop/tablet-band (1024–1279px): de fluïde paneelbreedtes vangen het
   meeste op; hier alleen de royale horizontale paddings inkrimpen zodat de master-
   detail-layouts geen ruimte verspillen. */
@media (min-width: 1024px) and (max-width: 1279px) {
  .dd-ck-body,
  .dd-cust-body {
    padding-left: 16px;
    padding-right: 16px;
  }
  .dd-pl {
    padding-left: 16px;
    padding-right: 16px;
  }
}

/* Touch-apparaten: WCAG 2.5.5 — interactieve elementen ≥44px. Op muis/precision
   pointers blijven de compactere desktop-maten staan. */
@media (pointer: coarse) {
  .dd-btn,
  .dd-studio-tab,
  .dd-studio-copilot-collapse,
  .dd-sidebar-toggle,
  .dd-ck-tab,
  .dd-ag-chip,
  .dd-ag-chipmain,
  .dd-ag-check,
  .dd-ag-dayadd,
  .dd-cust-row {
    min-height: 44px;
  }
  .dd-studio-copilot-collapse,
  .dd-sidebar-toggle {
    min-width: 44px;
    width: 44px;
    height: 44px;
  }
  /* Hit-area-vergroting voor de kleine agenda-controls op touch. */
  .dd-ag-check,
  .dd-ag-dayadd {
    min-width: 44px;
    justify-content: center;
  }
  /* Dayadd is op desktop hover-only (opacity:0). Op coarse pointers bestaat geen
     hover → maak 'm permanent zichtbaar en bedienbaar. */
  .dd-ag-dayadd {
    opacity: 1;
  }
}

/* =========================================================================
   Dealdesk Fase 6 — Klant 360 (master-detail relatie-cockpit)
   ========================================================================= */
.dd-cust {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}
.dd-cust-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  padding: 24px 32px 16px;
  flex: none;
}
.dd-cust-eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--acc-d);
}
.dd-cust-title {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 2px;
}
.dd-cust-sub {
  font-size: 13.5px;
  color: var(--ink-2);
  margin-top: 3px;
}
.dd-cust-sub strong {
  color: var(--ink);
  font-weight: 600;
}

.dd-cust-body {
  flex: 1;
  display: flex;
  gap: 20px;
  padding: 0 32px 22px;
  min-height: 0;
}

/* ---- linker werklijst ---- */
.dd-cust-listcard {
  flex: 0 0 clamp(260px, 26vw, 340px);
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.dd-cust-search {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 48px;
  flex: none;
  padding: 0 16px;
  border-bottom: 1px solid var(--divider);
  color: var(--ink-3);
}
.dd-cust-search input {
  border: 0;
  outline: 0;
  background: transparent;
  font: inherit;
  font-size: 13.5px;
  color: var(--ink);
  flex: 1;
  min-width: 0;
}
.dd-cust-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.dd-cust-row {
  display: flex;
  align-items: center;
  gap: 11px;
  width: 100%;
  text-align: left;
  border: 0;
  background: transparent;
  cursor: pointer;
  padding: 9px 11px;
  border-radius: 12px;
  font: inherit;
  transition:
    background 0.12s,
    box-shadow 0.12s;
}
.dd-cust-row:hover {
  background: #f4f6fa;
}
.dd-cust-row.sel {
  background: var(--acc-bg);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--acc) 30%, transparent);
}
.dd-cust-av {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  flex: none;
  display: grid;
  place-items: center;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
}
.dd-cust-rowmain {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.dd-cust-rowname {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dd-cust-rowsub {
  font-size: 11.5px;
  color: var(--ink-3);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dd-cust-rowamt {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--ink-2);
  flex: none;
}
.dd-cust-noresult,
.dd-cust-section-empty {
  padding: 18px 14px;
  font-size: 13px;
  color: var(--ink-3);
  text-align: center;
}
.dd-cust-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
  padding: 40px 22px;
  color: var(--ink-2);
  font-size: 13px;
  line-height: 1.5;
}

/* ---- rechter detail-paneel ---- */
.dd-cust-detail {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.dd-cust-detail-skel {
  margin: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  color: var(--ink-3);
  font-size: 13px;
}
.dd-cust-skel-spin {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 3px solid var(--divider);
  border-top-color: var(--acc);
  animation: dd-cust-spin 0.8s linear infinite;
}
@keyframes dd-cust-spin {
  to {
    transform: rotate(360deg);
  }
}
.dd-cust-pv {
  height: 100%;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

/* hero */
.dd-cust-hero {
  position: relative;
  flex: none;
  padding: 22px 24px;
  /* Licht i.p.v. donkere --sidebar-gradient (AI-dark tell): kalme accent-tint. */
  background: var(--acc-bg);
  border-bottom: 1px solid var(--divider);
  border-radius: 18px 18px 0 0;
  overflow: hidden;
}
.dd-cust-hero-overlay {
  position: absolute;
  inset: 0;
  opacity: 0.55;
  background-image: radial-gradient(
    circle at 84% 16%,
    color-mix(in srgb, var(--acc) 14%, transparent),
    transparent 58%
  );
}
.dd-cust-hero-row {
  position: relative;
  display: flex;
  align-items: center;
  gap: 14px;
}
.dd-cust-hero-av {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  flex: none;
  display: grid;
  place-items: center;
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  box-shadow: 0 6px 16px -8px rgba(14, 16, 20, 0.35);
}
.dd-cust-hero-id {
  flex: 1;
  min-width: 0;
}
.dd-cust-hero-name {
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1.2;
}
.dd-cust-hero-contact {
  font-size: 12.5px;
  color: var(--ink-2);
  margin-top: 3px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dd-cust-hero-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: none;
}
.dd-cust-hero-btn {
  background: var(--surface);
  border-color: var(--divider);
  color: var(--ink-2);
}
.dd-cust-hero-btn:hover {
  background: var(--body);
  color: var(--ink);
}

/* KPI-tegels */
.dd-cust-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--divider);
  border-bottom: 1px solid var(--divider);
  flex: none;
}
.dd-cust-kpi {
  background: var(--surface);
  padding: 14px 18px;
}
.dd-cust-kpi-lbl {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.dd-cust-kpi-val {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-top: 4px;
}

/* speelveld / AI-callout */
.dd-cust-field-card {
  display: flex;
  gap: 12px;
  margin: 18px 22px 0;
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--amber-bg);
  border: 1px solid color-mix(in srgb, var(--amber) 22%, transparent);
}
.dd-cust-field-icon {
  flex: none;
  color: var(--amber);
  margin-top: 1px;
}
.dd-cust-field-body {
  flex: 1;
  min-width: 0;
}
.dd-cust-field-h {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 5px;
}
.dd-cust-field-p {
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
.dd-cust-ai-out {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed color-mix(in srgb, var(--amber) 30%, transparent);
}
.dd-cust-ai-err {
  margin-top: 6px;
  font-size: 12px;
  color: var(--red);
}
.dd-cust-ai-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: none;
  cursor: pointer;
  border: 1px solid color-mix(in srgb, var(--amber) 35%, transparent);
  background: var(--surface);
  color: var(--amber);
  border-radius: 99px;
  padding: 3px 10px;
}
.dd-cust-ai-btn:hover {
  background: #fff;
  filter: brightness(0.98);
}
.dd-cust-ai-btn:disabled {
  opacity: 0.6;
  cursor: default;
}

/* secties (offertes + tijdlijn) */
.dd-cust-section {
  padding: 0 22px;
  margin-top: 20px;
}
.dd-cust-section:last-child {
  padding-bottom: 22px;
}
.dd-cust-section-h {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 10px;
}
.dd-cust-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
}
.dd-cust-table th {
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding: 0 10px 8px;
  border-bottom: 1px solid var(--divider);
}
.dd-cust-th-r {
  text-align: right;
}
.dd-cust-trow {
  cursor: pointer;
  transition: background 0.12s;
}
.dd-cust-trow:hover {
  background: #f4f6fa;
}
.dd-cust-table td {
  padding: 10px;
  border-bottom: 1px solid var(--divider);
  vertical-align: middle;
}
.dd-cust-td-num {
  font-weight: 600;
  color: var(--ink-2);
  white-space: nowrap;
}
.dd-cust-td-subj {
  color: var(--ink);
  font-weight: 500;
}
.dd-cust-td-last {
  color: var(--ink-3);
  white-space: nowrap;
}

.dd-cust-timeline {
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.dd-cust-tl-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
}
.dd-cust-tl-dot {
  width: 8px;
  height: 8px;
  border-radius: 99px;
  flex: none;
}
.dd-cust-tl-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  line-height: 1.3;
}
.dd-cust-tl-lbl {
  color: var(--ink);
  font-weight: 500;
}
.dd-cust-tl-sub {
  color: var(--ink-3);
  font-size: 11.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dd-cust-tl-when {
  margin-left: auto;
  color: var(--ink-3);
  font-size: 12px;
  flex: none;
}

/* scrollbars in lijn met de rest van de shell */
.dd-cust-list::-webkit-scrollbar,
.dd-cust-pv::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
.dd-cust-list::-webkit-scrollbar-thumb,
.dd-cust-pv::-webkit-scrollbar-thumb {
  background: #d3d9e3;
  border-radius: 8px;
}

/* create / edit modal */
.dd-cust-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: rgba(14, 16, 20, 0.42);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.dd-cust-modal {
  width: 100%;
  max-width: 540px;
  max-height: 90vh;
  overflow-y: auto;
}
.dd-cust-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid var(--divider);
}
.dd-cust-modal-head h2 {
  font-size: 16px;
  font-weight: 700;
}
.dd-cust-modal-x {
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 16px;
  color: var(--ink-3);
  line-height: 1;
}
.dd-cust-modal-x:hover {
  color: var(--ink);
}
.dd-cust-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  padding: 20px 22px;
}
.dd-cust-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.dd-cust-field-full {
  grid-column: 1 / -1;
}
.dd-cust-field > span {
  font-size: 11px;
  font-weight: 600;
  color: var(--ink-2);
}
.dd-cust-field input,
.dd-cust-field textarea {
  font: inherit;
  font-size: 13px;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 9px;
  padding: 8px 11px;
  outline: none;
  transition:
    border-color 0.12s,
    box-shadow 0.12s;
}
.dd-cust-field input:focus,
.dd-cust-field textarea:focus {
  border-color: var(--acc);
  box-shadow: 0 0 0 3px var(--acc-bg);
}
.dd-cust-modal-err {
  grid-column: 1 / -1;
  font-size: 12.5px;
  color: var(--red);
  margin: -2px 0 0;
}
.dd-cust-modal-foot {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 2px;
}

@media (max-width: 1023px) {
  .dd-cust-body {
    flex-direction: column;
    padding: 0 18px 18px;
  }
  .dd-cust-listcard {
    width: 100%;
    max-height: 38vh;
  }
  .dd-cust-form {
    grid-template-columns: 1fr;
  }
}

/* =========================================================================
   Dealdesk Fase 7 — Agenda (kalender), belmoment-modal & cockpit-strip
   ========================================================================= */

/* ---- cockpit belmomenten-strip ---- */
.dd-ck-agenda {
  margin-top: 14px;
  padding: 14px 16px;
}
.dd-ck-agenda-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.dd-ck-agenda-h {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
}
.dd-ck-agenda-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.dd-ck-agenda-all {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--acc-d);
  text-decoration: none;
}
.dd-ck-agenda-all:hover {
  text-decoration: underline;
}
.dd-ck-agenda-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.dd-ck-agenda-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 6px;
  border-radius: 9px;
}
.dd-ck-agenda-item:hover {
  background: var(--body);
}
.dd-ck-agenda-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex: none;
}
.dd-ck-agenda-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.dd-ck-agenda-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dd-ck-agenda-sub {
  font-size: 11.5px;
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dd-ck-agenda-when {
  flex: none;
}
.dd-ck-agenda-empty {
  font-size: 12.5px;
  color: var(--ink-3);
  margin: 4px 2px 0;
}

/* ---- agenda-pagina ---- */
.dd-ag-wrap {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}
.dd-ag-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  padding: 24px 32px 16px;
  flex: none;
}
.dd-ag-eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--acc-d);
}
.dd-ag-title {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 2px;
}
.dd-ag-sub {
  font-size: 13.5px;
  color: var(--ink-2);
  margin-top: 3px;
}
.dd-ag-sub strong {
  color: var(--ink);
  font-weight: 600;
}
.dd-ag-headright {
  display: flex;
  align-items: center;
  gap: 10px;
}
.dd-ag-filter {
  font: inherit;
  font-size: 12.5px;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 9px;
  padding: 7px 10px;
  outline: none;
  cursor: pointer;
}
.dd-ag-filter:focus {
  border-color: var(--acc);
  box-shadow: 0 0 0 3px var(--acc-bg);
}

.dd-ag-card {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  margin: 0 32px 24px;
  padding: 14px 16px;
  overflow: hidden;
}
.dd-ag {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}
.dd-ag-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 12px;
  flex: none;
}
.dd-ag-nav {
  display: flex;
  align-items: center;
  gap: 8px;
}
.dd-ag-navbtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--divider);
  background: var(--surface);
  border-radius: 8px;
  color: var(--ink-2);
  cursor: pointer;
  transition:
    background 0.12s,
    color 0.12s;
}
.dd-ag-navbtn:hover {
  background: var(--body);
  color: var(--ink);
}
.dd-ag-period {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-left: 6px;
}
.dd-ag-viewtoggle {
  display: inline-flex;
  background: var(--body);
  border: 1px solid var(--divider);
  border-radius: 9px;
  padding: 2px;
  gap: 2px;
}
.dd-ag-vbtn {
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink-3);
  padding: 5px 14px;
  border-radius: 7px;
  cursor: pointer;
}
.dd-ag-vbtn.on {
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 1px 2px rgba(14, 16, 20, 0.08);
}
.dd-ag-weekhead {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
  flex: none;
  padding-bottom: 6px;
}
.dd-ag-wh {
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.dd-ag-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  align-content: start;
}
.dd-ag-month {
  grid-auto-rows: minmax(96px, 1fr);
}
.dd-ag-week {
  grid-auto-rows: minmax(380px, 1fr);
}
.dd-ag-day {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  border: 1px solid var(--divider);
  border-radius: 12px;
  background: var(--surface);
  padding: 6px;
  transition:
    border-color 0.12s,
    background 0.12s;
}
.dd-ag-day.out {
  background: var(--body);
  opacity: 0.6;
}
.dd-ag-day.today {
  border-color: var(--acc);
  background: var(--acc-bg);
}
.dd-ag-day.drop {
  border: 1px dashed var(--acc);
  background: var(--acc-bg);
}
.dd-ag-daynum {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-2);
}
.dd-ag-day.today .dd-ag-daynum {
  color: var(--acc-ink);
}
.dd-ag-daywd {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--ink-3);
}
.dd-ag-dayadd {
  margin-left: auto;
  border: 0;
  background: transparent;
  color: var(--ink-3);
  font-size: 15px;
  line-height: 1;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.12s;
}
.dd-ag-day:hover .dd-ag-dayadd {
  opacity: 1;
}
.dd-ag-dayadd:hover {
  color: var(--acc);
}
.dd-ag-chips {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  overflow: hidden;
}
.dd-ag-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--divider);
  background: var(--body);
  border-radius: 7px;
  padding: 3px 6px;
  cursor: grab;
  min-width: 0;
}
.dd-ag-chip.dragging {
  opacity: 0.45;
}
.dd-ag-chip.type-call {
  border-color: color-mix(in srgb, var(--purple) 28%, var(--divider));
  background: var(--purple-bg);
}
.dd-ag-chip.type-task {
  border-color: color-mix(in srgb, var(--blue) 28%, var(--divider));
  background: var(--blue-bg);
}
.dd-ag-chip.type-note {
  border-color: var(--divider);
}
.dd-ag-chip.overdue {
  border-color: color-mix(in srgb, var(--red) 32%, var(--divider));
  background: var(--red-bg);
}
.dd-ag-chip.done {
  opacity: 0.55;
}
.dd-ag-check {
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  flex: none;
}
.dd-ag-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  display: block;
}
.dd-ag-chip.done .dd-ag-dot {
  box-shadow: inset 0 0 0 2px var(--surface);
}
.dd-ag-chipmain {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 5px;
  border: 0;
  background: transparent;
  padding: 0;
  text-align: left;
  cursor: pointer;
  overflow: hidden;
}
.dd-ag-time {
  font-size: 11px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--ink-2);
  flex: none;
}
.dd-ag-chiptitle {
  font-size: 12px;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dd-ag-chip.done .dd-ag-chiptitle {
  text-decoration: line-through;
}
.dd-ag-chipsub {
  font-size: 11px;
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ---- belmoment-modal (gebruikt modal-shell dd-cust-modal-*) ---- */
.dd-bm-modal {
  max-width: 460px;
}
.dd-bm-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 20px 22px;
}
.dd-bm-context {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--acc-ink);
  background: var(--acc-bg);
  border-radius: 8px;
  padding: 7px 10px;
  margin: 0;
}
.dd-bm-types {
  display: flex;
  gap: 8px;
}
.dd-bm-type {
  flex: 1;
  border: 1px solid var(--divider);
  background: var(--surface);
  border-radius: 9px;
  padding: 8px;
  font: inherit;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink-2);
  cursor: pointer;
  transition:
    border-color 0.12s,
    background 0.12s,
    color 0.12s;
}
.dd-bm-type.on {
  border-color: var(--acc);
  background: var(--acc-bg);
  color: var(--acc-ink);
}
.dd-bm-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.dd-bm-field > span {
  font-size: 11px;
  font-weight: 600;
  color: var(--ink-2);
}
.dd-bm-field input {
  font: inherit;
  font-size: 13px;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 9px;
  padding: 8px 11px;
  outline: none;
  transition:
    border-color 0.12s,
    box-shadow 0.12s;
}
.dd-bm-field input:focus {
  border-color: var(--acc);
  box-shadow: 0 0 0 3px var(--acc-bg);
}
.dd-bm-row {
  display: flex;
  gap: 12px;
}
.dd-bm-row .dd-bm-field {
  flex: 1;
}

@media (max-width: 1023px) {
  .dd-ag-head {
    flex-direction: column;
    align-items: flex-start;
    padding: 18px 18px 12px;
  }
  .dd-ag-card {
    margin: 0 18px 18px;
  }
  .dd-ag-headright {
    width: 100%;
    flex-wrap: wrap;
  }
}

/* ── Generieke pagina-header + settings-layout ─────────────────────────────
   Gebruikt door gemigreerde base.html-pagina's (AI-instellingen, Huisstijl,
   Templates, Handleiding, Documentbewerker) zodat ze de Dealdesk-look delen. */
.dd-page {
  max-width: 940px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.dd-page-head {
  display: flex;
  /* flex-end matcht de overige schermheaders (dd-ck-head/dd-cust-head/
     dd-ag-head): de actie-knop lijnt uit op de onderkant van het titelblok
     i.p.v. omhoog te zweven naar de eyebrow-regel. */
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 2px;
}
.dd-page-eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--acc-d);
}
.dd-page-title {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 2px;
  color: var(--ink);
}
.dd-page-sub {
  font-size: 13.5px;
  color: var(--ink-2);
  margin-top: 3px;
  max-width: 62ch;
}
.dd-page-sub strong {
  color: var(--ink);
  font-weight: 600;
}

/* Brand-overrides voor de bestaande Tailwind settings-includes (card()-macro
   + _company_*_card / _ai_*_card), scoped op .dd-page zodat de rest ongemoeid
   blijft. Witte kaarten krijgen de dealdesk-rand/-radius; gele focus-ringen
   (oude huisstijl) worden vervangen door de indigo accent. */
.dd-page .rounded-xl,
.dd-page [data-card-id] > div {
  border-radius: 16px;
  border-color: var(--line, #e6e8ef);
  box-shadow:
    0 1px 2px rgba(16, 18, 40, 0.04),
    0 8px 24px rgba(16, 18, 40, 0.04);
}
/* Zichtbare toetsenbord-focus op formuliervelden. Eerder stond hier
   outline:none !important — dat strip de UA-focusring; vervangen door een
   expliciete accent-outline + border/box-shadow zodat een gefocust veld
   nooit zonder zichtbare staat overblijft. */
.dd-page input:focus-visible,
.dd-input:focus-visible,
.dd-page select:focus-visible,
.dd-page textarea:focus-visible {
  outline: 2px solid var(--acc);
  outline-offset: 1px;
}
.dd-page :where(input, select, textarea):focus {
  border-color: var(--acc) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--acc) 22%, transparent) !important;
}

/* =========================================================================
   Responsieve breakpoints — Shell + Studio
   ≥1024px  : volledige 3-koloms layout (standaard)
   768–1023px: sidebar versmalt naar iconen-only; studio-paper verbergen
   <768px   : volledig gestapeld; sidebar als topbar achter hamburger
   ========================================================================= */

/* 768–1023px: compacte sidebar (iconen, geen labels) */
@media (max-width: 1023px) {
  .dd-sidebar {
    width: 56px;
  }
  .dd-brand-name,
  .dd-brand-sub,
  .dd-nav-label,
  .dd-navlink > span:not(.dd-ico):not(.dd-count) {
    display: none;
  }
  .dd-navlink {
    justify-content: center;
    padding: 10px 0;
  }
  .dd-navlink .dd-ico {
    margin: 0;
  }
  .dd-sidebar-foot .dd-btn {
    font-size: 0;
    padding: 10px;
    justify-content: center;
  }
  .dd-studio-paper {
    display: none;
  }
}

/* <768px: sidebar volledig verborgen, content vult breedte */
@media (max-width: 767px) {
  .dd-sidebar {
    display: none;
  }
  .dd-shell {
    height: auto;
    min-height: 100vh;
  }
  .dd-content {
    overflow-y: visible;
  }
  /* studio: enkel de form-pane, volledig gestapeld */
  .dd-studio {
    height: auto;
    padding: 12px;
  }
  .dd-studio-panes {
    flex-direction: column;
  }
  .dd-studio-build,
  .dd-studio-copilot,
  .dd-studio-paper {
    width: 100%;
    display: block;
  }
  .dd-studio-build-scroll {
    overflow-y: visible;
  }
  .dd-studio-paper {
    min-height: 50vh;
  }
  /* cockpit/klant-360 kaarten: enkelvoudige kolom */
  .dd-ck-grid {
    grid-template-columns: 1fr;
  }
  .dd-ck-preview {
    display: none !important;
  }
}

/* ── Toegankelijkheid: respecteer prefers-reduced-motion ───────────────────
   PRODUCT.md eist dat alle entrance/hover-motion gehonoreerd wordt. dealdesk.css
   had hier niets voor. Deze reset neutraliseert transitions/animaties (incl. de
   spinners en hover-transforms) voor gebruikers die reductie hebben gevraagd. */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* =========================================================================
   Generieke modal + formuliervelden (G-06 catalogus, herbruikbaar app-breed)
   Vult het gat dat .dd-input/.dd-label nergens gedefinieerd waren. Spiegelt
   het .dd-cust-field-patroon maar zonder customers-binding. Centreren gebeurt
   via de class (display:grid) i.p.v. inline style, zodat Alpine x-show de
   display niet wegtoggelt (modal bleef anders links-boven plakken).
   ========================================================================= */
.dd-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: grid;
  place-items: center;
  padding: 20px;
  background: color-mix(in srgb, #0b0d1a 52%, transparent);
  backdrop-filter: blur(3px) saturate(120%);
  -webkit-backdrop-filter: blur(3px) saturate(120%);
}
.dd-modal {
  width: 100%;
  max-width: 560px;
  max-height: calc(100dvh - 40px);
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 18px;
  box-shadow:
    0 1px 2px rgba(16, 18, 40, 0.06),
    0 24px 60px rgba(16, 18, 40, 0.28);
  overflow: hidden;
}
.dd-modal-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 20px 22px 16px;
  border-bottom: 1px solid var(--divider);
}
.dd-modal-head-txt {
  flex: 1;
  min-width: 0;
}
.dd-modal-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--acc-d);
  margin-bottom: 3px;
}
.dd-modal-title {
  margin: 0;
  font-size: 1.18rem;
  font-weight: 650;
  line-height: 1.2;
  color: var(--ink);
}
.dd-modal-sub {
  margin: 4px 0 0;
  font-size: 0.82rem;
  color: var(--ink-2);
}
.dd-modal-close {
  flex: none;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border: 1px solid var(--divider);
  border-radius: 9px;
  background: var(--surface);
  color: var(--ink-2);
  cursor: pointer;
  transition:
    background 0.12s,
    color 0.12s,
    border-color 0.12s;
}
.dd-modal-close:hover {
  background: var(--red-bg);
  border-color: var(--red-bg);
  color: var(--red);
}
.dd-modal-body {
  padding: 20px 22px;
  overflow-y: auto;
}
.dd-modal-foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 22px;
  border-top: 1px solid var(--divider);
  background: color-mix(in srgb, var(--acc) 4%, var(--surface));
}

/* ---- formuliergrid + velden ---- */
.dd-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 14px;
}
.dd-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.dd-field-full {
  grid-column: 1 / -1;
}
.dd-label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ink-2);
  display: flex;
  align-items: center;
  gap: 4px;
}
.dd-label .req {
  color: var(--acc-d);
}
.dd-hint {
  font-size: 11px;
  color: var(--ink-3);
  margin-top: -1px;
}
.dd-input {
  width: 100%;
  font: inherit;
  font-size: 13.5px;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--divider);
  border-radius: 10px;
  padding: 9px 12px;
  outline: none;
  transition:
    border-color 0.12s,
    box-shadow 0.12s;
}
.dd-input::placeholder {
  color: var(--ink-3);
  opacity: 0.7;
}
.dd-input:focus {
  border-color: var(--acc);
  box-shadow: 0 0 0 3px var(--acc-bg);
}
textarea.dd-input {
  resize: vertical;
  min-height: 76px;
  line-height: 1.45;
}
select.dd-input {
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%234a4a5a' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 11px center;
  padding-right: 32px;
}
/* prijs-veld met €-prefix */
.dd-input-money {
  display: flex;
  align-items: center;
  border: 1px solid var(--divider);
  border-radius: 10px;
  background: var(--surface);
  overflow: hidden;
  transition:
    border-color 0.12s,
    box-shadow 0.12s;
}
.dd-input-money:focus-within {
  border-color: var(--acc);
  box-shadow: 0 0 0 3px var(--acc-bg);
}
.dd-input-money .sym {
  padding: 9px 0 9px 12px;
  color: var(--ink-2);
  font-size: 13.5px;
}
.dd-input-money input {
  flex: 1;
  min-width: 0;
  border: none;
  outline: none;
  background: transparent;
  font: inherit;
  font-size: 13.5px;
  color: var(--ink);
  padding: 9px 12px 9px 6px;
  font-variant-numeric: tabular-nums;
}
@media (max-width: 560px) {
  .dd-form {
    grid-template-columns: 1fr;
  }
}

/* ── Eyebrow-labels: kalme sentence-case i.p.v. tracked-caps ───────────────
   De getrackte uppercase-eyebrow is een herkenbare "AI-template"-tell. Deze
   override houdt de spans als kleine, rustige muted labels (normaal letter-
   beeld, ink-3) zonder de markup te wijzigen. Bewust onderaan zodat de
   source-order de eerdere per-feature definities overschrijft. */
.dd-ck-eyebrow,
.dd-cust-eyebrow,
.dd-ag-eyebrow,
.dd-pl-eyebrow,
.dd-studio-eyebrow,
.dd-page-eyebrow {
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-3);
}
