/* ============================================================
   VANZA — Component layer (consumes tokens.css; nothing here
   may introduce a colour/size that isn't a token).
   Source: Claude Design handoff ds-kit.jsx + ds-components.jsx
   (2026-06-11), translated to framework-free CSS. Status chips
   extended to the 10-state job enum.
   ============================================================ */

/* ---------- BUTTON ---------- */
.v-btn{ --bh:var(--h-control); height:var(--bh); display:inline-flex; align-items:center; justify-content:center;
  gap:8px; padding:0 16px; border-radius:var(--r-md); border:1px solid transparent; cursor:pointer;
  font-family:var(--font-sans); font-weight:600; font-size:14px; letter-spacing:-0.005em; white-space:nowrap;
  transition:background var(--dur-fast) var(--ease-out), border-color var(--dur-fast), box-shadow var(--dur-fast), transform var(--dur-fast); user-select:none; text-decoration:none; }
.v-btn:focus-visible{ outline:none; box-shadow:var(--ring); }
.v-btn:active{ transform:translateY(1px); }
.v-btn.sz-sm{ --bh:var(--h-control-sm); padding:0 12px; font-size:13px; border-radius:var(--r-sm); }
.v-btn.sz-lg{ --bh:var(--h-control-lg); padding:0 20px; font-size:15px; }
.v-btn.sz-touch{ --bh:var(--h-touch); padding:0 24px; font-size:16px; border-radius:var(--r-lg); }
.v-btn.is-block{ width:100%; }
.v-btn:disabled{ opacity:.5; cursor:not-allowed; transform:none; }
.v-btn.is-primary{ background:var(--primary); color:var(--on-primary); box-shadow:var(--shadow-xs); }
.v-btn.is-primary:hover{ background:var(--primary-hover); }
.v-btn.is-primary:active{ background:var(--primary-press); }
.v-btn.is-secondary{ background:var(--bg-surface); color:var(--text-strong); border-color:var(--border-strong); box-shadow:var(--shadow-xs); }
.v-btn.is-secondary:hover{ background:var(--bg-hover); border-color:var(--text-subtle); }
.v-btn.is-ghost{ background:transparent; color:var(--text-default); }
.v-btn.is-ghost:hover{ background:var(--bg-hover); }
.v-btn.is-subtle{ background:var(--primary-tint); color:var(--primary); }
.v-btn.is-subtle:hover{ background:var(--primary-tint-2); }
.v-btn.is-danger{ background:var(--danger); color:#fff; }
.v-btn.is-danger:hover{ filter:brightness(1.06); }
.v-btn.is-danger:focus-visible{ box-shadow:var(--ring-danger); }

/* ---------- ICON BUTTON ---------- */
.v-iconbtn{ width:var(--h-control); height:var(--h-control); display:inline-flex; align-items:center; justify-content:center;
  border-radius:var(--r-md); border:1px solid transparent; background:transparent; color:var(--text-muted); cursor:pointer;
  transition:background var(--dur-fast), color var(--dur-fast), box-shadow var(--dur-fast); }
.v-iconbtn:hover{ background:var(--bg-hover); color:var(--text-strong); }
.v-iconbtn:focus-visible{ outline:none; box-shadow:var(--ring); }
.v-iconbtn.is-bordered{ border-color:var(--border-default); background:var(--bg-surface); }
.v-iconbtn.sz-lg{ width:var(--h-control-lg); height:var(--h-control-lg); }

/* ---------- SEGMENTED ---------- */
.v-seg{ display:inline-flex; padding:3px; background:var(--bg-sunken); border-radius:var(--r-md); gap:2px; }
.v-seg-item{ appearance:none; border:0; background:transparent; cursor:pointer; padding:0 14px; height:32px; border-radius:6px;
  font-family:var(--font-sans); font-weight:600; font-size:13px; color:var(--text-muted); display:inline-flex; align-items:center; gap:6px;
  transition:all var(--dur-fast) var(--ease-out); }
.v-seg-item:hover{ color:var(--text-strong); }
.v-seg-item.is-on{ background:var(--bg-surface); color:var(--text-strong); box-shadow:var(--shadow-xs); }
.v-seg.sz-lg .v-seg-item{ height:40px; padding:0 18px; font-size:14px; }

/* ---------- TABS ---------- */
.v-tabs{ display:flex; gap:4px; border-bottom:1px solid var(--border-subtle); }
.v-tab{ appearance:none; border:0; background:transparent; cursor:pointer; padding:10px 4px; margin:0 8px; position:relative;
  font-family:var(--font-sans); font-weight:600; font-size:14px; color:var(--text-muted); display:inline-flex; align-items:center; gap:7px; }
.v-tab:first-child{ margin-left:0; }
.v-tab:hover{ color:var(--text-strong); }
.v-tab.is-on{ color:var(--primary); }
.v-tab.is-on::after{ content:''; position:absolute; left:0; right:0; bottom:-1px; height:2.5px; background:var(--primary); border-radius:2px; }

/* ---------- FIELDS ---------- */
.v-label{ display:block; font-size:13px; font-weight:600; color:var(--text-strong); margin-bottom:6px; }
.v-hint{ font-size:12.5px; color:var(--text-muted); margin-top:6px; display:block; }
.v-hint.is-error{ color:var(--danger-text); }
.v-input,.v-select,.v-textarea{ width:100%; height:var(--h-control); padding:0 13px; border-radius:var(--r-md);
  border:1px solid var(--border-default); background:var(--bg-inset); color:var(--text-strong); font-family:var(--font-sans); font-size:14.5px;
  transition:border-color var(--dur-fast), box-shadow var(--dur-fast), background var(--dur-fast); }
.v-textarea{ height:auto; padding:11px 13px; line-height:1.5; resize:vertical; min-height:84px; }
.v-input::placeholder,.v-textarea::placeholder{ color:var(--text-subtle); }
.v-input:hover,.v-select:hover,.v-textarea:hover{ border-color:var(--border-strong); }
.v-input:focus,.v-select:focus,.v-textarea:focus{ outline:none; border-color:var(--border-focus); background:var(--bg-surface); box-shadow:var(--ring); }
.v-input.is-error,.v-textarea.is-error{ border-color:var(--danger); }
.v-input.is-error:focus{ box-shadow:var(--ring-danger); }
.v-input.sz-lg{ height:var(--h-control-lg); font-size:16px; }
.v-field-ico{ position:relative; display:block; }
.v-field-ico .v-input{ padding-left:40px; }
.v-field-ico > svg{ position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--text-subtle); pointer-events:none; }
.v-select{ appearance:none; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%23586884' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l4 4 4-4'/></svg>"); background-repeat:no-repeat; background-position:right 11px center; padding-right:38px; cursor:pointer; }

/* ---------- CHECK / RADIO / TOGGLE ---------- */
.v-check{ width:20px; height:20px; border-radius:6px; border:2px solid var(--border-strong); background:var(--bg-surface); display:inline-flex;
  align-items:center; justify-content:center; cursor:pointer; transition:all var(--dur-fast) var(--ease-out); color:transparent; flex-shrink:0; padding:0; }
.v-check.is-on{ background:var(--primary); border-color:var(--primary); color:#fff; }
.v-radio{ width:20px; height:20px; border-radius:999px; border:2px solid var(--border-strong); background:var(--bg-surface); cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; transition:all var(--dur-fast); flex-shrink:0; padding:0; }
.v-radio.is-on{ border-color:var(--primary); }
.v-radio.is-on::after{ content:''; width:10px; height:10px; border-radius:999px; background:var(--primary); }
.v-toggle{ width:44px; height:26px; border-radius:999px; background:var(--border-strong); position:relative; cursor:pointer; transition:background var(--dur) var(--ease-out); flex-shrink:0; border:0; padding:0; }
.v-toggle::after{ content:''; position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:999px; background:#fff; box-shadow:var(--shadow-sm); transition:transform var(--dur) var(--ease-out); }
.v-toggle.is-on{ background:var(--primary); }
.v-toggle.is-on::after{ transform:translateX(18px); }

/* ---------- STATUS CHIP — Vanza 10-state job enum ---------- */
.v-chip{ display:inline-flex; align-items:center; gap:6px; height:24px; padding:0 9px 0 8px; border-radius:var(--r-pill);
  font-size:12px; font-weight:700; letter-spacing:0.01em; line-height:1; white-space:nowrap; }
.v-chip .dot{ width:7px; height:7px; border-radius:999px; background:currentColor; flex-shrink:0; }
.v-chip.sz-lg{ height:30px; padding:0 13px 0 11px; font-size:13px; }
.v-chip[data-st=new]{ color:var(--st-new); background:var(--st-new-bg); }
.v-chip[data-st=scheduled]{ color:var(--st-scheduled); background:var(--st-scheduled-bg); }
.v-chip[data-st=dispatched]{ color:var(--st-dispatched); background:var(--st-dispatched-bg); }
.v-chip[data-st=in_progress]{ color:var(--st-in-progress); background:var(--st-in-progress-bg); }
.v-chip[data-st=on_hold]{ color:var(--st-on-hold); background:var(--st-on-hold-bg); }
.v-chip[data-st=awaiting_parts]{ color:var(--st-awaiting-parts); background:var(--st-awaiting-parts-bg); }
.v-chip[data-st=completed]{ color:var(--st-completed); background:var(--st-completed-bg); }
.v-chip[data-st=invoiced]{ color:var(--st-invoiced); background:var(--st-invoiced-bg); }
.v-chip[data-st=closed]{ color:var(--st-closed); background:var(--st-closed-bg); }
.v-chip[data-st=cancelled]{ color:var(--st-cancelled); background:var(--st-cancelled-bg); }

/* ---------- BADGE / TAG ---------- */
.v-badge{ display:inline-flex; align-items:center; justify-content:center; min-width:20px; height:20px; padding:0 6px;
  border-radius:999px; font-size:12px; font-weight:700; background:var(--danger); color:#fff; line-height:1; font-variant-numeric:tabular-nums; }
.v-badge.is-neutral{ background:var(--bg-sunken); color:var(--text-muted); }
.v-tag{ display:inline-flex; align-items:center; gap:5px; height:22px; padding:0 9px; border-radius:var(--r-sm); font-size:12px; font-weight:600;
  background:var(--bg-sunken); color:var(--text-muted); }

/* ---------- AVATAR ---------- */
.v-av{ display:inline-flex; align-items:center; justify-content:center; border-radius:999px; font-family:var(--font-sans);
  font-weight:700; color:#fff; flex-shrink:0; font-size:13px; }

/* ---------- CARD ---------- */
.v-card{ background:var(--bg-surface); border:1px solid var(--border-subtle); border-radius:var(--r-lg); box-shadow:var(--shadow-sm); }
.v-card.is-interactive{ cursor:pointer; transition:box-shadow var(--dur) var(--ease-out), border-color var(--dur), transform var(--dur); }
.v-card.is-interactive:hover{ box-shadow:var(--shadow-md); border-color:var(--border-default); transform:translateY(-1px); }

/* ---------- BANNER ---------- */
.v-banner{ display:flex; gap:12px; padding:13px 15px; border-radius:var(--r-md); font-size:14px; align-items:flex-start; border:1px solid transparent; }
.v-banner .ico{ flex-shrink:0; margin-top:1px; }
.v-banner.is-info{ background:var(--info-tint); color:var(--info-text); border-color:color-mix(in srgb,var(--info) 28%,transparent); }
.v-banner.is-success{ background:var(--success-tint); color:var(--success-text); border-color:color-mix(in srgb,var(--success) 28%,transparent); }
.v-banner.is-warning{ background:var(--warning-tint); color:var(--warning-text); border-color:color-mix(in srgb,var(--warning) 32%,transparent); }
.v-banner.is-danger{ background:var(--danger-tint); color:var(--danger-text); border-color:color-mix(in srgb,var(--danger) 30%,transparent); }

/* ---------- TOAST ---------- */
.v-toast{ display:flex; gap:12px; align-items:center; padding:13px 14px; border-radius:var(--r-lg); background:var(--navy-900);
  color:#F5F8FC; box-shadow:var(--shadow-lg); min-width:300px; }
[data-theme=dark] .v-toast{ background:var(--bg-raised); border:1px solid var(--border-default); }
.v-toast .ic{ width:28px; height:28px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }

/* ---------- EMPTY ---------- */
.v-empty{ text-align:center; padding:40px 24px; }
.v-empty .ring{ width:60px; height:60px; border-radius:999px; background:var(--bg-sunken); display:inline-flex; align-items:center; justify-content:center; color:var(--text-subtle); margin-bottom:16px; }
.v-empty .t{ font-family:var(--font-display); font-weight:700; font-size:17px; color:var(--text-strong); margin-bottom:6px; }
.v-empty .d{ color:var(--text-muted); font-size:14px; max-width:300px; margin:0 auto; }

/* ---------- SPINNER / PROGRESS / SKELETON / KBD ---------- */
.v-spin{ width:20px; height:20px; border-radius:999px; border:2.5px solid var(--border-default); border-top-color:var(--primary); animation:vspin .7s linear infinite; display:inline-block; }
@keyframes vspin{ to{ transform:rotate(360deg); } }
.v-prog{ height:8px; border-radius:999px; background:var(--bg-sunken); overflow:hidden; }
.v-prog > i{ display:block; height:100%; border-radius:999px; background:var(--primary); transition:width var(--dur-slow) var(--ease-out); }
.v-skel{ background:linear-gradient(90deg,var(--bg-sunken) 25%,var(--bg-hover) 37%,var(--bg-sunken) 63%); background-size:400% 100%; animation:vskel 1.4s ease infinite; border-radius:6px; }
@keyframes vskel{ 0%{ background-position:100% 50%; } 100%{ background-position:0 50%; } }
.v-kbd{ font-family:var(--font-mono); font-size:11px; font-weight:500; padding:2px 6px; border-radius:5px; background:var(--bg-sunken); border:1px solid var(--border-default); color:var(--text-muted); }

/* ---------- TABLE (work-order/table treatment per handoff) ---------- */
.v-table{ width:100%; border-collapse:collapse; font-size:14px; }
.v-table th{ text-align:left; font-size:var(--fs-meta); font-weight:700; letter-spacing:var(--ls-meta); text-transform:uppercase;
  color:var(--text-subtle); background:var(--bg-sunken); padding:10px 14px; border-bottom:1px solid var(--border-default); white-space:nowrap; }
.v-table td{ padding:12px 14px; border-bottom:1px solid var(--border-subtle); color:var(--text-default); vertical-align:middle; }
.v-table tbody tr{ transition:background var(--dur-fast); }
.v-table tbody tr:hover{ background:var(--bg-hover); }
.v-table tbody tr.is-selected{ background:var(--bg-selected); }
.v-table .num{ font-variant-numeric:tabular-nums; font-feature-settings:"tnum"; text-align:right; }
.v-table .id{ font-family:var(--font-mono); font-size:var(--fs-mono); color:var(--text-muted); }

/* ---------- MOBILE LIST ROW ---------- */
.v-mrow{ display:flex; align-items:center; gap:12px; min-height:var(--tap-min); padding:14px 16px; background:var(--bg-surface);
  border-bottom:1px solid var(--border-subtle); cursor:pointer; transition:background var(--dur-fast); }
.v-mrow:active{ background:var(--bg-hover); }

/* ---------- MODAL ---------- */
.v-scrim{ position:fixed; inset:0; background:rgba(8,14,28,.55); backdrop-filter:blur(3px); display:grid; place-items:center; z-index:150; padding:20px; animation:vfade .2s ease; }
@keyframes vfade{ from{ opacity:0; } }
.v-modal{ width:min(440px,100%); background:var(--bg-surface); border-radius:var(--r-xl); box-shadow:var(--shadow-xl); overflow:hidden;
  border:1px solid var(--border-subtle); animation:vmodal .26s var(--ease-out); }
@keyframes vmodal{ from{ opacity:0; transform:translateY(16px) scale(.97); } }
.v-modal .body{ padding:26px 26px 22px; }
.v-modal .foot{ display:flex; gap:10px; padding:16px 26px; background:var(--bg-inset); border-top:1px solid var(--border-subtle); }
.v-modal .ic-feature{ width:46px; height:46px; border-radius:12px; display:inline-flex; align-items:center; justify-content:center; margin-bottom:16px; }
.v-modal h3{ font:700 20px var(--font-display); color:var(--text-strong); margin-bottom:8px; }
.v-modal .desc{ font-size:14.5px; line-height:1.55; color:var(--text-muted); }

/* ---------- UPLOAD AREA ---------- */
.v-upload{ border:2px dashed var(--border-strong); border-radius:var(--r-lg); padding:32px 24px; text-align:center;
  background:var(--bg-inset); transition:all var(--dur); cursor:pointer; }
.v-upload.is-over,.v-upload:hover{ border-color:var(--primary); background:var(--primary-tint); }

/* ---------- TOAST ENTRY ANIMATION ---------- */
.v-toast-in{ animation:vtoast .26s var(--ease-out); }
@keyframes vtoast{ from{ opacity:0; transform:translateY(12px); } }

/* ---------- WORDMARK (from handoff boot logo) ---------- */
.v-mark{ border-radius:13px; background:var(--brand-ink); display:inline-grid; place-items:center; }
.v-wordmark{ font-family:var(--font-display); font-weight:800; letter-spacing:-0.03em; color:var(--text-strong); }
