@charset "UTF-8";
* {
  box-sizing: border-box;
}

body {
  font-family: "Noto sans JP", san-serif;
  background-color: #f4f5f7;
  color: #333333;
}

html,
body {
  height: 100%;
  margin: 0;
}

body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.largeFrame {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

main {
  flex: 1;
}

header {
  position: fixed;
  width: 100vw;
  height: 80px;
  background-color: rgba(244, 245, 247, 0.6);
  z-index: 100;
  border-bottom: solid 1px rgba(200, 200, 200, 0.3);
  padding: 0px min(3.333vw, 40px) 0px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 767px) {
  header {
    height: 50px;
  }
}
header a img {
  height: min(3.472vw, 50px);
}
@media screen and (max-width: 767px) {
  header a img {
    height: 45px;
  }
}
header nav ul {
  display: flex;
  align-items: center;
}
header nav ul li {
  width: min(10.417vw, 100px);
  position: relative;
}
header nav ul li.hasChild:hover ul {
  visibility: visible;
  opacity: 1;
}
header nav ul li a,
header nav ul li p {
  width: 100%;
  display: block;
  height: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
}
header nav ul li a:hover,
header nav ul li p:hover {
  background-color: rgba(233, 235, 239, 0.8);
}
header nav ul li ul {
  display: block;
  position: absolute;
  background-color: rgba(233, 235, 239, 0.8);
  visibility: hidden;
  opacity: 0;
  transition: all 0.3s;
}
header nav ul li ul li a {
  height: 50px;
}
header nav ul li ul li a:hover {
  background-color: rgba(204, 204, 204, 0.7);
}

@media screen and (max-width: 767px) {
  .hamburgerMenuButton {
    display: block;
    width: 40px;
    height: 40px;
    background-color: rgba(40, 40, 40, 0.5);
    border-radius: 2px;
    z-index: 1000;
    position: fixed;
    right: 4px;
  }
}
.hamburgerMenuButton span {
  display: inline-block;
  transition: all 0.4s;
  /*アニメーションの設定*/
  position: absolute;
  left: 11px;
  height: 3px;
  border-radius: 2px;
  background: #fff;
  width: 45%;
}
.hamburgerMenuButton span:nth-of-type(1) {
  top: 12px;
}
.hamburgerMenuButton span:nth-of-type(2) {
  top: 18px;
}
.hamburgerMenuButton span:nth-of-type(3) {
  top: 24px;
}

.hamburgerMenuButton.active span:nth-of-type(1) {
  top: 14px;
  left: 14px;
  transform: translateY(5px) rotate(-45deg);
  width: 30%;
}
.hamburgerMenuButton.active span:nth-of-type(2) {
  opacity: 0;
}
.hamburgerMenuButton.active span:nth-of-type(3) {
  top: 24px;
  left: 14px;
  transform: translateY(-5px) rotate(45deg);
  width: 30%;
}

.hamburgerMenu {
  display: none;
}

@media screen and (max-width: 767px) {
  .hamburgerMenu.active {
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(220, 220, 220, 0.9);
    width: 100vw;
    height: 100vh;
    z-index: 900;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .hamburgerMenu.active table {
    display: grid;
    grid-template-columns: 120px auto;
    grid-template-rows: repeat(10, auto);
    width: calc(100% - 23px);
    border-bottom: solid 1px #999999;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .hamburgerMenu.active table tbody,
  .hamburgerMenu.active table tr {
    display: contents;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .hamburgerMenu.active table tbody th,
  .hamburgerMenu.active table tbody td,
  .hamburgerMenu.active table tr th,
  .hamburgerMenu.active table tr td {
    display: block;
    padding: 15px 10px 15px 0px;
    border-top: solid 1px #999999;
  }
  .hamburgerMenu.active table tbody th[colspan="2"],
  .hamburgerMenu.active table tbody td[colspan="2"],
  .hamburgerMenu.active table tr th[colspan="2"],
  .hamburgerMenu.active table tr td[colspan="2"] {
    grid-column: auto/span 2;
  }
  .hamburgerMenu.active table tbody th[colspan="3"],
  .hamburgerMenu.active table tbody td[colspan="3"],
  .hamburgerMenu.active table tr th[colspan="3"],
  .hamburgerMenu.active table tr td[colspan="3"] {
    grid-column: auto/span 3;
  }
  .hamburgerMenu.active table tbody th[rowspan="2"],
  .hamburgerMenu.active table tbody td[rowspan="2"],
  .hamburgerMenu.active table tr th[rowspan="2"],
  .hamburgerMenu.active table tr td[rowspan="2"] {
    grid-row: auto/span 2;
  }
  .hamburgerMenu.active table tbody th[rowspan="3"],
  .hamburgerMenu.active table tbody td[rowspan="3"],
  .hamburgerMenu.active table tr th[rowspan="3"],
  .hamburgerMenu.active table tr td[rowspan="3"] {
    grid-row: auto/span 3;
  }
  .hamburgerMenu.active table tbody th[rowspan="4"],
  .hamburgerMenu.active table tbody td[rowspan="4"],
  .hamburgerMenu.active table tr th[rowspan="4"],
  .hamburgerMenu.active table tr td[rowspan="4"] {
    grid-row: auto/span 4;
  }
  .hamburgerMenu.active table tbody th[rowspan="8"],
  .hamburgerMenu.active table tbody td[rowspan="8"],
  .hamburgerMenu.active table tr th[rowspan="8"],
  .hamburgerMenu.active table tr td[rowspan="8"] {
    grid-row: auto/span 8;
  }
}
@media screen and (max-width: 767px) {
  .hamburgerMenu.active .contactButton {
    width: calc(100% - 23px);
    padding: 15px 0px;
    background-color: #e60012;
    margin-top: 20px;
    border-radius: 2px;
    display: flex;
    justify-content: center;
  }
}

footer {
  width: 100%;
  height: min(160px, 13.333vw);
  border-top: 1px solid #e1e1e7;
}
@media screen and (max-width: 767px) {
  footer {
    height: auto;
  }
}
footer .container {
  height: min(112px, 9.333vw);
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #f9f9f9;
}
@media screen and (max-width: 767px) {
  footer .container {
    height: auto;
    flex-direction: column;
    padding: 20px 28px;
  }
}
@media screen and (max-width: 767px) {
  footer .container .branchWrapper {
    margin: 20px 0px;
  }
}
footer .container .branchWrapper .address {
  width: min(65vw, 780px);
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  footer .container .branchWrapper .address {
    width: auto;
    margin: 10px 0px;
    flex-direction: column;
    align-items: start;
  }
}
@media screen and (min-width: 768px) {
  footer .container .branchWrapper .address p {
    font-size: min(1.083vw, 13px);
    line-height: min(1.833vw, 22px);
  }
}
footer .container .branchWrapper .address .branch {
  margin-right: 20px;
}
@media screen and (max-width: 767px) {
  footer .container .branchWrapper .address .branch {
    width: auto;
    margin: 0;
  }
}
footer .container .branchWrapper .address:first-child {
  margin-bottom: 4px;
}
footer .footerFbLogo {
  width: min(18.114vw, 217.373px);
  margin-right: min(50px, 4.167vw);
}
@media screen and (max-width: 767px) {
  footer .footerFbLogo {
    width: 290px;
    margin: 0px;
  }
}
footer .segWrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
}
footer .segWrapper .footerSegLogo {
  width: min(10vw, 120px);
}
@media screen and (max-width: 767px) {
  footer .segWrapper .footerSegLogo {
    width: 100px;
  }
}
footer .copyright {
  height: min(48px, 4vw);
  border-top: solid 2px #e60012;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #e1e1e7;
}
@media screen and (max-width: 767px) {
  footer .copyright {
    height: 50px;
  }
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
th,
td {
  text-box-trim: trim-both;
  text-box-edge: text;
}

.fontSize10px {
  font-size: min(1vw, 10px);
}

.fontSize12px {
  font-size: min(1.2vw, 12px);
}

.fontSize13px {
  font-size: min(1.3vw, 13px);
}

.fontSize14px {
  font-size: min(1.4vw, 14px);
}

.fontSize15px {
  font-size: min(1.5vw, 15px);
}

.fontSize16px {
  font-size: min(1.6vw, 16px);
}

.fontSize18px {
  font-size: min(1.8vw, 18px);
}

.fontSize20px {
  font-size: min(2vw, 20px);
}

.fontSize24px {
  font-size: min(2.4vw, 24px);
}

.fontSize28px {
  font-size: min(2.8vw, 28px);
}

.fontSize32px {
  font-size: min(3.2vw, 32px);
}

.fontSize36px {
  font-size: min(3.6vw, 36px);
}

.fontSize40px {
  font-size: min(4vw, 40px);
}

/*＝＝＝＝＝＝＝＝　　SP　　＝＝＝＝＝＝＝＝*/
@media screen and (max-width: 767px) {
  .SP_fontSize10px {
    font-size: max(2.66vw, 10px);
  }
  .SP_fontSize11px {
    font-size: max(2.926vw, 11px);
  }
  .SP_fontSize12px {
    font-size: max(3.191vw, 12px);
  }
  .SP_fontSize13px {
    font-size: max(3.457vw, 13px);
  }
  .SP_fontSize14px {
    font-size: max(3.723vw, 14px);
  }
  .SP_fontSize16px {
    font-size: max(4.255vw, 16px);
  }
  .SP_fontSize18px {
    font-size: max(4.787vw, 18px);
  }
  .SP_fontSize20px {
    font-size: max(5.319vw, 20px);
  }
  .SP_fontSize24px {
    font-size: max(6.383vw, 24px);
  }
  .SP_fontSize30px {
    font-size: max(7.979vw, 30px);
  }
}
.lineHeight16px {
  line-height: min(1.6vw, 16px);
}

.lineHeight20px {
  line-height: min(2vw, 20px);
}

.lineHeight24px {
  line-height: min(2.4vw, 24px);
}

.lineHeight32px {
  line-height: min(3.2vw, 32px);
}

.lineHeight40px {
  line-height: min(4vw, 40px);
}

.lineHeight48px {
  line-height: min(4.8vw, 48px);
}

/*＝＝＝＝＝＝＝＝　　SP　　＝＝＝＝＝＝＝＝*/
@media screen and (max-width: 767px) {
  .SP_lineHeight16px {
    line-height: max(4.255vw, 16px);
  }
  .SP_lineHeight20px {
    line-height: max(5.319vw, 20px);
  }
  .SP_lineHeight24px {
    line-height: max(6.383vw, 24px);
  }
  .SP_lineHeight28px {
    line-height: max(7.447vw, 28px);
  }
  .SP_lineHeight32px {
    line-height: max(8.511vw, 32px);
  }
  .SP_lineHeight36px {
    line-height: max(9.574vw, 36px);
  }
}
.fontWeightExtraLight {
  font-weight: 200;
}

.fontWeightLight {
  font-weight: 300;
}

.fontWeightRegular {
  font-weight: 400;
}

.fontWeightMedium {
  font-weight: 500;
}

.fontWeightSemiBold {
  font-weight: 600;
}

.fontWeightBold {
  font-weight: 700;
}

.fontWeightExtraBold {
  font-weight: 800;
}

.fontWeightBlack {
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .SP_fontWeightLight {
    font-weight: 300;
  }
  .SP_fontWeightRegular {
    font-weight: 400;
  }
  .SP_fontWeightMedium {
    font-weight: 500;
  }
  .SP_fontWeightSemiBold {
    font-weight: 600;
  }
  .SP_fontWeightBold {
    font-weight: 700;
  }
  .SP_fontWeightExtraBold {
    font-weight: 800;
  }
  .SP_fontWeightBlack {
    font-weight: 900;
  }
}
.letterSpace0 {
  letter-spacing: 0em;
}

.letterSpace100 {
  letter-spacing: 0.1em;
}

.letterSpace200 {
  letter-spacing: 0.2em;
}

.letterSpace250 {
  letter-spacing: 0.25em;
}

.letterSpace500 {
  letter-spacing: 0.5em;
}

/*＝＝＝＝＝＝＝＝　　SP　　＝＝＝＝＝＝＝＝*/
@media screen and (max-width: 767px) {
  .SP_letterSpace150 {
    letter-spacing: 0.15em;
  }
}
.fontColorBlue {
  color: #3d62ad;
}

.fontColorBlueGrey {
  color: #0081a4;
}

.fontColorGreen {
  color: #579055;
}

.fontColorGrey {
  color: #666666;
}

.fontColorMagenta {
  color: #db007a;
}

.fontColorOrange {
  color: #ff8534;
}

.fontColorPink {
  color: #cd7e9a;
}

.fontColorDarkPink {
  color: #c80852;
}

.fontColorPurple {
  color: #7e4a7b;
}

.fontColorRedPurple {
  color: #b70868;
}

.fontColorRed {
  color: #e60012;
}

.fontColorCautionRed {
  color: #ff0000;
}

.fontColorWhite {
  color: #ffffff;
}

/*＝＝＝＝＝＝＝＝　　SP　　＝＝＝＝＝＝＝＝*/
@media screen and (max-width: 767px) {
  .SP_fontColorBlack {
    color: #333333;
  }
}
.baseLine1PxUp {
  vertical-align: 1px;
}

.textShadow {
  text-shadow: 0px 0px 4px #333333;
}

.textCenter {
  text-align: center;
}

.textJust {
  text-align: justify;
}

.textRight {
  text-align: end;
}

/*＝＝＝＝＝＝＝＝　　SP　　＝＝＝＝＝＝＝＝*/
@media screen and (max-width: 767px) {
  .SP_textLeft {
    text-align: left;
  }
  .SP_textCenter {
    text-align: center;
  }
  .SP_textRight {
    text-align: right;
  }
  .SP_textJust {
    text-align: justify;
  }
}
.PcON {
  display: block;
}

@media screen and (max-width: 767px) {
  .PcON {
    display: none;
  }
}
.PcONtext {
  display: inline;
}

@media screen and (max-width: 767px) {
  .PcONtext {
    display: none;
  }
}
.SpON {
  display: none;
}

@media screen and (max-width: 767px) {
  .SpON {
    display: block;
  }
}
.SpONtext {
  display: none;
}

@media screen and (max-width: 767px) {
  .SpONtext {
    display: inline;
  }
}/*# sourceMappingURL=common.css.map */