/* ==========================================================================
   site-visits.css — "Coordinate Site Visits" module view.
   Ported from Helix-Integration-prototype/coordinate-site-visits.html, scoped
   under #siteVisitsView with sv- class names. Brand/surface/ink/line map to the
   app's --cw-* tokens; semantic teal/green/amber/red + WhatsApp colours stay
   local. Loaded BEFORE module-shell.css so the shell's responsive rules win.
   ========================================================================== */
#siteVisitsView {
  --sv-surface: var(--cw-surface, #fff);
  --sv-ink: var(--cw-text, #1b1b1f);
  --sv-ink-2: var(--cw-text, #3c3c43);
  --sv-muted: var(--cw-text-muted, #6b6b76);
  --sv-faint: var(--cw-text-subtle, #9a9aa3);
  --sv-line: var(--cw-border, #e8e8ec);
  --sv-line-2: var(--cw-surface-muted, #f0f0f3);
  --sv-brand: var(--cw-accent, #4f46e5);
  --sv-green: #1da955; --sv-green-weak: #e7f6ee; --sv-green-ink: #147a3d;
  --sv-amber: #f0a823; --sv-amber-weak: #fdf3e0; --sv-amber-ink: #9a6b09;
  --sv-red: #e5484d;
  --sv-teal: #0d9488; --sv-teal-weak: #e2f5f2; --sv-teal-ink: #0a6e66;
  --sv-wa-weak: #e7f6ee;
  --sv-radius: 16px; --sv-radius-sm: 10px;
  --sv-shadow: 0 1px 2px rgba(20,20,30,.05), 0 6px 20px rgba(20,20,30,.05);
  --sv-shadow-hover: 0 2px 4px rgba(20,20,30,.06), 0 12px 30px rgba(20,20,30,.10);
}

/* header */
#siteVisitsView .sv-head { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:16px; }
#siteVisitsView .sv-eyebrow { font-size:12px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--sv-faint); margin:0 0 6px; }
#siteVisitsView .sv-h1 { font-size:26px; font-weight:700; letter-spacing:-.01em; margin:0; line-height:1.15; color:var(--sv-ink); }
#siteVisitsView .sv-sub { margin:6px 0 0; color:var(--sv-muted); font-size:14px; max-width:54ch; }
#siteVisitsView .sv-count-pill { display:inline-flex; align-items:baseline; gap:6px; background:var(--sv-surface); border:1px solid var(--sv-line); border-radius:999px; padding:8px 14px; box-shadow:var(--sv-shadow); }
#siteVisitsView .sv-count-pill b { font-size:18px; font-weight:700; color:var(--sv-ink); }
#siteVisitsView .sv-count-pill span { font-size:12px; color:var(--sv-muted); }

/* filters */
#siteVisitsView .sv-filters { display:flex; gap:8px; flex-wrap:wrap; margin:4px 0 18px; }
#siteVisitsView .sv-chip { appearance:none; cursor:pointer; font-family:inherit; font-size:13px; font-weight:600; color:var(--sv-ink-2); background:var(--sv-surface); border:1px solid var(--sv-line); border-radius:999px; padding:8px 14px; display:inline-flex; align-items:center; gap:7px; transition:background .15s,border-color .15s,color .15s,box-shadow .15s; }
#siteVisitsView .sv-chip:hover { border-color:#d9d9e0; }
#siteVisitsView .sv-chip .c-num { font-weight:700; color:var(--sv-faint); font-variant-numeric:tabular-nums; }
#siteVisitsView .sv-chip[aria-pressed="true"] { background:var(--sv-brand); border-color:var(--sv-brand); color:#fff; box-shadow:var(--sv-shadow); }
#siteVisitsView .sv-chip[aria-pressed="true"] .c-num { color:rgba(255,255,255,.75); }
#siteVisitsView .sv-chip:focus-visible { outline:2px solid var(--sv-brand); outline-offset:2px; }

/* section label */
#siteVisitsView .sv-sec { margin:26px 0 12px; display:flex; align-items:center; gap:10px; }
#siteVisitsView .sv-sec h2 { font-size:13px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--sv-muted); margin:0; }
#siteVisitsView .sv-rule { flex:1; height:1px; background:var(--sv-line); }
#siteVisitsView .sv-n { font-size:12px; font-weight:700; color:var(--sv-faint); font-variant-numeric:tabular-nums; }

/* hero */
#siteVisitsView .sv-hero { background:linear-gradient(135deg,var(--sv-surface),#fbfdfc); border:1px solid var(--sv-line); border-radius:20px; box-shadow:var(--sv-shadow); padding:22px; display:flex; gap:22px; align-items:center; flex-wrap:wrap; position:relative; overflow:hidden; }
#siteVisitsView .sv-hero::before { content:""; position:absolute; inset:0 auto 0 0; width:4px; background:linear-gradient(var(--sv-teal),#0a6e66); }
#siteVisitsView .sv-hero-when { min-width:132px; }
#siteVisitsView .sv-hero-time { font-size:28px; font-weight:700; letter-spacing:-.02em; line-height:1.05; margin-top:8px; color:var(--sv-ink); }
#siteVisitsView .sv-hero-time small { display:block; font-size:13px; font-weight:500; color:var(--sv-muted); margin-top:6px; letter-spacing:0; }
#siteVisitsView .sv-hero-mid { flex:1; min-width:230px; }
#siteVisitsView .sv-hero-cust { display:flex; align-items:center; gap:11px; margin-bottom:8px; }
#siteVisitsView .sv-hero-cust .sv-lead-name { font-size:18px; font-weight:700; margin:0; }
#siteVisitsView .sv-hero-loc { font-size:13.5px; margin:0; display:inline-flex; gap:7px; align-items:flex-start; line-height:1.4; color:var(--sv-teal-ink); text-decoration:none; }
#siteVisitsView .sv-hero-loc:hover { text-decoration:underline; }
#siteVisitsView .sv-hero-parties { font-size:12.5px; color:var(--sv-muted); margin:8px 0 0; display:flex; gap:7px; align-items:center; flex-wrap:wrap; }
#siteVisitsView .sv-hero-actions { display:flex; flex-direction:column; gap:8px; min-width:188px; }

/* grid + cards */
#siteVisitsView .sv-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(360px,1fr)); gap:16px; }
#siteVisitsView .sv-card { background:var(--sv-surface); border:1px solid var(--sv-line); border-radius:var(--sv-radius); box-shadow:var(--sv-shadow); padding:16px 16px 14px; display:flex; flex-direction:column; gap:12px; transition:box-shadow .18s,transform .18s,border-color .18s; }
#siteVisitsView .sv-card:hover { box-shadow:var(--sv-shadow-hover); transform:translateY(-2px); border-color:#e0e0e6; }
#siteVisitsView .sv-row1 { display:flex; gap:12px; align-items:flex-start; }
#siteVisitsView .sv-timecol { flex:0 0 auto; text-align:center; min-width:62px; padding-top:1px; }
#siteVisitsView .sv-timecol .sv-dd { font-size:19px; font-weight:700; letter-spacing:-.01em; line-height:1; color:var(--sv-ink); }
#siteVisitsView .sv-timecol .sv-mo { font-size:11px; font-weight:600; color:var(--sv-muted); text-transform:uppercase; margin-top:2px; }
#siteVisitsView .sv-timecol .sv-tm { font-size:11.5px; color:var(--sv-faint); margin-top:4px; }
#siteVisitsView .sv-vsep { width:1px; align-self:stretch; background:var(--sv-line-2); }
#siteVisitsView .sv-who { flex:1; min-width:0; }
#siteVisitsView .sv-name-row { display:flex; align-items:center; gap:8px; }
#siteVisitsView .sv-lead-name { font-size:15.5px; font-weight:700; letter-spacing:-.005em; margin:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; color:var(--sv-ink); }
#siteVisitsView .sv-rag { flex:0 0 auto; width:8px; height:8px; border-radius:50%; }
#siteVisitsView .sv-rag.Red { background:var(--sv-red); } #siteVisitsView .sv-rag.Amber { background:var(--sv-amber); } #siteVisitsView .sv-rag.Green { background:var(--sv-green); }
#siteVisitsView .sv-proj { font-size:13.5px; font-weight:600; color:var(--sv-ink-2); margin:4px 0 0; }
#siteVisitsView .sv-loc { font-size:12.5px; margin:3px 0 0; display:inline-flex; gap:6px; align-items:flex-start; line-height:1.35; color:var(--sv-teal-ink); text-decoration:none; }
#siteVisitsView .sv-loc:hover { text-decoration:underline; }
#siteVisitsView .sv-loc svg { flex:0 0 auto; margin-top:1px; }
#siteVisitsView .sv-mm { font-size:12px; color:var(--sv-muted); margin:6px 0 0; display:flex; gap:7px; align-items:center; flex-wrap:wrap; }
#siteVisitsView .sv-dot { width:3px; height:3px; border-radius:50%; background:var(--sv-faint); }

/* SM chip */
#siteVisitsView .sv-sm-chip { display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:600; color:var(--sv-ink-2); background:var(--sv-line-2); border-radius:999px; padding:4px 10px; }
#siteVisitsView .sv-sm-chip svg { color:var(--sv-teal); }
#siteVisitsView .sv-sm-chip.none { background:var(--sv-amber-weak); color:var(--sv-amber-ink); }
#siteVisitsView .sv-sm-chip.none svg { color:var(--sv-amber-ink); }

#siteVisitsView .sv-note { display:flex; gap:9px; align-items:flex-start; background:var(--sv-line-2); border-radius:var(--sv-radius-sm); padding:9px 11px; }
#siteVisitsView .sv-note svg { flex:0 0 auto; margin-top:1px; color:var(--sv-amber-ink); }
#siteVisitsView .sv-note span { font-size:12.5px; color:var(--sv-ink-2); line-height:1.35; }
#siteVisitsView .sv-note b { font-weight:600; color:var(--sv-ink); }

#siteVisitsView .sv-badge { display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:700; border-radius:999px; padding:4px 10px; }
#siteVisitsView .sv-badge.confirmed { background:var(--sv-green-weak); color:var(--sv-green-ink); }
#siteVisitsView .sv-badge.today { background:var(--sv-teal-weak); color:var(--sv-teal-ink); }
#siteVisitsView .sv-badge.requested { background:var(--sv-amber-weak); color:var(--sv-amber-ink); }

/* dual push area */
#siteVisitsView .sv-coord { display:flex; flex-direction:column; gap:9px; margin-top:auto; padding-top:13px; border-top:1px solid var(--sv-line-2); }
#siteVisitsView .sv-push { display:flex; align-items:center; gap:10px; }
#siteVisitsView .sv-push-label { flex:0 0 auto; width:84px; font-size:10.5px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--sv-faint); }
#siteVisitsView .sv-push-actions { flex:1; display:flex; gap:8px; }

#siteVisitsView .sv-btn { appearance:none; cursor:pointer; text-decoration:none; font-family:inherit; font-size:13px; font-weight:600; display:inline-flex; align-items:center; justify-content:center; gap:7px; border-radius:var(--sv-radius-sm); padding:9px 12px; border:1px solid transparent; transition:filter .15s,background .15s,transform .05s; }
#siteVisitsView .sv-btn:active { transform:translateY(1px); }
#siteVisitsView .sv-btn:focus-visible { outline:2px solid var(--sv-brand); outline-offset:2px; }
#siteVisitsView .sv-btn.wa { flex:1; background:var(--sv-wa-weak); color:var(--sv-green-ink); }
#siteVisitsView .sv-btn.wa:hover { filter:brightness(.98); }
#siteVisitsView .sv-btn.wa[aria-disabled="true"] { opacity:.45; pointer-events:none; }
#siteVisitsView .sv-btn.assign { flex:1; background:var(--sv-amber-weak); color:var(--sv-amber-ink); }
#siteVisitsView .sv-btn.assign:hover { filter:brightness(.98); }
#siteVisitsView .sv-btn.assign[aria-disabled="true"] { opacity:.55; pointer-events:none; }
#siteVisitsView .sv-icon-btn { appearance:none; cursor:pointer; background:transparent; border:1px solid var(--sv-line); color:var(--sv-ink-2); border-radius:var(--sv-radius-sm); width:38px; min-height:38px; display:grid; place-items:center; transition:background .15s,border-color .15s; }
#siteVisitsView .sv-icon-btn:hover { background:var(--sv-line-2); border-color:#dcdce2; }
#siteVisitsView .sv-icon-btn:focus-visible { outline:2px solid var(--sv-brand); outline-offset:2px; }
#siteVisitsView .sv-icon-btn[aria-disabled="true"] { opacity:.4; pointer-events:none; }

#siteVisitsView .sv-avatar { flex:0 0 auto; width:38px; height:38px; border-radius:11px; display:grid; place-items:center; font-weight:700; font-size:14px; color:#fff; }
#siteVisitsView .sv-avatar.lg { width:46px; height:46px; font-size:16px; border-radius:13px; }

#siteVisitsView .sv-empty { grid-column:1/-1; text-align:center; padding:30px 20px; color:var(--sv-muted); background:var(--sv-surface); border:1px dashed var(--sv-line); border-radius:var(--sv-radius); }
#siteVisitsView .sv-empty p { margin:0; font-size:14px; }

@media (max-width:560px) {
  #siteVisitsView .sv-h1 { font-size:22px; }
  #siteVisitsView .sv-grid { grid-template-columns:1fr; }
  #siteVisitsView .sv-hero { padding:18px; }
  #siteVisitsView .sv-hero-actions { min-width:0; width:100%; }
  #siteVisitsView .sv-push { align-items:stretch; flex-direction:column; gap:6px; }
  #siteVisitsView .sv-push-label { width:auto; }
}
