:root{
  --bg:#f6f7fb;
  --card:#fff;
  --text:#101828;
  --muted:#667085;
  --blue:#1f6feb;
  --red:#e11d48;
  --shadow: 0 8px 30px rgba(0,0,0,.07);
  --radius: 16px;
}

*{ box-sizing:border-box; }
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial;
  background:var(--bg);
  color:var(--text);
}

.topbar{
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--card);
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
  padding: 12px 14px;
}

.topbar__inner{
  max-width: 1200px;
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.title{ font-weight:800; font-size:18px; }
.subtitle{ color:var(--muted); font-size:13px; margin-top:2px; }

.wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 14px;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.card{
  background:var(--card);
  border-radius: var(--radius);
  padding: 14px;
  box-shadow: var(--shadow);
}

.muted{ color:var(--muted); }

.btn{
  border:0;
  padding: 12px 14px;
  border-radius: 14px;
  cursor:pointer;
  font-weight: 650;
}
.btn--primary{ background: var(--blue); color:#fff; }
.btn--secondary{ background:#eef2ff; color:#1f2a44; }
.btn--danger{ background: var(--red); color:#fff; }

.map{
  position: relative;
  margin-top: 12px;
  border-radius: 14px;
  overflow:hidden;
  background:#fff;
}

.map__img{
  width:100%;
  height:auto;
  display:block;
}

.map__svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  /* sur tablette: évite les scroll/zoom parasites */
  touch-action: manipulation;
}

/* hotspots */
.hit{
  fill: transparent;
}
.dot{
  fill: var(--blue);
  opacity: .95;
}

/* segments : hitbox large via stroke transparent */
.segment{
  fill:none;
  stroke: transparent;
  stroke-width: 34px;
  stroke-linecap: round;
  cursor:pointer;
}

/* highlight */
.hotspot.is-selected .dot{ fill: var(--red); }
.segment.is-selected{ stroke: rgba(225,29,72,0.22); }

.pin{
  position:absolute;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: var(--red);
  transform: translate(-50%, -50%);
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
  pointer-events:none;
}

.panel{
  margin-top: 12px;
  padding: 12px;
  border-radius: 14px;
  background: #f2f4f7;
}

.panel__title{
  font-weight: 750;
  margin-bottom: 8px;
}

.panel__value{
  font-size: 16px;
}

.actions{
  margin-top: 12px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.actions .btn{
  flex: 1 1 240px;
  text-align:left;
}

.debug{
  margin-top: 10px;
  padding: 12px;
  background: #0b1220;
  color: #e6edf3;
  border-radius: 14px;
  overflow:auto;
  font-size: 12px;
}
