/*
Theme Name:web
*/
@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,700;1,700&family=Shippori+Mincho:wght@500;700&display=swap');

/* Reset ----- */
html,
body,
p,
ol,
ul,
li,
dl,
dt,
dd,
blockquote,
figure,
fieldset,
legend,
textarea,
pre,
iframe,
hr,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0
}

article,
aside,
footer,
header,
nav,
section,
figcaption,
figure,
main {
  display: block;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal;
}

ul {
  list-style: none;
}

button,
input,
select,
textarea {
  margin: 0;
  background-color: transparent;
  color: inherit;
  font-size: inherit;
  line-height: inherit;
}

button,
input {
  overflow: visible;
  vertical-align: middle;
}

button,
select {
  text-transform: none;
}

input,
button,
select {
  font-family: inherit;
  font-weight: inherit;
}

input[type="submit"],
input[type="button"],
button[type="submit"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type="submit"]:-webkit-search-decoration,
input[type="button"]:-webkit-search-decoration,
button[type="submit"]:-webkit-search-decoration {
  display: none;
}

input[type="submit"]:focus,
input[type="button"]:focus,
button[type="submit"]:focus {
  outline: none;
}

/* IE 10+ ----- */
:-ms-input-placeholder {
  color: #999;
}

html {
  box-sizing: border-box;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  -webkit-text-size-adjust: 100%;
}

*,
*:before,
*:after {
  background-repeat: no-repeat;
  box-sizing: inherit;
}

:before,
:after {
  text-decoration: inherit;
  vertical-align: inherit;
}

img,
embed,
object,
audio,
video {
  height: auto;
  max-width: 100%;
}

img,
iframe {
  border: 0
}

img {
  vertical-align: bottom;
}

svg {
  fill: currentColor;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
  text-align: left;
  font-weight: normal;
}

a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects;
}

/*++++++++++++++++++*/
body {
  font-family: "Shippori Mincho", serif;
  font-size: 16px;
  font-weight: 500;
  font-style: normal;
  background: #f0f0f0;
}

a {
  text-decoration: none;
}

.center {
  text-align: center;
}

.sp-only {
  display: none;
}

.btn {
  position: relative;
  display: inline-block;

  img {
    display: inline-block;
  }

  span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-weight: bold;
    white-space: nowrap;
  }
}

.btn_04 {
  color: #484036;
  font-size: 26px;
  letter-spacing: .25em;
  border: 1px solid #484036;
}

.btn_05 {
  color: #82969C;
  font-size: 19px;
  letter-spacing: .25em;
  border: 1px solid #82969C;

  img {
    width: 100%;
  }
}

.btn_06 {
  color: #fff;
  font-size: 16px;
  letter-spacing: .25em;
  border: 1px solid #fff;
}

.btn_07 {
  color: #000;
  font-size: 21px;
  letter-spacing: .2em;
  border: 1px solid #000;

  span {
    margin-left: 25px;
  }
}

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #484036;
  color: #fff;

  h1 {
    margin-left: 30px;
  }

  .btns {
    padding: 25px;
    display: flex;
    align-items: center;
    gap: 30px;
    background: #EAE3DA;
  }
}

@media (max-width: 1100px) {
  .header {
    .btns {
      padding: 20px 17px;
    }

    .pc-only {
      display: none;
    }

    .sp-only {
      display: block;
    }
  }
}

.mv {
  img {
    height: 930px;
    width: 100%;
    object-fit: cover;
  }
}

@media (max-width: 780px) {
  .mv {
    .pc-only {
      display: none;
    }

    .sp-only {
      display: block;
    }
  }
}

.section_01 {
  padding: 80px 50px;
  background: url(img/bg_01.png) center center / cover no-repeat;

  .inner {
    width: 100%;
    max-width: 1100px;
    margin: auto;
  }

  .btns_list {
    display: flex;
    gap: 40px;
    width: 100%;

    li {
      width: calc((100% - 40px * 3)/4);
    }

    a {
      display: flex;
      justify-content: center;
      align-items: center;
      background: url(img/btn-bg.png) center center / cover no-repeat;
      width: 100%;
      aspect-ratio: 270 / 58;
      color: #000;
      font-size: 20px;
      font-weight: bold;
    }
  }

  .copy {
    margin: 70px 0 45px;
    font-size: 28px;
    color: #fff;
    text-align: center;
  }

  .slider {
    margin-left: 50px;
    margin-right: 50px;

    .slick-slide {
      border-radius: 5px;
      overflow: hidden;
      margin: 0 10px;
    }

    .slick-dots li,
    .slick-dots li button,
    .slick-dots li button:before {
      width: 13px;
      height: 13px;
    }

    .slick-dots li button:before {
      content: "";
      background: #fff;
      opacity: 1;
      border-radius: 100px;
      box-shadow: inset 2px 2px 2px rgba(0, 0, 0, .3);
    }

    .slick-dots li.slick-active button:before {
      opacity: 1;
      background: #82969C;
    }

    .slick-list {
      z-index: 2;
    }

    .slick-prev,
    .slick-next {
      z-index: 1;
      width: 45px;
      height: 45px;
    }

    .slick-prev {
      left: -15px;
    }

    .slick-next {
      right: -15px;
    }

    .slick-prev:before,
    .slick-next:before {
      content: '';
      display: block;
      font-family: 'slick';
      opacity: 1;
      width: 45px;
      height: 45px;
      background: #fff;
      background: url(img/slider_next.png) center center / cover no-repeat;
    }

    .slick-prev:before {
      background: url(img/slider_prev.png) center center / cover no-repeat;
    }


  }

  .slick-dotted.slick-slider {
    padding: 25px 0 40px;
  }

  .center.btn {
    margin-top: 80px;
    display: block;
  }
}

@media (max-width: 780px) {
  .section_01 {
    padding: 60px 40px;

    .btns_list {
      flex-wrap: wrap;
      gap: 30px 22px;

      li {
        width: calc((100% - 30px)/2);
      }
    }

    .slider {
      margin: 32px -40px 0;
    }

    .center.btn {
      margin-top: 60px;
    }
  }

}


.section_02 {
  min-height: 1000px;
  padding: 200px 0;
  background-color: #ECECEC;
  background-image: url(img/bg-p_01.png), url(img/bg-p_02.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: top, bottom;

  .menu1,
  .menu2 {
    margin-bottom: 100px;
    height: 600px;
    width: 100%;

    .inner {
      position: relative;
      display: flex;
      max-width: 1300px;
      padding: 0 50px;
      margin: auto;

      .tate {
        position: absolute;
        display: block;
        font-size: 39px;
        font-weight: bold;
        writing-mode: vertical-rl;
        letter-spacing: .3em;

        span {
          color: #C92E36;
        }
      }
    }
  }

  .menu1 {
    background: url(img/bg_menu1.png) center center / cover no-repeat;

    .inner {
      padding-left: 200px;

      .tate {
        left: 50px;
      }
    }
  }

  .menu2 {
    background: url(img/bg_menu2.png) center center / cover no-repeat;

    .inner {
      flex-direction: row-reverse;
      padding-right: 200px;

      .tate {
        right: 50px;
      }
    }
  }


  .slider_wrap {
    width: 450px;
    margin-top: 80px;

    p {
      margin-top: 0.5em;
      font-weight: bold;
      font-size: 18px;
    }

  }

  .slider_menu01_txt,
  .slider_menu02_txt {
    width: calc(100% - 450px);
    margin-top: 80px;

    h2 {
      padding: 40px 10px 30px 30px;
      font-size: 24px;
      font-weight: bold;
      border-bottom: 1px solid #000;
    }

    p {
      padding: 40px 10px 30px 30px;
      font-size: 18px;
      line-height: 2;

    }
  }

  .slider_menu01_02,
  .slider_menu02_02 {
    .slick-slide {
      filter: brightness(40%);
    }

    .slick-current {
      filter: brightness(100%);
    }
  }

  .menu3 {
    display: flex;
    max-width: 900px;
    margin: 120px auto 0;
    padding: 0 50px;

    >img,
    .txt {
      width: 50%;
    }

    >img {
      object-fit: cover;
    }

    .txt {
      padding: 34px;
      background: url(img/bg-p_04.jpg) center center / cover no-repeat;

      h2 {
        text-align: center;
        font-size: 35px;
        font-weight: bold;
        writing-mode: vertical-rl;
        letter-spacing: .3em;
        margin: auto;
        margin-bottom: 30px;
        border-bottom: 1px solid #82969C;
      }

      p {
        font-size: 16px;
        letter-spacing: .02em;
        line-height: 1.8;
      }

      .btn {
        margin-top: 30px;
      }

    }


    .inner {
      padding-left: 200px;

      .tate {
        left: 50px;
      }
    }
  }

}

@media (max-width: 1100px) {
  .section_02 {

    .menu1,
    .menu2 {
      height: 900px;

      .inner {
        flex-wrap: wrap;
      }
    }

    .slider_menu01_txt,
    .slider_menu02_txt {
      width: 100%;
      margin-top: 30px;
    }
  }
}

@media (max-width: 780px) {
  .section_02 {
    padding: 80px 0;

    .slider_wrap {
      width: 530px;
      margin-top: 60px;
    }

    .menu1 {
      background: url(img/bg_menu_sp.png) no-repeat center right;
      margin-bottom: 60px;

      .inner {
        padding-left: 120px;

        .tate {
          padding-left: 0;
          left: 40px;
        }
      }
    }

    .menu2 {
      background: url(img/bg_menu_sp.png) no-repeat center left;
      margin-bottom: 40px;

      .inner {
        padding-right: 120px;

        .tate {
          padding-right: 0;
          right: 40px;
        }
      }
    }

    .slider_menu01_txt,
    .slider_menu02_txt {
      width: 530px;
      margin-top: 0;
    }

    .menu3 {
      margin-top: 40px;

      .txt {
        h2 {
          font-size: 38px;
          letter-spacing: .1em;
          margin-bottom: 25px;
        }

        p {
          font-size: 13px;
        }
      }
    }
  }



}


.red {
  padding: 35px;
  background: #82969C;
  text-align: center;
}

.section_03 {
  background: url(img/bg_02.png) center center / cover no-repeat;
  padding: 80px 50px;

  .inner {
    width: 100%;
    max-width: 1100px;
    margin: auto;

    h2 {
      margin-bottom: 24px;
      font-size: 32px;
      font-weight: bold;
    }

    .w {
      display: flex;
      gap: 50px;
      background: #fff;
      padding: 50px;
      border-radius: 5px;

      .left {
        width: 200px;

        .flex {
          display: flex;
          gap: 24px;
          justify-content: center;
          margin-top: 24px;
        }
      }

      table {
        line-height: 2;
        font-size: 18px;

        span {
          font-size: 14px;
        }

        th,
        td {
          padding: 0 20px 30px;
          vertical-align: top;
        }

        th {
          width: 170px;
          font-weight: bold;
        }

      }
    }

    .map {
      width: 100%;
    }

    .sns_list {
      display: flex;
      gap: 24px;
      justify-content: flex-end;
      align-items: center;
      margin-top: 20px;
      margin-bottom: 80px;
      font-family: "Josefin Sans", sans-serif;
      font-optical-sizing: auto;
      font-weight: 700;
      font-style: normal;
      font-size: 20px;

      .copy {
        position: relative;
        cursor: pointer;

        .msg {
          display: none;
          position: fixed;
          right: 0;
          bottom: 100px;
          width: 150px;
          font-size: 16px;
          border: 1px solid #000;
          padding: .5em;
          background: #000;
          color: #fff;
        }
      }
    }
  }
}

@media (max-width: 780px) {
  .section_03 {
    padding: 60px 40px;

    .inner {
      h2 {
        margin-bottom: 20px;
        font-size: 28px;
      }

      .w {
        flex-flow: column;
        padding: 40px;

        .left {
          width: 100%;
          text-align: center;
        }

        table {

          th,
          td {
            border-bottom: 1px solid #E6E6E6;
            padding: 24px;
          }

          tr:last-child {

            th,
            td {
              border: none;
              padding-bottom: 0;
            }
          }
        }
      }


    }
  }
}


.footer {
  background: #fff;
  padding: 24px 0;
  font-size: 14px;
  text-align: center;
}



@media (max-width: 779.9px) {
  body {
    width: 780px;
    transform-origin: top center;
    transform: scale(calc(100vw / 780));
  }
}

@media (max-width: 640px) {
  /* .sp-only {
    display: block;
  }

  .pc-only {
    display: none;
  } */
}