/* ============================================================
   cont.css — Buyer portal (promoted from V2 in phase 63, 2026-04-20)
   ------------------------------------------------------------
   Ground rules:
   - Canonical tokens only: --brand, --ink, --line, --surface,
     --surface-alt, --radius*, --fs-*, --space-*. No custom
     --cv-* design tokens; --cv-* is reserved for layout-only
     values that have no canonical equivalent.
   - Mirrors supplier sp2-drawer patterns (section title,
     card-surface item, addr row, totals block).
   - Mobile-first. Tabs at top on desktop, bottom on mobile.
   ============================================================ */

:root {
  /* Buyer portal local palette — status pills, alert variants, white ink.
     Hoisted from inline hex to satisfy drift check (raw_hex_outside_root).
     Values mirror existing project palette. */
  --cv-white: #fff;
  --cv-danger-ink: #dc2626;
  --cv-danger-ink-strong: #b91c1c;
  --cv-danger-bg: #fef2f2;
  --cv-info-bg: #eff6ff;
  --cv-info-border: #bfdbfe;
  --cv-info-ink: #1d4ed8;
  --cv-success-bg: #f0fdf4;
  --cv-success-border: #bbf7d0;
  --cv-success-ink: #166534;
  --cv-error-border: #fecaca;
  --cv-status-noua-bg: #dbeafe;
  --cv-status-noua-ink: #1d4ed8;
  /* phase 81ao+: mov (#ede9fe / #6d28d9) → teal (paletă coerentă cu brand). */
  --cv-status-conf-bg: #ccfbf1;
  --cv-status-conf-ink: #115e59;
  --cv-status-exp-bg: #fef3c7;
  --cv-status-exp-ink: #92400e;
  --cv-status-final-bg: #dcfce7;
  --cv-status-final-ink: #166534;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  margin: 0;
  background: var(--page-bg);
  color: var(--ink);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

.skip-link {
  position: absolute; left: -9999px; top: auto;
  padding: var(--space-2) var(--space-3);
  background: var(--ink); color: var(--cv-white); border-radius: var(--radius-sm);
  z-index: 1000;
}
.skip-link:focus { left: var(--space-3); top: var(--space-3); }

/* Boot state ------------------------------------------------- */
.cv-boot {
  min-height: 100vh;
  display: grid; place-items: center;
  font-size: var(--fs-sm);
  color: var(--ink-soft);
}
.cv-boot[hidden] { display: none; }

/* Shell layout ----------------------------------------------- */
.cv-shell {
  min-height: 100vh;
  display: flex; flex-direction: column;
  background: var(--page-bg);
}

/* Header ----------------------------------------------------- */
.cv-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  gap: var(--space-3);
}
.cv-brand {
  display: flex; align-items: center; gap: var(--space-2);
  text-decoration: none; color: inherit;
}
.cv-brand-logo { width: 32px; height: 32px; border-radius: var(--radius-sm); }
.cv-brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.cv-brand-title { font-size: var(--fs-sm); font-weight: 700; color: var(--ink); }
.cv-brand-sub { font-size: var(--fs-xs); color: var(--ink-mute); }
.cv-header-actions { display: flex; gap: var(--space-2); align-items: center; }

/* Buttons ---------------------------------------------------- */
.cv-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  min-height: 40px;
  padding: 0 var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  font: inherit; font-size: var(--fs-sm); font-weight: 600;
  text-decoration: none; cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}
.cv-btn:hover { border-color: var(--brand); color: var(--brand); }
.cv-btn--primary {
  background: var(--brand); border-color: var(--brand); color: var(--cv-white);
}
.cv-btn--primary:hover { background: var(--brand-600); border-color: var(--brand-600); color: var(--cv-white); }
.cv-btn--ghost { background: transparent; }
.cv-btn--danger:hover { border-color: var(--cv-danger-ink); color: var(--cv-danger-ink); }
.cv-btn--lg { min-height: 48px; padding: 0 var(--space-4); font-size: var(--fs-base); }
.cv-btn--block { width: 100%; justify-content: center; min-height: 48px; font-size: var(--fs-base); font-weight: 700; }
.cv-btn[disabled] { opacity: .5; cursor: not-allowed; }
.cv-btn[disabled]:hover { border-color: var(--line); color: var(--ink); }

/* Tabs (desktop top bar) ------------------------------------- */
.cv-tabs {
  position: sticky; top: 57px; z-index: 40;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  display: flex; gap: 0;
  padding: 0 var(--space-4);
  overflow-x: auto;
}
.cv-tab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: var(--space-3) var(--space-4);
  background: transparent; border: none; border-bottom: 2px solid transparent;
  color: var(--ink-soft); font: inherit; font-size: var(--fs-sm); font-weight: 600;
  cursor: pointer; white-space: nowrap;
  min-height: 48px;
}
.cv-tab svg { width: 18px; height: 18px; }
.cv-tab:hover { color: var(--ink); }
.cv-tab.active { color: var(--brand); border-bottom-color: var(--brand); }

/* Main area -------------------------------------------------- */
.cv-main {
  flex: 1;
  max-width: 1040px;
  width: 100%;
  margin: 0 auto;
  padding: var(--space-5) var(--space-4) calc(var(--space-5) + 80px);
  box-sizing: border-box;
}
.cv-panel-head { margin-bottom: var(--space-4); }
.cv-panel-title {
  margin: 0 0 4px 0;
  font-size: var(--fs-xl); font-weight: 800; color: var(--ink);
  line-height: 1.2;
}
.cv-panel-sub {
  margin: 0;
  font-size: var(--fs-sm); color: var(--ink-soft);
}
#cvPanelComenzi .cv-panel-head { margin-bottom: var(--space-2); }

.cv-empty {
  padding: var(--space-5);
  text-align: center;
  color: var(--ink-mute);
  font-size: var(--fs-sm);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

/* Alerts ----------------------------------------------------- */
.cv-alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  border: 1px solid transparent;
  margin-bottom: var(--space-3);
}
.cv-alert--info { background: var(--cv-info-bg); border-color: var(--cv-info-border); color: var(--cv-info-ink); }
.cv-alert--success { background: var(--cv-success-bg); border-color: var(--cv-success-border); color: var(--cv-success-ink); }
.cv-alert--error { background: var(--cv-danger-bg); border-color: var(--cv-error-border); color: var(--cv-danger-ink-strong); }

/* ============================================================
   COMENZI tab
   ============================================================ */
.cv-search {
  display: flex; align-items: center; gap: var(--space-2);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 0 var(--space-3);
  margin-bottom: var(--space-3);
}
.cv-search svg { width: 18px; height: 18px; color: var(--ink-mute); flex: 0 0 auto; }
.cv-search input {
  flex: 1; min-height: 44px;
  border: none; background: transparent;
  font: inherit; font-size: var(--fs-sm); color: var(--ink);
}
.cv-search input::placeholder { color: var(--ink-mute); }

.cv-order-list {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}
.cv-order-row {
  display: grid;
  grid-template-columns: minmax(120px, 140px) 1fr minmax(90px, 110px) minmax(110px, 130px) 36px;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: none;
  border-bottom: 1px solid var(--line);
  /* phase 81ao+: accent strip stânga colorat după status — listă mai vie. */
  border-left: 3px solid transparent;
  background: var(--surface);
  width: 100%;
  text-align: left; font: inherit; color: inherit;
  cursor: pointer;
  transition: background .12s, border-left-color .12s;
}
.cv-order-row:last-child { border-bottom: none; }
.cv-order-row:hover { background: var(--surface-alt); }
.cv-order-row:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
.cv-order-row[data-status="noua"]       { border-left-color: var(--cv-status-noua-ink); }
.cv-order-row[data-status="confirmata"] { border-left-color: var(--cv-status-conf-ink); }
.cv-order-row[data-status="expediata"]  { border-left-color: var(--cv-status-exp-ink); }
.cv-order-row[data-status="finalizata"] { border-left-color: var(--cv-status-final-ink); }
.cv-order-row[data-status="anulata"]    { border-left-color: var(--ink-mute); }

.cv-order-number-wrap {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 6px; min-width: 0;
}
.cv-order-number {
  font-size: var(--fs-sm); font-weight: 700; color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.cv-cart-chip {
  display: inline-flex; align-items: center;
  padding: 2px 8px;
  font-size: var(--fs-xs); font-weight: 700; line-height: 1.4;
  color: var(--brand);
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.18);
  border-radius: 999px;
  white-space: nowrap;
}
.cv-order-meta {
  display: flex; flex-direction: column; gap: 2px;
  min-width: 0;
}
.cv-order-date { font-size: var(--fs-xs); color: var(--ink-mute); }
.cv-order-supplier {
  font-size: var(--fs-sm); color: var(--ink-soft);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cv-order-total {
  font-size: var(--fs-sm); font-weight: 700; color: var(--ink);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.cv-order-chev {
  color: var(--ink-mute);
  display: flex; align-items: center; justify-content: flex-end;
}
.cv-order-chev svg { width: 18px; height: 18px; }

/* Status badge (mirrors supplier sp2-drawer-status-badge) ---- */
/* phase 81ao+: drop uppercase + letter-spacing — Title Case natural,
   aliniat cu badges din supplier/admin v2. */
.cv-status {
  display: inline-flex; align-items: center;
  padding: 4px var(--space-2);
  border-radius: var(--radius-sm);
  font-size: var(--fs-xs);
  font-weight: 600;
  white-space: nowrap;
}
.cv-status--noua        { background: var(--cv-status-noua-bg); color: var(--cv-status-noua-ink); }
.cv-status--confirmata  { background: var(--cv-status-conf-bg); color: var(--cv-status-conf-ink); }
.cv-status--expediata   { background: var(--cv-status-exp-bg); color: var(--cv-status-exp-ink); }
.cv-status--finalizata  { background: var(--cv-status-final-bg); color: var(--cv-status-final-ink); }
.cv-status--anulata     { background: var(--surface-alt); color: var(--ink-mute); }

/* Pagination ------------------------------------------------- */
.cv-pagination {
  display: flex; justify-content: center; align-items: center; gap: var(--space-2);
  margin-top: var(--space-4);
  flex-wrap: wrap;
}
.cv-page-btn {
  min-width: 36px; min-height: 36px;
  padding: 0 var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: var(--surface);
  font: inherit; font-size: var(--fs-sm); color: var(--ink);
  cursor: pointer;
}
.cv-page-btn:hover:not([disabled]) { border-color: var(--brand); color: var(--brand); }
.cv-page-btn.active { background: var(--brand); border-color: var(--brand); color: var(--cv-white); }
.cv-page-btn[disabled] { opacity: .4; cursor: not-allowed; }
.cv-page-info { font-size: var(--fs-sm); color: var(--ink-soft); padding: 0 var(--space-2); }

/* ============================================================
   DRAWER — order detail (mirrors supplier sp2-drawer)
   ============================================================ */
.cv-drawer-root[hidden] { display: none; }
.cv-drawer-backdrop {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(15, 23, 42, 0.45);
  animation: cv-fade-in .15s ease-out;
}
@keyframes cv-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes cv-slide-in { from { transform: translateX(100%); } to { transform: translateX(0); } }

.cv-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 901;
  width: min(640px, 100vw);
  background: var(--surface);
  box-shadow: -10px 0 40px rgba(15, 23, 42, 0.18);
  display: flex; flex-direction: column;
  animation: cv-slide-in .18s ease-out;
}
.cv-drawer-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4);
  border-bottom: 1px solid var(--line);
}
.cv-drawer-title-wrap { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.cv-drawer-title {
  margin: 0;
  font-size: var(--fs-lg); font-weight: 800; color: var(--ink);
  line-height: 1.2;
  font-variant-numeric: tabular-nums;
}
.cv-drawer-subtitle { font-size: var(--fs-sm); color: var(--ink-soft); }
.cv-drawer-close {
  /* UX-092 (phase 66): 44×44 tap target (WCAG 2.5.5). */
  flex: 0 0 auto;
  width: 44px; height: 44px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: var(--surface);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-soft);
}
.cv-drawer-close:hover { border-color: var(--brand); color: var(--brand); }

.cv-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-4);
  display: flex; flex-direction: column; gap: var(--space-5);
}

/* Drawer section — mirrors .sp2-drawer-section */
.cv-section { display: flex; flex-direction: column; gap: var(--space-3); }
.cv-section-title {
  margin: 0;
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--ink-mute);
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* Siblings (multi-supplier cart) */
.cv-section--siblings {
  padding: var(--space-3);
  background: rgba(37, 99, 235, 0.04);
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: var(--radius);
}
.cv-section-hint {
  margin: 0;
  font-size: var(--fs-xs);
  line-height: 1.55;
  color: var(--ink-soft);
}
.cv-sibling-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  overflow: hidden;
}
.cv-sibling-row {
  display: grid;
  grid-template-columns: 1fr auto auto 20px;
  align-items: center;
  gap: var(--space-3);
  padding: 10px var(--space-3);
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background .12s;
}
.cv-sibling-row:last-child { border-bottom: none; }
.cv-sibling-row:hover { background: var(--surface-alt); }
.cv-sibling-row:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
.cv-sibling-supplier {
  font-size: var(--fs-sm); font-weight: 600; color: var(--ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cv-sibling-meta {
  display: flex; align-items: center; gap: var(--space-2);
}
.cv-sibling-num {
  font-size: var(--fs-xs); color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
}
.cv-sibling-total {
  font-size: var(--fs-sm); font-weight: 700; color: var(--ink);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
@media (max-width: 640px) {
  .cv-sibling-row {
    grid-template-columns: 1fr auto;
    grid-template-areas: "supplier total" "meta total";
    row-gap: 4px;
  }
  .cv-sibling-supplier { grid-area: supplier; }
  .cv-sibling-meta { grid-area: meta; }
  .cv-sibling-total { grid-area: total; align-self: center; }
  .cv-sibling-row .cv-order-chev { display: none; }
}

/* Repeat-order modal ----------------------------------------- */
.cv-modal-root {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
}
.cv-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(15, 23, 42, 0.5);
  animation: cv-fade-in .15s ease-out;
}
.cv-modal {
  position: relative;
  width: min(620px, 100%);
  height: min(720px, calc(100vh - 32px));
  max-height: 100vh;
  background: var(--surface);
  border-radius: var(--radius-md);
  box-shadow: 0 30px 80px rgba(15, 23, 42, 0.22);
  display: flex; flex-direction: column;
  overflow: hidden;
  animation: cv-fade-in .18s ease-out;
}
@media (max-width: 640px) {
  .cv-modal {
    width: 100%; height: 100vh; max-height: 100vh;
    border-radius: 0;
  }
}
.cv-modal-header {
  flex: 0 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--line);
}
.cv-modal-title {
  margin: 0;
  font-size: var(--fs-base); font-weight: 800; color: var(--ink);
  line-height: 1.25;
}
.cv-modal-subtitle { font-size: var(--fs-xs); color: var(--ink-soft); display: block; margin-top: 2px; }
.cv-modal-pickers {
  flex: 0 0 auto;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--line);
  background: var(--surface-alt);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.cv-modal-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: var(--space-3) var(--space-4);
}
.cv-modal-field { display: flex; flex-direction: column; gap: 4px; }
.cv-modal-label {
  font-size: var(--fs-xs); font-weight: 600; color: var(--ink-soft);
}
.cv-modal-select {
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  font: inherit; color: var(--ink);
  width: 100%;
}
.cv-modal-select:focus { border-color: var(--brand); outline: 2px solid var(--brand-50, rgba(37,99,235,.16)); outline-offset: 0; }
.cv-modal-note {
  grid-column: 1 / -1;
  padding: 10px 12px;
  background: rgba(245, 158, 11, 0.1);
  color: var(--cv-status-exp-ink);
  border-radius: var(--radius-sm);
  font-size: var(--fs-xs);
}
.cv-modal-items {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 2px;
}
.cv-modal-item {
  display: grid;
  grid-template-columns: 24px 1fr auto;
  grid-template-areas:
    "idx main amount"
    ".   qty  amount";
  column-gap: var(--space-3);
  row-gap: 6px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid var(--line);
}
.cv-modal-item:first-child { border-top: 0; }
.cv-modal-item .cv-item-idx { grid-area: idx; align-self: start; padding-top: 2px; }
.cv-modal-item-main { grid-area: main; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cv-modal-item .cv-qty-stepper { grid-area: qty; justify-self: start; }
.cv-modal-item .cv-item-amount { grid-area: amount; align-self: center; }
.cv-qty-stepper {
  display: inline-flex; align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--surface);
}
.cv-qty-btn {
  width: 30px; height: 30px;
  border: 0; background: transparent;
  font-size: var(--fs-base); font-weight: 700; color: var(--ink);
  cursor: pointer;
}
.cv-qty-btn:hover { background: var(--surface-alt); color: var(--brand); }
.cv-qty-value {
  min-width: 28px; text-align: center;
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-sm); font-weight: 600;
}
.cv-totals-muted { color: var(--ink-soft); font-size: var(--fs-xs); }
.cv-modal-footer {
  flex: 0 0 auto;
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: var(--space-2);
  background: var(--surface);
}
.cv-btn--link {
  background: transparent; border: 0; color: var(--ink-soft);
  min-height: auto; padding: 6px 0;
  font-size: var(--fs-sm); font-weight: 500;
  align-self: center;
}
.cv-btn--link:hover { color: var(--brand); background: transparent; border: 0; }

/* Totals bar — fixat sus, între body scrollabil și footer (drawer + modal) */
.cv-totals-bar {
  flex: 0 0 auto;
  padding: var(--space-3) var(--space-4);
  background: var(--surface-alt);
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 4px;
  font-variant-numeric: tabular-nums;
}
.cv-totals-bar .cv-totals-row {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: var(--fs-sm); color: var(--ink-soft);
}
.cv-totals-bar .cv-totals-row--grand {
  padding-top: 6px;
  margin-top: 4px;
  border-top: 1px solid var(--line);
  color: var(--ink); font-weight: 800;
  font-size: var(--fs-base);
}
.cv-totals-row--discount {
  color: var(--brand, #2563eb);
  font-weight: 600;
}

/* Address card — mirrors .sp2-addr-card */
.cv-addr-card {
  padding: var(--space-3);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  display: flex; flex-direction: column; gap: 6px;
}
.cv-addr-row {
  display: flex; gap: var(--space-2);
  font-size: var(--fs-sm); line-height: 1.4;
}
.cv-addr-label { flex: 0 0 92px; color: var(--ink-mute); }
.cv-addr-value { flex: 1 1 auto; color: var(--ink); word-break: break-word; }
.cv-addr-name { font-weight: 600; color: var(--ink); font-size: var(--fs-sm); }

/* Items list — compact numbered rows, fără cadre/linii */
.cv-items-list {
  list-style: none; margin: 0; padding: 0;
}
.cv-item {
  padding: 6px 0;
  display: grid;
  grid-template-columns: 28px 1fr auto;
  column-gap: var(--space-3);
  row-gap: 2px;
  align-items: baseline;
}
.cv-item-idx {
  grid-column: 1; grid-row: 1;
  font-size: var(--fs-xs); color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.cv-item-title {
  grid-column: 2; grid-row: 1;
  font-size: var(--fs-sm); font-weight: 600; color: var(--ink);
}
.cv-item-meta {
  grid-column: 2; grid-row: 2;
  font-size: var(--fs-xs); color: var(--ink-mute);
}
.cv-item-amount {
  grid-column: 3; grid-row: 1 / span 2;
  font-size: var(--fs-sm); font-weight: 700; color: var(--ink);
  text-align: right; white-space: nowrap;
  font-variant-numeric: tabular-nums;
  align-self: center;
}

/* Items count header inside drawer */
.cv-items-count {
  font-size: var(--fs-xs); color: var(--ink-mute);
  font-weight: 500;
}

/* Totals block ----------------------------------------------- */
.cv-totals {
  background: var(--surface-alt);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  display: flex; flex-direction: column; gap: 6px;
}
.cv-totals-row {
  display: flex; justify-content: space-between;
  font-size: var(--fs-sm); color: var(--ink-soft);
  font-variant-numeric: tabular-nums;
}
.cv-totals-row--grand {
  padding-top: var(--space-2);
  margin-top: 2px;
  border-top: 1px solid var(--line);
  color: var(--ink);
  font-weight: 800;
  font-size: var(--fs-base);
}

.cv-drawer-footer {
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--line);
  display: flex; gap: var(--space-2); flex-wrap: wrap;
  background: var(--surface);
}

/* ============================================================
   CONT tab — Contact + Facturare + Livrare
   ============================================================ */
.cv-form-stack { display: flex; flex-direction: column; gap: var(--space-5); }

.cv-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-4) var(--space-4) var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.cv-card-head { display: flex; flex-direction: column; gap: 4px; margin-bottom: var(--space-2); }
.cv-card-title { margin: 0; font-size: var(--fs-md); font-weight: 700; color: var(--ink); }
.cv-card-sub { margin: 0; font-size: var(--fs-sm); color: var(--ink-soft); }
.cv-card--loyalty {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-sm);
}
.cv-card--loyalty .cv-loy-meter { margin-bottom: 0; }

.cv-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
@media (max-width: 640px) { .cv-row { grid-template-columns: 1fr; } }

.cv-field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.cv-field label {
  font-size: var(--fs-xs); font-weight: 600; color: var(--ink-soft);
}
.cv-field input, .cv-field select, .cv-field textarea {
  width: 100%; box-sizing: border-box;
  min-height: 44px;
  padding: 0 var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--ink);
  font: inherit; font-size: var(--fs-sm);
}
.cv-field textarea { min-height: 90px; padding: var(--space-2) var(--space-3); resize: vertical; }
.cv-field input:focus, .cv-field select:focus, .cv-field textarea:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(26, 86, 219, .1);
}
.cv-field input[disabled] {
  background: var(--surface-alt);
  color: var(--ink-mute);
  cursor: not-allowed;
}

/* Multi-address accordion (phase 66 UX-106) */
.cv-addr-list {
  display: flex; flex-direction: column;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  overflow: hidden;
}
.cv-addr-block {
  display: flex; flex-direction: column;
}
.cv-addr-block + .cv-addr-block {
  border-top: 1px solid var(--line);
}
.cv-addr-summary {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-3);
  cursor: pointer;
  min-height: 56px;
  user-select: none;
  transition: background 120ms ease;
}
.cv-addr-summary:hover { background: var(--surface-alt); }
.cv-addr-summary:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
.cv-addr-block.is-open .cv-addr-summary { background: var(--surface-alt); border-bottom: 1px solid var(--line); }
.cv-addr-summary-main {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px 10px;
  flex: 1 1 auto; min-width: 0;
}
.cv-addr-summary-title {
  font-weight: 600; color: var(--ink); font-size: var(--fs-sm);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cv-addr-summary-sub {
  flex-basis: 100%;
  color: var(--ink-soft); font-size: var(--fs-xs);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cv-addr-badge {
  display: inline-flex; align-items: center;
  padding: 2px 8px; border-radius: 999px;
  background: var(--brand-soft);
  color: var(--brand); font-size: var(--fs-xs); font-weight: 600;
  letter-spacing: 0.02em;
}
.cv-addr-chev {
  flex: 0 0 auto;
  color: var(--ink-mute); font-size: var(--fs-sm); line-height: 1;
  padding: 0 4px;
}
.cv-addr-body {
  display: flex; flex-direction: column; gap: var(--space-3);
  padding: var(--space-3);
}
.cv-addr-actions {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-2);
  padding-bottom: var(--space-2);
  border-bottom: 1px dashed var(--line);
}
.cv-addr-archived {
  padding: var(--space-3);
  color: var(--ink-mute); font-size: var(--fs-sm); font-style: italic;
  border-top: 1px dashed var(--line);
}
.cv-addr-radio {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--fs-sm); color: var(--ink); cursor: pointer;
}
.cv-addr-radio input { width: 16px; height: 16px; accent-color: var(--brand); }
.cv-addr-remove {
  background: transparent; border: none; color: var(--ink-mute);
  cursor: pointer; padding: 4px 8px; border-radius: var(--radius-sm);
  font: inherit; font-size: var(--fs-xs);
}
.cv-addr-remove:hover { color: var(--cv-danger-ink-strong); background: var(--cv-danger-bg); }
.cv-addr-add {
  background: transparent;
  border: 1px dashed var(--line);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  font: inherit; font-size: var(--fs-sm); color: var(--ink-mute);
  cursor: pointer;
  min-height: 44px;
}
.cv-addr-add:hover { border-color: var(--brand); color: var(--brand); }

/* Save-all footer */
.cv-save-bar {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-3) var(--space-4);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-4);
}
.cv-save-hint { font-size: var(--fs-xs); color: var(--ink-mute); }

/* ============================================================
   Responsive — tabs move to bottom on mobile
   ============================================================ */
@media (max-width: 760px) {
  .cv-header { padding: var(--space-2) var(--space-3); }
  .cv-header-actions .cv-btn:first-child { display: none; }
  .cv-tabs {
    position: fixed; top: auto; bottom: 0; left: 0; right: 0;
    border-top: 1px solid var(--line); border-bottom: none;
    padding: 0;
    justify-content: space-around;
    background: var(--surface);
    box-shadow: 0 -4px 12px rgba(15, 23, 42, .06);
  }
  .cv-tab {
    flex: 1 1 0;
    flex-direction: column;
    gap: 2px;
    padding: var(--space-2);
    font-size: var(--fs-xs);
    min-height: 60px;
    border-bottom: none;
    border-top: 2px solid transparent;
  }
  .cv-tab.active { border-bottom-color: transparent; border-top-color: var(--brand); }
  .cv-main { padding: var(--space-4) var(--space-3) calc(var(--space-4) + 80px); }
  .cv-order-row {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "num   status"
      "meta  total";
    gap: 6px var(--space-3);
    padding: var(--space-3);
  }
  .cv-order-row .cv-order-number-wrap { grid-area: num; }
  .cv-order-row .cv-order-meta { grid-area: meta; }
  .cv-order-row .cv-order-total { grid-area: total; }
  .cv-order-row .cv-status { grid-area: status; justify-self: end; }
  .cv-order-row .cv-order-chev { display: none; }
  .cv-drawer { width: 100vw; }
  .cv-save-bar {
    position: sticky; bottom: 80px; z-index: 10;
    box-shadow: var(--shadow-md);
  }
}

/* ============================================================
   Utility primitives (phase 66 P1-UI-01 — class-reference gate)
   ============================================================ */

/* SVG icon wrapper used in search / chevron / close affordances */
.cv-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  color: currentColor;
  line-height: 0;
}
.cv-ico > svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Drill-in account/order line — product name label */
.account-item-name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold, 600);
  color: var(--ink);
  line-height: 1.35;
}

/* Phase 81ak (2026-04-27): tab Recomandă cabinete — referral system. */
.cv-card--soft {
  background: var(--surface-soft, var(--surface));
  border: 1px dashed var(--line);
}
.cv-bulleted {
  margin: 0;
  padding-left: 1.25em;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  color: var(--ink-soft);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.cv-bulleted li { padding-left: 4px; }
.cv-referral-code-box {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--surface-2, var(--surface));
  border: 2px dashed var(--brand);
  border-radius: var(--radius);
  margin: var(--space-3) 0;
  flex-wrap: wrap;
}
.cv-referral-code-text {
  flex: 1;
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--brand);
  font-variant-numeric: tabular-nums;
}
.cv-referral-share {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  flex-wrap: wrap;
  margin-top: var(--space-2);
}
.cv-stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-3);
  margin: var(--space-4) 0;
}
.cv-stat-box {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  text-align: center;
}
.cv-stat-value {
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.cv-stat-label {
  font-size: var(--fs-xs);
  color: var(--ink-soft);
  margin-top: var(--space-1);
}
.cv-stat-sub {
  font-size: var(--fs-xs);
  color: var(--ink-mute);
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.cv-bonus-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.cv-bonus-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  flex-wrap: wrap;
}
.cv-bonus-code {
  flex: 1;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
  /* phase 81ar: button click → copy în clipboard */
  background: transparent;
  border: none;
  color: var(--brand);
  cursor: pointer;
  padding: 0;
  font: inherit;
  text-align: left;
  font-weight: 700;
  letter-spacing: 0.04em;
  transition: color .12s;
}
.cv-bonus-code:hover { text-decoration: underline; }
.cv-bonus-code--copied { color: var(--success-700); }
.cv-bonus-code--copied::after {
  content: " ✓";
  color: var(--success-700);
}
.cv-bonus-date {
  font-size: var(--fs-xs);
  color: var(--ink-mute);
  white-space: nowrap;
}
.cv-bonus-value {
  font-weight: 700;
  color: var(--brand);
  font-variant-numeric: tabular-nums;
}
.cv-bonus-status {
  font-size: var(--fs-xs);
  font-weight: 600;
  padding: 2px var(--space-2);
  border-radius: var(--radius-pill, 999px);
}
.cv-bonus-status--available {
  background: var(--success-bg, var(--surface));
  color: var(--success-text, var(--ink));
}
.cv-bonus-status--used {
  background: var(--surface-2, var(--surface));
  color: var(--ink-soft);
}

/* phase 81ao+++ (2026-04-28): Loyalty progress tracker.
   Etape vizibile: Bronze / Silver / Gold, cu context în tabul Cont. */
.cv-loy-meter {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  padding: 0;
}
.cv-loy-summary {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
}
.cv-loy-current {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  min-width: 0;
}
.cv-loy-current-label {
  color: var(--ink-mute);
  font-size: var(--fs-xs);
  font-weight: 600;
}
.cv-loy-current-name {
  color: var(--ink);
  font-size: var(--fs-md);
  font-weight: 700;
}
.cv-loy-stage {
  position: relative;
  min-height: calc(var(--space-12) + var(--space-6));
}
.cv-loy-track {
  position: absolute;
  top: var(--space-1);
  left: 0;
  right: 0;
  height: var(--space-2);
  background: var(--surface-alt);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.cv-loy-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--brand-200), var(--brand));
  border-radius: var(--radius-pill);
  transition: width var(--dur-normal) var(--ease);
}
.cv-loy-steps {
  position: relative;
  min-height: calc(var(--space-12) + var(--space-4));
  margin: 0;
  padding: 0;
  list-style: none;
}
.cv-loy-step {
  position: absolute;
  top: 0;
  inline-size: calc(var(--space-12) * 3);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  transform: translateX(-50%);
  text-align: center;
  color: var(--ink-mute);
  font-size: var(--fs-xs);
}
.cv-loy-step--first {
  align-items: flex-start;
  transform: translateX(0);
  text-align: left;
}
.cv-loy-step--last {
  align-items: flex-end;
  transform: translateX(-100%);
  text-align: right;
}
.cv-loy-step-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--space-5);
  height: var(--space-5);
  border: 2px solid var(--line);
  border-radius: 50%;
  background: var(--surface);
  color: var(--ink-mute);
  box-shadow: var(--shadow-sm);
}
.cv-loy-step-icon {
  font-size: var(--fs-xs);
  line-height: 1;
}
.cv-loy-step-name {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--ink-soft);
  font-weight: 700;
  white-space: nowrap;
}
.cv-loy-step-meta {
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.cv-loy-step--reached .cv-loy-step-dot {
  border-color: var(--brand);
  background: var(--brand-50);
  color: var(--brand);
}
.cv-loy-step--current .cv-loy-step-dot {
  box-shadow: 0 0 0 var(--space-1) var(--brand-50);
}
.cv-loy-step--current .cv-loy-step-name {
  color: var(--ink);
}
.cv-loy-step--bronze.cv-loy-step--reached .cv-loy-step-dot {
  border-color: var(--cv-status-exp-ink);
  color: var(--cv-status-exp-ink);
}
.cv-loy-step--silver.cv-loy-step--reached .cv-loy-step-dot {
  border-color: var(--ink-mute);
  color: var(--ink-mute);
}
.cv-loy-step--gold.cv-loy-step--reached .cv-loy-step-dot {
  border-color: var(--warn-text);
  color: var(--warn-text);
}
.cv-loy-step--platinum.cv-loy-step--reached .cv-loy-step-dot {
  border-color: var(--accent);
  color: var(--accent);
}

@media (max-width: 640px) {
  .cv-loy-summary {
    align-items: start;
    gap: var(--space-1);
  }
  .cv-loy-stage { min-height: var(--space-12); }
  .cv-loy-steps { min-height: var(--space-12); }
  .cv-loy-step { inline-size: calc(var(--space-12) * 2); }
  .cv-loy-step-meta { display: none; }
}

/* ============================================================
   Orders summary (phase 81aq) — count sub page header, no duplicate title.
   ============================================================ */
.cv-order-summary {
  margin: 0 0 var(--space-3);
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   Empty state (phase 81ao+) — icon + titlu + helper + CTA
   Fix AP-007: pattern canonical [icon 48px][title fs-lg][helper fs-sm][CTA].
   ============================================================ */
.cv-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-2);
  padding: var(--space-6) var(--space-4);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.cv-empty-state .cv-empty-icon {
  width: 48px; height: 48px;
  color: var(--ink-mute);
  margin-bottom: var(--space-2);
}
.cv-empty-state .cv-empty-icon svg {
  width: 100%; height: 100%;
}
.cv-empty-title {
  margin: 0;
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--ink);
}
.cv-empty-helper {
  margin: 0;
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  max-width: 360px;
}
.cv-empty-state .cv-btn { margin-top: var(--space-3); }

/* ============================================================
   Recomandă (phase 81ar 2026-04-29) — howto + per-pair list
   ============================================================ */
.cv-howto {
  margin-bottom: var(--space-4);
}
.cv-howto-grid {
  list-style: none;
  margin: var(--space-3) 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-3);
}
.cv-howto-step {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.cv-howto-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: var(--radius-pill, 999px);
  background: var(--brand-50);
  color: var(--brand);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-base);
}
.cv-howto-title {
  margin: 0;
  font-size: var(--fs-base);
  font-weight: 700;
  color: var(--ink);
  line-height: 1.3;
}
.cv-howto-desc {
  margin: 0;
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  line-height: 1.5;
}

/* Per-pair list (cabinete invitate cu progres) ─────────────── */
.cv-pair-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.cv-pair-item {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cv-pair-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.cv-pair-name {
  font-size: var(--fs-base);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.cv-pair-status {
  font-size: var(--fs-xs);
  font-weight: 600;
  padding: 2px var(--space-2);
  border-radius: var(--radius-pill, 999px);
  white-space: nowrap;
}
.cv-pair-status--waiting {
  background: var(--cv-status-noua-bg);
  color: var(--cv-status-noua-ink);
}
.cv-pair-status--active {
  background: var(--cv-status-conf-bg);
  color: var(--cv-status-conf-ink);
}
.cv-pair-status--max {
  background: var(--cv-status-final-bg);
  color: var(--cv-status-final-ink);
}
.cv-pair-meta {
  display: flex;
  justify-content: space-between;
  gap: var(--space-2);
  font-size: var(--fs-xs);
  color: var(--ink-soft);
  flex-wrap: wrap;
}
.cv-pair-date { color: var(--ink-mute); }
.cv-pair-count {
  font-weight: 700;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.cv-pair-progress {
  height: 6px;
  background: var(--surface-alt);
  border-radius: var(--radius-pill, 999px);
  overflow: hidden;
  position: relative;
}
.cv-pair-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--brand-200), var(--brand));
  border-radius: var(--radius-pill, 999px);
  transition: width 0.5s ease;
}
