@charset "utf-8";

/*================================================
  business
================================================*/


/* .page-header::after {
  background-image: url(../../image/business/page_header_img.svg);
  height: 120px;
  bottom: -16px;
} */

.page-header-img {
  height: 120px;
  bottom: -16px;
}

@media print, screen and (min-width: 769px) {
  .page-header-img {
    height: 180px;
  }
}


@media print, screen and (min-width: 1200px) {
  .page-header-img {
    height: 222px;
    width: 228.5px;
    bottom: -18px;
  }
}

/*------------------------------------------------
  intro
------------------------------------------------*/

.intro-title {
  font-size: clamp(1.6rem, 1.08rem + 2.6vw, 4.2rem);
  font-weight: 900;
  margin-bottom: 1.5em;
  line-height: 1.75;
  text-align: center;
}

.intro-text {
  font-size: clamp(1.4rem, 1.28rem + 0.6vw, 2rem);
  font-weight: 700;
  line-height: 2.25;
}

@media print, screen and (min-width: 769px) {
  .intro-text {
    text-align: center;
  }
}


/*link*/

.business-link {
  margin: 0 auto;
  padding-top: calc(var(--layout-gap)*1.5);
  display: grid;
  grid-template-columns: 1fr;
  gap: calc(var(--layout-gap)*1.5);
}

.business-link-item {
  display: block;
  position: relative;
  padding:calc(var(--layout-gap)* 1.25) calc(var(--layout-gap) / 1.25) calc(var(--layout-gap) / 1.25);
  border: 5px solid var(--secondary-color);
  border-radius: 30px;
  background-color: var(--color-white);
  transition: background-color .3s ease-in-out;
}

.business-link-item::after {
  content: "";
  display: block;
  border-width: 2em 3em;
  border-style: solid;
  border-color: var(--secondary-color) transparent transparent transparent;
  position: absolute;
  bottom: -4em;
  left: 50%;
  transform: translateX(-50%);
}

.business-link-item:hover {
  background-color: var(--secondary-color);
  opacity: 1;
  transition: background-color .3s ease-in-out;
}
.business-link-label {
  color: var(--color-white);
  font-size: clamp(1.6rem, 1.44rem + 0.8vw, 2.4rem);
  font-weight: 900;
  line-height: 1;
  position: absolute;
  top: -1.25em;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--color-dark-gray);
  padding: 0.5em 1.5em;
  white-space: nowrap;
}
.business-link-img {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-evenly;
}
.business-link-img > span.bg-gray {
  max-width: calc(100% / 2.5);
  display: block;
  background-color: var(--color-gray);
  border-radius: 50%;
}
.business-link-img > span.bg-white {
  max-width: calc(100%/5);
  display: block;
}

@media print, screen and (min-width: 560px) {
  .business-link {
    padding-top: calc(var(--layout-gap)*1.75);
    grid-template-columns: 1fr 1fr;
    gap: calc(var(--layout-gap) / 2);
  }
  .business-link-item {
    padding:var(--layout-gap) calc(var(--layout-gap) / 2.5) calc(var(--layout-gap) / 1.5);
  }
  .business-link-item::after {
    border-width: 1.5em 1.75em;
    bottom: -3em;
  }
}

@media print, screen and (min-width: 769px) {
  .business-link {
    gap: var(--layout-gap);
    padding-top: calc(var(--layout-gap) *3);
  }
  .business-link-item {
    padding:var(--layout-gap) calc(var(--layout-gap) / 1.25) calc(var(--layout-gap) / 1.25);
  }
}

@media print, screen and (min-width: 1200px) {
  .business-link {
    gap: calc(var(--layout-gap) * 2);
  }
  .business-link-item {
    padding:calc(var(--layout-gap) * 2) calc(var(--layout-gap) * 1.25) calc(var(--layout-gap) * 1.75);
    border: 10px solid var(--secondary-color);
  }
  .business-link-item::after {
    border-width: 2em 3em;
    bottom: -4em;
  }
}



/*------------------------------------------------
  business-item
------------------------------------------------*/
#maintenance {
  background-color: #F6F6F6;
  position: relative;
}
#maintenance::after {
  content: "";
  display: block;
  width: 100px;
  height: 90px;
  background-image: url(../../image/business/maintenance_bottom_img.svg);
  background-size: contain;
  background-position: center bottom;
  position: absolute;
  bottom: 0;
  right: 5%;
}

@media print, screen and (min-width: 769px) {
  #maintenance::after {
    width: 160px;
    height: 140px;
  }
}


@media print, screen and (min-width: 1600px) {
  #maintenance::after {
    width: 200px;
    height: 163px;
    right: calc(50% - 780px);
  }
}

#accommodation {
  background-color: rgba(var(--secondary-color-rgb),0.15);
  border-top:1px dashed var(--point-color);
}

/*-----business-item-head-----*/

.business-item-head {
  padding-bottom: calc(var(--layout-gap)*1.5);
}

.business-item-head-img {
  margin: auto;
}

/*機械整備*/
#maintenance .business-item-head-img {
  width: 50%;
  max-width: 400px;
}
#maintenance .business-item-head-text p {
  font-size: clamp(1.6rem, 1.44rem + 0.8vw, 2.4rem);
  font-weight: 700;
  margin-bottom: 1em;
}

/*宿泊*/
#accommodation .business-item-head-img {
  width: 100%;
}
#accommodation .business-item-head-text p {
  font-size: clamp(1.4rem, 1.32rem + 0.4vw, 1.8rem);
  margin: 1em 0;
}
#accommodation .business-item-head-text p > span.emphasis {
  font-size: clamp(1.8rem, 1.52rem + 1.4vw, 3.2rem);
  font-weight: 900;
  line-height: 1;
  display: block;
  margin-bottom: 1em;
}


@media print, screen and (min-width: 769px) {
  #maintenance .business-item-head,
  #accommodation .business-item-head  {
    display: flex;
    flex-wrap: wrap;
    align-items: self-start;
    justify-content:flex-start;
  }
  #maintenance .business-item-head-text {
    width: 50%;
  }
  #maintenance .business-item-head-img {
    width: 40%;
  }
}


@media print, screen and (min-width: 960px) {
  #maintenance .business-item-head-text {
    width: calc(100% - 290px);
  }
  #maintenance .business-item-head-img {
    width: 250px;
  }
  #accommodation .business-item-head-img {
    width: 250px;
    height: 250px;
    border-radius: 50%;
    overflow: hidden;
    display: flex;
    justify-content: center;
  }
  #accommodation .business-item-head-img > img {
    height: 100%;
    width: auto;
  }
}

@media print, screen and (min-width: 1200px) {
  #maintenance .business-item-head-text,
  #accommodation .business-item-head-text {
    width: calc(100% - 440px);
  }
  #maintenance .business-item-head-img,
  #accommodation .business-item-head-img {
    width: 400px;
    height: 400px;
  }
}




/*-----business-item-body------*/
.business-item-body {
  border-top: 1px dashed var(--color-dark-gray);
  padding-top: calc(var(--layout-gap)/1.5);
}

.business-detail-list {
  margin: calc(var(--layout-gap)/1.5) auto 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: calc(var(--layout-gap)*1.5);
}

.business-detail-label {
  color: var(--color-white);
  display: inline-block;
  background-color: var(--point-color);
  font-size: clamp(1.4rem, 1.36rem + 0.2vw, 1.6rem);
  font-weight: 700;
  line-height: 1;
  padding: 0.75em 1.25em;
  border-radius: 3em;
}
.business-detail-title {
  font-size: clamp(1.6rem, 1.44rem + 0.8vw, 2.4rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0.5em 0 1.25em;
}
.business-detail-img {
  border-radius: 25px;
  overflow: hidden;
}
.business-detail-item > p {
  font-size: clamp(1.2rem, 1.08rem + 0.6vw, 1.8rem);
  margin-top: 1.25em;
}

@media print, screen and (min-width: 769px) {
  .business-detail-title {
    font-size: clamp(1.2rem, 0.3983rem + 1.6681vw, 2.4rem);
  }
  .business-detail-list {
    grid-template-columns: 1fr 1fr;
    gap: calc(var(--layout-gap) * 1.25);
  }
}

@media print, screen and (min-width: 1200px) {
  .business-item-body {
    padding-top: var(--layout-gap);
  }
  .business-detail-list {
    gap: calc(var(--layout-gap) * 1.5);
  }
}

@media print, screen and (min-width: 1600px) {
  .business-detail-list {
    gap: calc(var(--layout-gap) * 2.5);
  }
}
