/**
 * Je Porte Le Rouge — Manifestation routes custom UI
 * Use this file for route single/archive page overrides instead of adding more inline CSS.
 */

/* -------------------------------------------------------------------------
   Route single page: Action/Petition layout alignment
   ------------------------------------------------------------------------- */

.jpr-manifestation-route-single.jpr-route-petition-layout {
  background: #fff;
}

.jpr-route-petition-layout .jpr-petition-topband,
.jpr-route-petition-layout .jpr-route-topband {
  margin: 0 !important;
  padding: 0 !important;
  background: #fff !important;
}

.jpr-route-petition-layout .jpr-route-topband-map,
.jpr-route-petition-layout .jpr-petition-topband-map {
  position: relative !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

.jpr-route-petition-layout .jpr-mani-route-card {
  position: relative !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.jpr-route-petition-layout .jpr-mani-map {
  position: relative !important;
  height: 520px !important;
  min-height: 58vh !important;
  width: 100% !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #f3f4f6 !important;
  overflow: hidden !important;
}

/* Header card: forced clean positioning, no broken shadow syntax, no hidden content. */
.jpr-route-petition-layout .jpr-petition-map-head,
.jpr-route-petition-layout .jpr-route-map-head {
  position: relative !important;
  z-index: 20 !important;
  margin-top: 0 !important;
  padding: 24px !important;
  border-radius: 0 0 24px 24px !important;
  background: #fff !important;
  box-shadow: none !important;
  transform: none !important;
}

.jpr-route-petition-layout .jpr-route-post-header h1 {
  line-height: 1.08 !important;
  letter-spacing: -0.025em;
}

.jpr-route-petition-layout .jpr-route-main-section {
  margin: 0 !important;
  padding-top: 3rem !important;
  overflow: visible !important;
}

.jpr-route-petition-layout .jpr-route-redline {
  z-index: 2 !important;
}

.jpr-route-petition-layout .jpr-route-noise {
  z-index: 1 !important;
}

.jpr-route-petition-layout .jpr-route-main-section > .container {
  z-index: 3 !important;
}

.jpr-route-petition-layout .jpr-route-sticky-panel {
  position: sticky !important;
  top: 96px !important;
  z-index: 5 !important;
}

/* -------------------------------------------------------------------------
   Map controls and subtle code form
   ------------------------------------------------------------------------- */

.jpr-route-petition-layout .jpr-mani-code-form,
.jpr-mani-code-form {
  position: absolute !important;
  right: 16px !important;
  bottom: 16px !important;
  z-index: 1000 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  width: auto !important;
  max-width: min(92vw, 430px) !important;
  margin-top: 0 !important;
  padding: 8px 10px !important;
  color: #111827 !important;
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(15,23,42,.10) !important;
  border-radius: 999px !important;
  box-shadow: 0 12px 28px rgba(15,23,42,.14) !important;
  backdrop-filter: blur(10px);
}

.jpr-route-petition-layout .jpr-mani-code-form label,
.jpr-mani-code-form label {
  margin: 0 !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  color: #374151 !important;
}

.jpr-route-petition-layout .jpr-mani-code-form > div,
.jpr-mani-code-form > div {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.jpr-route-petition-layout .jpr-mani-code-form input,
.jpr-mani-code-form input {
  width: 96px !important;
  max-width: 32vw !important;
  height: 30px !important;
  padding: 4px 8px !important;
  border: 1px solid rgba(15,23,42,.12) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.98) !important;
  color: #111827 !important;
  font-size: 12px !important;
  outline: none !important;
}

.jpr-route-petition-layout .jpr-mani-code-form input:focus,
.jpr-mani-code-form input:focus {
  border-color: rgba(220,38,38,.65) !important;
  box-shadow: 0 0 0 3px rgba(220,38,38,.12) !important;
}

.jpr-route-petition-layout .jpr-mani-code-form button,
.jpr-mani-code-form button {
  height: 30px !important;
  padding: 4px 10px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #111827 !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.jpr-route-petition-layout .jpr-mani-error,
.jpr-route-petition-layout .jpr-mani-success,
.jpr-mani-error,
.jpr-mani-success {
  position: absolute !important;
  right: 0 !important;
  bottom: calc(100% + 6px) !important;
  width: max-content !important;
  max-width: 320px !important;
  margin: 0 !important;
  padding: 6px 9px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  background: rgba(17,24,39,.94) !important;
  color: #fff !important;
}

/* Keep zoom-protected badge visible and away from Leaflet +/- controls. */
.jpr-route-petition-layout .jpr-mani-map.leaflet-container::after,
.jpr-mani-map.leaflet-container::after {
  content: "Zoom protégé : utilisez + / −" !important;
  position: absolute !important;
  top: 12px !important;
  left: 64px !important;
  right: auto !important;
  z-index: 1001 !important;
  display: inline-flex !important;
  align-items: center !important;
  min-height: 30px !important;
  padding: 7px 10px !important;
  border-radius: 999px !important;
  background: rgba(17,24,39,.86) !important;
  color: #fff !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  pointer-events: none !important;
  box-shadow: 0 8px 20px rgba(15,23,42,.18) !important;
}

.jpr-route-petition-layout .leaflet-control-container .leaflet-top,
.jpr-route-petition-layout .leaflet-control-container .leaflet-bottom {
  z-index: 1000 !important;
}

.jpr-route-petition-layout .jpr-mani-directions-link,
.jpr-mani-directions-link {
  z-index: 1001 !important;
  right: 16px !important;
  bottom: 72px !important;
  border-radius: 999px !important;
}

.jpr-route-petition-layout .jpr-mani-private-note,
.jpr-mani-private-note {
  margin: 14px 16px 0 !important;
  border-left: 4px solid #dc2626 !important;
  background: #fff7ed !important;
}

/* -------------------------------------------------------------------------
   Archive: keep Actualités two-column rhythm but allow route-specific tuning
   ------------------------------------------------------------------------- */

.jpr-mani-archive-page .jpr-mani-archive-card {
  overflow: hidden;
}

.jpr-mani-archive-actualites-layout .jpr-mani-archive-sidebar {
  top: 96px;
}

/* -------------------------------------------------------------------------
   Responsive
   ------------------------------------------------------------------------- */

@media (max-width: 991.98px) {
  .jpr-route-petition-layout .jpr-mani-map {
    height: 440px !important;
    min-height: 52vh !important;
  }

  .jpr-route-petition-layout .jpr-petition-map-head,
  .jpr-route-petition-layout .jpr-route-map-head {
    padding: 18px !important;
    border-radius: 0 0 18px 18px !important;
  }

  .jpr-route-petition-layout .jpr-route-sticky-panel {
    position: static !important;
    top: auto !important;
  }
}

@media (max-width: 575.98px) {
  .jpr-route-petition-layout .jpr-mani-map {
    height: 390px !important;
    min-height: 50vh !important;
  }

  .jpr-route-petition-layout .jpr-mani-map.leaflet-container::after,
  .jpr-mani-map.leaflet-container::after {
    top: 12px !important;
    left: 56px !important;
    max-width: calc(100vw - 74px) !important;
    font-size: 11px !important;
  }

  .jpr-route-petition-layout .jpr-mani-code-form,
  .jpr-mani-code-form {
    right: 10px !important;
    bottom: 10px !important;
    max-width: calc(100vw - 20px) !important;
    padding: 7px 8px !important;
  }

  .jpr-route-petition-layout .jpr-mani-code-form label,
  .jpr-mani-code-form label {
    max-width: 86px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .jpr-route-petition-layout .jpr-mani-code-form input,
  .jpr-mani-code-form input {
    width: 76px !important;
  }

  .jpr-route-petition-layout .jpr-mani-directions-link,
  .jpr-mani-directions-link {
    right: 10px !important;
    bottom: 62px !important;
    padding: 10px 12px !important;
    font-size: 12px !important;
  }
}
