
    body { margin:0; font-family:sans-serif; }

    /* Form container */
    #form {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 8px;
      justify-content: center;
    }
    /* Chaque “row” regroupe icon+input */
    .row {
      display: flex;
      align-items: center;
      gap: 8px;
      flex: 1;              /* sur desktop, les deux rows s'élargissent */
      min-width: 0;         /* pour éviter overflow */
    }
    .icon-btn {
      cursor: pointer;
      font-size: 20px;
      user-select: none;
      flex: none;
    }
    #form input {
      flex: 1;
      padding: 6px;
      font-size: 14px;
      min-width: 120px;
    }
    #form button {
      flex: none;
      padding: 8px 12px;
      font-size: 14px;
    }

    /* MOBILE: empilement */
    @media (max-width: 600px) {
      #form {
        flex-direction: column;
      }
      .row {
        width: 100%;
      }
      #form button {
        width: 100%;
        margin-top: 4px;
      }
    }

    #map { height:300px; border-radius: 5px; border: 2px solid #003C64; }
    #route-info { padding:10px; }
    #route-info ol {
      list-style:none;
      padding-left:0;
      margin-top:5px;
    }
    #route-info li {
      display:flex;
      align-items:center;
      margin-bottom:15px;
      line-height:1.5;
      font-size:14px;
    }
    #route-info li span.icon {
      display:inline-block;
      width:20px;
      text-align:center;
      margin-right:8px;
	  color: #1A578A;
      font-weight: bold;
    }
    #toggle-steps {
      display:block;
      margin:8px 0;
      color:#1A578A;
      cursor:pointer;
      text-decoration:underline;
    }
#map,
#route-info {
  margin: 0 auto;
}

/* Passe la liste des étapes en grille 3 colonnes */
#route-info ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: auto 1fr auto;
  column-gap: 5px;
  row-gap: 10px;
}

#route-info li {
  display: contents; /* on prend juste les children pour la grille */
  color: #1A578A;
}

#route-info li .icon,
#route-info li .instruction,
#route-info li .distance {
  /* chaque span occupe une « cellule » */
  display: block;
  align-self: center;
}
/* Desktop uniquement */
@media (min-width: 769px) {
  .route-summary {
    display: flex;
    justify-content: center;
    gap: 0; /* pas de gap car chaque bloc prend 50% */
  }

  .route-summary .summary-item {
    flex: 0 0 50%;          /* chaque bloc = 50% */
    text-align: center;     /* contenu centré */
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

/* Mobile */
@media (max-width: 768px) {
  .route-summary {
    display: flex;
    flex-direction: column; /* empile verticalement */
    align-items: flex-start; /* aligne à gauche */
    gap: 20px; /* espace entre distance et durée */
  }

  .route-summary .summary-item {
    width: 100%;
    text-align: left;
    justify-content: flex-start;
  }
}