.canaan-directions {
  display: grid;
  gap: 0.75rem;
}

.canaan-directions__panel {
  padding: 0;
}

.canaan-directions__panel p {
  margin: 0;
}

.canaan-directions__panel--top {
  margin-top: 0;
}

.canaan-directions__panel--bottom {
  border-top: 1px solid #d4d4d4;
  padding-top: 0.75rem;
}

.canaan-directions__map {
  min-height: 368px;
  border: 1px solid #bdbdbd;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

.canaan-directions__map-wrap {
  position: relative;
}

.canaan-directions__map-toggle {
  position: absolute;
  left: 50%;
  bottom: 0.85rem;
  transform: translateX(-50%);
  z-index: 500;
  border: 1px solid rgba(0, 0, 0, 0.25);
  background: rgba(255, 255, 255, 0.35);
  color: #111;
  padding: 0.42rem 0.65rem;
  font: inherit;
  font-weight: 700;
  font-size: 0.78rem;
  line-height: 1.1;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.16);
  white-space: nowrap;
}

.canaan-directions__form {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
  border: 1px solid #d4d4d4;
  background: #f6f6f6;
}

.canaan-directions__input {
  width: 100%;
  max-width: 34rem;
  padding: 0.75rem 0.9rem;
  border: 1px solid #b9b9b9;
  font: inherit;
}

.canaan-directions__actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.75rem;
}

.canaan-directions__button {
  flex: 1 1 50%;
  border: 1px solid #970e0e;
  background: #c71919;
  color: #fff;
  padding: 0.72rem 1rem;
  font: inherit;
  font-weight: 700;
  font-size: 0.92rem;
  line-height: 1.1;
  cursor: pointer;
  white-space: nowrap;
}

.canaan-directions__button--secondary {
  border-color: #8e8e8e;
  background: #ececec;
  color: #222;
}

.canaan-directions__hint,
.canaan-directions__message {
  margin: 0;
}

.canaan-directions__message {
  padding: 1rem;
  border: 1px solid #d4d4d4;
  background: #f6f6f6;
}

@media (max-width: 760px) {
  .canaan-directions__map {
    min-height: 288px;
  }

  .canaan-directions__map-toggle[hidden] {
    display: none;
  }

  .canaan-directions__actions {
    gap: 0.5rem;
  }

  .canaan-directions__button {
    font-size: 0.8rem;
    padding: 0.72rem 0.55rem;
  }

  .canaan-directions__map-toggle {
    bottom: 0.6rem;
    padding: 0.34rem 0.55rem;
    font-size: 0.68rem;
  }
}

.leaflet-container .leaflet-tile {
  outline: 1px solid transparent;
  backface-visibility: hidden;
}
