@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Zen+Maru+Gothic:wght@500;700&family=Manrope:wght@200..800&display=swap");
*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  line-height: 1;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* 引用符の自動挿入を無効にする */
blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

/* フォーカス時のアウトラインを消す */
:focus {
  outline: 0;
}

/* リストのマーカーを削除 */
ul, ol, dl {
  list-style: none;
}

/* リンク */
a {
  text-decoration: none;
  color: inherit;
}

/* ボタン */
button {
  border: none; /* ボタンの境界線を削除 */
  background: none; /* ボタンの背景を削除 */
  cursor: pointer; /* マウスオーバーでカーソルを変更 */
}

.sp {
  display: none;
}
@media screen and (max-width: 1023px) {
  .sp {
    display: revert;
  }
}

:root {
  scroll-behavior: smooth;
}

body {
  color: #333;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: min(20px, 1.3888888889vw);
  font-weight: 700;
  line-height: 1.75;
  background: #F4EFD6 url("../../images/bg01.jpg") center top repeat;
  background-size: min(500px, 34.7222222222vw) auto;
}
@media screen and (max-width: 1023px) {
  body {
    font-size: 4.2666666667vw;
    background-size: 300vw auto;
  }
}

.mv {
  width: 100%;
  height: min(690px, 47.9166666667vw);
  overflow: hidden;
  margin: -54px 0 min(28px, 1.9444444444vw);
  padding-top: min(42px, 2.9166666667vw);
  background: transparent image-set(url("../../images/mv-bg-pc.png") 1x, url("../../images/mv-bg-pc@2x.png") 2x) center top max(-47px, -3.2638888889vw) no-repeat;
  background-size: min(2155px, 149.6527777778vw) auto;
}
@media screen and (max-width: 1023px) {
  .mv {
    height: 189.8666666667vw;
    margin: -2.6666666667vw 0 10.6666666667vw;
    padding-top: 0;
    background: none;
  }
}
.mv--title {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  margin: 0;
}
.mv--title picture {
  display: contents;
}
.mv--image {
  display: block;
  width: min(1114px, 77.3611111111vw);
  height: auto;
}
@media screen and (max-width: 1023px) {
  .mv--image {
    width: 100%;
    height: auto;
  }
}

.contents {
  width: min(1240px, 86.1111111111vw);
  margin: 0 auto;
}
@media screen and (max-width: 1023px) {
  .contents {
    width: 100%;
    padding: 0 8vw;
    overflow-x: hidden;
  }
}

.instruction {
  width: 100%;
  margin-bottom: min(110px, 7.6388888889vw);
}
@media screen and (max-width: 1023px) {
  .instruction {
    margin-bottom: 26.6666666667vw;
  }
}
.instruction--lead {
  font-size: min(24px, 1.6666666667vw);
  line-height: 1.8;
  text-align: center;
  margin-bottom: min(60px, 4.1666666667vw);
}
@media screen and (max-width: 1023px) {
  .instruction--lead {
    font-size: 4.8vw;
    margin-bottom: 10.6666666667vw;
  }
}
.instruction--list {
  height: min(132px, 9.1666666667vw);
  display: grid;
  grid-template: auto/min(305px, 21.1805555556vw) 1fr;
  align-items: center;
  border: 4px solid #3C7DBE;
  border-radius: min(20px, 1.3888888889vw);
  background: white;
  overflow: hidden;
}
@media screen and (max-width: 1023px) {
  .instruction--list {
    height: auto;
    grid-template: auto/1fr;
    border-width: 0.8vw;
    border-radius: 5.3333333333vw;
  }
}
.instruction--title {
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  background: #3C7DBE;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1023px) {
  .instruction--title {
    font-size: 5.3333333333vw;
    padding: 5.3333333333vw 0;
  }
}
.instruction--text {
  padding: 0 min(40px, 2.7777777778vw);
}
@media screen and (max-width: 1023px) {
  .instruction--text {
    padding: 5.3333333333vw 8vw;
    text-align: center;
  }
}
.instruction--text-caption {
  font-size: min(14px, 0.9722222222vw);
  font-weight: 500;
}
@media screen and (max-width: 1023px) {
  .instruction--text-caption {
    display: block;
    font-size: 3.2vw;
    text-align: left;
    margin-top: 2.6666666667vw;
  }
}

.box {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: calc(100% - 10px);
  padding: min(60px, 4.1666666667vw) min(80px, 5.5555555556vw);
  margin: 0 auto min(105px, 7.2916666667vw);
  border: 4px solid black;
  border-image-source: url("../../images/bg-rect.png");
  border-image-slice: 40 fill;
  border-image-width: 10;
  border-image-repeat: repeat;
  border-image-outset: 4px;
}
@media screen and (max-width: 1023px) {
  .box {
    width: 100%;
    padding: 0 4vw 6.4vw;
    margin-bottom: 20.5333333333vw;
  }
}
.box:last-of-type {
  margin-bottom: min(120px, 8.3333333333vw);
}
@media screen and (max-width: 1023px) {
  .box:last-of-type {
    margin-bottom: 25.3333333333vw;
  }
}
.box.new:after {
  position: absolute;
  right: max(-32px, -2.2222222222vw);
  top: max(-32px, -2.2222222222vw);
  content: "";
  width: min(144px, 10vw);
  height: min(144px, 10vw);
  background: transparent url("../../images/new@2x.png") left top no-repeat;
  background-size: cover;
}
@media screen and (max-width: 1023px) {
  .box.new:after {
    width: 23.7333333333vw;
    height: 23.7333333333vw;
    top: -12.8vw;
    right: -10.6666666667vw;
  }
}
.box--title_img {
  display: block;
  width: auto;
  height: min(150px, 10.4166666667vw);
  margin-top: max(-84px, -5.8333333333vw);
}
@media screen and (max-width: 1023px) {
  .box--title_img-calendar {
    height: 34.9333333333vw;
    margin-top: -4.2666666667vw;
  }
  .box--title_img-photo {
    height: 33.3333333333vw;
    margin-top: -2.6666666667vw;
  }
  .box--title_img-seasonal {
    height: 25.6vw;
    margin-top: -3.7333333333vw;
  }
}
.box--subtitle {
  font-size: min(48px, 3.3333333333vw);
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: min(26px, 1.8055555556vw);
}
@media screen and (max-width: 1023px) {
  .box--subtitle {
    font-size: 7.4666666667vw;
    line-height: 1.8;
    margin-bottom: 2.6666666667vw;
  }
}
.box--wrap {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  gap: min(24px, 1.6666666667vw);
}
@media screen and (max-width: 1023px) {
  .box--wrap {
    display: grid;
    grid-template: auto/auto auto;
    gap: 5.3333333333vw 0;
  }
}
.box--thumb {
  border: min(2px, 0.1388888889vw) solid #e3e3e3;
  border-radius: min(14px, 0.9722222222vw);
  height: min(340px, 23.6111111111vw);
  width: auto;
}
@media screen and (max-width: 1023px) {
  .box--thumb {
    height: 32vw;
    border-radius: 1.3333333333vw;
    border-width: 0.2666666667vw;
  }
}

.links {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: min(14px, 0.9722222222vw);
  margin: 0 0 0 auto;
}
@media screen and (max-width: 1023px) {
  .links {
    grid-column: 1/span 2;
    gap: 3.7333333333vw;
    margin: 0;
  }
}
.links--label {
  font-size: min(20px, 1.3888888889vw);
  font-weight: 700;
}
@media screen and (max-width: 1023px) {
  .links--label {
    font-size: 4.8vw;
  }
}
.links--btn {
  color: white;
  font-family: Manrope, sans-serif;
  font-size: min(20px, 1.3888888889vw);
  line-height: 1;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(12px, 0.8333333333vw);
  width: min(247px, 17.1527777778vw);
  height: min(60px, 4.1666666667vw);
  background: #00A0E9;
  border-radius: min(30px, 2.0833333333vw);
  transition: 0.15s linear;
  will-change: transform;
}
@media screen and (max-width: 1023px) {
  .links--btn {
    font-size: 5.3333333333vw;
    gap: 3.2vw;
    width: 100%;
    height: 16vw;
    border-radius: 8vw;
  }
}
.links--btn:hover {
  transform: scale(1.05);
}
@media screen and (max-width: 1023px) {
  .links--btn:hover {
    transform: none;
  }
}
.links--btn:after {
  content: "";
  width: min(16px, 1.1111111111vw);
  height: min(17px, 1.1805555556vw);
  background: transparent url("data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2218%22%20height%3D%2219%22%20viewBox%3D%220%200%2018%2019%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M1%2014V16C1%2016.5304%201.21071%2017.0391%201.58579%2017.4142C1.96086%2017.7893%202.46957%2018%203%2018H15C15.5304%2018%2016.0391%2017.7893%2016.4142%2017.4142C16.7893%2017.0391%2017%2016.5304%2017%2016V14M4%208L9%2013M9%2013L14%208M9%2013V1%22%20stroke%3D%22white%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E%0A") left top no-repeat;
  background-size: contain;
}
@media screen and (max-width: 1023px) {
  .links--btn:after {
    width: 4.2666666667vw;
    height: 4.5333333333vw;
  }
}

.backnumber {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: #885C2F url("../../images/bg02.jpg") center top repeat;
  background-size: min(500px, 34.7222222222vw) auto;
  border-radius: min(120px, 8.3333333333vw) min(120px, 8.3333333333vw) 0 0;
  padding: min(120px, 8.3333333333vw) 0 min(90px, 6.25vw);
}
@media screen and (max-width: 1023px) {
  .backnumber {
    background-size: 300vw auto;
    border-radius: 16vw 16vw 0 0;
    padding: 16vw 0 22.9333333333vw;
  }
}
.backnumber--title {
  margin-bottom: min(100px, 6.9444444444vw);
}
@media screen and (max-width: 1023px) {
  .backnumber--title {
    margin-bottom: 11.7333333333vw;
  }
}
.backnumber--title_img {
  display: block;
  width: min(687px, 47.7083333333vw);
  height: auto;
}
@media screen and (max-width: 1023px) {
  .backnumber--title_img {
    width: 73.3333333333vw;
  }
}
.backnumber .filter {
  font-size: min(14px, 0.9722222222vw);
  border: 4px solid black;
  border-image-source: url("../../images/bg-rect.png");
  border-image-slice: 40 fill;
  border-image-width: 10;
  border-image-repeat: repeat;
  border-image-outset: 4px;
  padding: min(13px, 0.9027777778vw) min(40px, 2.7777777778vw) min(30px, 2.0833333333vw);
  margin-bottom: min(108px, 7.5vw);
  margin-trim: block;
}
@media screen and (max-width: 1023px) {
  .backnumber .filter {
    font-size: 3.7333333333vw;
    padding: 2.6666666667vw 5.3333333333vw 5.3333333333vw;
    margin-bottom: 16vw;
  }
}
.backnumber .filter--title {
  font-size: min(24px, 1.6666666667vw);
  text-align: center;
  line-height: min(43px, 2.9861111111vw);
  margin-bottom: min(14px, 0.9722222222vw);
}
@media screen and (max-width: 1023px) {
  .backnumber .filter--title {
    font-size: 5.3333333333vw;
    line-height: 2.1;
    margin-bottom: 3.2vw;
  }
}
.backnumber .filter--section {
  display: flex;
  align-items: center;
  justify-content: start;
  gap: min(8px, 0.5555555556vw);
  margin-bottom: min(14px, 0.9722222222vw);
}
@media screen and (max-width: 1023px) {
  .backnumber .filter--section {
    gap: 2.1333333333vw;
    margin-bottom: 3.2vw;
  }
}
.backnumber .filter--label {
  width: min(80px, 5.5555555556vw);
}
@media screen and (max-width: 1023px) {
  .backnumber .filter--label {
    width: 11.7333333333vw;
  }
}
.backnumber .filter--btn {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: min(92px, 6.3888888889vw);
  height: min(37px, 2.5694444444vw);
  border-radius: min(20px, 1.3888888889vw);
  background: #E9F7FE;
  padding: 0 min(16px, 1.1111111111vw);
  cursor: pointer;
  transition: 0.15s linear;
  will-change: transform;
}
@media screen and (max-width: 1023px) {
  .backnumber .filter--btn {
    min-width: 14.4vw;
    height: 9.8666666667vw;
    padding: 0 3.2vw;
    border-radius: 5.3333333333vw;
  }
}
.backnumber .filter--btn:hover {
  color: white;
  background-color: #00A0E9;
}
.backnumber .filter--btn.selected {
  background-color: #84D8FF;
}
.backnumber .thumbs {
  display: grid;
  grid-template: auto/repeat(4, 1fr);
  gap: min(40px, 2.7777777778vw);
  margin-bottom: min(60px, 4.1666666667vw);
}
@media screen and (max-width: 1023px) {
  .backnumber .thumbs {
    grid-template: auto/repeat(2, 1fr);
    gap: 4vw;
    margin-bottom: 16vw;
  }
}
.backnumber .thumbs--item {
  width: min(280px, 19.4444444444vw);
  height: min(280px, 19.4444444444vw);
  border: min(3px, 0.2083333333vw) solid #e3e3e3;
  border-radius: min(10px, 0.6944444444vw);
  overflow: hidden;
}
@media screen and (max-width: 1023px) {
  .backnumber .thumbs--item {
    width: 42.6666666667vw;
    height: 42.6666666667vw;
    border-width: 0.8vw;
    border-radius: 2.6666666667vw;
  }
}
.backnumber .thumbs--img {
  width: min(280px, 19.4444444444vw);
  height: min(280px, 19.4444444444vw);
  cursor: pointer;
  transition: 0.15s linear;
  will-change: transform;
}
@media screen and (max-width: 1023px) {
  .backnumber .thumbs--img {
    width: 42.6666666667vw;
    height: 42.6666666667vw;
    transition: none;
  }
}
.backnumber .thumbs--img:hover {
  transform: scale(1.05);
}
@media screen and (max-width: 1023px) {
  .backnumber .thumbs--img:hover {
    transform: none;
  }
}
.backnumber--more {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(16px, 1.1111111111vw);
  color: white;
  font-size: min(26px, 1.8055555556vw);
  cursor: pointer;
  transition: 0.15s linear;
  will-change: transform;
}
@media screen and (max-width: 1023px) {
  .backnumber--more {
    gap: 3.4666666667vw;
    font-size: 4.8vw;
    transition: none;
  }
}
.backnumber--more:hover {
  transform: translate(0, 3px);
}
@media screen and (max-width: 1023px) {
  .backnumber--more:hover {
    transform: none;
  }
}
.backnumber--more:after {
  content: "";
  width: min(24px, 1.6666666667vw);
  height: min(14px, 0.9722222222vw);
  background: transparent url("data:image/svg+xml;charset=utf8,%3Csvg%20fill%3D%22none%22%20height%3D%2214%22%20viewBox%3D%220%200%2024%2014%22%20width%3D%2224%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m21.0608.450439c.6046-.602144%201.5832-.600496%202.1855.003907.6023.604544.6005%201.583124-.0039%202.185544l-10.3398%2010.30271c-.2903.2892-.684.4518-1.0938.4512-.4097-.0007-.8025-.1649-1.0918-.4551l-10.266561-10.30271c-.602169-.60452-.600306-1.58313.003907-2.185551.604584-.602118%201.583174-.600433%202.185544.003907l9.17581%209.208984z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E") left top no-repeat;
  background-size: contain;
}
@media screen and (max-width: 1023px) {
  .backnumber--more:after {
    width: 4.2666666667vw;
    height: 2.1333333333vw;
  }
}

.modal {
  border: none;
  border-radius: min(40px, 2.7777777778vw);
  padding: min(50px, 3.4722222222vw) min(98px, 6.8055555556vw) min(66px, 4.5833333333vw);
  transition: 0.25s ease;
  opacity: 0;
  transform: scale(0.95);
  will-change: transform;
}
@media screen and (max-width: 1023px) {
  .modal {
    border-radius: 10.6666666667vw;
    padding: 16vw 12vw 16vw;
    overflow: visible;
  }
}
.modal::backdrop {
  background-color: #00a0e9;
  opacity: 0;
  transition: 0.2s linear;
}
.modal.is-open {
  opacity: 1;
  transform: scale(1);
}
.modal.is-open::backdrop {
  opacity: 0.4;
}
.modal--close {
  line-height: 1;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  right: 20px;
  top: 20px;
  width: min(60px, 4.1666666667vw);
  height: min(60px, 4.1666666667vw);
  border-radius: min(30px, 2.0833333333vw);
  background: #00A0E9;
  transition: 0.15s linear;
  will-change: transform;
}
@media screen and (max-width: 1023px) {
  .modal--close {
    width: 16vw;
    height: 16vw;
    right: -5.3333333333vw;
    top: -5.3333333333vw;
    border-radius: 8vw;
    transition: none;
  }
}
.modal--close:hover {
  transform: scale(1.05);
}
@media screen and (max-width: 1023px) {
  .modal--close:hover {
    transform: none;
  }
}
.modal--close:after {
  content: "";
  width: min(18px, 1.25vw);
  height: min(18px, 1.25vw);
  background: transparent url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2017%2017%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m.42.42c.56-.56%201.46-.56%202.02%200l6.06%206.06%206.06-6.06c.56-.56%201.46-.56%202.02%200s.56%201.46%200%202.02l-6.06%206.06%206.06%206.06c.56.56.56%201.46%200%202.02s-1.46.56-2.02%200l-6.06-6.06-6.06%206.06c-.56.56-1.46.56-2.02%200s-.56-1.46%200-2.02l6.06-6.06-6.06-6.06c-.56-.56-.56-1.46%200-2.02z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E") left top no-repeat;
  background-size: contain;
}
@media screen and (max-width: 1023px) {
  .modal--close:after {
    width: 4.8vw;
    height: 4.8vw;
  }
}
.modal--lead {
  font-size: min(24px, 1.6666666667vw);
  line-height: 1.5;
  text-align: center;
  margin-bottom: min(34px, 2.3611111111vw);
}
@media screen and (max-width: 1023px) {
  .modal--lead {
    font-size: 5.3333333333vw;
    margin-bottom: 8vw;
  }
}
.modal--wrap {
  display: none;
  grid-template: auto/1fr 1fr;
  gap: min(14px, 0.9722222222vw) min(60px, 4.1666666667vw);
}
@media screen and (max-width: 1023px) {
  .modal--wrap {
    grid-template: auto/1fr;
    gap: 3.7333333333vw;
  }
}
.modal--wrap.active {
  display: grid;
}
@media screen and (max-width: 1023px) {
  .modal--wrap01 .modal--label:nth-of-type(2) {
    grid-row: 3;
  }
}
.modal--wrap01 a[href*="1920_1080"] {
  grid-column: 2;
}
@media screen and (max-width: 1023px) {
  .modal--wrap01 a[href*="1920_1080"] {
    grid-column: auto;
  }
}
.modal--wrap02 {
  display: none;
}
.modal--wrap02 .modal--label {
  grid-column: 1/span 2;
}
@media screen and (max-width: 1023px) {
  .modal--wrap02 .modal--label {
    grid-column: 1;
  }
}
.modal--label {
  text-align: center;
  font-size: min(20px, 1.3888888889vw);
  font-weight: 700;
}
@media screen and (max-width: 1023px) {
  .modal--label {
    font-size: 4.8vw;
  }
}
.modal--btn {
  color: white;
  font-family: Manrope, sans-serif;
  font-size: min(20px, 1.3888888889vw);
  line-height: 1;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(12px, 0.8333333333vw);
  width: min(247px, 17.1527777778vw);
  height: min(60px, 4.1666666667vw);
  background: #00A0E9;
  border-radius: min(30px, 2.0833333333vw);
  transition: 0.15s linear;
  will-change: transform;
}
@media screen and (max-width: 1023px) {
  .modal--btn {
    font-size: 5.3333333333vw;
    gap: 3.2vw;
    width: 100%;
    height: 16vw;
    border-radius: 8vw;
  }
}
.modal--btn:hover {
  transform: scale(1.05);
}
@media screen and (max-width: 1023px) {
  .modal--btn:hover {
    transform: none;
  }
}
.modal--btn:after {
  content: "";
  width: min(16px, 1.1111111111vw);
  height: min(17px, 1.1805555556vw);
  background: transparent url("data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2218%22%20height%3D%2219%22%20viewBox%3D%220%200%2018%2019%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M1%2014V16C1%2016.5304%201.21071%2017.0391%201.58579%2017.4142C1.96086%2017.7893%202.46957%2018%203%2018H15C15.5304%2018%2016.0391%2017.7893%2016.4142%2017.4142C16.7893%2017.0391%2017%2016.5304%2017%2016V14M4%208L9%2013M9%2013L14%208M9%2013V1%22%20stroke%3D%22white%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E%0A") left top no-repeat;
  background-size: contain;
}
@media screen and (max-width: 1023px) {
  .modal--btn:after {
    width: 4.2666666667vw;
    height: 4.5333333333vw;
  }
}

.home_header {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.75;
  height: 54px;
  position: relative;
  z-index: 10001;
}
.home_header .header_logo {
  margin: 18px 0 0 17px;
  width: 165px;
}
.home_header .nav_btn {
  background: #00A0E9;
  position: fixed;
  top: 0;
  right: 0;
  width: min(110px, 7.6388888889vw);
  height: min(110px, 7.6388888889vw);
  cursor: pointer;
  transform-origin: right top;
}
@media screen and (max-width: 1023px) {
  .home_header .nav_btn {
    width: 54px;
    height: 54px;
  }
}
.home_header .nav_btn:before,
.home_header .nav_btn span:before,
.home_header .nav_btn span:after {
  background: #fff;
  content: "";
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 37%;
  height: 2px;
}
.home_header .nav_btn:before {
  top: 48.14%;
}
.home_header .nav_btn span::before {
  top: 35.18%;
}
.home_header .nav_btn span::after {
  top: 61.1%;
}
.home_header .nav_main {
  background: #fff;
  bottom: 0;
  overflow-y: auto;
  padding-top: 35px;
  position: fixed;
  top: 0;
  right: -200vw;
  transition: right 0.3s;
  width: 100%;
}
.home_header .nav_main.shownav {
  right: 0;
}
.home_header .nav_logo {
  height: 97px;
  padding: 0 24px 30px;
}
.home_header .nav_logo img {
  width: 291px;
}
.home_header .nav_list {
  margin: 0 30px;
}
.home_header .nav_list li {
  border-top: 1px solid #c8c9ca;
}
.home_header .nav_list li a {
  color: #646464;
  display: block;
  font-size: 16px;
  font-weight: 500;
  padding: 16px 0;
  position: relative;
  text-decoration: none;
}
.home_header .nav_list li a::before {
  background: #00085f url("../../images/ico-arrow-wh-r.png") center/6px 10px no-repeat;
  content: "";
  height: 20px;
  right: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
}
.home_header .nav_close {
  position: absolute;
  right: 0;
  top: 0;
  cursor: pointer;
  width: min(110px, 7.6388888889vw);
  height: min(110px, 7.6388888889vw);
}
@media screen and (max-width: 1023px) {
  .home_header .nav_close {
    width: 54px;
    height: 54px;
  }
}
.home_header .nav_close:before, .home_header .nav_close:after {
  background: #000;
  content: "";
  height: 3.7%;
  left: 50%;
  position: absolute;
  top: 50%;
  width: 37%;
}
.home_header .nav_close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.home_header .nav_close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(14px, 0.9722222222vw);
  line-height: 1.75;
  font-weight: 400;
  padding: min(21px, 1.4583333333vw) min(30px, 2.0833333333vw);
  background: white;
}
@media screen and (max-width: 1023px) {
  .footer {
    font-size: 3.2vw;
    flex-direction: column;
    padding: 0 0 5.3333333333vw;
  }
}
.footer--link {
  order: 3;
}
@media screen and (max-width: 1023px) {
  .footer--link {
    width: 100%;
    order: 1;
    border-bottom: 1px solid #c8c9ca;
  }
}
.footer--link ul {
  display: flex;
  justify-content: space-between;
  gap: 14px;
}
@media screen and (max-width: 1023px) {
  .footer--link ul {
    gap: auto;
    padding: 0 30px;
  }
}
.footer--link ul a {
  color: #929292;
  display: block;
  padding: 10px 0;
  text-decoration: none;
}
.footer--logo {
  display: block;
  width: min(168px, 11.6666666667vw);
  height: auto;
  order: 1;
}
@media screen and (max-width: 1023px) {
  .footer--logo {
    width: 38.6666666667vw;
    margin: 5.3333333333vw auto 2.6666666667vw;
  }
}
.footer--copyright {
  font-size: min(12px, 0.8333333333vw);
  color: #929292;
  order: 2;
  margin: 0 auto 0 min(20px, 1.3888888889vw);
}
@media screen and (max-width: 1023px) {
  .footer--copyright {
    font-size: 3.2vw;
    order: 3;
    text-align: center;
    margin: 0;
  }
}
.footer .pagetop {
  bottom: -100px;
  right: 15px;
  position: fixed;
  transition: bottom 0.2s;
  width: min(90px, 6.25vw);
  height: min(90px, 6.25vw);
  z-index: 9999;
}
@media screen and (max-width: 1023px) {
  .footer .pagetop {
    width: 16vw;
    height: 16vw;
  }
}
.footer .pagetop.showpagetop {
  bottom: min(140px, 9.7222222222vw);
}
@media screen and (max-width: 1023px) {
  .footer .pagetop.showpagetop {
    bottom: 4vw;
  }
}
.footer .pagetop a {
  background: #00A0E9 url("data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2224%22%20height%3D%2214%22%20viewBox%3D%220%200%2024%2014%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M1.66663%2011.6667L11.6666%201.66675L21.6666%2011.6667%22%20stroke%3D%22white%22%20stroke-width%3D%223.33333%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E%0A") center center no-repeat;
  background-size: 25% auto;
  border: min(5px, 0.3472222222vw) solid white;
  border-radius: 50%;
  display: block;
  height: 100%;
  width: 100%;
}

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