/* =========================================================
   M'SAFARA — HOME.CSS
   Page : index.php
   Scope : .home-page
========================================================= */

.home-page {
  position: relative;
}

.home-page *,
.home-page *::before,
.home-page *::after {
  box-sizing: border-box;
  min-width: 0;
}

/* HOME — Hero réseau */
.home-page #plan-du-reseau {
  position: relative;
}

.home-page .hero-network-heading,
.home-page .hero-network-layout {
  position: relative;
  z-index: 2;
}

.home-page .hero-network-layout {
  align-items: start;
}

/* HOME — Carte */
.home-page .hero-network-map,
.home-page .hero-network-map__stage,
.home-page .network-map-stage {
  min-width: 0;
}

.home-page .hero-network-map__stage,
.home-page .network-map-stage {
  width: 100%;
  overflow: hidden;
}

/* =========================================================
   HOME — Liste lignes gauche PRO
   Desktop/tablette : 1 colonne
   Mobile : grille 2 colonnes
========================================================= */

.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 12px !important;
}

/* Bouton */
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 12px !important;
  width: 100% !important;
  min-height: 76px !important;
  padding: 14px 16px !important;
  border: 1px solid rgba(255,255,255,.72) !important;
  border-left: 5px solid var(--line-color) !important;
  border-radius: 18px !important;
  
  text-align: left !important;
  cursor: pointer !important;
}

/* Icône */
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button > img {
  display: block !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  object-fit: contain !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* Texte */
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button > span {
  min-width: 0 !important;
  display: grid !important;
  gap: 4px !important;
}

.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button strong {
  font-size: clamp(.8rem, .9vw, .96rem) !important;
  line-height: 1.15 !important;
  color: #102652 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}

.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button small {
  font-size: .72rem !important;
  color: rgba(16,38,82,.58) !important;
}

/* Masquer pastille droite */
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-count {
  display: none !important;
}

/* Hover */
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button:hover,
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button.is-hover-linked {

  background: rgba(255,255,255,.96) !important;
  border-color: var(--line-color) !important;

}

/* Actif */
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button.is-active,
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button.is-focused,
.home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button[aria-pressed="true"] {
  background: linear-gradient(135deg, rgba(255,255,255,.98), color-mix(in srgb, var(--line-color) 0%, white)) !important;
  border-color: var(--line-color) !important;
	transform: translateY(0px) !important;
}

/* Mobile : 2 colonnes */
@media (max-width: 760px) {
  .home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button {
    grid-template-columns: 34px minmax(0, 1fr) !important;
    min-height: 92px !important;
    padding: 12px !important;
    border-radius: 16px !important;
  }

  .home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button > img {
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
  }

  .home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button strong {
    font-size: .76rem !important;
    line-height: 1.12 !important;
  }

  .home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button small {
    font-size: .66rem !important;
  }
}

/* Très petit mobile */
@media (max-width: 380px) {
  .home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .home-page #plan-du-reseau .hero-network-map__mini-controls .network-line-button > img {
    margin-inline: auto !important;
  }
}

.home-page .network-line-button {
  border-left-color: transparent !important;
}

.home-page .network-line-button::before,
.home-page .network-line-button::after {
  display: none !important;
}

/* HOME MOBILE — panneau droit : 4 arrêts visibles */
@media (max-width: 760px) {
  .home-page .hero-network-layout {
    --network-panel-height: 540px !important;
  }

  .home-page aside[data-network-detail],
  .home-page .network-detail-panel.hero-network-map__detail {
    height: 540px !important;
    max-height: 540px !important;
    overflow: hidden !important;
  }

  .home-page .network-detail-card.network-detail-card--line-focus {
    height: 100% !important;
    max-height: 100% !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }

  .home-page .network-detail-line {
    flex: 0 0 auto !important;
  }

  .home-page .network-stop-list {
    flex: 0 1 auto !important;
    max-height: 500px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }
}

/* HOME — état initial / rollover / actif des lignes */
.home-page #plan-du-reseau
.hero-network-map__mini-controls
.network-line-list
button.network-line-button {
  border: 1px solid color-mix(in srgb, var(--line-color) 95%, white) !important;
}

/* Rollover */
.home-page #plan-du-reseau
.hero-network-map__mini-controls
.network-line-list
button.network-line-button:hover {
  border-color: var(--line-color) !important;

}

/* Actif / cliqué */
.home-page #plan-du-reseau
.hero-network-map__mini-controls
.network-line-list
button.network-line-button[aria-pressed="true"],
.home-page #plan-du-reseau
.hero-network-map__mini-controls
.network-line-list
button.network-line-button.is-active,
.home-page #plan-du-reseau
.hero-network-map__mini-controls
.network-line-list
button.network-line-button.is-focused {
    border: 4px solid var(--line-color) !important;
}

/* HOME — masquer "Détail" dans la liste des arrêts */
.home-page aside[data-network-detail] .network-stop-access {
  display: none !important;
}

/* HOME — donner toute la place au nom de l’arrêt */
.home-page aside[data-network-detail] .network-stop-row {
  grid-template-columns: auto minmax(0, 1fr) !important;
}

.home-page aside[data-network-detail] .network-stop-content {
  min-width: 0 !important;
}

.home-page aside[data-network-detail] .network-stop-content strong {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}

/* HOME — icône média arrêt alignée à droite */
.home-page aside[data-network-detail] .network-stop-row {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  column-gap: 12px !important;
}

.home-page aside[data-network-detail] .network-stop-tools {
  justify-self: end !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.home-page aside[data-network-detail] .network-stop-tool {
  display: inline-grid !important;
  place-items: center !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  background: color-mix(in srgb, var(--line-color) 12%, white) !important;
  color: var(--line-color) !important;
  font-size: .82rem !important;
}

.home-page aside[data-network-detail] .network-stop-access {
  display: none !important;
}

/* HOME — arrêts : initial / rollover / actif */
.home-page aside[data-network-detail] .network-stop-row {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 12px !important;

  border: 1px solid color-mix(in srgb, var(--line-color) 22%, white) !important;
  border-radius: 16px !important;

  background: rgba(255,255,255,.78) !important;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease !important;
}

.home-page aside[data-network-detail] .network-stop-row:hover {
  transform: translateY(-1px) !important;
  border-color: var(--line-color) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 10px 24px rgba(16,38,82,.14),
              0 0 0 2px color-mix(in srgb, var(--line-color) 24%, transparent) !important;
}

.home-page aside[data-network-detail] .network-stop-row.is-current,
.home-page aside[data-network-detail] .network-stop-row.is-focused,
.home-page aside[data-network-detail] .network-stop-item.is-open .network-stop-row {
  border: 2px solid var(--line-color) !important;
  background: color-mix(in srgb, var(--line-color) 9%, white) !important;
  box-shadow: 0 14px 32px rgba(16,38,82,.16),
              0 0 0 3px color-mix(in srgb, var(--line-color) 28%, transparent) !important;
}

.home-page aside[data-network-detail] .network-stop-tools {
  justify-self: end !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.home-page aside[data-network-detail] .network-stop-access {
  display: none !important;
}

.home-page aside[data-network-detail] .network-stop-tool {
  display: inline-grid !important;
  place-items: center !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  background: color-mix(in srgb, var(--line-color) 12%, white) !important;
  color: var(--line-color) !important;
}

@media (max-width: 760px) {
  .home-page .hero-network-map {
    scroll-margin-top: 92px;
  }
}


/* =========================================================
   HOME — FIX PRO 821px → 1180px
   Empêche network-map.css de casser le layout
========================================================= */

@media (min-width: 821px) and (max-width: 1180px) {
  .home-page #plan-du-reseau .hero-network-layout {
    display: grid !important;
    grid-template-columns:
      minmax(210px, .75fr)
      minmax(520px, 1.7fr)
      minmax(260px, .85fr) !important;
    grid-template-areas: "lines map detail" !important;
    gap: 18px !important;
    align-items: stretch !important;
  }

  .home-page #plan-du-reseau .hero-network-map__mini-controls {
    grid-area: lines !important;
    height: var(--network-panel-height, 640px) !important;
    min-height: var(--network-panel-height, 640px) !important;
  }

  .home-page #plan-du-reseau .hero-network-map {
    grid-area: map !important;
    height: var(--network-panel-height, 640px) !important;
    min-height: var(--network-panel-height, 640px) !important;
  }

  .home-page #plan-du-reseau .network-detail-panel {
    grid-area: detail !important;
    height: var(--network-panel-height, 640px) !important;
    min-height: var(--network-panel-height, 640px) !important;
  }

  .home-page #plan-du-reseau .hero-network-map__stage,
  .home-page #plan-du-reseau .network-map-stage {
    height: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
  }

  .home-page #plan-du-reseau .network-svg {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
  }

  .home-page #plan-du-reseau .hero-network-map__lines,
  .home-page #plan-du-reseau .network-line-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    max-height: calc(var(--network-panel-height, 640px) - 40px) !important;
  }

  .home-page #plan-du-reseau .network-line-button {
    min-width: 0 !important;
  }
}

@media (max-width: 1100px) {
  .home-page #plan-du-reseau .hero-network-layout {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "map"
      "lines"
      "detail" !important;
  }

  .home-page #plan-du-reseau .hero-network-map {
    grid-area: map !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .home-page #plan-du-reseau .hero-network-map__mini-controls {
    grid-area: lines !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .home-page #plan-du-reseau .network-detail-panel {
    grid-area: detail !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .home-page #plan-du-reseau .hero-network-map__stage,
  .home-page #plan-du-reseau .network-map-stage {
    aspect-ratio: 2834 / 2598 !important;
    height: auto !important;
    min-height: 420px !important;
  }
}