/* ═══════════════════════════════════════════════════════════════
   We Tidy Toledo — Dispatch Tool v2 Styles
   ═══════════════════════════════════════════════════════════════ */

:root {
  --bg: #f8f9fb;
  --bg-card: #ffffff;
  --bg-hover: #f1f5ff;
  --bg-selected: #eef4ff;
  --text: #111827;
  --text-sec: #6b7280;
  --text-dim: #9ca3af;
  --border: #e5e7eb;
  --primary: #2563eb;
  --primary-light: #eff6ff;
  --green: #16a34a;
  --green-light: #dcfce7;
  --orange: #ea580c;
  --orange-light: #fff7ed;
  --red: #dc2626;
  --red-light: #fef2f2;
  --yellow: #ca8a04;
  --yellow-light: #fefce8;
  --gold: #f59e0b;
  --gold-bg: #fffbeb;
  --silver: #4b5563;
  --bronze: #c2855a;
  --bronze-bg: #fff5ee;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
  --shadow: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.12);
  --radius: 12px;
  --radius-sm: 8px;
  --radius-pill: 999px;
}

[data-theme="dark"] {
  --bg: #0f172a;
  --bg-card: #1e293b;
  --bg-hover: #263450;
  --bg-selected: #1e3a5f;
  --text: #f1f5f9;
  --text-sec: #94a3b8;
  --text-dim: #64748b;
  --border: #334155;
  --primary-light: #1e3a5f;
  --green-light: #064e3b;
  --orange-light: #431407;
  --red-light: #450a0a;
  --yellow-light: #422006;
  --gold-bg: #422006;
  --bronze-bg: #431407;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.2);
  --shadow: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.3);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.4);
}

* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; background:var(--bg); color:var(--text); }
.hidden { display:none !important; }

/* ─── Header ─────────────────────────────────────────────────── */
.header {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 24px; background:var(--bg-card); border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:100;
}
.header-left { display:flex; align-items:center; gap:12px; }
.header-right { display:flex; align-items:center; gap:10px; }
.app-title { font-size:17px; font-weight:700; white-space:nowrap; }
.app-title .accent { color:var(--primary); }
.app-subtitle { font-size:12px; color:var(--text-sec); white-space:nowrap; }
.icon-btn {
  width:36px; height:36px; border:1px solid var(--border); border-radius:var(--radius-sm);
  background:var(--bg-card); cursor:pointer; font-size:16px; display:flex; align-items:center;
  justify-content:center; transition:all .15s; color:var(--text);
}
.icon-btn:hover { background:var(--bg-hover); }
.back-btn { font-size:18px; font-weight:700; }
.pill-badge { padding:4px 12px; border-radius:var(--radius-pill); font-size:12px; font-weight:600; }
.demo-badge { background:var(--green-light); color:var(--green); }
.live-badge { background:var(--primary-light); color:var(--primary); }
.toggle-wrap { display:flex; align-items:center; gap:6px; }
.toggle-label { font-size:12px; color:var(--text-sec); font-weight:500; }
.toggle {
  width:36px; height:20px; background:var(--border); border-radius:10px; position:relative;
  cursor:pointer; transition:background .2s;
}
.toggle.active { background:var(--primary); }
.toggle::after {
  content:''; position:absolute; width:16px; height:16px; background:white; border-radius:50%;
  top:2px; left:2px; transition:transform .2s;
}
.toggle.active::after { transform:translateX(16px); }

/* ─── Opening Screen ─────────────────────────────────────────── */
.opening-screen .header { border-bottom:1px solid var(--border); }
.opening-content {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:calc(100vh - 60px); padding:40px;
}
.mode-toggle-row {
  display:flex; align-items:center; gap:10px; margin-bottom:20px;
  padding:8px 16px; background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-pill); box-shadow:var(--shadow-sm);
}
.mode-toggle-label { font-size:13px; font-weight:600; color:var(--text-sec); }
.opening-heading { font-size:28px; font-weight:800; margin-bottom:32px; }
.opening-cards { display:flex; gap:20px; }
.opening-card {
  width:280px; padding:40px 30px; background:var(--bg-card); border:2px solid var(--border);
  border-radius:var(--radius); text-align:center; cursor:pointer; transition:all .2s;
  box-shadow:var(--shadow);
}
.opening-card:hover { border-color:var(--primary); box-shadow:var(--shadow-md); }
.opening-card.selected { border-color:var(--primary); background:var(--primary-light); }
.opening-icon { font-size:36px; margin-bottom:16px; }
.green-circle {
  width:50px; height:50px; background:var(--green-light); color:var(--green);
  border-radius:50%; display:inline-flex; align-items:center; justify-content:center;
  font-size:24px; font-weight:700;
}
.opening-card-title { font-size:18px; font-weight:700; margin-bottom:6px; }
.opening-card-sub { font-size:13px; color:var(--text-sec); }

/* ─── Main Columns ───────────────────────────────────────────── */
.columns { display:grid; grid-template-columns:380px 1fr; height:calc(100vh - 57px); }
.left-col {
  background:var(--bg-card); border-right:1px solid var(--border);
  display:flex; flex-direction:column; overflow:hidden;
}
.col-header { padding:16px 18px 0; font-size:15px; font-weight:700; }
.search-wrap { padding:12px 18px 0; }
.search-input {
  width:100%; padding:9px 16px; border:1px solid var(--border); border-radius:var(--radius-pill);
  font-size:13px; background:var(--bg); color:var(--text); outline:none; transition:border .15s;
}
.search-input:focus { border-color:var(--primary); }
.search-input::placeholder { color:var(--text-dim); }
.filter-row { display:flex; gap:6px; padding:10px 18px; }
.filter-pill {
  padding:5px 14px; border-radius:var(--radius-pill); font-size:12px; font-weight:600;
  border:1px solid var(--border); background:var(--bg-card); color:var(--text-sec);
  cursor:pointer; transition:all .15s;
}
.filter-pill:hover { border-color:var(--primary); color:var(--primary); }
.filter-pill.active { background:var(--primary); color:white; border-color:var(--primary); }
.bookings-list { flex:1; overflow-y:auto; padding:6px 10px; }

/* ─── Booking Card ───────────────────────────────────────────── */
.bk-card {
  padding:12px 14px; border-radius:var(--radius-sm); cursor:pointer; border-left:3px solid transparent;
  margin-bottom:4px; transition:all .15s;
}
.bk-card:hover { background:var(--bg-hover); }
.bk-card.selected { background:var(--bg-selected); border-left-color:var(--primary); }
.bk-row1 { display:flex; justify-content:space-between; align-items:center; margin-bottom:2px; }
.bk-date { font-size:13px; font-weight:700; }
.bk-service { font-size:11px; color:var(--text-sec); }
.bk-name { font-size:14px; font-weight:700; margin-bottom:1px; }
.bk-addr { font-size:12px; color:var(--text-sec); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.bk-bottom-row { display:flex; align-items:center; gap:8px; margin-top:4px; }
.bk-price { font-size:12px; font-weight:700; color:var(--primary); }
.bk-provider { font-size:12px; color:var(--primary); font-weight:600; }
.bk-provider.unassigned { color:var(--orange); }

/* ─── Status Badges ──────────────────────────────────────────── */
.status-badge {
  display:inline-flex; align-items:center; padding:2px 10px;
  border-radius:var(--radius-pill); font-size:11px; font-weight:700;
  letter-spacing:0.3px;
}
.status-red { background:var(--red-light); color:var(--red); }
.status-yellow { background:var(--yellow-light); color:var(--yellow); }
.status-green { background:var(--green-light); color:var(--green); }

/* ─── Right Column ───────────────────────────────────────────── */
.right-col { overflow-y:auto; padding:20px 24px; }
.empty-state {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:100%; gap:8px; color:var(--text-sec);
}
.empty-icon { font-size:42px; }
.empty-state p { font-size:14px; }

/* ─── Info Bar ───────────────────────────────────────────────── */
.info-bar {
  padding:16px 18px; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius-sm); margin-bottom:20px;
  box-shadow:var(--shadow-sm); font-size:13px;
}
.info-row-main { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:8px; }
.info-item { display:flex; align-items:center; gap:5px; color:var(--text-sec); }
.info-item strong { color:var(--text); font-weight:600; }

/* Customer Intel */
.insights-row {
  padding:10px 0; border-top:1px solid var(--border); margin-top:8px;
}
.insights-label { font-size:12px; font-weight:700; color:var(--primary); margin-bottom:6px; }
.insights-tags { display:flex; flex-wrap:wrap; gap:6px; }
.insight-tag {
  display:inline-flex; align-items:center; padding:3px 10px;
  background:var(--primary-light); border-radius:var(--radius-pill);
  font-size:11px; font-weight:600; color:var(--primary);
}
.insight-recurring { background:var(--green-light); color:var(--green); }

/* Special Requirements */
.special-reqs {
  padding:8px 0; font-size:12px; color:var(--text-sec);
}
.req-tag {
  display:inline-flex; padding:2px 8px; margin-left:4px;
  background:var(--orange-light); color:var(--orange); border-radius:var(--radius-pill);
  font-size:11px; font-weight:600;
}

/* Booking note & team note */
.booking-note { font-size:12px; color:var(--text-sec); padding:4px 0; }
.team-note { font-size:11px; color:var(--text-dim); padding:4px 0; }

/* ─── Section Titles ─────────────────────────────────────────── */
.section-title { font-size:15px; font-weight:700; margin-bottom:12px; }

/* ─── Provider Card ──────────────────────────────────────────── */
.prov-card {
  border:1px solid var(--border); border-radius:var(--radius); padding:18px 20px;
  margin-bottom:12px; box-shadow:var(--shadow); transition:box-shadow .15s;
  background:var(--bg-card);
}
.prov-card:hover { box-shadow:var(--shadow-md); }
.prov-card.rank-1-bg { background:var(--gold-bg); }
.prov-card.rank-2-bg { background:var(--bg-card); }
.prov-card.rank-dimmed { opacity:0.6; background:var(--bg); }
[data-theme="dark"] .prov-card.rank-1-bg { background:#2a2000; }
[data-theme="dark"] .prov-card.rank-dimmed { opacity:0.5; }

.prov-top { display:flex; align-items:center; gap:14px; }
.rank-circle {
  width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:14px; color:white; flex-shrink:0;
}
.rank-1 { background:linear-gradient(135deg,#f59e0b,#d97706); }
.rank-2 { background:linear-gradient(135deg,#6b7280,#4b5563); }
.rank-3 { background:linear-gradient(135deg,#c2855a,#a16207); }
.rank-other { background:var(--border); color:var(--text-sec); }
.avatar {
  width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:16px; flex-shrink:0; color:white;
}
.prov-info { flex:1; min-width:0; }
.prov-name { font-size:16px; font-weight:700; }
.prov-meta { font-size:12px; color:var(--text-sec); }
.prov-phone { font-size:12px; color:var(--text-sec); margin-top:1px; }
.team-badge {
  display:inline-flex; padding:1px 8px; background:var(--primary); color:white;
  border-radius:var(--radius-pill); font-size:10px; font-weight:700; vertical-align:middle;
  margin-left:6px;
}

/* ─── Score Ring ─────────────────────────────────────────────── */
.score-ring-wrap { text-align:center; flex-shrink:0; }
.score-ring { width:56px; height:56px; position:relative; }
.score-ring svg { transform:rotate(-90deg); }
.score-ring-bg { fill:none; stroke:var(--border); stroke-width:4; }
.score-ring-fill { fill:none; stroke:var(--primary); stroke-width:4; stroke-linecap:round; transition:stroke-dashoffset .5s; }
.score-ring-text {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-size:16px; font-weight:800;
}
.score-ring-label { font-size:9px; color:var(--text-dim); text-transform:uppercase; font-weight:600; margin-top:2px; }

/* ─── Tags ───────────────────────────────────────────────────── */
.tag-row { display:flex; flex-wrap:wrap; gap:6px; margin:12px 0; }
.tag {
  display:inline-flex; align-items:center; gap:4px; padding:3px 10px;
  border-radius:var(--radius-pill); font-size:11px; font-weight:600;
}
.tag-gray { background:var(--bg); color:var(--text-sec); border:1px solid var(--border); }
.tag-green { background:var(--green-light); color:var(--green); }
.tag-red { background:var(--red-light); color:var(--red); }
.tag-icon { font-size:12px; }

/* ─── Action Buttons ─────────────────────────────────────────── */
.action-row { display:flex; gap:8px; align-items:center; }
.action-btn {
  padding:7px 16px; border-radius:var(--radius-sm); font-size:13px; font-weight:600;
  border:none; cursor:pointer; display:inline-flex; align-items:center; gap:6px; transition:opacity .15s;
  text-decoration:none;
}
.action-btn:hover { opacity:.85; }
.btn-call { background:var(--green); color:white; }
.btn-sms { background:var(--primary); color:white; }
.btn-copy { background:var(--bg); color:var(--text-sec); border:1px solid var(--border); }
.btn-cancel { background:var(--bg); color:var(--text-sec); border:1px solid var(--border); }
.btn-approve { background:var(--green); color:white; font-weight:700; }
.btn-approve:disabled { opacity:0.5; cursor:not-allowed; }

/* ─── Score Details ──────────────────────────────────────────── */
.score-toggle {
  font-size:12px; color:var(--primary); cursor:pointer;
  display:inline-flex; align-items:center; gap:4px; font-weight:600;
}
.score-toggle:hover { text-decoration:underline; }
.score-details { overflow:hidden; max-height:0; transition:max-height .3s ease; }
.score-details.open { max-height:300px; }
.score-breakdown {
  padding:12px 14px; background:var(--bg); border-radius:var(--radius-sm); margin-top:8px;
}
.score-row { display:flex; align-items:center; margin-bottom:6px; font-size:12px; }
.score-cat { width:90px; color:var(--text-sec); font-weight:500; }
.score-bar-bg { flex:1; height:6px; background:var(--border); border-radius:3px; margin:0 10px; overflow:hidden; }
.score-bar-fill { height:100%; border-radius:3px; background:var(--primary); transition:width .3s; }
.score-pts { width:45px; text-align:right; font-weight:700; font-size:11px; }

/* ─── Text Popup ─────────────────────────────────────────────── */
.text-popup-overlay {
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:rgba(0,0,0,0.4); z-index:1000;
  display:flex; align-items:center; justify-content:center;
  backdrop-filter:blur(2px);
}
.text-popup {
  background:var(--bg-card); border-radius:var(--radius);
  box-shadow:var(--shadow-lg); width:560px; max-width:95vw;
  max-height:90vh; overflow-y:auto;
}
.text-popup-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid var(--border);
}
.text-popup-header h3 { font-size:16px; font-weight:700; }
.text-popup-close {
  width:32px; height:32px; border:none; background:none;
  font-size:18px; cursor:pointer; color:var(--text-sec);
  border-radius:var(--radius-sm); transition:background .15s;
}
.text-popup-close:hover { background:var(--bg-hover); }
.text-popup-info {
  padding:12px 20px; font-size:13px; color:var(--text-sec);
  border-bottom:1px solid var(--border);
}
.text-popup-info div { margin-bottom:4px; }
.text-popup-textarea {
  width:calc(100% - 40px); margin:16px 20px; min-height:160px;
  padding:12px 16px; border:1px solid var(--border); border-radius:var(--radius-sm);
  font-family:inherit; font-size:14px; line-height:1.5;
  color:var(--text); background:var(--bg); resize:vertical; outline:none;
}
.text-popup-textarea:focus { border-color:var(--primary); }
.text-popup-actions {
  display:flex; gap:10px; justify-content:flex-end;
  padding:12px 20px 16px; border-top:1px solid var(--border);
}

/* ─── Loading ────────────────────────────────────────────────── */
.loading {
  display:flex; align-items:center; justify-content:center;
  padding:40px; color:var(--text-sec); gap:8px; font-size:13px;
}
.spinner {
  width:16px; height:16px; border:2px solid var(--border);
  border-top-color:var(--primary); border-radius:50%;
  animation:spin .6s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ─── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }

/* ─── Mobile Responsive ──────────────────────────────────────── */
@media (max-width: 768px) {
  /* Opening screen */
  .opening-cards { flex-direction:column; gap:12px; align-items:center; }
  .opening-card { width:100%; max-width:320px; padding:24px 20px; }
  .opening-heading { font-size:22px; margin-bottom:20px; }
  .opening-content { padding:20px 16px; min-height:calc(100vh - 56px); }

  /* Header */
  .header { padding:10px 14px; }
  .app-title { font-size:14px; }
  .app-subtitle { display:none; }
  .header-right { gap:6px; }
  .toggle-wrap { display:none; }
  .mode-toggle-row { display:flex !important; }
  .pill-badge { font-size:10px; padding:3px 8px; }

  /* Main layout: stack columns vertically */
  .columns {
    display:flex; flex-direction:column; height:auto; min-height:calc(100vh - 56px);
  }
  .left-col {
    border-right:none; border-bottom:1px solid var(--border);
    max-height:45vh; min-height:200px;
  }
  .right-col {
    padding:14px 12px; min-height:55vh;
  }

  /* Search & filters */
  .col-header { padding:10px 12px 0; font-size:14px; }
  .search-wrap { padding:8px 12px 0; }
  .filter-row { padding:8px 12px; gap:4px; overflow-x:auto; flex-wrap:nowrap; }
  .filter-pill { padding:4px 10px; font-size:11px; white-space:nowrap; }

  /* Booking cards */
  .bookings-list { padding:4px 8px; }
  .bk-card { padding:10px 12px; }
  .bk-name { font-size:13px; }
  .bk-date { font-size:12px; }
  .bk-addr { font-size:11px; }
  .bk-bottom-row { gap:6px; flex-wrap:wrap; }

  /* Info bar */
  .info-bar { padding:12px 14px; margin-bottom:14px; }
  .info-row-main { gap:8px; }
  .info-item { font-size:12px; }
  .insights-tags { gap:4px; }
  .insight-tag { font-size:10px; padding:2px 8px; }

  /* Provider cards */
  .prov-card { padding:14px 14px; margin-bottom:10px; }
  .prov-top { gap:10px; flex-wrap:wrap; }
  .rank-circle { width:28px; height:28px; font-size:12px; }
  .avatar { width:38px; height:38px; font-size:14px; }
  .prov-name { font-size:14px; }
  .prov-meta { font-size:11px; }
  .prov-phone { font-size:11px; }
  .score-ring { width:48px; height:48px; }
  .score-ring svg { width:48px; height:48px; }
  .score-ring-text { font-size:14px; }

  /* Tags */
  .tag-row { gap:4px; margin:8px 0; }
  .tag { font-size:10px; padding:2px 8px; }

  /* Action buttons */
  .action-row { flex-wrap:wrap; gap:6px; }
  .action-btn { padding:6px 12px; font-size:12px; }

  /* Score details */
  .score-breakdown { padding:8px 10px; }
  .score-cat { width:70px; font-size:11px; }
  .score-pts { font-size:10px; }

  /* Text popup */
  .text-popup { width:95vw; max-width:95vw; }
  .text-popup-header { padding:12px 14px; }
  .text-popup-header h3 { font-size:14px; }
  .text-popup-info { padding:10px 14px; font-size:12px; }
  .text-popup-textarea { margin:12px 14px; min-height:140px; font-size:13px; width:calc(100% - 28px); }
  .text-popup-actions { padding:10px 14px 14px; }

  /* Section titles */
  .section-title { font-size:14px; margin-bottom:8px; }
}

/* Small phones */
@media (max-width: 400px) {
  .header { padding:8px 10px; }
  .app-title { font-size:13px; }
  .icon-btn { width:32px; height:32px; font-size:14px; }
  .opening-card { padding:20px 16px; }
  .opening-card-title { font-size:16px; }
  .prov-top { gap:8px; }
  .score-ring-wrap { display:none; } /* Hide score ring on very small screens */
  .action-btn { padding:5px 10px; font-size:11px; }
}
