/* ===========================================================
   ÉCRAN « MES COURSES DISPATCH » (Espace Pro) — tableau + détail
   Rendu dans #dpro-page[data-page="courses"]. Réutilise le chrome
   .prn-* (kpis/onglets/filtres/pager/aside) ; spécifique = .prc-*.
   Réutilise les tokens --dpc-*.
   =========================================================== */
body.is-desktop.is-logged.dpro-page-open #dpro-page[data-page="courses"] { background: var(--dpc-bg, #F6F8FB); }

/* ── Tableau ── */
.prc-table { background: #fff; border: 1px solid var(--dpc-line); border-radius: 14px; overflow: hidden; box-shadow: var(--dpc-e1); }
.prc-empty { padding: 44px 16px; text-align: center; color: var(--dpc-faint); font-size: 14px; }
.prc-thead, .prc-tr { display: grid; grid-template-columns: 96px minmax(0,1fr) 116px 150px 172px 104px; align-items: center; gap: 12px; }
.prc-thead { padding: 11px 18px; background: #F8FAFC; border-bottom: 1px solid var(--dpc-line);
  font-size: 11px; font-weight: 700; color: var(--dpc-faint); text-transform: uppercase; letter-spacing: .4px; }
.prc-tr { padding: 13px 18px; border-bottom: 1px solid #F1F5F9; cursor: pointer; transition: background .12s; }
.prc-tr:last-child { border-bottom: none; }
.prc-tr:hover { background: var(--dpc-hover); }
.prc-tr.selected { background: #F0FBF6; box-shadow: inset 3px 0 0 var(--dpc-green); }

.prc-c-time { display: flex; flex-direction: column; gap: 2px; }
.prc-c-time b { font-size: 14px; font-weight: 800; color: var(--dpc-ink); font-variant-numeric: tabular-nums; }
.prc-c-time i { font-size: 10.5px; font-style: normal; font-weight: 600; color: var(--dpc-muted); }
.prc-c-trip { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.prc-trip-route { font-size: 14px; font-weight: 700; color: var(--dpc-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.prc-trip-route em { color: var(--dpc-faint); font-style: normal; margin: 0 3px; }
.prc-trip-cli { font-size: 12px; color: var(--dpc-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.prc-c-det { display: flex; flex-direction: column; gap: 2px; font-size: 12.5px; font-weight: 600; color: var(--dpc-text); }
.prc-det-sub { font-size: 11.5px; font-weight: 500; color: var(--dpc-muted); }

/* Badge statut */
.prc-badge { font-size: 11px; font-weight: 800; padding: 3px 10px; border-radius: 999px; white-space: nowrap; }
.prc-badge.s-todo     { background: var(--dpc-todo-bg); color: var(--dpc-todo); }
.prc-badge.s-urgent   { background: var(--dpc-urgent-bg); color: var(--dpc-urgent); }
.prc-badge.s-active   { background: var(--dpc-active-bg); color: var(--dpc-active); }
.prc-badge.s-assigned { background: var(--dpc-assigned-bg); color: var(--dpc-assigned); }
.prc-badge.s-done     { background: var(--dpc-done-bg); color: #475569; }

/* Affectation */
.prc-aff { display: flex; align-items: center; gap: 9px; min-width: 0; }
.prc-aff.none { flex-direction: column; align-items: flex-start; gap: 4px; }
.prc-av { width: 30px; height: 30px; border-radius: 50%; background: #475569; color: #fff; font-size: 11px; font-weight: 800; display: grid; place-items: center; flex-shrink: 0; }
.prc-av.sm { width: 22px; height: 22px; font-size: 9.5px; display: inline-grid; vertical-align: middle; }
.prc-aff-n { font-size: 12.5px; font-weight: 700; color: var(--dpc-ink); display: block; }
.prc-aff-s { font-size: 11px; color: var(--dpc-muted); display: block; }
.prc-aff.none .prc-aff-n { color: var(--dpc-faint); }
.prc-mini-btn { height: 26px; padding: 0 10px; border: 1px solid var(--dpc-green); border-radius: 8px; background: var(--dpc-green); color: #fff; font-size: 11.5px; font-weight: 700; cursor: pointer; }
.prc-mini-btn:hover { background: var(--dpc-green-h); }

.prc-c-act { display: flex; align-items: center; gap: 6px; justify-content: flex-end; }
.prc-kebab { width: 32px; height: 32px; border: 1px solid var(--dpc-line); border-radius: 8px; background: #fff; color: #64748B; font-size: 16px; cursor: pointer; }
.prc-kebab:hover { background: var(--dpc-hover); }

/* ── Détail latéral riche ── */
.prc-d-top { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.prc-d-meta { font-size: 11px; color: var(--dpc-faint); flex: 1; min-width: 0; }
.prc-d-x { border: none; background: none; font-size: 18px; color: var(--dpc-faint); cursor: pointer; }
.prc-d-route-h { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.prc-d-title { font-size: 18px; font-weight: 800; color: var(--dpc-ink); }
.prc-d-title em { color: var(--dpc-faint); font-style: normal; margin: 0 4px; }
.prc-d-price { text-align: right; flex-shrink: 0; }
.prc-d-price b { font-size: 17px; font-weight: 800; color: var(--dpc-ink); font-variant-numeric: tabular-nums; display: block; }
.prc-d-price span { font-size: 10.5px; color: var(--dpc-faint); }
.prc-d-when { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--dpc-muted); font-weight: 600; margin-bottom: 14px; }
.prc-d-tiles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 14px; }
.prc-d-tile { background: var(--dpc-hover); border: 1px solid var(--dpc-line); border-radius: 10px; padding: 8px 9px; display: flex; flex-direction: column; gap: 2px; }
.prc-d-tile span { font-size: 10px; font-weight: 700; color: var(--dpc-faint); text-transform: uppercase; letter-spacing: .3px; }
.prc-d-tile b { font-size: 13px; font-weight: 700; color: var(--dpc-ink); }
.prc-d-sec { font-size: 11px; font-weight: 800; color: var(--dpc-faint); text-transform: uppercase; letter-spacing: .4px; margin: 6px 0 8px; }
.prc-d-itin { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; }
.prc-d-step { display: flex; align-items: flex-start; gap: 10px; }
.prc-d-step > div { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.prc-d-step b { font-size: 13.5px; font-weight: 700; color: var(--dpc-ink); }
.prc-d-step span { font-size: 12px; color: var(--dpc-muted); }
.prc-d-step i { font-size: 12.5px; font-style: normal; font-weight: 700; color: var(--dpc-ink); font-variant-numeric: tabular-nums; }
.prc-pin { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
.prc-pin.from { background: var(--dpc-green); } .prc-pin.to { background: var(--dpc-urgent); }
.prc-d-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; margin-bottom: 14px; }
.prc-d-grid2.sm { gap: 10px 16px; }
.prc-d-grid2 > div { display: flex; flex-direction: column; min-width: 0; }
.prc-d-lbl { font-size: 11px; color: var(--dpc-faint); font-weight: 600; text-transform: uppercase; letter-spacing: .3px; margin-bottom: 2px; }
.prc-d-grid2 b { font-size: 13.5px; font-weight: 700; color: var(--dpc-ink); }
.prc-d-sub { font-size: 12px; color: var(--dpc-muted); }
.prc-d-muted { color: var(--dpc-faint); }
.prc-d-notes { background: var(--dpc-hover); border: 1px solid var(--dpc-line); border-radius: 11px; padding: 10px 12px; margin-bottom: 14px; }
.prc-d-notes p { margin: 4px 0 0; font-size: 13px; color: #475569; line-height: 1.45; }
.prc-d-aff { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--dpc-ink); margin-bottom: 14px; }
.prc-d-map { height: 180px; border-radius: 12px; overflow: hidden; border: 1px solid var(--dpc-line); margin-bottom: 14px; background: #EAF1F4; }
.prc-d-actions { display: flex; gap: 8px; }
.prc-d-actions .prn-btn { flex: 1; height: 42px; }

@media (max-width: 1240px) { .prc-thead, .prc-tr { grid-template-columns: 80px minmax(0,1fr) 100px 130px 150px 90px; } }
