@charset "UTF-8";

/*=============================================
******************* key  **********************
*=============================================*/

#head-key .key {
  margin: 0 -9%;
}
#head-key .key-ttl {
  text-align: center;
  margin-left: 4vw;
}
#head-key .key-ttl .block {
  display: block;
}

/*=============================================
******************* rss  **********************
*=============================================*/
#rss {
  width: 92vw;
  margin: -19vw auto 16.5vw;
  text-align: center;
  padding: 19vw 0 15vw;
}
#rss h2 {
  line-height: 1;
  letter-spacing: 4px;
  font-size: 6vw;
  margin-bottom: 2vw;
}
#rss #feed .row {
  gap: 2vw;
  width: 42vw;
  margin: 0 auto;
}
#rss #feed .row .photo {
  width: 100%;
  height: 26vw;
  border-bottom: 1px solid #dfdfdf;
  border-top: 1px solid #dfdfdf;
  padding: 2vw 0;
}
#rss #feed .row .photo span {
  width: 100% !important;
  height: 100% !important;
}
#rss #feed .row dl {
  font-family: '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'メイリオ', Meiryo, 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
}
#rss #feed .row dl dt {
  font-size: 12px;
}
#rss #feed .row dl dd {
  font-size: 13px;
  line-height: 21px;
}
#rss .btn-cus {
  margin-top: 4.2vw;
}

/*=============================================
******************* sec1  **********************
*=============================================*/
#sec1 {
  padding: 8vw 0;
}
#sec1 .sec1-js {
  line-height: 1;
}
#sec1 .sec1-js p {
  height: 100vw;
}
#sec1 .sec1-js p img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#sec1 .content {
  margin-top: 12vw;
  text-align: center;
}
#sec1 .content h2 {
  margin-left: 3vw;
}
#sec1 .content .txt {
  margin: 8vw 9.5vw 12.5vw;
  padding-bottom: 29px;
}
#sec1 .content .txt span {
  display: block;
}
#sec1 .sp-slide {
  line-height: 1;
}

/*=============================================
******************* sec2  **********************
*=============================================*/
#sec2 {
  background: url(../img/index/sec2_bg.jpg) no-repeat center top;
  background-size: auto 73vw;
  padding-top: 73vw;
}

/*=============================================
******************* sec4  **********************
*=============================================*/
#sec4 {
  padding: 13px 0 10px;
  position: relative;
}
#sec4:before,
#sec4:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 7px;
  background: url(../img/index/sec4_line.png) repeat-x center top;
  background-size: auto 100%;
}
#sec4:after {
  top: auto;
  bottom: 0;
}
#sec4 .inner {
  background: var(--red);
  color: #fff;
  text-align: center;
  position: relative;
}
#sec4 .inner:before {
  content: '';
  position: absolute;
  top: 5px;
  left: 4px;
  bottom: 6px;
  right: 4px;
  background: url(../img/index/frame_tl.png) top left, url(../img/index/frame_tr.png) top right, url(../img/index/frame_bl.png) bottom left, url(../img/index/frame_br.png) bottom right;
  background-repeat: no-repeat;
  background-size: 13px;
  z-index: 2;
}
#sec4 .inner .frame {
  position: relative;
}
#sec4 .inner .frame::before {
  content: '';
  position: absolute;
  top: 9px;
  left: 17px;
  bottom: 10px;
  right: 17px;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  z-index: 3;
}
#sec4 .inner .frame:after {
  content: '';
  position: absolute;
  top: 9px;
  left: 8px;
  bottom: 10px;
  right: 9px;
  border-right: 1px solid #fff;
  border-left: 1px solid #fff;
  z-index: 3;
}
#sec4 .inner .frame a {
  display: block;
  text-decoration: none;
}
#sec4 .inner .banner {
  display: block;
  padding: 10vw 0 18vw;
  text-decoration: none;
  position: relative;
}
#sec4 .inner .banner::before {
  content: '';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 11vw;
  background: url(../img/shared/arrow2.png) no-repeat center top;
  width: 8px;
  height: 13px;
  background-size: contain;
}
#sec4 .inner .banner .ttl {
  color: #949494;
}
#sec4 .inner .banner h2 {
  margin-left: 2vw;
  margin-bottom: -1.5vw;
}

/*=============================================
******************* sec5  **********************
*=============================================*/
#sec5 {
  padding: 20vw 0 36vw;
  position: relative;
  z-index: 1;
}
#sec5:before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 44vw;
  background: url(../img/index/sec5_bg.png) no-repeat center top;
  background-size: contain;
  z-index: -1;
}
#sec5 .line {
  position: absolute;
  left: 0;
  width: 40vw;
  background: #000;
  top: 26vw;
}
#sec5 h2 {
  margin-left: 4vw;
  letter-spacing: 4px;
}
#sec5 .row {
  width: 74vw;
  margin: 9.5vw auto 0;
  gap: 11.5vw;
}
#sec5 .row .ttl {
  color: #949494;
}
#sec5 .row h3 {
  margin: -1.5vw 0 3.5vw;
}

/*=============================================
******************* sec6  **********************
*=============================================*/
#sec6 {
  background: url(../img/shared/black_bg.jpg) repeat;
  color: #fff;
  margin-top: -9vw;
  padding-top: 17vw;
  padding-bottom: 20vw;
}
#sec6 .row1 {
  gap: 12vw;
}
#sec6 .row1 h2 {
  text-align: center;
  margin-left: 2vw;
}
#sec6 .row1 h2 span {
  display: block;
}
#sec6 .row1 .ttl {
  text-align: center;
  margin-top: -0.5vw;
}
#sec6 .row2 {
  margin-top: 11vw;
  gap: 11vw;
}
#sec6 .row2 .photos p {
  margin-bottom: 3vw;
}
#sec6 .row2 .content h3 {
  text-align: center;
  margin: 12.5vw 0 5vw 2vw;
  --gap: -1vw;
  letter-spacing: 8px;
}
#sec6 .row2 .content .txt {
  margin: 0 9.5vw;
}

/*=============================================
******************* sec7  **********************
*=============================================*/
#sec7 {
  padding: 31.5vw 0 25vw;
  background: url(../img/index/sec7_bg.png) no-repeat center bottom;
  background-size: 100%;
}
#sec7 h2 {
  text-align: center;
  position: relative;
  --gap: 0.5vw;
  letter-spacing: 3px;
  margin-left: 1vw;
}
#sec7 h2:before {
  content: '';
  position: absolute;
  top: -10vw;
  left: 50%;
  transform: translateX(-50%);
  width: 8vw;
  height: 20vw;
  background: url(../img/index/sec7_deco.png) no-repeat center top;
  background-size: contain;
}
#sec7 .row {
  margin-top: 10vw;
  gap: 19vw;
}
#sec7 .row .logo {
  width: 39vw;
  margin: 0 auto 15vw;
}
#sec7 .row h3 {
  margin-top: 10vw;
  font-size: 16px;
  text-align: center;
}
#sec7 .row .txt {
  text-align: center;
  margin: 3vw 0 0 2vw;
}
#sec7 .row .info {
  font-size: 13.2px;
  line-height: 23.1px;
}
#sec7 .row .info dl {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  margin-bottom: 23.2px;
}
#sec7 .row .info dl dt {
  min-width: 33vw;
  box-sizing: border-box;
  padding-left: 9vw;
}
#sec7 .row .info dl dt.mt {
  margin-top: -23px;
}
#sec7 .row .info dl dd {
  text-wrap: wrap;
}

/*=============================================
******************* gmap  **********************
*=============================================*/
#gmap .g-map {
  box-sizing: border-box;
  border-bottom: 1px solid #777777;
}
#gmap .g-map iframe {
  filter: grayscale(1);
  width: 100%;
  margin-bottom: -9px;
  height: 324px;
}

/*=============================================
******************* PC  **********************
*=============================================*/
@media screen and (min-width: 768px) {
  main {
    overflow: visible;
  }

  section > div {
    overflow: hidden;
  }

  /*=============================================
  ******************* key  **********************
  *=============================================*/

  #head-key .key {
    margin: 258px auto -251px;
    text-align: center;
  }
  #head-key .key-ttl {
    text-align: left;
    position: absolute;
    bottom: 435px;
    right: calc(50% - 475px);
    margin-left: 0;
    width: 140px;
    height: 342px;
  }
  #head-key .key-ttl .block {
    margin-top: 114px;
    position: relative;
  }
  #head-key .key-ttl .block:after {
    content: '';
    position: absolute;
    top: calc(100% + 14px);
    left: 48%;
    background: url(../img/index/key_deco.png) no-repeat center top;
    width: 1px;
    height: 100px;
    background-size: contain;
  }

  /*=============================================
  ******************* #rss  **********************
  *=============================================*/
  #rss {
    position: absolute;
    left: 0;
    width: 273px;
    top: 402px;
    margin: 0;
    box-sizing: border-box;
    padding: 42px 41px 43px;
    text-align: left;
  }
  #rss h2 {
    font-size: 28px;
    margin-left: -2px;
    letter-spacing: 5px;
    margin-bottom: 8px;
  }
  #rss #feed .row {
    flex-direction: column;
    width: 100%;
    gap: 10px;
  }
  #rss #feed .row .photo {
    padding: 7px 0 8px;
    height: 120px;
  }
  #rss #feed .row .photo:hover {
    opacity: 0.8;
  }
  #rss #feed .row dl dt {
    font-size: 14px;
  }
  #rss #feed .row dl dd {
    font-size: 16px;
    line-height: 25px;
    overflow: hidden;
    text-overflow: ellipsis;
    height: 50px;
  }
  #rss .btn-cus {
    width: auto;
    position: absolute;
    top: 43px;
    right: 59px;
    margin-top: 0;
  }
  #rss .btn-cus a {
    border: none;
    font-family: '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'メイリオ', Meiryo, 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
    font-size: 16px;
    text-transform: lowercase;
    color: #000;
    background: transparent;
  }
  #rss .btn-cus a:before {
    right: -14px;
    background: url(../img/shared/arrow2.png) no-repeat center top;
    background-size: 100% 100%;
    filter: invert(1);
    height: 8px;
  }
  #rss .btn-cus a:hover {
    text-decoration: underline;
	  background-color: #fff;
  }
	#rss .btn-cus a:after {
		background: #fff;
	}

  /*=============================================
  ******************* sec1  **********************
  *=============================================*/
  #sec1 {
    padding: 0;
    overflow: visible;
    position: relative;
  }
  #sec1 .sec1-js {
    position: sticky;
    top: 75px;
    margin-bottom: -2px;
  }
  #sec1 .sec1-js p {
    height: calc(100vh - 75px);
  }
  #sec1 .sec1-js .slick-dots {
    display: none !important;
  }
  #sec1 .mask {
    background: rgba(255, 255, 255, 0.8);
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
  #sec1 .content {
    position: relative;
    margin-top: -96px;
    padding: 225px 0 183px;
    z-index: 2;
  }
  #sec1 .content .wrap {
    max-width: 1177px;
  }
  #sec1 .content h2 {
    margin-left: 14px;
  }
  #sec1 .content .txt {
    margin: 55px 0 0 8px;
    padding-bottom: 0;
  }
  #sec1 .content .txt span {
    margin-top: 32px;
  }
  #sec1 .content .photos {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    margin-top: 107px;
    gap: 20px;
    margin-right: -2px;
  }
  #sec1 .content .photos p {
    width: calc(100% / 3);
  }

  /*=============================================
  ******************* sec2  **********************
  *=============================================*/
  #sec2 {
    padding: 0;
    background-size: cover;
  }

  /*=============================================
  ******************* sec4  **********************
  *=============================================*/
  #sec4 {
    padding: 20px 0 21px;
  }
  #sec4:before,
  #sec4::after {
    height: 15px;
  }
  #sec4 .inner:before {
    top: 13px;
    left: 11px;
    bottom: 13px;
    right: 14px;
    background-size: 27px;
  }
  #sec4 .inner .frame:before,
  #sec4 .inner .frame:after {
    border-width: 2px;
  }
  #sec4 .inner .frame:before {
    top: 23px;
    left: 38px;
    bottom: 22px;
    right: 41px;
  }
  #sec4 .inner .frame::after {
    top: 23px;
    left: 18px;
    bottom: 10px;
    right: 23px;
  }
  #sec4 .inner .frame a {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
  }
  #sec4 .inner .frame .photo {
    width: 50%;
    height: 405px;
  }
  #sec4 .inner .frame .photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  #sec4 .inner .frame .banner {
    width: 50%;
    padding: 121px 29px 0 0;
    box-sizing: border-box;
  }
  #sec4 .inner .frame .banner:before {
    bottom: 112px;
    margin-left: -19px;
  }
  #sec4 .inner .frame .banner h2 {
    margin-left: 0;
  }
  #sec4 .inner .frame .banner .ttl {
    margin: 25px 0 0 -8px;
  }

  /*=============================================
  ******************* sec5  **********************
  *=============================================*/
  #sec5 {
    padding: 126px 0 306px;
  }
  #sec5:before {
    height: 654px;
    background-position: bottom;
  }
  #sec5 h2 {
    margin-left: 72px;
    letter-spacing: 5px;
  }
  #sec5 .line {
    width: calc(50% - 277px);
    top: 154px;
  }
  #sec5 .row {
    flex-direction: row-reverse;
    margin-top: 50px;
    width: 805px;
    gap: 0;
    justify-content: space-between;
  }
  #sec5 .row h3 {
    margin: -11px 0 15px -2px;
  }
  #sec5 .row .photo {
    margin: 11px -46px 0 0;
  }

  /*=============================================
  ******************* sec6  **********************
  *=============================================*/
  #sec6 {
    padding: 261px 0 146px;
    margin-top: -140px;
  }
  #sec6 .row1 {
    justify-content: end;
  }
  #sec6 .row1 .photo {
    position: absolute;
    right: calc(50% - 250px);
    left: calc(50% - 50vw);
    height: 600px;
  }
  #sec6 .row1 .photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  #sec6 .row1 h2 {
    margin: 59px 37px 0px 0;
    text-align: left;
    width: 140px;
    height: 342px;
    position: relative;
  }
  #sec6 .row1 h2:before {
    content: '';
    position: absolute;
    bottom: 59px;
    right: -55px;
    width: 263px;
    height: 1px;
    background: #fff;
    transform: rotate(-38deg);
    transform-origin: top right;
  }
  #sec6 .row1 h2 .block {
    margin-top: 76px;
  }
  #sec6 .row1 .ttl {
    text-align: right;
    margin-right: 26px;
    margin-top: 36px;
  }
  #sec6 .row2 {
    flex-direction: row-reverse;
    justify-content: space-between;
    margin-top: 221px;
    gap: 20px;
  }
  #sec6 .row2 .photos {
    margin: -34px -113px 0 0;
  }
  #sec6 .row2 .photos p {
    margin-bottom: 22px;
  }
  #sec6 .row2 .content {
    width: 491px;
    margin-left: -2px;
  }
  #sec6 .row2 .content h3 {
    text-align: left;
    margin: 54px 0 27px -1px;
    letter-spacing: 8.5px;
  }
  #sec6 .row2 .content .txt {
    margin: 0;
  }

  /*=============================================
  ******************* sec7  **********************
  *=============================================*/
  #sec7 {
    padding: 174px 0 262px;
  }
  #sec7 h2 {
    margin-left: 7px;
    letter-spacing: 5px;
  }
  #sec7 h2:before {
    width: 36px;
    height: 36px;
    top: -46px;
    margin-left: -4px;
  }
  #sec7 .row {
    margin-top: 80px;
    gap: 0px;
    justify-content: end;
  }
  #sec7 .row .logo {
    width: 194px;
  }
  #sec7 .row .left {
    width: 50%;
  }
  #sec7 .row .left .logo {
    width: 197px;
    padding-right: 12px;
    margin-bottom: 39px;
  }
  #sec7 .row .left .tel dl {
    line-height: 40px;
  }
  #sec7 .row .left .tel dl dt {
    margin-left: 10px;
  }
  #sec7 .row .left .tel p {
    margin: -2px 0 0 18px;
  }
  #sec7 .row .left h3 {
    margin-top: 51px;
    font-size: 20px;
    letter-spacing: 0.03em;
    margin-left: 5px;
  }
  #sec7 .row .left .txt {
    margin: 14px 0 0 10px;
  }
  #sec7 .row .info {
    font-size: 16px;
    line-height: 28px;
    margin-top: -6px;
    margin-right: -3px;
    letter-spacing: 0.11em;
    width: 50%;
    padding-left: 16px;
    box-sizing: border-box;
  }
  #sec7 .row .info dl {
    margin-bottom: 28px;
    gap: 20px;
  }
  #sec7 .row .info dl dt {
    min-width: 87px;
    padding-left: 0;
  }
  #sec7 .row .info dl dt.mt {
    margin-top: 0;
  }
  #sec7 .row .info dl dd {
    margin-right: -30px;
  }

  /*=============================================
  ******************* gmap  **********************
  *=============================================*/
  #gmap {
    position: relative;
  }
  #gmap .g-map {
    border-width: 2px;
  }
  #gmap .g-map iframe {
    height: 650px;
  }
  #gmap .g-btn {
    width: 541px;
    position: absolute;
    z-index: 2;
    bottom: 2px;
    right: 0;
    background: rgba(0, 0, 0, 0.8);
    display: flex;
    color: #fff;
    padding: 33px 0 33px 54px;
    align-items: end;
    box-sizing: border-box;
    gap: 24px;
  }
  #gmap .g-btn .btn-cus {
    margin: 0;
  }
  #gmap .g-btn .btn-cus a {
    padding-right: 24px;
  }
  #gmap .g-btn .btn2 {
    letter-spacing: 3px;
  }
  #gmap .g-btn .btn2 a {
    text-decoration: none !important;
    border-bottom: 2px solid #aaaaaa;
    padding-bottom: 3px;
  }
  #gmap .g-btn .btn2 a:hover {
    border-color: transparent;
  }
}
@media (min-width: 768px) and (max-width: 1100px) {
  #sec6 {
    margin-top: -103px;
  }
}
@media screen and (min-width: 1501px) {
  #sec5:before {
    background-size: 100%;
    height: 100%;
  }
  #sec6 {
    margin-top: -190px;
  }
}

/*# sourceMappingURL=index.css.map */
