
    :root {
      --bg: #ece4d8;
      --bg-2: #dccdb6;
      --ink: #2a1816;
      --brick: #7a2e23;
      --brick-deep: #4a1812;
      --brick-light: #c46451;
      --rust: #d97a3f;
      --moss: #5a6a3c;
      --ink-soft: #574039;
      --ink-mute: #8a7565;
      --grot: 'Bricolage Grotesque', system-ui, sans-serif;
      --mono: 'JetBrains Mono', ui-monospace, monospace;
      --ease-out: cubic-bezier(.22,1,.36,1);
      --ease-spring: cubic-bezier(.34,1.56,.64,1);
      --t-base: .32s;
    }
    *, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
    html, body, #root { height: 100%; }
    body {
      font-family: var(--grot);
      color: var(--ink);
      background: var(--bg);
      overflow: hidden;
      -webkit-font-smoothing: antialiased;
      font-size: 16px; line-height: 1.45;
    }
    /* Grain overlay */
    body::before {
      content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 999;
      opacity: .45; mix-blend-mode: multiply;
      background-image:
        radial-gradient(circle at 20% 30%, rgba(74,24,18,.08) 0, transparent 1px),
        radial-gradient(circle at 80% 70%, rgba(74,24,18,.06) 0, transparent 1px),
        radial-gradient(circle at 50% 50%, rgba(74,24,18,.04) 0, transparent 1px);
      background-size: 3px 3px, 5px 5px, 2px 2px;
    }
    ::selection { background: var(--brick); color: var(--bg); }

    /* Layout */
    .pm-app { display: flex; height: 100%; }

    /* Sidebar (dark) */
    .pm-sidebar {
      width: 220px; height: 100%; flex-shrink: 0;
      background: var(--ink); color: var(--bg);
      border-right: 2px solid var(--brick);
      display: flex; flex-direction: column;
      font-family: var(--mono);
    }
    .pm-sidebar-brand {
      padding: 20px 18px 18px;
      border-bottom: 1px solid rgba(236,228,216,.12);
      display: flex; align-items: center; gap: 10px;
    }
    .pm-sidebar-stamp {
      width: 28px; height: 28px;
      background: var(--brick-light);
      -webkit-mask: url("8668e9e9-b23b-47af-9fe3-b12e769f4b5e") center/contain no-repeat;
      mask: url("8668e9e9-b23b-47af-9fe3-b12e769f4b5e") center/contain no-repeat;
      flex-shrink: 0;
    }
    .pm-sidebar-brand-text {
      font-family: var(--grot); font-weight: 700; font-size: 17px;
      letter-spacing: -.02em; color: var(--bg);
    }
    .pm-sidebar-brand-dot {
      width: 7px; height: 7px; border-radius: 50%;
      background: var(--brick-light);
      animation: pm-blink 1.4s infinite;
      margin-left: auto; flex-shrink: 0;
    }
    .pm-sidebar-nav {
      flex: 1; padding: 14px 10px;
      display: flex; flex-direction: column; gap: 2px;
    }
    .pm-sidebar-item {
      display: flex; align-items: center; gap: 10px;
      padding: 10px 12px;
      font-size: 11px; font-weight: 500;
      letter-spacing: .14em; text-transform: uppercase;
      color: rgba(236,228,216,.5);
      cursor: pointer; transition: all .2s; user-select: none;
    }
    .pm-sidebar-item:hover {
      color: var(--bg); background: rgba(236,228,216,.06);
    }
    .pm-sidebar-item.active {
      background: var(--brick); color: var(--bg);
    }
    .pm-sidebar-item svg { flex-shrink: 0; }
    .pm-sidebar-footer {
      padding: 14px 16px 18px;
      border-top: 1px solid rgba(236,228,216,.12);
      font-family: var(--grot);
    }

    /* Main content */
    .pm-main {
      flex: 1; height: 100%; overflow-y: auto;
      padding: 28px 36px; position: relative; z-index: 2;
    }
    .pm-main::-webkit-scrollbar { width: 8px; }
    .pm-main::-webkit-scrollbar-track { background: transparent; }
    .pm-main::-webkit-scrollbar-thumb { background: var(--brick); border: 2px solid var(--bg); border-radius: 4px; }

    /* View titles */
    .pm-view { min-height: 100%; }
    .pm-view-title {
      font-family: var(--grot); font-weight: 300;
      font-size: clamp(32px, 4vw, 44px);
      letter-spacing: -.03em; line-height: 1;
      margin-bottom: 28px;
    }
    .pm-view-title em { font-style: normal; font-weight: 800; color: var(--brick); }

    /* Eyebrow labels */
    .pm-eyebrow {
      font-family: var(--mono); font-size: 10px; font-weight: 500;
      letter-spacing: .16em; text-transform: uppercase;
      color: var(--brick); display: inline-flex; align-items: center; gap: 8px;
    }
    .pm-eyebrow-dot {
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--brick-light);
      animation: pm-pulse-dot 1.8s ease infinite;
    }

    /* Cards */
    .pm-card {
      background: var(--bg);
      border: 2px solid var(--ink);
      padding: 22px;
      transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
    }
    .pm-card-hover:hover {
      transform: translate(-3px, -3px);
      box-shadow: 6px 6px 0 0 var(--ink);
    }
    .pm-card-warm { background: var(--bg-2); }

    /* Stat cards */
    .pm-stat-card {
      border-top: 2px solid var(--ink);
      border-left: none; border-right: none; border-bottom: none;
      padding: 18px 4px;
    }
    .pm-stat-num {
      font-family: var(--grot); font-weight: 700;
      font-size: clamp(36px, 5vw, 56px);
      line-height: .9; letter-spacing: -.04em;
      color: var(--ink);
    }
    .pm-stat-tail {
      font-family: var(--mono); font-size: 12px;
      letter-spacing: .12em; text-transform: uppercase;
      color: var(--brick); margin-left: 4px;
    }
    .pm-stat-label {
      font-family: var(--mono); font-size: 10px; font-weight: 500;
      letter-spacing: .08em; text-transform: uppercase;
      color: var(--ink-mute); margin-top: 8px; line-height: 1.4;
    }

    /* Badges */
    .pm-badge {
      display: inline-flex; align-items: center;
      font-family: var(--mono); font-size: 10px; font-weight: 500;
      letter-spacing: .1em; text-transform: uppercase;
      padding: 3px 8px; white-space: nowrap;
    }

    /* Table */
    .pm-table-wrap {
      border: 2px solid var(--ink); overflow: hidden;
    }

    /* Inputs */
    .pm-input {
      width: 100%; padding: 12px 14px;
      font-family: var(--grot); font-size: 15px;
      border: 2px solid var(--ink); background: var(--bg);
      color: var(--ink); outline: none;
      transition: border-color .25s;
    }
    .pm-input:focus { border-color: var(--brick); }
    .pm-select {
      padding: 10px 12px;
      font-family: var(--mono); font-size: 11px;
      letter-spacing: .06em; text-transform: uppercase;
      border: 2px solid var(--ink); background: var(--bg);
      color: var(--ink); cursor: pointer; outline: none;
    }

    /* Buttons */
    .pm-btn {
      display: inline-flex; align-items: center; gap: 10px;
      padding: 14px 22px; font-family: var(--grot); font-weight: 500;
      font-size: 15px; letter-spacing: -.005em;
      border: 2px solid var(--ink); cursor: pointer;
      transition: all .25s; text-decoration: none;
    }
    .pm-btn:hover { transform: translateY(-2px); }
    .pm-btn:active { transform: translateY(0); }
    .pm-btn-primary {
      background: var(--brick); color: var(--bg); border-color: var(--brick);
    }
    .pm-btn-primary:hover {
      background: var(--brick-deep); border-color: var(--brick-deep);
      box-shadow: 0 8px 24px -8px rgba(74,24,18,.4);
    }
    .pm-btn-ghost { background: transparent; color: var(--ink); }
    .pm-btn-ghost:hover { background: var(--ink); color: var(--bg); }

    /* Animations */
    @keyframes pm-blink { 50% { opacity: .2; } }
    @keyframes pm-pulse-dot {
      0%,100% { box-shadow: 0 0 0 0 rgba(196,100,81,.6); opacity: 1; }
      50% { box-shadow: 0 0 0 6px rgba(196,100,81,0); opacity: .6; }
    }
    @keyframes pm-stat-in {
      from { filter: blur(12px); opacity: 0; transform: scale(1.15); }
      to { filter: blur(0); opacity: 1; transform: scale(1); }
    }
    @keyframes pm-fade-up {
      from { opacity: 0; transform: translateY(14px); }
      to { opacity: 1; transform: none; }
    }
    @keyframes pm-scan-sweep {
      from { transform: rotate(0deg); }
      to { transform: rotate(360deg); }
    }
    @keyframes pm-bar-grow {
      from { transform: scaleY(0); }
      to { transform: scaleY(1); }
    }

    /* Scrollbar for dark areas */
    .pm-terminal::-webkit-scrollbar { width: 4px; }
    .pm-terminal::-webkit-scrollbar-track { background: transparent; }
    .pm-terminal::-webkit-scrollbar-thumb { background: rgba(196,100,81,.3); border-radius: 2px; }

    /* Leaflet warm filter */
    .pm-leaflet-wrap .leaflet-tile-pane { filter: sepia(.35) saturate(.8) brightness(1.02) hue-rotate(-5deg); }
    .pm-leaflet-wrap .leaflet-control-zoom a {
      background: var(--ink) !important; color: var(--bg) !important;
      border-color: var(--brick) !important; border-radius: 0 !important;
      font-family: var(--mono) !important; font-weight: 700;
    }
    .pm-leaflet-wrap .leaflet-control-zoom { border: none !important; border-radius: 0 !important; box-shadow: none !important; }
    .pm-leaflet-wrap .leaflet-control-attribution { display: none; }
    .pm-leaflet-wrap { position: relative; z-index: 1; }

    /* ═══ RESPONSIVE ═══ */
    @media (max-width: 900px) {
      .pm-app { flex-direction: column; }
      .pm-sidebar {
        width: 100%; height: auto; flex-shrink: 0;
        border-right: none; border-bottom: 2px solid var(--brick);
        order: 2;
      }
      .pm-sidebar-brand { display: none; }
      .pm-sidebar-footer { display: none; }
      .pm-sidebar-nav {
        flex-direction: row; padding: 4px 0; gap: 0;
        justify-content: space-around;
      }
      .pm-sidebar-item {
        flex-direction: column; gap: 2px;
        padding: 8px 6px; font-size: 8px; letter-spacing: .1em;
        justify-content: center; align-items: center; flex: 1;
      }
      .pm-sidebar-item svg { width: 18px; height: 18px; }
      .pm-main {
        order: 1; padding: 16px 14px;
        height: 0; flex: 1;
      }
      .pm-view-title { font-size: 26px !important; margin-bottom: 16px; }

      /* Dashboard stats */
      .pm-dash-stats { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
      .pm-dash-stats .pm-stat-card:last-child { grid-column: span 2; }
      .pm-stat-num { font-size: 32px !important; }
      .pm-dash-bottom { grid-template-columns: 1fr !important; }

      /* Scan toolbar */
      .pm-scan-toolbar { flex-direction: column !important; align-items: flex-start !important; gap: 8px !important; }
      .pm-scan-toolbar-controls { flex-wrap: wrap; width: 100%; }
      .pm-scan-bottom {
        flex-direction: column !important; gap: 12px !important; padding: 12px 14px !important;
      }
      .pm-scan-bottom-stats { gap: 12px !important; flex-wrap: wrap; }

      /* Type picker dropdown */
      .pm-type-dropdown {
        width: calc(100vw - 60px) !important; left: 0 !important; right: auto !important;
        max-height: 50vh !important;
      }
      .pm-type-dropdown-grid { grid-template-columns: repeat(2, 1fr) !important; }

      /* Prospect detail */
      .pm-detail-grid { grid-template-columns: 1fr !important; }
      .pm-detail-header { flex-direction: column !important; gap: 10px !important; }
      .pm-detail-stats-grid { grid-template-columns: 1fr !important; }
      .pm-detail-velocity { flex-direction: column; gap: 4px; }

      /* Table filters */
      .pm-table-filters { padding: 10px 12px !important; }
      .pm-table-filters .pm-input { flex: 1 1 100% !important; }
      .pm-table-wrap { border-width: 1px; }

      /* Cards */
      .pm-card { padding: 14px; border-width: 1.5px; }

      /* Scan progress */
      .pm-scan-progress-row { flex-direction: column !important; gap: 12px !important; }
      .pm-scan-progress-row > div:last-child { border-left: none !important; padding-left: 0 !important; border-top: 1px solid rgba(42,24,22,.1); padding-top: 12px; }
      .pm-scan-counters { justify-content: center; }
    }

    @media (max-width: 480px) {
      .pm-main { padding: 12px 10px; }
      .pm-view-title { font-size: 22px !important; margin-bottom: 12px; }
      .pm-dash-stats { grid-template-columns: 1fr 1fr !important; }
      .pm-stat-num { font-size: 26px !important; }
      .pm-stat-label { font-size: 9px; }
      .pm-card { padding: 12px; }
      .pm-type-dropdown-grid { grid-template-columns: 1fr !important; }
      .pm-btn { padding: 10px 14px; font-size: 13px; }
      .pm-scan-bottom-stats > div { padding-left: 0 !important; border-left: none !important; }
    }
  
/* ═══ Ajouts ProspectMap (vanilla) ═══ */

/* Vue active / transitions */
.pm-view-host { animation: pm-fade-up .3s var(--ease-out); }
[hidden] { display: none !important; }

/* Loader */
.pm-spin { width:16px; height:16px; border:2px solid rgba(236,228,216,.25); border-top-color:var(--brick-light);
  border-radius:50%; animation:pm-rotate .7s linear infinite; display:inline-block; }
@keyframes pm-rotate { to { transform: rotate(360deg); } }

/* Toast */
.pm-toast { position:fixed; bottom:24px; right:24px; background:var(--ink); color:var(--bg);
  padding:12px 18px; font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  display:flex; align-items:center; gap:8px; border:2px solid var(--brick); z-index:2000;
  animation:pm-fade-up .2s ease; }

/* Téléphone (vue mobile terrain) */
.pm-phone { width:340px; height:680px; background:var(--ink); border-radius:38px; padding:10px;
  box-shadow:0 30px 80px -20px rgba(42,24,22,.5), 0 0 0 2px var(--brick); position:relative; }
.pm-phone-screen { width:100%; height:100%; border-radius:28px; overflow:hidden; background:var(--bg); position:relative; }
.pm-phone-notch { position:absolute; top:10px; left:50%; transform:translateX(-50%); width:120px; height:22px;
  background:var(--ink); border-radius:0 0 14px 14px; z-index:50; }

/* Liste cliquable générique */
.pm-row-click { cursor:pointer; transition:background .15s, padding-left .2s; }
.pm-row-click:hover { background:rgba(122,46,35,.04); }

/* Inputs range */
input[type=range] { accent-color: var(--brick); }

/* Boutons statut mobile larges */
.pm-tap { padding:14px; font-size:14px; font-weight:700; font-family:var(--grot);
  border:2px solid rgba(42,24,22,.12); background:var(--bg-2); color:var(--ink); cursor:pointer; transition:all .2s; }
.pm-tap.on { border-color:var(--brick); }

/* Skeleton vide */
.pm-empty { padding:40px; text-align:center; color:var(--ink-mute); font-family:var(--mono);
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; }
