@charset "UTF-8";

#gmap {
  aspect-ratio: 3 / 2;
  width: 100%;
  height: auto;
}

#gmap * {
  max-width: none;
}

#item_map #gmap {
  margin-bottom: 16px;
}

#gmap .gmap_icon {
  display: inline-block;
  width: 40px;
  height: 40px;
  font-weight: bold;
  text-align: center;
  line-height: 40px;
  background: #4a4a4a;
  border-radius: 50%;
  position: relative;
}
#gmap .gmap_icon::before {
  content: '';
  position: absolute;
  width: 12px;
  height: 10px;
  background: #4a4a4a;
  bottom: -6px;
  left: 0;
  right: 0;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  margin: auto;
}
#gmap .gmap_icon span {
  color: #fff;
  font-size: 25px;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  margin-top: -0.5em;
}
#gmap .gmap_icon.start {
  width: 26px;
  height: 26px;
}
#gmap .gmap_icon.start::before {
  content: none;
}
#gmap .gmap_icon.start span {
  font-size: 16px;
  margin-top: -0.5em;
}
#gmap .gmap_icon.shop span {
  font-size: 27px;
  margin-top: -0.55em;
}
#gmap .shop_bubble {
  background-color: rgba(255, 255, 255, 0.8);
  padding: 10px;
  border-radius: 5px;
  font-size: 13px;
  text-align: center;
  position: absolute;
  bottom: 52px;
  left: -90px;
  width: 180px;
  box-shadow: 1px 1px 4px 0 rgba(0, 0, 0, 0.2);
}
#gmap .shop_bubble p {
  display: inline-block;
  margin: 0;
}
#gmap .shop_bubble p.txt {
  text-align: left;
}
#gmap .shop_bubble p.img {
  width: 100%;
}
#gmap .shop_bubble p.img img {
  max-width: 100%;
}
/* サイトに合わせて設定 */
#gmap .shop_bubble p.img img {
  width: 90px;
}
#gmap.map_type_leaflet .leaflet-popup {
  position: static;
}
#gmap.map_type_leaflet .leaflet-popup .leaflet-popup-content-wrapper {
  background: transparent;
  color: #333;
  box-shadow: none;
}
#gmap.map_type_leaflet .leaflet-popup .leaflet-popup-tip-container,
#gmap.map_type_leaflet .leaflet-popup .leaflet-popup-close-button {
  display: none;
}
#gmap.map_type_leaflet .shop_bubble {
  bottom: 34px;
}
