header {
  width: 100%;
  z-index: 10;
  top: 0;
  position: absolute;
  transition: background 0.3s ease, padding 0.3s ease, border-bottom 0.3s ease;
  background: #fff;
}

.header_wrap {
  margin-top: 30px;
  max-width: 1800px;
  min-width: 1000px;
  margin: 0 auto 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 10px 2%;
}
header a.logo {
  width: 140px;
  margin: auto;
  display: block;
  padding: 30px 0;
}
header a.tel {
  font-size: 3.2rem;
}
header.scrolled img.logo {
  width: 140px;
  margin: 0 auto 10px;
}
header .menu {
  width: calc(100% - 280px);
  margin-left: 40px;
  display: flex;
  flex-wrap: wrap;
}
header .menu .time_wrap {
  width: 100%;
  margin-bottom: 1rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: end;
}
header .menu .time_wrap ul {
  width: 350px;
  display: flex;
  flex-wrap: wrap;
  padding: 5px 4px;
  gap: 10px;
  border: 1px solid var(--sub-brand-color);
}
header .menu .time_wrap ul li {
  width: calc((100% - 10px) / 2);
  text-align: left;
  font-size: 1.2rem;
}
header .menu .time_wrap .contact {
  width: 100%;
  background-color: var(--sub-brand-color);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  margin-bottom: 10px;
}

header .menu .time_wrap .contact.line {
  background-color: #82b64a;
}

header .menu .time_wrap .contact a {
  color: #fff;
  padding: 1rem 4rem;
  font-weight: 700;
  font-size: 15px;
}
header .menu ul.header_menu {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 3rem;
  align-items: center;
  text-align: center;
  justify-content: right;
  padding-right: 4%;
  padding-bottom: 12px;
}

header ul.header_menu li {
  text-align: center;
}

header ul.header_menu li:last-child {
  border: none;
  padding-right: 0;
}
header ul.header_menu li a {
  color: #000;
  font-weight: 500;
  font-size: 1.6rem;
}

header img.instagram {
  width: 20px;
}

.header_sp {
  display: none;
}

/* 追加css */

.contact_box {
  padding: 10px;
}

.contact_box .border {
  display: inline-block;
  border: solid 1px var(--sub-brand-color);
  padding: 0px 3px;
  margin: 2px;
  border-radius: 4px;
}

/* 2番目のボックスに左の縦線を追加 */
.contact_box:nth-child(2) {
  border-left: 1px solid #ccc; /* 縦線の色と太さを調整 */
}

.border-link {
  text-decoration: underline;
  color: inherit;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.icon_map {
  width: 16px;
  height: auto;
}

.contact_box_text {
  font-size: 15px;
}

.contact__link {
  display: flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
}

.contact__link .icon_net {
  width: 20px;
  height: auto;
  margin-left: -33px;
}

.contact__link .icon_line_top {
  width: 20px;
  height: auto;
  margin-left: -33px;
}

.icon_net02 {
  width: 16px;
  height: auto;
}

.icon_access {
  width: 16px;
  height: auto;
}
