/* CivielControl application styles.
 * Base reset + full-viewport shell sizing, then the ported design system
 * (doc/handoff/civielcontrol/project/styles.css). Tokens, fonts (Archivo +
 * IBM Plex Mono) and components match the prototype.
 */

html, body { margin: 0; padding: 0; height: 100%; }
body {
  font-family: 'Archivo', system-ui, sans-serif;
  background: var(--paper);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
}

/* Full-viewport shells (prototype used a fixed 1440x900 canvas) */
.cv-app  { width: 100vw; height: 100vh; }
.cv-main { height: 100vh; }
.cv-shell-mobile { height: 100vh; }

/* flash messages on bare/minimal pages */
.flash { padding: 12px 16px; margin: 12px; border-radius: 9px; font-size: 13px; font-weight: 600; }
.flash--notice { background: var(--green-soft); color: oklch(0.42 0.11 152); border: 1px solid var(--green-line); }
.flash--alert  { background: var(--red-soft); color: oklch(0.47 0.17 30); border: 1px solid var(--red-line); }

/* Reusable success toast (prototype DesktopApp toast, promoted to a class) */
.cv-toast {
  position: fixed; right: 24px; bottom: 24px; z-index: 80;
  display: flex; align-items: center; gap: 12px; max-width: 360px;
  background: var(--night); color: #fff; padding: 13px 16px;
  border-radius: 12px; box-shadow: var(--shadow-lg);
  animation: cvToast .25s cubic-bezier(.2,.8,.3,1);
}
.cv-toast.is-alert .cv-toast-ico { background: var(--red); }
.cv-toast-ico { width: 32px; height: 32px; border-radius: 8px; background: var(--green); display: grid; place-items: center; flex-shrink: 0; color: #fff; }
.cv-toast-msg { font-size: 13px; font-weight: 700; }
.cv-toast-sub { font-size: 11.5px; color: var(--night-ink); }
@keyframes cvToast { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* ============================================================ */

/* ============================================================
   CivielControl — Design System
   Industrieel, modern SaaS. Archivo + IBM Plex Mono. Amber.
   ============================================================ */

:root {
  /* Surfaces — warm neutral "beton/papier" */
  --paper:      oklch(0.984 0.004 80);
  --surface:    #ffffff;
  --surface-2:  oklch(0.974 0.005 80);
  --surface-3:  oklch(0.955 0.006 78);

  /* Ink */
  --ink:    oklch(0.255 0.012 60);
  --ink-2:  oklch(0.46 0.012 62);
  --ink-3:  oklch(0.60 0.010 64);
  --ink-4:  oklch(0.72 0.008 70);

  /* Lines */
  --line:        oklch(0.905 0.006 75);
  --line-2:      oklch(0.86 0.008 72);
  --line-strong: oklch(0.78 0.010 70);

  /* Amber — enige signaalkleur */
  --amber:       oklch(0.70 0.165 62);
  --amber-deep:  oklch(0.60 0.155 56);
  --amber-ink:   oklch(0.46 0.12 56);
  --amber-soft:  oklch(0.955 0.038 78);
  --amber-line:  oklch(0.86 0.07 72);

  /* Status — gedeelde chroma family */
  --red:       oklch(0.585 0.165 30);
  --red-soft:  oklch(0.955 0.035 32);
  --red-line:  oklch(0.86 0.07 32);
  --green:     oklch(0.595 0.115 152);
  --green-soft:oklch(0.955 0.032 152);
  --green-line:oklch(0.85 0.06 152);
  --slate:     oklch(0.55 0.018 250);
  --slate-soft:oklch(0.955 0.008 250);

  /* Ink for dark panels (sidebar) */
  --night:     oklch(0.255 0.012 65);
  --night-2:   oklch(0.305 0.013 65);
  --night-line:oklch(0.36 0.014 65);
  --night-ink: oklch(0.80 0.010 75);
  --night-ink2:oklch(0.62 0.012 72);

  --radius:    9px;
  --radius-sm: 6px;
  --radius-lg: 14px;
  --shadow-sm: 0 1px 2px rgba(40,32,20,0.05), 0 1px 1px rgba(40,32,20,0.04);
  --shadow:    0 4px 14px rgba(40,32,20,0.07), 0 1px 3px rgba(40,32,20,0.05);
  --shadow-lg: 0 18px 48px rgba(40,32,20,0.16), 0 4px 12px rgba(40,32,20,0.08);

  --sans: 'Archivo', system-ui, sans-serif;
  --mono: 'IBM Plex Mono', ui-monospace, monospace;
}

/* hazard-stripe — meerwerk signatuur */
.cv-hazard {
  background-image: repeating-linear-gradient(
    -45deg,
    var(--amber) 0 9px,
    var(--ink) 9px 18px
  );
}

/* ---- reset / base inside app scopes ---- */
.cv-app, .cv-mobile {
  font-family: var(--sans);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'cv01','ss01';
}
.cv-app *, .cv-mobile * { box-sizing: border-box; }
.cv-app button, .cv-mobile button { font-family: inherit; }
.cv-app h1,.cv-app h2,.cv-app h3,.cv-app h4,
.cv-mobile h1,.cv-mobile h2,.cv-mobile h3 { margin: 0; font-weight: 700; letter-spacing: -0.01em; }
.cv-app p, .cv-mobile p { margin: 0; }
.cv-mono { font-family: var(--mono); font-feature-settings: 'tnum'; }
.cv-num  { font-family: var(--mono); font-variant-numeric: tabular-nums; letter-spacing: -0.02em; }

/* ============================================================
   DESKTOP SHELL
   ============================================================ */
.cv-app {
  width: 100%; height: 100vh; height: 100dvh;
  display: grid; grid-template-columns: 232px 1fr;
  /* Fill the viewport height even when the page body is short, so the sidebar
     always reaches the bottom (E13-S4). The columns scroll internally. */
  grid-template-rows: minmax(0, 1fr);
  background: var(--paper);
  overflow: hidden;
  position: relative;
}

/* --- Sidebar --- */
.cv-side {
  background: var(--night);
  color: var(--night-ink);
  display: flex; flex-direction: column;
  border-right: 1px solid var(--night-line);
}
.cv-brand {
  display: flex; align-items: center; gap: 11px;
  padding: 20px 18px 18px;
}
.cv-brand-mark {
  width: 34px; height: 34px; border-radius: 8px;
  display: grid; place-items: center; flex-shrink: 0;
  background: var(--amber);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.12);
  overflow: hidden;
}
.cv-brand-name {
  font-weight: 800; font-size: 16px; letter-spacing: -0.02em; color: #fff;
  line-height: 1;
}
.cv-brand-sub {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.18em;
  color: var(--night-ink2); text-transform: uppercase; margin-top: 3px;
}
.cv-nav { padding: 6px 12px; display: flex; flex-direction: column; gap: 2px; }
.cv-nav-label {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--night-ink2);
  padding: 16px 10px 7px;
}
.cv-nav-item {
  display: flex; align-items: center; gap: 11px;
  padding: 9px 10px; border-radius: 7px;
  color: var(--night-ink); font-size: 13.5px; font-weight: 500;
  cursor: pointer; border: none; background: transparent; text-align: left;
  width: 100%; transition: background .13s, color .13s;
  position: relative;
}
.cv-nav-item:hover { background: var(--night-2); color: #fff; }
.cv-nav-item.is-active { background: var(--night-2); color: #fff; }
.cv-nav-item.is-active::before {
  content: ''; position: absolute; left: -12px; top: 8px; bottom: 8px;
  width: 3px; border-radius: 0 3px 3px 0; background: var(--amber);
}
.cv-nav-ico { width: 18px; height: 18px; flex-shrink: 0; opacity: 0.92; }
.cv-nav-count {
  margin-left: auto; font-family: var(--mono); font-size: 11px; font-weight: 600;
  min-width: 20px; height: 19px; padding: 0 6px; border-radius: 20px;
  display: grid; place-items: center;
  background: var(--red); color: #fff; letter-spacing: -0.02em;
}
.cv-side-foot {
  margin-top: auto; padding: 14px; border-top: 1px solid var(--night-line);
  display: flex; align-items: center; gap: 10px;
}
.cv-avatar {
  width: 30px; height: 30px; border-radius: 7px; flex-shrink: 0;
  background: var(--night-2); color: var(--night-ink);
  display: grid; place-items: center; font-size: 12px; font-weight: 700;
  border: 1px solid var(--night-line);
}

/* --- Main column --- */
.cv-main { display: flex; flex-direction: column; min-width: 0; min-height: 0; height: 100%; }
.cv-topbar {
  height: 60px; flex-shrink: 0; background: var(--surface);
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 16px; padding: 0 26px;
}
.cv-crumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink-3); }
.cv-crumb b { color: var(--ink); font-weight: 600; }
.cv-search {
  margin-left: auto; display: flex; align-items: center; gap: 8px;
  height: 36px; padding: 0 12px; min-width: 230px;
  background: var(--surface-2); border: 1px solid var(--line);
  border-radius: 8px; color: var(--ink-3); font-size: 13px;
}
.cv-content { flex: 1; overflow-y: auto; padding: 26px; }
.cv-content::-webkit-scrollbar { width: 10px; }
.cv-content::-webkit-scrollbar-thumb { background: var(--line-2); border-radius: 10px; border: 3px solid var(--paper); }

/* --- Page header --- */
.cv-page-head { display: flex; align-items: flex-end; gap: 16px; margin-bottom: 22px; }
.cv-page-title { font-size: 25px; font-weight: 800; letter-spacing: -0.025em; }
.cv-page-sub { font-size: 13px; color: var(--ink-3); margin-top: 4px; }

/* ============================================================
   COMPONENTS
   ============================================================ */
/* buttons */
.cv-btn {
  display: inline-flex; align-items: center; gap: 7px;
  height: 36px; padding: 0 14px; border-radius: 8px;
  font-size: 13px; font-weight: 600; cursor: pointer;
  border: 1px solid var(--line-2); background: var(--surface); color: var(--ink);
  transition: background .13s, border-color .13s, transform .05s;
  white-space: nowrap;
}
.cv-btn:hover { background: var(--surface-2); border-color: var(--line-strong); }
.cv-btn:active { transform: translateY(1px); }
.cv-btn-primary {
  background: var(--amber); border-color: var(--amber-deep); color: #2a1a08;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.25), var(--shadow-sm);
}
.cv-btn-primary:hover { background: var(--amber-deep); border-color: var(--amber-deep); }
.cv-btn-ghost { border-color: transparent; background: transparent; }
.cv-btn-ghost:hover { background: var(--surface-2); }
.cv-btn-sm { height: 30px; padding: 0 11px; font-size: 12px; gap: 5px; }
.cv-icon-btn {
  width: 36px; height: 36px; padding: 0; justify-content: center; border-radius: 8px;
  border: 1px solid var(--line-2); background: var(--surface); cursor: pointer; color: var(--ink-2);
  display: inline-flex; align-items: center;
}
.cv-icon-btn:hover { background: var(--surface-2); }

/* cards */
.cv-card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
}
.cv-card-pad { padding: 18px 20px; }
.cv-card-head {
  display: flex; align-items: center; gap: 12px;
  padding: 15px 20px; border-bottom: 1px solid var(--line);
}
.cv-card-title { font-size: 14.5px; font-weight: 700; letter-spacing: -0.01em; }

/* KPI */
.cv-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 22px; }
.cv-kpi {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 17px 18px; position: relative; overflow: hidden;
}
.cv-kpi-label {
  font-size: 11.5px; font-weight: 600; color: var(--ink-3); letter-spacing: 0.01em;
  display: flex; align-items: center; gap: 7px;
}
.cv-kpi-val { font-size: 29px; font-weight: 800; letter-spacing: -0.03em; margin-top: 11px; line-height: 1; }
.cv-kpi-val .cur { font-size: 18px; font-weight: 700; color: var(--ink-3); margin-right: 1px; }
.cv-kpi-foot { font-size: 11.5px; color: var(--ink-3); margin-top: 9px; display: flex; align-items: center; gap: 6px; }
.cv-kpi.is-alert { border-color: var(--red-line); background: linear-gradient(180deg, var(--red-soft), var(--surface) 70%); }
.cv-kpi.is-alert .cv-kpi-val { color: oklch(0.50 0.17 30); }
.cv-kpi-ico { width: 15px; height: 15px; }
.cv-kpi-strip { position: absolute; top: 0; left: 0; right: 0; height: 3px; }

/* badges / pills */
.cv-pill {
  display: inline-flex; align-items: center; gap: 5px;
  height: 22px; padding: 0 9px; border-radius: 20px;
  font-size: 11.5px; font-weight: 600; letter-spacing: 0.005em; white-space: nowrap;
  border: 1px solid transparent;
}
.cv-pill .dot { width: 6px; height: 6px; border-radius: 50%; }
.cv-pill-red    { background: var(--red-soft); color: oklch(0.47 0.17 30); border-color: var(--red-line); }
.cv-pill-red .dot { background: var(--red); }
.cv-pill-green  { background: var(--green-soft); color: oklch(0.42 0.11 152); border-color: var(--green-line); }
.cv-pill-green .dot { background: var(--green); }
.cv-pill-amber  { background: var(--amber-soft); color: var(--amber-ink); border-color: var(--amber-line); }
.cv-pill-amber .dot { background: var(--amber); }
.cv-pill-slate  { background: var(--slate-soft); color: oklch(0.40 0.02 250); border-color: var(--line-2); }
.cv-pill-slate .dot { background: var(--slate); }

/* meerwerk flag tag */
.cv-flag {
  display: inline-flex; align-items: center; gap: 6px; height: 23px; padding: 0 4px 0 0;
  border-radius: 5px; font-size: 11px; font-weight: 700; overflow: hidden;
  border: 1px solid var(--amber-line); background: var(--amber-soft); color: var(--amber-ink);
  letter-spacing: 0.01em;
}
.cv-flag .stub { width: 9px; align-self: stretch; }
.cv-flag.is-open { border-color: var(--red-line); background: var(--red-soft); color: oklch(0.47 0.17 30); }
.cv-flag-ico { width: 13px; height: 13px; }

/* tables */
.cv-table { width: 100%; border-collapse: collapse; font-size: 13px; }
/* Hide secondary inline detail (e.g. a project's end date) when space is tight */
@media (max-width: 1100px) { .cv-hide-narrow { display: none; } }
.cv-table thead th {
  text-align: left; font-size: 10.5px; font-weight: 700; letter-spacing: 0.07em;
  text-transform: uppercase; color: var(--ink-3); padding: 10px 16px;
  border-bottom: 1px solid var(--line); white-space: nowrap; background: var(--surface-2);
}
.cv-table thead th.r, .cv-table td.r { text-align: right; }
.cv-table tbody td { padding: 13px 16px; border-bottom: 1px solid var(--line); vertical-align: middle; }
.cv-table tbody tr:last-child td { border-bottom: none; }
.cv-table tbody tr { transition: background .1s; cursor: pointer; }
.cv-table tbody tr:hover { background: var(--surface-2); }
.cv-table tbody tr.is-flagged:hover { background: var(--red-soft); }
.cv-t-strong { font-weight: 700; }
.cv-t-muted { color: var(--ink-3); }
.cv-t-code { font-family: var(--mono); font-size: 11.5px; color: var(--ink-3); letter-spacing: -0.02em; }

/* per-column search row (sits under the header row) */
.cv-table thead tr.cv-filter-row th { padding: 6px 12px; background: var(--surface); border-bottom: 1px solid var(--line); }
.cv-filter-input {
  width: 100%; min-width: 0; height: 30px; padding: 0 9px; box-sizing: border-box;
  border: 1px solid var(--line-2); border-radius: 7px; background: var(--surface-2);
  font-family: var(--sans); font-size: 12px; color: var(--ink); transition: border-color .12s, box-shadow .12s;
}
.cv-filter-input::placeholder { color: var(--ink-4); font-weight: 500; }
.cv-filter-input:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-soft); background: var(--surface); }
.cv-filter-input.cv-num { font-family: var(--mono); }

/* pagination footer */
.cv-pager { display: flex; align-items: center; gap: 12px; padding: 12px 18px; border-top: 1px solid var(--line); background: var(--surface-2); }
.cv-pager-info { font-size: 12px; color: var(--ink-3); }
.cv-pager-info b { color: var(--ink-2); font-weight: 700; }
.cv-pager-nav { margin-left: auto; display: inline-flex; gap: 6px; }
.cv-pager-nav a, .cv-pager-nav span {
  display: inline-grid; place-items: center; min-width: 30px; height: 30px; padding: 0 9px;
  border-radius: 7px; border: 1px solid var(--line-2); background: var(--surface);
  font-family: var(--mono); font-size: 12px; font-weight: 600; color: var(--ink-2);
  text-decoration: none; transition: background .12s, border-color .12s;
}
.cv-pager-nav a:hover { background: var(--surface-2); border-color: var(--line-strong); }
.cv-pager-nav .is-on { background: var(--ink); border-color: var(--ink); color: #fff; }
.cv-pager-nav .is-disabled { opacity: 0.4; pointer-events: none; }
.cv-pager-nav .cv-gap { border: none; background: transparent; color: var(--ink-4); min-width: 14px; padding: 0; }

/* progress bar */
.cv-prog { height: 7px; border-radius: 5px; background: var(--surface-3); overflow: hidden; display: flex; }
.cv-prog-seg { height: 100%; }
.cv-prog-g { background: var(--green); }
.cv-prog-a { background: var(--amber); }
.cv-prog-r { background: var(--red); }

/* filter chips */
.cv-chips { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cv-chip {
  display: inline-flex; align-items: center; gap: 7px; height: 32px; padding: 0 12px;
  border-radius: 8px; border: 1px solid var(--line-2); background: var(--surface);
  font-size: 12.5px; font-weight: 600; color: var(--ink-2); cursor: pointer; transition: all .12s;
}
.cv-chip:hover { background: var(--surface-2); }
.cv-chip.is-on { background: var(--ink); color: #fff; border-color: var(--ink); }
.cv-chip.is-on.is-red { background: var(--red); border-color: var(--red); }
.cv-chip-count { font-family: var(--mono); font-size: 11px; opacity: 0.75; }

/* segmented (buttons or link tabs) */
.cv-seg { display: inline-flex; background: var(--surface-2); border: 1px solid var(--line); border-radius: 9px; padding: 3px; gap: 2px; }
.cv-seg button, .cv-seg a {
  display: inline-flex; align-items: center; gap: 6px;
  height: 28px; padding: 0 13px; border: none; background: transparent; border-radius: 6px;
  font-size: 12.5px; font-weight: 600; color: var(--ink-3); cursor: pointer; transition: all .12s;
  text-decoration: none;
}
.cv-seg a:hover { color: var(--ink-2); }
.cv-seg button.is-on, .cv-seg a.is-on { background: var(--surface); color: var(--ink); box-shadow: var(--shadow-sm); }

/* misc */
.cv-row { display: flex; align-items: center; }
.cv-meta { font-size: 12px; color: var(--ink-3); }
.cv-divider { height: 1px; background: var(--line); }
.cv-amt-pos { color: oklch(0.45 0.11 152); }
.cv-amt-neg { color: oklch(0.50 0.17 30); }

/* small machine/avatar token */
.cv-tok {
  display: inline-flex; align-items: center; gap: 7px; height: 26px; padding: 0 9px 0 6px;
  border-radius: 6px; background: var(--surface-2); border: 1px solid var(--line);
  font-size: 12px; font-weight: 600; color: var(--ink-2);
}
.cv-tok-ico { width: 18px; height: 18px; border-radius: 4px; display: grid; place-items: center; background: var(--ink); color: var(--amber); }

/* ============================================================
   MOBILE
   ============================================================ */
.cv-mobile {
  height: 100%; display: flex; flex-direction: column;
  background: var(--paper); color: var(--ink); position: relative;
}
.cv-m-top {
  padding: 14px 18px 13px; background: var(--night); color: #fff;
  display: flex; align-items: center; gap: 12px; flex-shrink: 0;
}
.cv-m-top .cv-brand-mark { width: 30px; height: 30px; }
.cv-m-greet-sm { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--night-ink2); }
.cv-m-greet { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.1; margin-top: 2px; }
/* PWA connectivity + update banners (Epic 12) */
.cv-m-offline, .cv-m-update {
  flex-shrink: 0; padding: 8px 16px; font-size: 12px; font-weight: 700;
  text-align: center; letter-spacing: 0.01em;
}
.cv-m-offline { background: var(--ink); color: var(--amber); }
.cv-m-update {
  background: var(--amber-soft); color: var(--amber-ink); border-bottom: 1px solid var(--amber-line);
  display: flex; align-items: center; justify-content: center; gap: 12px;
}
.cv-m-update .cv-btn { background: var(--amber); color: #fff; border-color: var(--amber-deep); }

/* Optimistically-rendered offline bookings (Epic 12) */
.cv-queued {
  padding: 13px 15px; margin-bottom: 10px; border-style: dashed;
  display: flex; align-items: center; gap: 10px;
}
.cv-queued-title { font-size: 14px; font-weight: 700; flex: 1; min-width: 0; }
.cv-queued-badge {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
  font-weight: 600; color: var(--amber-ink); background: var(--amber-soft);
  border: 1px solid var(--amber-line); border-radius: 999px; padding: 3px 9px; white-space: nowrap;
}
.cv-queued-badge.is-error { color: oklch(0.47 0.17 30); background: var(--red-soft); border-color: var(--red-line); }

.cv-m-body { flex: 1; overflow-y: auto; padding: 16px; }
.cv-m-body::-webkit-scrollbar { display: none; }
.cv-m-h { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); margin: 4px 2px 11px; }

.cv-m-card { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow-sm); }

/* big tap option */
.cv-opt {
  display: flex; align-items: center; gap: 13px; width: 100%; text-align: left;
  padding: 15px 15px; border: 1px solid var(--line); background: var(--surface);
  border-radius: 13px; cursor: pointer; transition: all .12s; min-height: 60px; margin-bottom: 10px;
}
.cv-opt:active { transform: scale(0.99); }
.cv-opt.is-sel { border-color: var(--amber); background: var(--amber-soft); box-shadow: inset 0 0 0 1px var(--amber); }
.cv-opt-ico { width: 42px; height: 42px; border-radius: 10px; flex-shrink: 0; display: grid; place-items: center; background: var(--ink); color: var(--amber); }
.cv-opt-ico.alt { background: var(--amber-soft); color: var(--amber-ink); border: 1px solid var(--amber-line); }
.cv-opt-body { flex: 1; min-width: 0; }
.cv-opt-title { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; }
.cv-opt-sub { font-size: 12px; color: var(--ink-3); margin-top: 2px; }
.cv-opt-meta { font-family: var(--mono); font-size: 11px; color: var(--ink-3); }
.cv-opt-check { width: 24px; height: 24px; border-radius: 50%; border: 2px solid var(--line-2); flex-shrink: 0; display: grid; place-items: center; }
.cv-opt.is-sel .cv-opt-check { background: var(--amber); border-color: var(--amber); }

/* mobile bottom action */
.cv-m-foot { flex-shrink: 0; padding: 12px 16px 14px; background: var(--surface); border-top: 1px solid var(--line); }
.cv-m-btn {
  width: 100%; height: 54px; border-radius: 13px; border: none; cursor: pointer;
  font-size: 16px; font-weight: 700; letter-spacing: -0.01em;
  display: flex; align-items: center; justify-content: center; gap: 9px;
  background: var(--amber); color: #2a1a08; box-shadow: inset 0 1px 0 rgba(255,255,255,0.3);
}
.cv-m-btn:disabled { background: var(--surface-3); color: var(--ink-4); cursor: not-allowed; box-shadow: none; }
.cv-m-btn.ghost { background: var(--surface-2); color: var(--ink); border: 1px solid var(--line-2); box-shadow: none; }

/* stepper */
.cv-step-bar { display: flex; gap: 5px; padding: 12px 16px 4px; background: var(--paper); }
.cv-step-seg { flex: 1; height: 4px; border-radius: 3px; background: var(--surface-3); }
.cv-step-seg.is-on { background: var(--amber); }
.cv-step-seg.is-done { background: var(--green); }

/* number stepper */
.cv-stepper { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.cv-step-btn {
  width: 58px; height: 58px; border-radius: 14px; border: 1px solid var(--line-2);
  background: var(--surface); font-size: 28px; font-weight: 600; color: var(--ink); cursor: pointer;
  display: grid; place-items: center; line-height: 1;
}
.cv-step-btn:active { background: var(--surface-2); }
.cv-step-val { font-family: var(--mono); font-size: 44px; font-weight: 600; letter-spacing: -0.03em; }
.cv-step-unit { font-size: 14px; color: var(--ink-3); font-family: var(--sans); font-weight: 600; }

.cv-input {
  width: 100%; border: 1px solid var(--line-2); border-radius: 11px; padding: 13px 14px;
  font-family: var(--sans); font-size: 15px; color: var(--ink); background: var(--surface); resize: none;
}
.cv-input::placeholder { color: var(--ink-4); }
.cv-input:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-soft); }
.cv-req { color: var(--red); font-weight: 700; }

/* chip row mobile */
.cv-mchips { display: flex; gap: 8px; flex-wrap: wrap; }
.cv-mchip { padding: 9px 14px; border-radius: 10px; border: 1px solid var(--line-2); background: var(--surface); font-size: 14px; font-weight: 600; color: var(--ink-2); cursor: pointer; }
.cv-mchip.is-on { background: var(--ink); color: #fff; border-color: var(--ink); }

/* success */
.cv-done-ring { width: 84px; height: 84px; border-radius: 50%; background: var(--green-soft); border: 2px solid var(--green-line); display: grid; place-items: center; margin: 0 auto 18px; }

/* mobile: tabs */
.cv-m-tabs { display: flex; gap: 4px; padding: 10px 16px 4px; background: var(--paper); flex-shrink: 0; }
.cv-m-tabs button {
  flex: 1; height: 38px; border: none; background: transparent; border-radius: 10px;
  font-family: var(--sans); font-size: 13.5px; font-weight: 700; color: var(--ink-3); cursor: pointer; transition: all .12s;
}
.cv-m-tabs button.is-on { background: var(--surface); color: var(--ink); box-shadow: var(--shadow-sm); border: 1px solid var(--line); }

/* mobile: booking card (button) */
.cv-book { width: 100%; padding: 14px; display: flex; align-items: center; gap: 12px; cursor: pointer; border: 1px solid var(--line); }
.cv-book:active { transform: scale(0.99); }
.cv-m-hint { display: flex; align-items: center; justify-content: center; gap: 6px; font-size: 11.5px; color: var(--ink-4); margin-top: 14px; }

/* mobile: week bars */
.cv-week-bars { display: flex; gap: 6px; align-items: flex-end; }
.cv-week-col { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 5px; }
.cv-week-track { width: 100%; height: 56px; border-radius: 7px; background: var(--surface-2); display: flex; align-items: flex-end; overflow: hidden; }
.cv-week-fill { width: 100%; border-radius: 7px; transition: height .2s; }
.cv-week-lbl { font-size: 10.5px; font-weight: 700; color: var(--ink-3); text-transform: capitalize; }
.cv-week-lbl.is-today { color: var(--amber-ink); }

/* mobile: edit-context chip */
.cv-edit-ctx { width: 100%; display: flex; align-items: center; gap: 11px; padding: 11px 12px; margin-bottom: 18px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface-2); cursor: pointer; }
.cv-edit-ctx:active { transform: scale(0.99); }

/* mobile: action sheet */
.cv-sheet-scrim { position: absolute; inset: 0; background: rgba(28,26,23,0.4); display: flex; align-items: flex-end; z-index: 70; animation: cvFade .15s; }
.cv-sheet { width: 100%; background: var(--surface); border-radius: 22px 22px 0 0; padding: 10px 16px 18px; box-shadow: 0 -8px 32px rgba(28,26,23,0.2); animation: cvSheet .26s cubic-bezier(.2,.8,.3,1); }
@keyframes cvSheet { from { transform: translateY(100%); } }
.cv-sheet-grip { width: 38px; height: 4px; border-radius: 3px; background: var(--line-strong); margin: 0 auto 14px; }
.cv-sheet-act {
  width: 100%; display: flex; align-items: center; gap: 13px; padding: 13px 8px; border: none; background: transparent;
  font-family: var(--sans); font-size: 15px; font-weight: 600; color: var(--ink); cursor: pointer; border-bottom: 1px solid var(--line);
}
.cv-sheet-act:active { background: var(--surface-2); }
.cv-sheet-act.danger { color: var(--red); border-bottom: none; }
.cv-sheet-ico { width: 38px; height: 38px; border-radius: 10px; background: var(--surface-2); border: 1px solid var(--line); display: grid; place-items: center; color: var(--ink-2); flex-shrink: 0; }
.cv-sheet-ico.danger { background: var(--red-soft); border-color: var(--red-line); color: var(--red); }

/* ============================================================
   PLANNING grid
   ============================================================ */
.cv-plan-grid { display: grid; grid-template-columns: 188px repeat(6, 1fr); }
.cv-plan-corner { padding: 12px 14px; display: flex; align-items: flex-end; border-bottom: 1px solid var(--line); border-right: 1px solid var(--line); background: var(--surface-2); }
.cv-plan-dayhead { padding: 10px 12px; border-bottom: 1px solid var(--line); border-right: 1px solid var(--line); background: var(--surface-2); }
.cv-plan-dayhead:last-child { border-right: none; }
.cv-plan-rowhead {
  display: flex; align-items: center; gap: 9px; padding: 11px 12px;
  border-bottom: 1px solid var(--line); border-right: 1px solid var(--line);
  background: var(--surface); position: sticky; left: 0;
}
.cv-plan-bez { display: flex; align-items: center; gap: 6px; margin-top: 5px; }
.cv-plan-bezbar { flex: 1; height: 4px; border-radius: 4px; background: var(--surface-3); overflow: hidden; max-width: 76px; }
.cv-plan-cell {
  border-bottom: 1px solid var(--line); border-right: 1px solid var(--line);
  padding: 7px; min-height: 74px; display: flex; flex-direction: column; gap: 5px;
  position: relative; transition: background .1s;
}
.cv-plan-cell:nth-child(7n) { border-right: none; }
.cv-plan-grid > .cv-plan-cell:hover { background: var(--surface-2); }
/* E16-S1: a day the resource is unavailable (verlof/ziek/onderhoud). */
.cv-plan-cell.is-unavailable {
  background: repeating-linear-gradient(135deg, var(--amber-soft) 0 6px, transparent 6px 12px);
}
.cv-plan-unavail {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 700; color: var(--amber-ink);
  background: var(--amber-soft); border: 1px solid var(--amber-line);
  border-radius: 5px; padding: 2px 6px; text-transform: capitalize; white-space: nowrap;
}
.cv-plan-chip {
  display: flex; align-items: stretch; gap: 7px; border: 1px solid; border-radius: 7px;
  padding: 5px 4px 5px 0; overflow: hidden; background: var(--surface);
}
.cv-plan-chip-bar { width: 4px; border-radius: 3px; flex-shrink: 0; }
.cv-plan-chip-t { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: -0.02em; }
.cv-plan-chip-s { display: flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 600; color: var(--ink-2); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* E16-S2: resource names in chips link to the resource drawer. */
.cv-plan-namelink { display: inline-flex; align-items: center; gap: 4px; color: inherit; min-width: 0; }
.cv-plan-namelink:hover { text-decoration: underline; }
.cv-plan-act { display: flex; align-items: center; gap: 3px; font-size: 10px; font-weight: 600; margin-top: 2px; opacity: 0.85; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cv-plan-ava { width: 16px; height: 16px; border-radius: 4px; background: var(--ink); color: #fff; font-size: 8.5px; font-weight: 700; display: inline-grid; place-items: center; flex-shrink: 0; }
.cv-plan-x { border: none; background: transparent; color: var(--ink-4); cursor: pointer; padding: 0 2px; display: grid; place-items: center; align-self: center; opacity: 0; transition: opacity .1s; }
.cv-plan-chip:hover .cv-plan-x { opacity: 1; }
.cv-plan-x:hover { color: var(--red); }
.cv-plan-add {
  border: 1px dashed var(--line-2); background: transparent; border-radius: 6px; color: var(--ink-4);
  font-size: 11px; font-weight: 600; font-family: var(--sans); cursor: pointer; padding: 6px;
  display: flex; align-items: center; justify-content: center; gap: 5px; margin-top: auto; transition: all .1s; opacity: 0;
}
.cv-plan-cell:hover .cv-plan-add { opacity: 1; }
.cv-plan-add:hover { border-color: var(--amber); color: var(--amber-ink); background: var(--amber-soft); }
.cv-plan-add.ghost { padding: 3px; align-self: flex-end; width: 24px; height: 22px; }

/* ============================================================
   MODAL + select
   ============================================================ */
.cv-modal-scrim { position: absolute; inset: 0; background: rgba(28,26,23,0.42); display: grid; place-items: center; z-index: 60; animation: cvFade .15s; }
.cv-modal { width: 420px; background: var(--surface); border-radius: 16px; box-shadow: var(--shadow-lg); overflow: hidden; animation: cvPop .2s cubic-bezier(.2,.8,.3,1); }
.cv-modal-head { display: flex; align-items: flex-start; padding: 18px 20px 16px; border-bottom: 1px solid var(--line); }
.cv-modal-head > a, .cv-modal-head > button { margin-left: auto; flex-shrink: 0; }
.cv-modal-foot { display: flex; justify-content: flex-end; gap: 10px; padding: 14px 20px; border-top: 1px solid var(--line); background: var(--surface-2); }
@keyframes cvFade { from { opacity: 0; } }
@keyframes cvPop { from { opacity: 0; transform: scale(0.96) translateY(8px); } }
.cv-select {
  width: 100%; appearance: none; -webkit-appearance: none; font-family: var(--sans); font-size: 13.5px; font-weight: 500;
  color: var(--ink); background: var(--surface); border: 1px solid var(--line-2); border-radius: 9px; padding: 10px 12px; cursor: pointer;
}
.cv-select:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-soft); }
.cv-select:disabled { background: var(--surface-2); color: var(--ink-2); cursor: default; font-weight: 600; }

/* ============================================================
   INKOOP
   ============================================================ */
.cv-ink-split { display: grid; grid-template-columns: 1fr 392px; gap: 18px; align-items: start; }
.cv-ink-item {
  display: flex; align-items: center; gap: 13px; padding: 13px 16px; border-bottom: 1px solid var(--line);
  cursor: pointer; transition: background .1s;
}
.cv-ink-item:hover { background: var(--surface-2); }
.cv-ink-item.is-sel { background: var(--amber-soft); box-shadow: inset 3px 0 0 var(--amber); }
.cv-ink-item.is-open { background: var(--red-soft); }
.cv-ink-item.is-open.is-sel { background: var(--amber-soft); }
.cv-ink-logo { width: 40px; height: 40px; border-radius: 9px; flex-shrink: 0; display: grid; place-items: center; font-family: var(--mono); font-weight: 700; font-size: 13px; background: var(--surface-3); color: var(--ink-2); border: 1px solid var(--line); }
.cv-koppel-row { display: flex; align-items: center; gap: 10px; padding: 11px 12px; border: 1px solid var(--line); border-radius: 10px; margin-bottom: 8px; background: var(--surface); }
.cv-koppel-amt { width: 96px; }
.cv-amt-input { width: 100%; font-family: var(--mono); font-size: 13px; text-align: right; border: 1px solid var(--line-2); border-radius: 7px; padding: 7px 9px; color: var(--ink); background: var(--surface); }
.cv-amt-input:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-soft); }

/* large modal (nieuw project) — fills the available height, scrolls only when needed */
.cv-modal.cv-modal-lg { width: 660px; max-height: 100%; display: flex; flex-direction: column; }
.cv-modal-body { padding: 20px; overflow-y: auto; min-height: 0; }
.cv-modal-body::-webkit-scrollbar { width: 10px; }
.cv-modal-body::-webkit-scrollbar-thumb { background: var(--line-2); border-radius: 10px; border: 3px solid var(--surface); }
.cv-form-sec { font-size: 11px; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 12px; }
.cv-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cv-tinput { width: 100%; font-family: var(--sans); font-size: 13.5px; color: var(--ink); background: var(--surface); border: 1px solid var(--line-2); border-radius: 9px; padding: 10px 12px; }
.cv-tinput::placeholder { color: var(--ink-4); }
.cv-tinput:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-soft); }

/* spinner */
.cv-spin { width: 15px; height: 15px; border-radius: 50%; border: 2px solid var(--line-strong); border-top-color: var(--ink); animation: cvSpin .7s linear infinite; display: inline-block; }
@keyframes cvSpin { to { transform: rotate(360deg); } }

/* language toggle */
.cv-lang { display: inline-flex; background: var(--surface-2); border: 1px solid var(--line); border-radius: 8px; padding: 2px; gap: 2px; }
.cv-lang button { border: none; background: transparent; border-radius: 6px; height: 26px; min-width: 30px; padding: 0 8px; font-family: var(--mono); font-size: 11px; font-weight: 600; letter-spacing: 0.04em; color: var(--ink-3); cursor: pointer; transition: all .12s; }
.cv-lang button.is-on { background: var(--surface); color: var(--ink); box-shadow: var(--shadow-sm); }
.cv-lang.dark { background: rgba(255,255,255,0.07); border-color: var(--night-line); }
.cv-lang.dark button { color: var(--night-ink2); }
.cv-lang.dark button.is-on { background: var(--night-2); color: #fff; box-shadow: none; }

/* opdracht (job) badge */
.cv-type-badge { display: inline-flex; align-items: center; gap: 4px; height: 18px; padding: 0 7px; border-radius: 5px; font-size: 10px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; border: 1px solid var(--line-2); background: var(--surface-2); color: var(--ink-3); }
.cv-type-badge.job { background: oklch(0.95 0.03 270); border-color: oklch(0.83 0.06 270); color: oklch(0.44 0.10 270); }

/* segmented control inside modal (type switch — buttons or radio-backed labels) */
.cv-typeseg { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.cv-typeseg button, .cv-typeseg label { position: relative; display: flex; align-items: flex-start; gap: 11px; text-align: left; padding: 13px 14px; border: 1.5px solid var(--line-2); background: var(--surface); border-radius: 12px; cursor: pointer; transition: all .12s; }
.cv-typeseg button:hover, .cv-typeseg label:hover { border-color: var(--line-strong); }
.cv-typeseg button.is-on, .cv-typeseg label.is-on { border-color: var(--amber); background: var(--amber-soft); }
.cv-typeseg .ts-ico { width: 34px; height: 34px; border-radius: 9px; flex-shrink: 0; display: grid; place-items: center; background: var(--surface-2); border: 1px solid var(--line); color: var(--ink-2); }
.cv-typeseg button.is-on .ts-ico, .cv-typeseg label.is-on .ts-ico { background: var(--amber); border-color: var(--amber-deep); color: #2a1a08; }
.cv-typeseg .ts-t { font-size: 13.5px; font-weight: 700; letter-spacing: -0.01em; }
.cv-typeseg .ts-d { font-size: 11px; color: var(--ink-3); margin-top: 2px; line-height: 1.35; }

/* datalist input (activiteit) */
.cv-combo { width: 100%; appearance: none; font-family: var(--sans); font-size: 13.5px; font-weight: 500; color: var(--ink); background: var(--surface); border: 1px solid var(--line-2); border-radius: 9px; padding: 10px 12px; }
.cv-combo:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-soft); }

/* ============================================================
   PLATFORM / ADMIN
   ============================================================ */
/* toggle switch */
.cv-switch { width: 40px; height: 23px; border-radius: 20px; background: var(--line-strong); position: relative; cursor: pointer; border: none; transition: background .15s; flex-shrink: 0; padding: 0; }
.cv-switch.is-on { background: var(--green); }
.cv-switch::after { content: ''; position: absolute; top: 2px; left: 2px; width: 19px; height: 19px; border-radius: 50%; background: #fff; transition: transform .16s cubic-bezier(.3,.8,.3,1.1); box-shadow: 0 1px 2px rgba(0,0,0,0.25); }
.cv-switch.is-on::after { transform: translateX(17px); }

/* tenant logo tile */
.cv-logo { border-radius: 10px; display: grid; place-items: center; flex-shrink: 0; color: #fff; font-weight: 800; letter-spacing: -0.02em; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.12); overflow: hidden; }

/* platform brand badge */
.cv-plat-badge { font-family: var(--mono); font-size: 8.5px; letter-spacing: 0.14em; text-transform: uppercase; color: #1c1a17; background: var(--amber); padding: 2px 6px; border-radius: 4px; font-weight: 700; }

/* module toggle row */
.cv-mod-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--line); border-radius: 11px; background: var(--surface); transition: border-color .12s, background .12s; }
.cv-mod-row.is-on { border-color: var(--amber-line); background: var(--amber-soft); }
.cv-mod-ico { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; flex-shrink: 0; background: var(--surface-2); border: 1px solid var(--line); color: var(--ink-3); }
.cv-mod-row.is-on .cv-mod-ico { background: var(--amber); border-color: var(--amber-deep); color: #2a1a08; }

/* subdomain input group */
.cv-url { display: flex; align-items: stretch; border: 1px solid var(--line-2); border-radius: 9px; overflow: hidden; background: var(--surface); }
.cv-url:focus-within { border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-soft); }
.cv-url .pre, .cv-url .post { display: flex; align-items: center; padding: 0 10px; background: var(--surface-2); color: var(--ink-3); font-family: var(--mono); font-size: 12.5px; white-space: nowrap; }
.cv-url .pre { border-right: 1px solid var(--line); }
.cv-url .post { border-left: 1px solid var(--line); }
.cv-url input { flex: 1; min-width: 40px; border: none; outline: none; padding: 10px 8px; font-family: var(--mono); font-size: 13px; font-weight: 600; color: var(--amber-ink); background: transparent; }

/* tenant card grid */
.cv-tcard { display: flex; align-items: center; gap: 14px; padding: 16px 18px; border: 1px solid var(--line); border-radius: 14px; background: var(--surface); cursor: pointer; transition: border-color .12s, box-shadow .12s; box-shadow: var(--shadow-sm); }
.cv-tcard:hover { border-color: var(--line-strong); box-shadow: var(--shadow); }
.cv-tcard.is-off { opacity: 0.72; }
.cv-modchip { display: inline-flex; align-items: center; gap: 4px; height: 22px; padding: 0 8px; border-radius: 6px; font-size: 11px; font-weight: 600; background: var(--surface-2); border: 1px solid var(--line); color: var(--ink-3); }
.cv-modchip.on { background: var(--amber-soft); border-color: var(--amber-line); color: var(--amber-ink); }

/* clickable planning rowhead */
.cv-plan-rowhead.is-click { cursor: pointer; }
.cv-plan-rowhead.is-click:hover { background: var(--surface-2); }

/* resource drawer */
.cv-drawer-scrim { position: absolute; inset: 0; background: rgba(28,26,23,0.42); z-index: 60; display: flex; justify-content: flex-end; animation: cvFade .15s; }
.cv-drawer { width: 440px; background: var(--paper); height: 100%; display: flex; flex-direction: column; box-shadow: -12px 0 40px rgba(28,26,23,0.18); animation: cvSlide .26s cubic-bezier(.2,.8,.3,1); }
@keyframes cvSlide { from { transform: translateX(100%); } }
.cv-drawer-head { display: flex; align-items: flex-start; justify-content: space-between; padding: 20px 22px 18px; border-bottom: 1px solid var(--line); background: var(--surface); }
.cv-drawer-body { flex: 1; overflow-y: auto; padding: 20px 22px; }
.cv-drawer-body::-webkit-scrollbar { width: 10px; }
.cv-drawer-body::-webkit-scrollbar-thumb { background: var(--line-2); border-radius: 10px; border: 3px solid var(--paper); }
.cv-drawer-day { display: flex; gap: 12px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 11px; background: var(--surface); }
.cv-drawer-day.is-free { background: transparent; border-style: dashed; align-items: center; }
.cv-drawer-daylbl { width: 38px; flex-shrink: 0; text-align: center; }
.cv-drawer-asg { display: flex; align-items: stretch; gap: 8px; padding: 7px 8px; border: 1px solid; border-radius: 8px; cursor: pointer; width: 100%; }
.cv-drawer-asg:hover { filter: brightness(0.98); }

/* ============================================================
   AUTH / centered shells (login + tenant-unavailable pages)
   ============================================================ */
.cv-centered { display: grid; place-items: center; min-height: 100vh; background: var(--paper); padding: 24px; }
.cv-auth-shell { width: 100%; max-width: 380px; }
.cv-auth-card { padding: 26px 24px; }
.cv-auth-brand { display: flex; align-items: center; gap: 11px; margin-bottom: 18px; }
.cv-auth-title { font-size: 20px; font-weight: 800; letter-spacing: -0.02em; margin-bottom: 16px; }
.cv-auth-form { display: flex; flex-direction: column; gap: 14px; }
.cv-field { display: flex; flex-direction: column; gap: 6px; }
.cv-field-lbl { font-size: 12px; font-weight: 600; color: var(--ink-2); }
.tenant-unavailable { text-align: center; }
.tenant-unavailable h1 { font-size: 20px; font-weight: 800; margin-bottom: 8px; }
.tenant-unavailable p { color: var(--ink-3); font-size: 13.5px; }
