/* LESS Document */
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUFjIg1_i6t8kCHKm459Wx7xQYXK0vOoz6jq6R9aX8.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUFjIg1_i6t8kCHKm459Wx7xQYXK0vOoz6jq5Z9aX8.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUFjIg1_i6t8kCHKm459Wx7xQYXK0vOoz6jq3p6aX8.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUFjIg1_i6t8kCHKm459Wx7xQYXK0vOoz6jq0N6aX8.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 800;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUFjIg1_i6t8kCHKm459Wx7xQYXK0vOoz6jqyR6aX8.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUFjIg1_i6t8kCHKm459Wx7xQYXK0vOoz6jqw16aX8.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCtr6Ew-.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCtZ6Ew-.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCu170w-.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCuM70w-.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCvr70w-.ttf) format('truetype');
}
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v21/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCvC70w-.ttf) format('truetype');
}
/* -------------------------------- lNav */
.lNav {
  margin: 0 0 70px;
}
@media screen and (max-width: 767px) {
  .lNav {
    margin-bottom: 30px;
  }
}
.lNav ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 960px;
  margin: 0 auto;
}
.lNav ul  > * {
  display: block;
  width: 33%;
}
.lNav ul::before,
.lNav ul::after {
  content: '';
  order: 1;
  display: block;
  width: 33%;
}
.lNav ul li {
  max-width: 300px;
}
.lNav ul li a {
  display: block;
  width: 100%;
  height: 120px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .lNav ul li a {
    height: 20vw;
  }
}
.lNav ul li a::before {
  content: '';
  display: block;
  width: 100%;
  max-width: 300px;
  height: 36px;
  background: #0066B2;
  mix-blend-mode: multiply;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: 0.3s;
}
.lNav ul li a.service_01 {
  background: url("../img/bg_lnav_01.jpg") no-repeat center center;
}
.lNav ul li a.service_02 {
  background: url("../img/bg_lnav_02.jpg") no-repeat center center;
}
.lNav ul li a.service_03 {
  background: url("../img/bg_lnav_03.jpg") no-repeat center center;
}
.lNav ul li a:hover::before,
.lNav ul li a:hover strong {
  height: 120px;
}
@media screen and (max-width: 767px) {
  .lNav ul li a:hover::before,
  .lNav ul li a:hover strong {
    height: 20vw;
  }
}
.lNav ul li a.current {
  pointer-events: none;
  filter: saturate(15%);
}
.lNav ul li a strong {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  width: 100%;
  height: 36px;
  padding: 0 5px 0 10px;
  color: #FFF;
  font-size: 2.4rem;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  box-sizing: border-box;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  .lNav ul li a strong {
    font-size: 4vw;
  }
}
.lNav ul li a i {
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  .lNav ul li a i {
    display: none;
  }
}
/* -------------------------------- index */
.serviceGuide {
  min-height: 760px;
  margin: 0 0 82px;
  padding: 55px 0;
  color: #FFF;
  background: url("../img/bg_service.jpg") no-repeat center center / cover;
}
@media screen and (max-width: 767px) {
  .serviceGuide {
    min-height: 0;
    margin-bottom: 40px;
    padding: 30px 0 40vw;
  }
}
.serviceGuide h3 {
  margin-bottom: 45px;
  padding: 0;
  background: none;
  color: #FFF;
  font-size: 3rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .serviceGuide h3 {
    margin-bottom: 20px;
    font-size: 6vw;
  }
}
.serviceGuide p {
  margin-bottom: 70px;
}
@media screen and (max-width: 767px) {
  .serviceGuide p {
    margin-bottom: 40px;
  }
}
.serviceGuide .btn {
  max-width: 400px;
  font-weight: bold;
}
/* -------------------------------- List */
.serviceList {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.serviceList  > * {
  display: block;
  width: 32%;
}
.serviceList::before,
.serviceList::after {
  content: '';
  order: 1;
  display: block;
  width: 32%;
}
@media screen and (max-width: 767px) {
  .serviceList {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .serviceList  > * {
    display: block;
    width: 100%;
  }
  .serviceList::before,
  .serviceList::after {
    content: '';
    order: 1;
    display: block;
    width: 100%;
  }
}
.serviceList > div {
  max-width: 340px;
}
@media screen and (max-width: 767px) {
  .serviceList > div {
    max-width: none;
    margin-bottom: 20px;
  }
}
.serviceList > div p {
  margin-bottom: 10px;
}
/* -------------------------------- merit */
.omakaseArea .columnBox {
  margin: 0 0 28px;
}
@media screen and (max-width: 767px) {
  .omakaseArea .columnBox {
    margin-bottom: 15px;
  }
}
.omakaseArea .columnBox > div {
  max-width: 344px;
}
@media screen and (max-width: 767px) {
  .omakaseArea .columnBox > div {
    max-width: none;
    margin: 0 0 30px;
  }
}
.omakaseArea .columnBox > div .question {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  width: 100%;
  height: 244px;
  margin: 0 0 36px;
  padding: 5px;
  background: url("../img/bg_merit_01.jpg") no-repeat center center / cover;
  color: #FFF;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 767px) {
  .omakaseArea .columnBox > div .question {
    height: 45vw;
    font-size: 4.8vw;
  }
}
.omakaseArea .columnBox > div .question::after {
  content: '';
  width: 0;
  height: 0;
  margin: auto;
  border-style: solid;
  border-width: 20px 30px 0 30px;
  border-color: #00518E transparent transparent transparent;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -18px;
}
.omakaseArea .columnBox > div dt {
  background: #00518E;
  color: #FFF;
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .omakaseArea .columnBox > div dt {
    font-size: 4vw;
  }
}
.omakaseArea .columnBox > div dd {
  padding: 12px;
  background: rgba(0, 81, 142, 0.09);
}
.omakaseArea .columnBox > div.omakase_1 .question {
  background-image: url("../img/bg_merit_01.jpg");
}
.omakaseArea .columnBox > div.omakase_1 .question::after {
  border-color: #00518E transparent transparent transparent;
}
.omakaseArea .columnBox > div.omakase_1 dt {
  background: #00518E;
}
.omakaseArea .columnBox > div.omakase_1 dd {
  background: rgba(0, 81, 142, 0.09);
}
.omakaseArea .columnBox > div.omakase_2 .question {
  background-image: url("../img/bg_merit_02.jpg");
}
.omakaseArea .columnBox > div.omakase_2 .question::after {
  border-color: #028641 transparent transparent transparent;
}
.omakaseArea .columnBox > div.omakase_2 dt {
  background: #029D4F;
}
.omakaseArea .columnBox > div.omakase_2 dd {
  background: rgba(2, 157, 79, 0.09);
}
.omakaseArea .columnBox > div.omakase_3 .question {
  background-image: url("../img/bg_merit_03.jpg");
}
.omakaseArea .columnBox > div.omakase_3 .question::after {
  border-color: #0086C5 transparent transparent transparent;
}
.omakaseArea .columnBox > div.omakase_3 dt {
  background: #15ABE6;
}
.omakaseArea .columnBox > div.omakase_3 dd {
  background: rgba(21, 171, 230, 0.09);
}
.omakaseArea .columnBox + .box {
  margin: 0 0 90px;
  padding: 35px;
  text-align: center;
  color: #0066B2;
  font-weight: bold;
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .omakaseArea .columnBox + .box {
    margin-bottom: 40px;
    padding: 15px;
    font-size: 4vw;
  }
}
.pointArea h2 {
  margin-bottom: 15px;
  padding: 0;
  text-align: left;
  font-weight: bold;
  font-size: 3.2rem;
  color: #0066B2;
}
@media screen and (max-width: 767px) {
  .pointArea h2 {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: nowrap;
    font-size: 6.4vw;
  }
}
.pointArea h2 img {
  width: 80px;
  margin: 0 28px 0 0;
  vertical-align: -30px;
}
.pointArea h2::before {
  content: none;
}
.pointArea h3 {
  padding: 0;
  margin-bottom: 15px;
  background: none;
  color: #000;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .pointArea h3 {
    font-weight: bold;
  }
}
.pointArea h3 span {
  display: inline-block;
  min-width: 103px;
  margin: 0 14px 0 0;
  padding: 3px 15px;
  background: #0066B3;
  color: #FFF;
  text-align: center;
  border-radius: 100px;
  font-family: 'Montserrat', sans-serif;
  font-size: 2.1rem;
  font-style: italic;
  font-weight: bold;
  vertical-align: -2px;
}
@media screen and (max-width: 767px) {
  .pointArea h3 span {
    margin: 0 0 7px;
    font-size: 4.1vw;
  }
}
.pointArea .point_1 {
  padding: 15px;
  background: rgba(0, 102, 179, 0.05);
}
.pointArea .point_1 h3 span {
  background: #0066B3;
}
.pointArea .point_2 {
  padding: 15px;
  background: rgba(2, 157, 79, 0.05);
}
.pointArea .point_2 h3 span {
  background: #029D4F;
}
.pointArea .point_3 {
  padding: 15px;
  background: rgba(21, 171, 230, 0.05);
}
.pointArea .point_3 h3 span {
  background: #15ABE6;
}
