/* =====================================================
 * MYCLEANHUB — PROS-V4.CSS
 * Skin futuriste pour pros.html — override des classes
 * existantes (.search-header, .pro-card, .pill, etc.)
 * S'applique si body.v4 ET présence de .search-header
 * ===================================================== */

/* ─── FOND GLOBAL — grille HUD subtile ─────────────────── */
body.v4 main,
body.v4 .container {
  position: relative;
}
body.v4 .search-header + div + .container,
body.v4 .container {
  background-image:
    linear-gradient(rgba(10,14,12,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10,14,12,.025) 1px, transparent 1px);
  background-size: 32px 32px;
}

/* ─── HEADER DE RECHERCHE — bandeau technique ─────────── */
body.v4 .search-header {
  background: var(--v4-surface, #FFFFFF) !important;
  border-bottom: 1px solid var(--v4-line-strong, rgba(10,30,20,.14)) !important;
  padding: 16px 0 !important;
  position: sticky !important;
  top: 72px;
  z-index: 80;
}
body.v4 .search-header::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--v4-neon, #00C86A) 25%,
    var(--v4-neon, #00C86A) 75%,
    transparent 100%);
  opacity: .5;
}
body.v4 .search-header::after {
  content: "// CATALOGUE PROS";
  position: absolute;
  top: 14px; right: 32px;
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif);
  font-size: 10px; letter-spacing: .18em;
  color: var(--v4-ink-4, #77827D);
  text-transform: uppercase;
  pointer-events: none;
}

/* ─── INPUT RECHERCHE — terminal ──────────────────────── */
body.v4 .search-input-wrap {
  background: var(--v4-bg-soft, #F1F4EE) !important;
  border: 1px solid var(--v4-line-strong, rgba(10,30,20,.14)) !important;
  border-radius: 0 !important;
  padding: 11px 16px !important;
  position: relative;
  transition: all .15s;
}
body.v4 .search-input-wrap:focus-within {
  border-color: var(--v4-neon, #00C86A) !important;
  box-shadow: 0 0 0 2px rgba(0,200,106,.15);
  background: var(--v4-surface, #FFFFFF) !important;
}
body.v4 .search-input-wrap > span:first-child {
  color: var(--v4-neon, #00C86A);
  font-size: 14px;
}
body.v4 .search-input-wrap input {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 14px !important;
  letter-spacing: .01em;
  color: var(--v4-ink, #0A0E0A) !important;
}
body.v4 .search-input-wrap input::placeholder {
  color: var(--v4-ink-4, #77827D) !important;
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif);
  letter-spacing: .05em;
  text-transform: uppercase;
  font-size: 12px;
}

/* ─── BOUTON FILTRES ──────────────────────────────────── */
body.v4 #filter-btn {
  background: var(--v4-ink, #0A0E0A) !important;
  color: #fff !important;
  border: 1px solid var(--v4-ink, #0A0E0A) !important;
  border-radius: 0 !important;
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase;
  padding: 11px 18px !important;
  transition: all .15s;
}
body.v4 #filter-btn:hover {
  background: var(--v4-neon, #00C86A) !important;
  color: var(--v4-ink, #0A0E0A) !important;
  box-shadow: 0 0 16px rgba(0,200,106,.35);
}
body.v4 #filter-btn #filter-count {
  background: var(--v4-neon, #00C86A) !important;
  color: var(--v4-ink, #0A0E0A) !important;
  font-weight: 700;
  border-radius: 0 !important;
  padding: 2px 6px !important;
  margin-left: 6px !important;
}

/* ─── PILLS (filtres rapides) ─────────────────────────── */
body.v4 .pills-row {
  padding-top: 12px !important;
  gap: 6px !important;
}
body.v4 .pill {
  background: var(--v4-surface, #FFFFFF) !important;
  border: 1px solid var(--v4-line-strong, rgba(10,30,20,.14)) !important;
  border-radius: 0 !important;
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 10.5px !important;
  font-weight: 500 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: var(--v4-ink-2, #1D2623) !important;
  padding: 8px 14px !important;
  transition: all .12s;
}
body.v4 .pill:hover {
  border-color: var(--v4-ink, #0A0E0A) !important;
  color: var(--v4-ink, #0A0E0A) !important;
}
body.v4 .pill.active {
  background: var(--v4-ink, #0A0E0A) !important;
  border-color: var(--v4-ink, #0A0E0A) !important;
  color: var(--v4-neon, #00C86A) !important;
  font-weight: 600 !important;
  box-shadow: 0 0 12px rgba(0,200,106,.25);
}
body.v4 .pill-clear {
  background: transparent !important;
  border-color: #E85D3A !important;
  color: #E85D3A !important;
}
body.v4 .pill-clear:hover {
  background: #E85D3A !important;
  color: #fff !important;
}

/* ─── CAT PICKER (bouton lieu) ────────────────────────── */
body.v4 .cat-chip {
  background: var(--v4-bg-soft, #F1F4EE) !important;
  border: 1px dashed var(--v4-line-strong, rgba(10,30,20,.14)) !important;
  border-radius: 0 !important;
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: .08em;
  color: var(--v4-ink-2, #1D2623) !important;
  padding: 11px 16px !important;
  transition: all .15s;
  position: relative;
}
body.v4 #cat-picker-btn::before {
  content: "//";
  color: var(--v4-neon, #00C86A);
  font-weight: 600;
  margin-right: 4px;
}
body.v4 .cat-chip:hover {
  border-color: var(--v4-neon, #00C86A) !important;
  background: var(--v4-surface, #FFFFFF) !important;
}
body.v4 .cat-chip.active,
body.v4 .cat-chip:not(#cat-picker-clear):has(#cat-picker-label:not(:empty)) {
  border-style: solid !important;
}

/* ─── BANNIÈRE URGENCE — ink + rouge néon ─────────────── */
body.v4 .container + div[style*="E85D3A"] {
  background: var(--v4-ink, #0A0E0A) !important;
  border-top: 1px solid #E85D3A;
  border-bottom: 1px solid #E85D3A;
  position: relative;
}

/* ─── RESULTATS — HEADER HUD ──────────────────────────── */
body.v4 .results-header {
  margin-top: 32px !important;
  margin-bottom: 20px !important;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--v4-line, rgba(10,30,20,.08));
  position: relative;
}
body.v4 .results-header::before {
  content: "";
  position: absolute;
  bottom: -1px; left: 0;
  width: 60px; height: 2px;
  background: var(--v4-neon, #00C86A);
  box-shadow: 0 0 8px var(--v4-neon, #00C86A);
}
body.v4 .results-count {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 12px !important;
  letter-spacing: .16em !important;
  text-transform: uppercase;
  color: var(--v4-ink-2, #1D2623) !important;
  font-weight: 600 !important;
  display: inline-flex; align-items: center; gap: 8px;
}
body.v4 .results-count::before {
  content: "●";
  color: var(--v4-neon, #00C86A);
  text-shadow: 0 0 8px var(--v4-neon, #00C86A);
  animation: prosPulse 1.8s ease-in-out infinite;
}
@keyframes prosPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .4; }
}

/* ─── PRO-CARD — cut corners + HUD brackets ───────────── */
body.v4 .pros-list { gap: 12px !important; }
body.v4 .pro-card {
  background: var(--v4-surface, #FFFFFF) !important;
  border: 1px solid var(--v4-line-strong, rgba(10,30,20,.14)) !important;
  border-radius: 0 !important;
  padding: 20px !important;
  transition: all .15s !important;
  clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px));
  position: relative;
}
body.v4 .pro-card::before,
body.v4 .pro-card::after {
  content: "";
  position: absolute;
  width: 10px; height: 10px;
  pointer-events: none;
  opacity: 0;
  transition: opacity .2s;
}
body.v4 .pro-card::before {
  top: 8px; left: 8px;
  border-top: 1.5px solid var(--v4-neon, #00C86A);
  border-left: 1.5px solid var(--v4-neon, #00C86A);
}
body.v4 .pro-card::after {
  bottom: 8px; right: 8px;
  border-bottom: 1.5px solid var(--v4-neon, #00C86A);
  border-right: 1.5px solid var(--v4-neon, #00C86A);
}
body.v4 .pro-card:hover {
  border-color: var(--v4-ink, #0A0E0A) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(10,14,12,.08);
}
body.v4 .pro-card:hover::before,
body.v4 .pro-card:hover::after {
  opacity: 1;
}
body.v4 .pro-card-name {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  color: var(--v4-ink, #0A0E0A) !important;
  letter-spacing: -.015em !important;
}
body.v4 .pro-card-city {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 10px !important;
  letter-spacing: .16em !important;
  color: var(--v4-ink-4, #77827D) !important;
  font-weight: 500;
}
body.v4 .pro-card-city::before {
  content: "▸ ";
  color: var(--v4-neon, #00C86A);
  font-weight: 600;
}
body.v4 .pro-card-meta {
  font-family: var(--v4-ff-body, 'Inter', sans-serif) !important;
  font-size: 12.5px !important;
  color: var(--v4-ink-3, #4A5551) !important;
}

/* Avatar — carré avec bordure néon au hover */
body.v4 .pro-card .avatar-wrap img,
body.v4 .pro-card img[class*="avatar"] {
  border-radius: 0 !important;
  border: 1px solid var(--v4-line-strong, rgba(10,30,20,.14)) !important;
  transition: all .15s;
}
body.v4 .pro-card:hover .avatar-wrap img {
  border-color: var(--v4-neon, #00C86A) !important;
  box-shadow: 0 0 0 2px rgba(0,200,106,.2);
}

/* Badge SAP / crédit d'impôt */
body.v4 .pro-card [class*="sap"],
body.v4 .pro-card [class*="badge"] {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif);
  letter-spacing: .1em;
  text-transform: uppercase;
  border-radius: 0 !important;
  font-weight: 600;
  font-size: 10px !important;
}

/* Service matched tag */
body.v4 .matched-service {
  background: var(--v4-ink, #0A0E0A) !important;
  color: var(--v4-neon, #00C86A) !important;
  border-radius: 0 !important;
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  letter-spacing: .12em !important;
  text-transform: uppercase;
  font-weight: 600 !important;
  font-size: 10px !important;
  padding: 3px 8px !important;
}

body.v4 .pro-bio {
  font-family: var(--v4-ff-body, 'Inter', sans-serif) !important;
  color: var(--v4-ink-3, #4A5551) !important;
  font-size: 12.5px !important;
}

/* Availability dot */
body.v4 .avail-dot.online {
  background: var(--v4-neon, #00C86A) !important;
  box-shadow: 0 0 8px var(--v4-neon, #00C86A);
}

/* ─── MODALES ────────────────────────────────────────── */
body.v4 .modal-overlay {
  background: rgba(10,14,12,.75) !important;
  backdrop-filter: blur(4px);
}
body.v4 .modal-box {
  background: var(--v4-surface, #FFFFFF) !important;
  border: 1px solid var(--v4-ink, #0A0E0A) !important;
  border-radius: 0 !important;
  box-shadow: 0 20px 60px rgba(10,14,12,.4) !important;
  clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 0 100%);
}
body.v4 .modal-header {
  border-bottom: 1px solid var(--v4-line, rgba(10,30,20,.08)) !important;
  padding-bottom: 14px !important;
  position: relative;
}
body.v4 .modal-header::after {
  content: "";
  position: absolute;
  left: 0; bottom: -1px;
  width: 40px; height: 2px;
  background: var(--v4-neon, #00C86A);
  box-shadow: 0 0 6px var(--v4-neon, #00C86A);
}
body.v4 .modal-title {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase;
  color: var(--v4-ink, #0A0E0A) !important;
}
body.v4 .modal-close {
  color: var(--v4-ink-3, #4A5551) !important;
  background: transparent !important;
  border: 1px solid var(--v4-line, rgba(10,30,20,.08)) !important;
  border-radius: 0 !important;
  width: 32px; height: 32px;
  transition: all .15s;
}
body.v4 .modal-close:hover {
  border-color: var(--v4-ink, #0A0E0A) !important;
  color: var(--v4-ink, #0A0E0A) !important;
  background: var(--v4-bg-soft, #F1F4EE) !important;
}

/* ─── SORT BUTTONS ──────────────────────────────────── */
body.v4 .filter-section-title {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 10px !important;
  letter-spacing: .18em !important;
  color: var(--v4-ink-2, #1D2623) !important;
  font-weight: 600 !important;
}
body.v4 .filter-section-title::before {
  content: "// ";
  color: var(--v4-neon, #00C86A);
}
body.v4 .sort-btn {
  background: var(--v4-surface, #FFFFFF) !important;
  border: 1px solid var(--v4-line-strong, rgba(10,30,20,.14)) !important;
  border-radius: 0 !important;
  padding: 14px 8px !important;
  transition: all .15s;
}
body.v4 .sort-btn:hover {
  border-color: var(--v4-ink, #0A0E0A) !important;
}
body.v4 .sort-btn.active {
  background: var(--v4-ink, #0A0E0A) !important;
  border-color: var(--v4-ink, #0A0E0A) !important;
}
body.v4 .sort-btn.active .icon { filter: hue-rotate(30deg) saturate(1.5); }
body.v4 .sort-btn .label {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 10px !important;
  letter-spacing: .14em !important;
  text-transform: uppercase;
  font-weight: 500 !important;
}
body.v4 .sort-btn.active .label { color: var(--v4-neon, #00C86A) !important; }

/* ─── BOUTONS DU MODAL ───────────────────────────────── */
body.v4 .modal-box .btn-outline {
  background: transparent !important;
  border: 1px solid var(--v4-ink, #0A0E0A) !important;
  color: var(--v4-ink, #0A0E0A) !important;
  border-radius: 0 !important;
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase;
  padding: 12px 16px !important;
}
body.v4 .modal-box .btn-outline:hover {
  background: var(--v4-ink, #0A0E0A) !important;
  color: var(--v4-neon, #00C86A) !important;
}
body.v4 .modal-box .btn-primary {
  background: var(--v4-ink, #0A0E0A) !important;
  color: var(--v4-neon, #00C86A) !important;
  border: 1px solid var(--v4-ink, #0A0E0A) !important;
  border-radius: 0 !important;
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase;
  padding: 12px 16px !important;
}
body.v4 .modal-box .btn-primary:hover {
  background: var(--v4-neon, #00C86A) !important;
  color: var(--v4-ink, #0A0E0A) !important;
  box-shadow: 0 0 16px rgba(0,200,106,.4);
}

/* ─── EMPTY STATE ───────────────────────────────────── */
body.v4 .empty-state {
  border: 1px dashed var(--v4-line-strong, rgba(10,30,20,.14));
  padding: 80px 24px !important;
  position: relative;
  background: var(--v4-bg-soft, #F1F4EE);
}
body.v4 .empty-state::before,
body.v4 .empty-state::after {
  content: "";
  position: absolute;
  width: 20px; height: 20px;
  border: 2px solid var(--v4-neon, #00C86A);
}
body.v4 .empty-state::before {
  top: 12px; left: 12px;
  border-right: none; border-bottom: none;
}
body.v4 .empty-state::after {
  bottom: 12px; right: 12px;
  border-left: none; border-top: none;
}
body.v4 .empty-title {
  font-family: var(--v4-ff-display, 'Space Grotesk', sans-serif) !important;
  font-weight: 600 !important;
  letter-spacing: -.01em;
}
body.v4 .empty-sub {
  font-family: var(--v4-ff-body, 'Inter', sans-serif) !important;
}

/* ─── MOBILE ────────────────────────────────────────── */
@media (max-width: 768px) {
  body.v4 .search-header { top: 0; padding: 12px 0 !important; }
  body.v4 .search-header::after { display: none; }
  body.v4 .pro-card {
    clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
    padding: 16px !important;
  }
}
