/*------------------------------
 all-page
------------------------------*/

:root {
  --color-1: #690308;
  --color-2: #b40019;
  --color-3: #b6d0f1;
  --color-4: #002d78;
  --color-5: #b1a16b;
  --color-6: #019b69;
  --color-7: #e6e6e6;
  --color-8: #c5c3c3;
  --color-9: #013826;
  --color-10: #c30d23;
}
/*fixed header*/
.pg-s-header{
  position: fixed;
  width: 100%;
}

.ozw {
  font-family: "Oswald", sans-serif;
  font-weight: bold;
}

.hirakaku {
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
}

.notosans {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
}

.l-content {
  height: fit-content;
  background-color: var(--color-10);
}
.slick01 .slick-prev {
  left: 2px !important;
  z-index: 1 !important;
}
.slick01 .slick-next {
  right: 28px !important;
  z-index: 1 !important;
}
#slick02 .slick-prev {
  left: 0px !important;
  z-index: 1 !important;
}
#slick02 .slick-next {
  right: 28.5px !important;
  z-index: 1 !important;
}
.slick03 .slick-prev {
  left: 2px !important;
  z-index: 1 !important;
}
.slick03 .slick-next {
  right: 28px !important;
  z-index: 1 !important;
}
.slick-prev:before,
.slick-next:before {
  font-size: 3rem !important;
}

.slick03 .slick-slide {
  padding: 1em;
}

.pc {
  display: none;
}

.mb1 {
  margin-bottom: 1rem;
}

.mb2 {
  margin-bottom: 2rem;
}

.mb3 {
  margin-bottom: 3rem;
}

@media only screen and (min-width: 1023.5px) {
  /*------------------------------
  m-special-campaign
 ------------------------------*/
  .m-special-campaign {
    margin: -6rem 0 0;
    padding: 9rem 0.5rem 3rem;
  }
  /*------------------------------
   m-special-nav
  ------------------------------*/
  .m-special-nav {
    padding: 0.5rem 0.25rem;
    background-color: #ae101c;
    position: sticky;
    top: 114px;
    z-index: 99;
    /*flex-wrap: nowrap !important;*/
  }
  .m-special-nav .unit .inner .nav {
    display: flex;
    flex-wrap: nowrap !important;
    justify-content: center;
  }
  .m-special-nav .unit .inner .nav a {
    display: flex;
    width: 11.11%;
    margin: 0 0.25rem;
    padding: 0.25rem 0;
    text-align: center;
    font-size: 0.8rem;
    color: #fff;
    background-color: #ae101c;
    border: 1px #fff solid;
    align-items: center;
    justify-content: center;
    font-family: "UrawaRedsDisplay", "Noto Sans JP", sans-serif;
    font-weight: bold;
  }
  .m-special-nav .unit .inner .nav a:hover {
    transform: scale(1.05);
  }

  /*------------------------------
   m-special-banner
  ------------------------------*/
  .m-special-banner {
    margin: 1rem 0 0;
    padding: 6rem 0 0;
  }
  .m-special-banner .unit .inner .banner {
    position: relative;
  }

  .m-special-banner .unit .inner .banner img {
    width: 100%;
  }

  /*------------------------------
   m-special-movie
  ------------------------------*/
  .m-special-movie {
    margin: -6rem 0 0;
    padding: 9rem 12rem 3rem;
  }
  .m-special-movie .unit .inner {
    width: min(100% - 2rem, 1360px);
    margin-inline: auto;
  }
  .m-special-movie .unit .inner video {
    display: block;
    width: 100%;
    margin: auto;
    position: relative;
    z-index: 1;
  }

  /*------------------------------
   m-special-concept
  ------------------------------*/
  .m-special-concept {
    margin: -4rem 0 0;
    padding: 6rem 3rem 3rem;
  }

  .m-special-concept .unit .inner h1 {
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: 800;
    color: white;
    font-size: max(4vw, 45px);
    text-align: center;
    margin: -110px auto 40px;
    padding-top: 150px;
  }

  .m-special-concept .unit .inner .-mainTtl {
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    color: white;
    font-weight: bold;
    font-size: max(1.7vw, 4rem);
    text-align: center;
    padding: 90px 0;
  }

  .m-special-concept .unit .inner p {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: white;
    font-size: max(1.7vw, 20px);
    line-height: 3vw;
    text-align: center;
  }

  .m-special-concept .unit .inner .btn-area {
    color: white;
    font-size: 20px;
    margin: 80px auto;
    text-align: center;
  }

  .m-special-concept .unit .inner .btn-area a {
    font-size: 30px;
    padding: 0.5rem 5rem;
    background-color: var(--color-1);
    color: white;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    margin: 0 20px;
  }

  .m-special-concept .unit .inner .btn-area a:hover {
    background-color: white;
    color: var(--color-1);
  }

  .m-special-concept .unit .inner .btn-area a:nth-of-type(2) {
    background-color: var(--color-7);
    color: black;
  }

  .m-special-concept .unit .inner .btn-area a:nth-of-type(2):hover {
    background-color: black;
    color: var(--color-7);
  }

  .m-special-concept .unit .inner .btn-area a:nth-of-type(3) {
    background-color: var(--color-6);
    color: white;
  }

  .m-special-concept .unit .inner .btn-area a:nth-of-type(3):hover {
    background-color: white;
    color: var(--color-6);
  }

  /*------------------------------
   m-special-uniform
  ------------------------------*/
  .m-special-uniform {
    margin: -6rem 0 0;
    padding: 6rem 0 3rem;
  }
  .m-special-uniform .unit .inner {
    width: min(100% - 2rem, 1560px);
    margin-inline: auto;
  }

  .m-special-uniform .unit .inner h2 {
    margin: 0 0 3rem;
    text-align: center;
    font-size: 5rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
    margin: -110px auto 40px;
    padding-top: 150px;
  }

  .m-special-uniform .unit .inner .uniform-top {
    display: flex;
    margin-inline: auto;
    margin-top: 90px;
    margin-bottom: 30px;
    align-items: center;
  }

  .m-special-uniform .unit .inner .uniform-top .image-area {
    width: 40%;
    /* margin: 50px auto; */
  }

  .m-special-uniform .unit .inner .uniform-top .image-area img {
    width: 100%;
    padding: 0 5vw;
    filter: drop-shadow(0 0 4px #000);
  }

  .m-special-uniform .unit .inner .uniform-top .text-area {
    width: 60%;
  }

  .m-special-uniform .unit .inner .uniform-top .text-area h1 {
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: 800;
    color: white;
    font-size: 50px;
    text-align: left;
    margin: 40px auto;
  }

  .m-special-uniform .unit .inner .uniform-top .text-area p {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: white;
    font-size: max(1.3vw, 18px);
    padding-right: 10%;
  }

  .m-special-uniform2 {
    background-color: var(--color-7);
    color: black;
  }

  .m-special-uniform2 .unit .inner h2 {
    color: black;
  }

  .m-special-uniform2 .unit .inner .uniform-top .text-area h1 {
    color: black;
  }

  .m-special-uniform2 .unit .inner .uniform-top .text-area p {
    color: black;
  }

  .m-special-uniform3 {
    background-color: var(--color-6);
    color: white;
  }

  .m-special-uniform3 .unit .inner h2 {
    color: white;
  }

  .m-special-uniform3 .unit .inner .uniform-top .text-area h1 {
    color: white;
  }

  .m-special-uniform3 .unit .inner .uniform-top .text-area p {
    color: white;
  }

  .m-special-uniform3 .unit .inner .gk_img_wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2rem;
    margin: 90px 0 90px 0;
  }

  /*------------------------------
   m-special-detail
  ------------------------------*/
  .m-special-detail {
    margin: -6rem 0 0;
    padding: 9rem 0 3rem;
  }
  .m-special-detail .unit .inner {
    width: min(100% - 2rem, 1360px);
    margin-inline: auto;
  }

  .m-special-detail .unit .inner h4 {
    font-size: 25px;
    padding: 1rem 5rem;
    background-color: var(--color-1);
    color: white;
    font-weight: bold;
    margin: 0 auto 80px;
    transition: 0.5s;
    font-family: "Noto Sans JP", sans-serif;
    width: 50%;
    text-align: center;
    cursor: pointer;
    position: relative;
  }

  .m-special-detail .unit .inner h4:hover {
    opacity: 0.7;
  }

  .m-special-detail .unit .inner h4 .slide-btn {
    position: absolute;
    display: block;
    height: 20px;
    right: 30px;
    top: 22px;
    transition: 0.5s;
  }

  .m-special-detail .unit .inner h4.active .slide-btn {
    transform: rotate(180deg);
  }

  .m-special-detail .unit .inner h4.btn2 {
    background-color: black;
  }

  .m-special-detail .unit .inner h4.btn2:hover {
    background-color: var(--color-8);
  }

  .m-special-detail .unit .inner h4.btn3 {
    background-color: var(--color-9);
  }

  .m-special-detail .unit .inner h4.btn3:hover {
    background-color: green;
  }

  .m-special-detail .unit .inner .detail-inner {
    display: none;
  }

  .m-special-detail .unit .inner h2 {
    margin: 0 0 3rem;
    text-align: center;
    font-size: 5rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-detail .unit .inner .-jp {
    margin-top: 90px;
    text-align: center;
    font-size: 4rem;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-detail .unit .inner .container {
    display: flex;
    align-items: center;
    margin-bottom: 2rem;
  }
  .m-special-detail .unit .inner .container.reverse {
    flex-direction: row-reverse;
  }
  .m-special-detail .unit .inner .container.reverse.center {
    justify-content: center;
  }
  .m-special-detail .unit .inner .container .txt {
    width: 50%;
    padding: 1rem;
  }
  .m-special-detail .unit .inner .container .txt h3 {
    margin: 0;
    text-align: center;
    font-size: 2rem;
    font-family: "UrawaRedsDisplay", sans-serif;
    font-size: 3rem;
    margin-bottom: 3rem;
    font-weight: bold;
    color: #fff;
  }
  .m-special-detail .unit .inner .container .txt p {
    margin: 1rem;
    text-align: left;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    font-size: max(1.3vw, 18px);
  }

  .m-special-detail .unit .inner .container .txt .text-center {
    text-align: center;
  }

  .m-special-detail .unit .inner .container .txt .note {
    margin: 1rem;
    text-align: left;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    font-size: 16px;
  }

  .m-special-detail .unit .inner .container .txt span {
    font-size: 1.3rem;
  }
  .m-special-detail .unit .inner .container .txt .small {
    font-size: 0.9rem;
  }
  .m-special-detail .unit .inner .container .img {
    width: 50%;
  }

  .m-special-detail .unit .inner .under-image {
    width: 90%;
    padding: 10% 0;
    margin: auto;
  }

  .m-special-detail .unit .inner .under-image img {
    padding: 0 5%;
  }

  .m-special-detail .unit .inner .under-image .image-holder {
    opacity: 1;
  }

  .m-special-detail .unit .inner .under-space {
    width: 100%;
    height: 100px;
    /* background-color: var(--color-2); */
  }

  .m-special-detail2 {
    background-color: var(--color-7);
    padding: 9rem 0 8rem;
  }

  .m-special-detail2 .unit .inner h2 {
    color: black;
  }

  .m-special-detail2 .unit .inner .container .txt h3 {
    color: black;
  }

  .m-special-detail2 .unit .inner .container .txt p {
    color: black;
  }
  .m-special-detail2 .unit .inner .container .note {
    font-size: 0.8rem;
    text-align: center;
  }
  .m-special-detail2 .unit .inner .-jp {
    margin-top: 90px;
    text-align: center;
    font-size: 4rem;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #000;
  }

  .m-special-detail3 {
    background-color: var(--color-6);
  }

  .m-special-detail3 .unit .inner h2 {
    color: white;
  }

  .m-special-detail3 .unit .inner .container .txt h3 {
    color: white;
  }

  .m-special-detail3 .unit .inner .container .txt p {
    color: white;
  }

  .m-special-detail .unit .inner .size {
    padding: 3rem 3rem 3rem;
  }

  .m-special-detail .unit .inner .size .txt h3 {
    margin-bottom: 1rem;
    text-align: left;
    font-size: 2rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }

  .m-special-detail .unit .inner table td {
    border: solid 2px black;
    background-color: white;
    text-align: center;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
  }

  .m-special-detail .unit .inner table td.bg-white {
    background-color: white;
    color: black;
  }

  .m-special-detail .unit .inner table td.bg-black {
    background-color: black;
    color: white;
  }
  .m-special-detail .unit .inner table td.bg-td-red {
    background-color: #c30d23;
    color: white;
  }

  .m-special-detail .unit .inner dl {
    display: flex;
    margin: 1rem 0 0;
    border: 1px #eee solid;
    flex-wrap: wrap;
  }

  .m-special-detail .unit .inner dl dt {
    width: 35%;
    padding: 1rem;
    font-size: 1.25rem;
    font-weight: bold;
    color: #000;
    background-color: #ccc;
    border: 1px #eee solid;
  }

  .m-special-detail .unit .inner dl dd {
    width: 65%;
    padding: 1rem;
    font-size: 1.25rem;
    color: #000;
    background-color: #fff;
    border: 1px #eee solid;
  }

  .m-special-detail .unit .inner dl dd a {
    color: #ae101c;
  }

  .m-special-detail .unit .inner a:hover {
    border-bottom: 1px #ae101c solid;
  }

  .m-special-detail .unit .inner dl dd span {
    font-weight: bold;
    color: #ae101c;
  }

  .m-special-detail2 .unit .inner .size {
    padding: 3rem 3rem 3rem;
  }

  .m-special-detail2 .unit .inner .size .txt h3 {
    margin-bottom: 1rem;
    text-align: left;
    font-size: 2rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: black;
  }

  .m-special-detail2 .unit .inner table td {
    border: solid 2px black;
    color: black;
    text-align: center;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
  }

  .m-special-detail2 .unit .inner table td.bg-white {
    background-color: white;
    color: black;
  }

  .m-special-detail2 .unit .inner dl {
    display: flex;
    margin: 1rem 0 0;
    border: 1px #eee solid;
    flex-wrap: wrap;
  }

  .m-special-detail2 .unit .inner dl dt {
    width: 35%;
    padding: 1rem;
    font-size: 1.25rem;
    font-weight: bold;
    color: #000;
    background-color: #ccc;
    border: 1px #eee solid;
  }

  .m-special-detail2 .unit .inner dl dd {
    width: 65%;
    padding: 1rem;
    font-size: 1.25rem;
    color: #000;
    background-color: #fff;
    border: 1px #eee solid;
  }

  .m-special-detail2 .unit .inner dl dd a {
    color: #ae101c;
  }

  .m-special-detail2 .unit .inner a:hover {
    border-bottom: 1px #ae101c solid;
  }

  .m-special-detail2 .unit .inner dl dd span {
    font-weight: bold;
    color: #ae101c;
  }

  .m-special-detail3 .unit .inner .size {
    padding: 3rem 3rem 3rem;
  }

  .m-special-detail3 .unit .inner .size .txt h3 {
    margin-bottom: 1rem;
    text-align: center;
    font-size: 2rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }

  .m-special-detail3 .unit .inner {
    margin: 1rem 0 1rem;
  }

  .m-special-detail3 .unit .inner table td {
    border: solid 1px black;
    color: white;
    text-align: center;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
  }

  .m-special-detail3 .unit .inner table td.bg-white {
    background-color: white;
    color: black;
  }

  .m-special-detail3 .unit .inner dl {
    display: flex;
    margin: 1rem 0 0;
    border: 1px #eee solid;
    flex-wrap: wrap;
  }

  .m-special-detail3 .unit .inner dl dt {
    width: 35%;
    padding: 1rem;
    font-size: 1.25rem;
    font-weight: bold;
    color: #000;
    background-color: #ccc;
    border: 1px #eee solid;
  }

  .m-special-detail3 .unit .inner dl dd {
    width: 65%;
    padding: 1rem;
    font-size: 1.25rem;
    color: #000;
    background-color: #fff;
    border: 1px #eee solid;
  }

  .m-special-detail3 .unit .inner dl dd a {
    color: #ae101c;
  }

  .m-special-detail3 .unit .inner a:hover {
    border-bottom: 1px #ae101c solid;
  }

  .m-special-detail3 .unit .inner dl dd span {
    font-weight: bold;
    color: #ae101c;
  }
  /*------------------------------
   m-special-font
  ------------------------------*/
  .m-special-font {
    margin: 0;
    padding: 4rem 0 3rem;
  }
  .m-special-font .unit .inner {
    width: min(100% - 2rem, 1560px);
    margin-inline: auto;
  }
  .m-special-font .unit .inner h2 {
    margin-top: 90px;
    text-align: center;
    font-size: 5rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-font .unit .inner h3 {
    margin: 3rem 0;
    text-align: center;
    font-size: 3rem;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #fff;
  }

  .m-special-font .unit .inner h4 {
    font-size: 3rem;
    padding: 1rem 5rem;
    background-color: #822d3b;
    color: white;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    margin: 5rem auto;
    width: 45%;
    text-align: center;
  }

  .pc_img {
    display: block !important;
  }
  .sp_img {
    display: none !important;
  }

  .m-special-font .unit .inner .nnimg {
    margin: 3rem 8rem;
  }

  .m-special-font .unit .inner .nnimg img {
    width: 100%;
  }

  .m-special-font .unit .inner p {
    margin: 3rem 0 0;
    text-align: center;
    color: #fff;
    font-size: 1.2rem;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
  }
  .m-special-font .unit .inner .img {
    margin: 3rem 0 0;
    text-align: center;
  }

  /*------------------------------
   m-special-product
  ------------------------------*/
  .m-special-product {
    margin: -6rem 0 0;
    padding: 9rem 3rem 3rem;
  }
  .m-special-product .unit .inner {
    width: min(100% - 2rem, 1560px);
    margin-inline: auto;
  }
  .m-special-product .unit .inner h2 {
    font-family: "UrawaRedsDisplay", sans-serif;
    margin: 0;
    text-align: center;
    font-size: 5rem;
    font-weight: bold;
    color: #fff;
  }
  .m-special-product .unit .inner .container {
    padding: 2rem 4rem 0;
    max-width: 100%;
  }
  .m-special-product .unit .inner .container .product {
    margin: 1rem 0 0;
    padding: 1rem 2rem;
  }
  .m-special-product .unit .inner .container .product img {
    filter: drop-shadow(0 0 4px #000);
  }
  .m-special-product .unit .inner .container .product.comingsoon img {
    filter: brightness(0.2) drop-shadow(0px 0px 4px #000);
  }
  .m-special-product .unit .inner .container .product.comingsoon a {
    background-color: gray;
  }
  .m-special-product .unit .inner .container .product.comingsoon a:hover {
    background-color: gray;
  }
  .m-special-product .unit .inner .container .product h3 {
    margin-bottom: 2rem;
    font-size: max(1.5vw, 15px);
    font-weight: bold;
    color: #fff;
    text-align: center;
  }
  .m-special-product .unit .inner .container .product p {
    margin: 1rem 0 0;
    text-align: center;
    color: #fff;
  }
  .m-special-product .unit .inner .container .product p span {
    font-size: 0.8rem;
  }

  .m-special-product .unit .inner .container .product .price {
    font-size: 1.3rem;
  }
  .m-special-product .unit .inner .container .product a {
    display: block;
    margin: 1rem 0 0;
    padding: 1rem 0;
    text-align: center;
    color: #fff;
    border: 2px #fff solid;
    background-color: #e4000d;
  }

  .m-special-product .unit .inner .container .product .comingSoon {
    background-color: #51595c;
    pointer-events: none;
  }

  .m-special-product .unit .inner .container .product .soldOut {
    background-color: #51595c;
    pointer-events: none;
  }

  .m-special-product .unit .inner .container .product a:hover {
    color: #fff;
    background-color: #ae101c;
  }

  .m-special-product .unit .inner .sentence p {
    margin: 3rem 8rem;
    font-size: 1rem;
    color: #fff;
  }
  .m-special-product .unit .inner .sentence p:last-of-type {
    margin: 1rem 0 3rem;
  }

  /*------------------------------
   m-special-img
  ------------------------------*/
  .m-special-img {
    margin: -6rem 0 0;
    padding: 9rem 6rem 3rem;
  }
  /*
  .m-special-img .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 4rem;
    font-weight: bold;
    color: #fff;
  }
  .m-special-img .unit .inner .img {
    margin: 3rem 0 0;
  }
  */

  /*------------------------------
   m-special-campaign
  ------------------------------*/
  .m-special-campaign {
    margin: 0;
    padding: 4rem 0.5rem 3rem;
  }
  .m-special-campaign .unit .inner {
    width: min(100% - 2rem, 1560px);
    margin-inline: auto;
    background: #000000;
  }
  .m-special-campaign .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 5rem;
    font-family: "UrawaRedsDisplay", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-campaign .unit .inner .container {
    display: flex;
    margin: 3rem 0rem;
    position: relative;
    min-width: 100%;
  }
  .m-special-campaign .unit .inner .container .campaign {
    display: flex;
    width: 100%;
    padding: 2rem;
    flex-direction: column;
    position: relative;
  }

  .m-special-campaign .unit .inner .container .campaign .image_wrapper {
    position: relative;
    display: inline-block;
  }

  .m-special-campaign .unit .inner .container .campaign .image_wrapper img {
    display: block;
    width: 100%;
    height: auto;
  }

  .m-special-campaign .unit .inner .container .campaign .image_wrapper .overlay {
    position: absolute;
    top: 15%;
    left: 15%;
    width: 70%;
    height: 70%;
    background-color: rgba(0, 0, 0, 0.6); /* 半透明のグレー */
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff; /* 白い文字 */
    font-size: 1.5em;
    font-weight: bold;
    z-index: 10;
    pointer-events: none; /* クリックを透過 */
  }

  .circle_badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background-color: #bc9a68;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    padding: 5px 10px;
    border-radius: 50%;
    text-align: center;
    width: 150px;
    height: 150px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 50;
  }

  .circle_badge span {
    font-size: 1.6rem;
  }

  .m-special-campaign .unit .inner .container .campaign .tag {
    width: fit-content;
    margin: 0;
    padding: 0.5rem 4rem;
    background-color: var(--color-5);
    position: absolute;
    font-size: 2rem;
    left: -1rem;
    font-family: "Noto Sans JP", sans-serif;
    transform: rotate(-15deg);
    top: 2rem;
  }
  .m-special-campaign .unit .inner .container .campaign h3 {
    min-height: 4rem;
    margin: 1rem 0 0;
    font-size: 2rem;
    font-weight: bold;
    color: #fff;
    text-align: center;
  }

  .m-special-campaign .unit .inner .container .campaign h4 {
    min-height: 8rem;
    margin: 3rem 0 0;
    font-size: 1.6rem;
    font-weight: bold;
    color: #fff;
  }
  .m-special-campaign .unit .inner .container .campaign img {
    display: block;
    margin: 1rem 0 1rem;
  }

  .m-special-campaign .unit .inner .container .campaign p {
    font-size: 1rem;
    color: #fff;
  }
  .m-special-campaign .unit .inner .container .campaign p:last-of-type {
    margin: 1rem 0 3rem;
  }
  .m-special-campaign .unit .inner .container .campaign a {
    font-size: 25px;
    padding: 1.5rem 4rem;
    background-color: var(--color-1);
    color: white;
    font-weight: bold;
    margin: 0 auto 50px;
    transition: 0.5s;
    font-family: "Noto Sans JP", sans-serif;
    width: 40%;
    text-align: center;
    cursor: pointer;
    position: relative;
  }
  .m-special-campaign .unit .inner .container .campaign a:hover {
    color: var(--color-1);
    background-color: #fff;
  }
  .m-special-campaign .unit .inner .container .campaign.close .tag {
    background-color: #003a90;
  }
  .m-special-campaign .unit .inner .container .campaign.close img {
    filter: brightness(0.2);
  }

  .m-special-campaign .unit .inner .container .video {
    width: 100%;
    padding: 1rem;
    flex-direction: column;
  }

  /*------------------------------
   m-special-news
  ------------------------------*/
  .m-special-news {
    margin: -6rem 0 0;
    padding: 9rem 3rem 3rem;
  }
  .m-special-news .unit .inner h2 {
    margin: 0 0 2rem;
    text-align: center;
    font-size: 5rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-news .unit .inner dl {
    display: flex;
    margin: 0;
    justify-content: space-between;
    border-bottom: 2px #fff solid;
  }
  .m-special-news .unit .inner dl dt {
    padding: 1rem;
    font-size: 1.25rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-news .unit .inner dl dd {
    width: 85%;
    padding: 1rem;
    font-size: 1.25rem;
    font-weight: bold;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
  }
  .m-special-news .unit .inner dl dd a {
    color: #fff;
    border-bottom: 1px #fff solid;
  }
  .m-special-news .unit .inner dl dd a:hover {
    border-bottom: 1px #ae101c solid;
  }

  /*------------------------------
   m-special-notice
  ------------------------------*/
  .m-special-notice {
    margin: -6rem 0 0;
    padding: 9rem 3rem 3rem;
  }
  .m-special-notice .unit .inner {
    width: min(100% - 2rem, 1560px);
    margin-inline: auto;
  }
  .m-special-notice .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 4rem;
    font-weight: 800;
    color: #fff;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  }

  .m-special-notice .unit .inner h4 {
    font-size: 3rem;
    color: white;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    margin: 5rem auto;
    text-align: center;
  }

  .m-special-notice .unit .inner h5 {
    margin: 3rem 0 0;
    text-align: left;
    font-size: 1.5rem;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
  }

  .m-special-notice .unit .inner table {
    margin: 1rem 0 1rem;
  }

  .m-special-notice .unit .inner table td {
    border: solid 2px #000;
    color: #000;
    text-align: center;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
    background-color: #fff;
  }

  .m-special-notice .unit .inner table td.bg-white {
    background-color: white;
    color: var(--color-1);
  }

  .m-special-notice .unit .inner .notice_list {
    color: #fff;
  }

  .m-special-notice .unit .inner .notice_list li {
    font-size: 1rem;
    margin-bottom: 0.5rem;
  }

  .m-special-notice .unit .inner .ttl_comingSoon {
    font-size: 5rem;
    font-weight: bold;
    color: #fff;
    text-align: center;
    margin: 90px 0 90px 0;
  }

  .m-special-notice .unit .inner h6 {
    margin: 0rem 0 0;
    text-align: left;
    font-size: 1.3rem;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
  }

  .m-special-notice .unit .inner dl {
    display: flex;
    margin: 1rem 0 0;
    flex-wrap: wrap;
  }
  .m-special-notice .unit .inner dl dt {
    width: 25%;
    padding: 1rem;
    font-size: 1.5rem;
    font-weight: bold;
    color: #000;
    background-color: #ccc;
    border-bottom: 5px solid #c30d23;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
  }
  .m-special-notice .unit .inner dl dd {
    width: 75%;
    padding: 1rem;
    font-size: 1.25rem;
    color: #000;
    background-color: #fff;
    border-bottom: 5px solid #c30d23;
  }
  .m-special-notice .unit .inner dl dd a {
    color: #e5012c;
  }
  .m-special-notice .unit .inner dl dd a:hover {
    border-bottom: 1px #e5012c solid;
  }
  .m-special-notice .unit .inner dl dd span {
    /* font-weight: bold; */
    color: #e5012c;
  }

  /*------------------------------
   m-special-faq
  ------------------------------*/

  .m-special-faq {
    padding: 3rem;
    /* background-color: var(--color-2); */
  }

  .m-special-faq .unit .inner {
    max-width: 1120px;
    margin: 0 auto;
    width: 100%;
  }

  .m-special-faq .unit .inner h1 {
    color: white;
    text-align: center;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    padding: 50px 0 20px;
    font-size: 70px;
    margin: 50px 10% 80px;
  }

  .m-special-faq .unit .inner .faq-block {
    padding: 3% 5%;
  }

  .m-special-faq .unit .inner .faq-block h2 {
    background-color: var(--color-1);
    font-size: 30px;
    color: #ffffff;
    position: relative;
    margin: 0;
    padding: 20px 4rem 20px 30px;
    font-family: "Oswald", "Noto Sans JP", sans-serif;
    font-weight: bold;
  }

  .m-special-faq .unit .inner .faq-block h2 span {
    padding-left: 4rem;
  }

  .m-special-faq .unit .inner .faq-block h2 .slide-btn {
    position: absolute;
    display: block;
    height: 20px;
    right: 30px;
    top: 50%;
    transition: 0.5s;
    transform: translateY(-50%);
  }

  .m-special-faq .unit .inner .faq-block h2.active .slide-btn {
    transform: rotate(180deg) translateY(10px);
  }

  .m-special-faq .unit .inner .faq-block h3 {
    background-color: #ffffff;
    font-size: 30px;
    color: var(--color-1);
    position: relative;
    border: 1px solid var(--color-1);
    margin: 0;
    padding: 20px 30px;
    display: none;
    font-family: "Oswald", "Noto Sans JP", sans-serif;
    font-weight: bold;
  }

  .m-special-faq .unit .inner .faq-block p {
    font-size: 30px;
    margin-bottom: 2rem;
  }

  .m-special-faq .unit .inner .btn-area {
    text-align: center;
    margin-top: 80px;
  }

  .m-special-faq .unit .inner .btn-area a {
    background-color: #ffffff;
    font-size: 30px;
    color: #b90e16;
    border: 1px solid #b90e16;
    padding: 20px 30px;
  }

  .m-special-faq .unit .inner .btn-area a:hover {
    background-color: #b90e16;
    color: #ffffff;
  }

  /*------------------------------
   m-special-other
  ------------------------------*/
  .m-special-other {
    margin: -6rem 0 0;
    padding: 9rem 3rem 3rem;
  }
  .m-special-other .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 4rem;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: 800;
    color: #fff;
  }
  .m-special-other .unit .inner .comingsoon {
    margin: 2.5rem 0 0;
    text-align: center;
    font-size: 2rem;
    color: #fff;
  }
  .m-special-other .unit .inner .container {
    display: flex;
    margin: 2.5rem 0 0;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .m-special-other .unit .inner .container .img {
    width: 50%;
    padding: 0.5rem;
  }

  /*------------------------------
   m-special-sns
  ------------------------------*/
  .m-special-sns .unit .inner p {
    color: #fff;
  }

  /*------------------------------
   m-special-buybtn
  ------------------------------*/
  .m-special-buybtn {
    position: fixed;
    bottom: 0;
    z-index: 52;
  }
  .m-special-buybtn .unit .inner .btn {
    width: 22rem;
  }

  .text-center {
    text-align: center;
  }

}

@media only screen and (max-width: 1023.5px) {
  /*------------------------------
 m-special-nav
------------------------------*/
  .m-special-nav .unit .inner .nav #checkbox {
    display: none;
  }
  .m-special-nav .unit .inner .nav #checkbox:checked ~ .content {
    left: 0;
  }
  .m-special-nav .unit .inner .nav #checkbox:checked ~ .btn {
    border: unset;
  }
  .m-special-nav .unit .inner .nav #checkbox:checked ~ .btn span {
    background-color: rgba(255, 255, 255, 0);
  }
  .m-special-nav .unit .inner .nav #checkbox:checked ~ .btn span::before {
    bottom: 0;
    transform: rotate(45deg);
  }
  .m-special-nav .unit .inner .nav #checkbox:checked ~ .btn span::after {
    top: 0;
    transform: rotate(-45deg);
  }
  .m-special-nav .unit .inner .nav .btn {
    display: flex;
    height: 3rem;
    width: 3rem;
    background-color: #ae101c;
    border: 2px #fff solid;
    border-radius: 0.25rem;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 115px;
    right: 0.8rem;
    z-index: 52;
  }
  .m-special-nav .unit .inner .nav .btn span,
  .m-special-nav .unit .inner .nav .btn span:before,
  .m-special-nav .unit .inner .nav .btn span:after {
    display: block;
    height: 4px;
    width: 1.5rem;
    background-color: #fff;
    border-radius: 1rem;
    position: absolute;
    content: "";
  }
  .m-special-nav .unit .inner .nav .btn span:before {
    bottom: 0.5rem;
  }
  .m-special-nav .unit .inner .nav .btn span:after {
    top: 0.5rem;
  }
  .m-special-nav .unit .inner .nav .content {
    height: 100%;
    width: 100%;
    background-color: #ae101c;
    transition: 0.3s;
    position: fixed;
    top: 85px;
    left: 100%;
    z-index: 51;
  }
  .m-special-nav .unit .inner .nav .content ul {
    padding: 2.5rem 1rem 0;
  }
  .m-special-nav .unit .inner .nav .content ul li {
    border-bottom: 2px #fff solid;
  }
  .m-special-nav .unit .inner .nav .content ul li a {
    display: block;
    width: 100%;
    padding: 0.8rem 2rem 0.8rem 1rem;
    color: #fff;
    position: relative;
    font-family: "Oswald", "Noto Sans JP", sans-serif;
    font-weight: bold;
  }
  .m-special-nav .unit .inner .nav .content ul li a:before {
    height: 0.5rem;
    width: 0.5rem;
    border-top: 2px #fff solid;
    border-right: 2px #fff solid;
    position: absolute;
    content: "";
    top: 1.25rem;
    right: 1rem;
    transform: rotate(45deg);
  }

  /*------------------------------
   m-special-banner
  ------------------------------*/
  .m-special-banner {
    margin: 3.5rem 0 0;
    padding: 3rem 0 0;
  }

  .m-special-banner .unit .inner .banner {
    position: relative;
  }

  .m-special-banner .unit .inner .banner img {
    width: 100%;
  }

  /*------------------------------
   m-special-movie
  ------------------------------*/
  .m-special-movie {
    margin: -3rem 0 0;
    padding: 3rem 0 0;
  }

  .m-special-movie .unit .inner video {
    display: block;
    width: 100%;
    margin: auto;
  }
  /*------------------------------
   m-special-concept
  ------------------------------*/
  .m-special-concept {
    margin: -2rem 0 0;
    padding: 2rem 0 0;
  }

  .m-special-concept .unit {
    margin-bottom: 3rem;
  }

  .m-special-concept .unit .inner h1 {
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: 800;
    color: white;
    font-size: 25px;
    text-align: center;
    margin: -60px auto 0px;
    padding-top: 90px;
  }
  .m-special-concept .unit .inner .-mainTtl {
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    text-align: center;
    color: #fff;
    font-weight: bold;
    font-size: 25px;
  }

  .m-special-concept .unit .inner p {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: white;
    font-size: 13px;
    text-align: center;
    padding: 1em;
    line-height: 2;
  }

  .m-special-concept .unit .inner .btn-area {
    color: white;
    font-size: 20px;
    margin: 40px auto;
    text-align: center;
  }

  .m-special-concept .unit .inner .btn-area a {
    font-size: 18px;
    padding: 0.5rem 1rem;
    background-color: var(--color-1);
    color: white;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    margin: 0 10px;
  }

  .m-special-concept .unit .inner .btn-area a:hover {
    background-color: white;
    color: var(--color-1);
  }

  .m-special-concept .unit .inner .btn-area a:nth-of-type(2) {
    background-color: var(--color-7);
    color: black;
  }

  .m-special-concept .unit .inner .btn-area a:nth-of-type(2):hover {
    background-color: black;
    color: var(--color-7);
  }

  .m-special-concept .unit .inner .btn-area a:nth-of-type(3) {
    background-color: var(--color-6);
    color: white;
  }

  .m-special-concept .unit .inner .btn-area a:nth-of-type(3):hover {
    background-color: white;
    color: var(--color-6);
  }

  /*------------------------------
   m-special-uniform
  ------------------------------*/
  .m-special-uniform {
    margin: -3rem 0 0;
    padding: 3rem 0;
  }

  .m-special-uniform .unit .inner h2 {
    margin: 3rem 0 2rem 0;
    text-align: center;
    font-size: 2.5rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }

  .m-special-uniform .unit .inner .uniform-top {
    display: flex;
    align-items: center;
    flex-direction: column;
  }

  .m-special-uniform .unit .inner .uniform-top .image-area {
    width: 90%;
    margin: 50px auto;
  }

  .m-special-uniform .unit .inner .uniform-top .image-area img {
    width: 100%;
    padding: 0 3vw;
    filter: drop-shadow(0 0 4px #000);
  }

  .m-special-uniform .unit .inner .uniform-top .text-area {
    width: 90%;
  }

  .m-special-uniform .unit .inner .uniform-top .text-area h1 {
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: 800;
    color: white;
    font-size: 18px;
    text-align: left;
    margin: 20px auto;
  }

  .m-special-uniform .unit .inner .uniform-top .text-area p {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: white;
    font-size: 16px;
    padding-right: 5%;
  }

  .m-special-uniform2 {
    background-color: var(--color-7);
    color: black;
  }

  .m-special-uniform2 .unit .inner h2 {
    margin-top: 1rem;
    color: black;
  }

  .m-special-uniform2 .unit .inner .uniform-top .text-area h1 {
    color: black;
  }

  .m-special-uniform2 .unit .inner .uniform-top .text-area p {
    color: black;
  }

  .m-special-uniform3 {
    background-color: var(--color-6);
    color: white;
  }

  .m-special-uniform3 .unit .inner h2 {
    color: white;
  }

  .m-special-uniform3 .unit .inner .uniform-top .text-area h1 {
    color: white;
  }

  .m-special-uniform3 .unit .inner .uniform-top .text-area p {
    color: white;
  }

  .gk_img_wrapper {
    display: flex;
    flex-direction: column;
    padding: 1em;
    gap: 2rem;
  }

  /*------------------------------
   m-special-detail
  ------------------------------*/
  .m-special-detail {
    margin: -3rem 0 0;
    padding: 1rem 0;
  }

  .m-special-detail .unit .inner h4 {
    font-size: 15px;
    padding: 0.5rem 3rem;
    background-color: var(--color-1);
    color: white;
    font-weight: bold;
    margin: 0 auto 10px;
    font-family: "Noto Sans JP", sans-serif;
    width: 60%;
    text-align: center;
    position: relative;
  }

  .m-special-detail .unit .inner h4 .slide-btn {
    position: absolute;
    display: block;
    height: 10px;
    right: 15px;
    top: 12px;
    transition: 0.5s;
  }

  .m-special-detail .unit .inner h4.active .slide-btn {
    transform: rotate(180deg);
  }

  .m-special-detail .unit .inner h4.btn2 {
    background-color: black;
  }

  .m-special-detail .unit .inner h4.btn3 {
    background-color: var(--color-9);
  }

  .m-special-detail .unit .inner .detail-inner {
    display: none;
  }

  .m-special-detail .unit .inner h2 {
    margin: 2rem 0 1rem;
    text-align: center;
    font-size: 3rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }

  .m-special-detail .unit .inner .-jp {
    margin-top: 5rem;
    text-align: center;
    font-size: 2rem;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-detail2 .unit .inner .-jp {
    margin-top: 5rem;
    text-align: center;
    font-size: 3rem;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #000;
  }
  .m-special-detail .unit .inner .container {
    overflow: visible;
    margin-bottom: 2rem;
  }
  .m-special-detail .unit .inner .container .txt {
    padding: 1rem;
  }
  .m-special-detail .unit .inner .container .txt h3 {
    margin: 0;
    text-align: center;
    font-size: 1.75rem;
    font-family: "UrawaRedsDisplay", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-detail .unit .inner .container .txt p {
    margin: 1rem 0 0;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
  }

  .m-special-detail .unit .inner .container .txt .note {
    font-size: 14px;
  }

  .m-special-detail .unit .inner .under-image {
    width: 90%;
    padding: 10% 0;
    margin: auto;
  }

  .m-special-detail .unit .inner .under-image img {
    padding: 0 5%;
  }

  .m-special-detail .unit .inner .under-space {
    width: 100%;
    height: 50px;
    /* background-color: var(--color-2); */
  }

  .m-special-detail2 {
    background-color: var(--color-7);
    padding-bottom: 4rem;
  }

  .m-special-detail2 .unit .inner h2 {
    color: black;
  }

  .m-special-detail2 .unit .inner .container .txt h3 {
    color: black;
  }

  .m-special-detail2 .unit .inner .container .txt p {
    color: black;
  }

  .m-special-detail2 .unit .inner .container .note {
    font-size: 0.8rem;
    text-align: center;
    padding: 3%;
  }

  .m-special-detail3 {
    background-color: var(--color-6);
  }

  .m-special-detail3 .unit .inner h2 {
    color: white;
  }

  .m-special-detail3 .unit .inner .container .txt h3 {
    color: white;
  }

  .m-special-detail3 .unit .inner .container .txt p {
    color: white;
  }

  .m-special-detail .unit .inner .size {
    padding: 3rem 1rem 3rem;
  }

  .m-special-detail .unit .inner .size .txt h3 {
    margin: 0;
    text-align: center;
    font-size: 1.3rem;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #fff;
  }

  .m-special-detail .unit .inner .table-fixed {
    overflow: auto;
  }

  .m-special-detail .unit .inner table {
    margin: 1rem 0 1rem;
    width: 800px;
    border-collapse: separate;
    border: solid 0.5px black;
  }

  .m-special-detail .unit .inner table td {
    border: solid 1px black;
    background-color: white;
    text-align: center;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.6rem;
    padding: 0.2rem;
    color: #000;
  }

  .m-special-detail .unit .inner table .fixed01 {
    position: sticky;
    left: 0;
  }
  .m-special-detail .unit .inner table .fixed01.bg-td-red {
    background-color: #c30d23;
    color: white;
  }

  .m-special-detail .unit .inner table td.bg-white {
    background-color: white;
    color: var(--color-1);
  }

  .m-special-detail .unit .inner table td.bg-white {
    background-color: white;
    color: black;
  }

  .m-special-detail .unit .inner table td.bg-black {
    background-color: black;
    color: white;
  }

  .m-special-detail .unit .inner dl {
    margin: 1rem 0 0;
    border: 1px #eee solid;
  }
  .m-special-detail .unit .inner dl dt {
    padding: 1rem;
    text-align: center;
    font-weight: bold;
    color: #000;
    background-color: #ccc;
    border: 1px #eee solid;
  }
  .m-special-detail .unit .inner dl dd {
    padding: 1rem;
    color: #000;
    background-color: #fff;
    border: 1px #eee solid;
    line-height: 1.5rem;
  }
  .m-special-detail .unit .inner dl dd a {
    color: #ae101c;
  }
  .m-special-detail .unit .inner dl dd span {
    font-weight: bold;
    color: #ae101c;
  }

  .m-special-detail2 .unit .inner .size {
    padding: 3rem 1rem 3rem;
  }

  .m-special-detail2 .unit .inner .size .txt h3 {
    margin: 0;
    text-align: center;
    font-size: 1.75rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: black;
  }

  .m-special-detail2 .unit .inner .table-fixed {
    overflow: auto;
  }

  .m-special-detail2 .unit .inner table {
    margin: 1rem 0 1rem;
    width: 800px;
    border-collapse: separate;
    border: solid 0.5px black;
  }

  .m-special-detail2 .unit .inner table td {
    border: solid 0.5px black;
    background-color: var(--color-7);
    color: black;
    text-align: center;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.6rem;
    padding: 0.2rem;
  }

  .m-special-detail2 .unit .inner table .fixed01 {
    position: sticky;
    left: 0;
    border: solid 0.5px black;
  }

  .m-special-detail2 .unit .inner table td.bg-white {
    background-color: white;
    color: black;
  }

  .m-special-detail2 .unit .inner dl {
    margin: 1rem 0 0;
    border: 1px #eee solid;
  }
  .m-special-detail2 .unit .inner dl dt {
    padding: 1rem;
    text-align: center;
    font-weight: bold;
    color: #000;
    background-color: #ccc;
    border: 1px #eee solid;
  }
  .m-special-detail2 .unit .inner dl dd {
    padding: 1rem;
    color: #000;
    background-color: #fff;
    border: 1px #eee solid;
    line-height: 1.5rem;
  }
  .m-special-detail2 .unit .inner dl dd a {
    color: #ae101c;
  }
  .m-special-detail2 .unit .inner dl dd span {
    font-weight: bold;
    color: #ae101c;
  }

  .m-special-detail3 .unit .inner .size {
    padding: 3rem 1rem 3rem;
  }

  .m-special-detail3 .unit .inner .size .txt h3 {
    margin: 0;
    text-align: center;
    font-size: 1.75rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }

  .m-special-detail3 .unit .inner .table-fixed {
    overflow: auto;
  }

  .m-special-detail3 .unit .inner table {
    margin: 1rem 0 1rem;
    width: 800px;
    border-collapse: separate;
    border: solid 0.5px black;
  }

  .m-special-detail3 .unit .inner table td {
    border: solid 0.5px black;
    background-color: var(--color-6);
    color: white;
    text-align: center;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.6rem;
    padding: 0.2rem;
  }

  .m-special-detail3 .unit .inner table .fixed01 {
    position: sticky;
    left: 0;
    border: solid 0.5px black;
  }

  .m-special-detail3 .unit .inner table td.bg-white {
    background-color: white;
    color: black;
  }

  .m-special-detail3 .unit .inner dl {
    margin: 1rem 0 0;
    border: 1px #eee solid;
  }
  .m-special-detail3 .unit .inner dl dt {
    padding: 1rem;
    text-align: center;
    font-weight: bold;
    color: #000;
    background-color: #ccc;
    border: 1px #eee solid;
  }
  .m-special-detail3 .unit .inner dl dd {
    padding: 1rem;
    color: #000;
    background-color: #fff;
    border: 1px #eee solid;
    line-height: 1.5rem;
  }
  .m-special-detail3 .unit .inner dl dd a {
    color: #ae101c;
  }
  .m-special-detail3 .unit .inner dl dd span {
    font-weight: bold;
    color: #ae101c;
  }
  /*------------------------------
   m-special-font
  ------------------------------*/
  .m-special-font {
            margin: -3rem 0 0;
        padding: 6rem 1rem 3rem;
  }
  .m-special-font .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 2.3rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-font .unit .inner h3 {
    margin: 2rem auto;
    text-align: center;
    font-size: 1.5rem;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #fff;
  }

  .m-special-font .unit .inner h4 {
    font-size: 2rem;
    padding: 0.5rem 2rem;
    background-color: #822d3b;
    color: white;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    margin: 2rem auto;
    width: 80%;
    text-align: center;
  }

  .pc_img {
    display: none !important;
  }
  .sp_img {
    display: block !important;
  }

  .m-special-font .unit .inner .nnimg {
    margin: 1rem 0;
  }

  .m-special-font .unit .inner .nnimg img {
    width: 100%;
  }

  .m-special-font .unit .inner p {
    margin: 3rem 0 0;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
  }
  .m-special-font .unit .inner .img {
    margin: 1rem 0 0;
  }

  /*------------------------------
   m-special-product
  ------------------------------*/
  .m-special-product {
    margin: -3rem 0 0;
    padding: 6rem 0;
  }
  .m-special-product .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 3rem;
    font-weight: bold;
    color: #fff;
    font-family: "UrawaRedsDisplay", sans-serif;
  }
  .m-special-product .unit .inner .container {
    padding: 2rem 0.5rem 0;
  }
  .m-special-product .unit .inner .container .product {
    margin: 1rem 0 0;
    padding: 0 0.5rem;
  }
  .m-special-product .unit .inner .container .product img {
    filter: drop-shadow(0 0 4px #000);
  }

  .m-special-product .unit .inner .container .product.comingsoon img {
    filter: brightness(0.2) drop-shadow(0px 0px 4px #000);
  }
  .m-special-product .unit .inner .container .product.comingsoon a {
    background-color: gray;
  }
  .m-special-product .unit .inner .container .product h3 {
    height: 4rem;
    margin: 1rem 0 0;
    font-size: 0.95rem;
    font-weight: bold;
    color: #fff;
    text-align: center;
  }
  .m-special-product .unit .inner .container .product p {
    margin: 1rem 0 0;
    text-align: center;
    color: #fff;
  }
  .m-special-product .unit .inner .container .product p span {
    font-size: 0.8rem;
  }
  .m-special-product .unit .inner .container .product .price {
    font-size: 1.1rem;
    font-weight: bold;
  }
  .m-special-product .unit .inner .container .product a {
    display: block;
    margin: 1rem 0 0;
    padding: 1rem 0;
    text-align: center;
    color: #fff;
    border: 2px #fff solid;
    background-color: #e4000d;
  }

  .m-special-product .unit .inner .container .product .comingSoon {
    background-color: #51595c;
    pointer-events: none;
  }

  .m-special-product .unit .inner .container .product .soldOut {
    background-color: #51595c;
    pointer-events: none;
  }

  .m-special-product .unit .inner .sentence p {
    margin: 2rem 0 0;
    padding: 1rem;
    color: #fff;
    font-size: 14px;
  }

  /*------------------------------
   m-special-img
  ------------------------------*/
  .m-special-img {
    margin: -3rem 0 0;
    padding: 6rem 0;
  }
  /*
  .m-special-img .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 1.5rem;
    font-weight: bold;
    color: #fff;
  }
  .m-special-img .unit .inner .img {
    margin: 3rem 0 0;
  }
  */

  /*------------------------------
   m-special-campaign
  ------------------------------*/
  .m-special-campaign {
    margin: 0;
    padding: 4rem 1rem;
  }
  .m-special-campaign .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 3rem;
    font-family: "UrawaRedsDisplay", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-campaign .unit .inner .container {
    margin: 2.5rem 0 0;
    overflow: visible;
  }
  .m-special-campaign .unit .inner .container .campaign {
    margin: 5rem 0 0;
    position: relative;
  }
  .m-special-campaign .unit .inner .container .campaign .image_wrapper {
    position: relative;
    display: inline-block;
  }

  .m-special-campaign .unit .inner .container .campaign .image_wrapper img {
    display: block;
    width: 100%;
    height: auto;
  }

  .m-special-campaign .unit .inner .container .campaign .image_wrapper .overlay {
    position: absolute;
    top: 20%;
    left: 15%;
    width: 70%;
    height: 70%;
    background-color: rgba(0, 0, 0, 0.6); /* 半透明のグレー */
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff; /* 白い文字 */
    font-size: 1.5em;
    font-weight: bold;
    z-index: 10;
    pointer-events: none; /* クリックを透過 */
  }

  .circle_badge {
    position: absolute;
    top: -60px;
    left: -10px;
    background-color: #bc9a68;
    color: #fff;
    font-size: 14px;
    font-weight: bold;
    padding: 5px 10px;
    border-radius: 50%;
    text-align: center;
    width: 100px;
    height: 100px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 50;
  }

  .circle_badge span {
    font-size: 20px;
  }

  .m-special-campaign .unit .inner .container .campaign .tag {
    width: fit-content;
    margin: 0;
    padding: 0.5rem 1rem;
    background-color: var(--color-5);
  }
  .m-special-campaign .unit .inner .container .campaign h3 {
    margin: 1rem 0 0;
    font-size: 1.5rem;
    font-weight: bold;
    color: #fff;
  }

  .m-special-campaign .unit .inner .container .campaign h4 {
    min-height: 8rem;
    margin: 3rem 0 0;
    font-size: 1.3rem;
    font-weight: bold;
    color: #fff;
  }

  .m-special-campaign .unit .inner .container .campaign img {
    display: block;
    margin: 1rem 0 0;
  }
  .m-special-campaign .unit .inner .container .campaign p {
    margin: 2rem 0 0;
    color: #fff;
  }
  .m-special-campaign .unit .inner .container .campaign a {
    display: block;
    width: fit-content;
    margin: 2rem auto 0;
    padding: 1rem 2rem;
    text-align: center;
    color: white;
    background-color: var(--color-1);
  }
  .m-special-campaign .unit .inner .container .campaign.close .tag {
    background-color: #003a90;
  }
  .m-special-campaign .unit .inner .container .campaign.close img {
    filter: brightness(0.2);
  }

  .m-special-campaign .unit .inner .container .video {
    margin: 3rem 0 0;
  }

  /*------------------------------
   m-special-news
  ------------------------------*/
  .m-special-news {
    margin: -3rem 0 0;
    padding: 6rem 1rem 3rem;
  }
  .m-special-news .unit .inner h2 {
    margin: 0 0 2rem;
    text-align: center;
    font-size: 3rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-news .unit .inner dl {
    margin: 0;
    padding: 0.25rem;
    border-bottom: 2px #fff solid;
  }
  .m-special-news .unit .inner dl dt {
    padding: 1rem 0 0.25rem;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-news .unit .inner dl dd {
    padding: 0.25rem 0 1rem;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #fff;
  }
  .m-special-news .unit .inner dl dd a {
    color: #fff;
    border-bottom: 1px #fff solid;
  }

  /*------------------------------
   m-special-notice
  ------------------------------*/
  .m-special-notice {
    margin: -3rem 0 0;
    padding: 6rem 1rem 3rem;
  }
  .m-special-notice .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 3rem;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: 800;
    color: #fff;
  }

  .m-special-notice .unit .inner h4 {
    font-size: 2rem;
    color: white;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    margin: 2rem auto;
    text-align: center;
  }

  .m-special-notice .unit .inner h5 {
    margin: 3rem 0 0;
    text-align: left;
    font-size: 0.9rem;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
  }

  .m-special-notice .unit .inner .table-fixed {
    overflow: auto;
  }

  .m-special-notice .unit .inner table {
    margin: 1rem 0 1rem;
    width: 800px;
  }

  .m-special-notice .unit .inner table td {
    border: solid 1px #000;
    color: #000;
    text-align: center;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.6rem;
    padding: 0.2rem;
    background-color: #fff;
  }

  .m-special-notice .unit .inner table .fixed01 {
    position: sticky;
    left: 0;
  }
  .m-special-notice .unit .inner table .fixed01.bg-td-red {
    background-color: #c30d23;
    color: white;
  }

  .m-special-notice .unit .inner table td.bg-white {
    background-color: white;
    color: var(--color-1);
  }
  .m-special-notice .unit .inner .notice_list {
    color: #fff;
  }

  .m-special-notice .unit .inner .notice_list li {
    font-size: 0.8rem;
    margin-bottom: 0.5rem;
  }

  .m-special-notice .unit .inner .ttl_comingSoon {
    font-size: 2rem;
    font-weight: bold;
    color: #fff;
    text-align: center;
    margin: 60px 0 60px 0;
  }

  .m-special-notice .unit .inner h6 {
    margin: 1rem 0 0;
    text-align: left;
    font-size: 0.9rem;
    color: #fff;
    font-family: "Noto Sans JP", sans-serif;
  }

  .m-special-notice .unit .inner dl {
    margin: 1rem 0 0;
    border: 1px #eee solid;
  }
  .m-special-notice .unit .inner dl dt {
    padding: 1rem;
    text-align: center;
    font-weight: bold;
    color: #000;
    background-color: #ccc;
    border: 1px #eee solid;
  }
  .m-special-notice .unit .inner dl dd {
    padding: 1rem;
    color: #000;
    background-color: #fff;
    border: 1px #eee solid;
    line-height: 1.5rem;
  }
  .m-special-notice .unit .inner dl dd a {
    color: #ae101c;
  }
  .m-special-notice .unit .inner dl dd span {
    font-weight: bold;
    color: #ae101c;
  }

  /*------------------------------
   m-special-faq
  ------------------------------*/
  .m-special-faq {
    padding: 3rem 1rem;
    /* background-color: var(--color-2); */
  }
  .m-special-faq .unit .inner h1 {
    color: white;
    text-align: center;
    padding: 50px 0 20px;
    font-size: 2rem;
    margin: 0 10% 30px;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
  }

  .m-special-faq .unit .inner .faq-block {
    margin: 20px 0;
  }

  .m-special-faq .unit .inner .faq-block h2 {
    background-color: var(--color-1);
    font-size: 12px;
    color: #ffffff;
    position: relative;
    margin: 0;
    padding: 10px 2.5rem 10px 20px;
    font-family: "Oswald", "Noto Sans JP", sans-serif;
    font-weight: bold;
  }

  .m-special-faq .unit .inner .faq-block h2 span {
    padding-left: 1.5rem;
  }

  .m-special-faq .unit .inner .faq-block h2 .slide-btn {
    position: absolute;
    display: block;
    height: 10px;
    right: 20px;
    top: 50%;
    transition: 0.5s;
    transform: translateY(-50%);
  }

  .m-special-faq .unit .inner .faq-block h2.active .slide-btn {
    transform: rotate(180deg) translateY(5px);
  }

  .m-special-faq .unit .inner .faq-block h3 {
    background-color: #ffffff;
    font-size: 12px;
    color: var(--color-1);
    position: relative;
    border: 1px solid var(--color-1);
    margin: 0;
    padding: 10px 20px;
    display: none;
    font-family: "Oswald", "Noto Sans JP", sans-serif;
    font-weight: bold;
  }

  .m-special-faq .unit .inner .faq-block p {
    font-size: 12px;
    margin-bottom: 1rem;
  }

  .m-special-faq .unit .inner .btn-area {
    text-align: center;
    margin-top: 50px;
  }

  .m-special-faq .unit .inner .btn-area a {
    background-color: #ffffff;
    font-size: 20px;
    color: #b90e16;
    border: 1px solid #b90e16;
    padding: 10px 20px;
  }

  /*------------------------------
   m-special-other
  ------------------------------*/
  .m-special-other {
    margin: -3rem 0 0;
    padding: 6rem 1rem 3rem;
  }
  .m-special-other .unit .inner h2 {
    margin: 0;
    text-align: center;
    font-size: 3rem;
    font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
    font-weight: 800;
    color: #fff;
  }
  .m-special-other .unit .inner .comingsoon {
    margin: 2.5rem 0 0;
    text-align: center;
    font-size: 1.5rem;
    color: #fff;
  }
  .m-special-other .unit .inner .container {
    margin: 2.5rem 0 0;
    overflow: visible;
  }
  .m-special-other .unit .inner .container .img {
    padding: 0.5rem 0;
  }

  /*------------------------------
   m-special-sns
  ------------------------------*/
  .m-special-sns .unit .inner p {
    color: #fff;
    border-bottom: 2px #fff solid;
  }

  /*------------------------------
   m-special-buybtn
  ------------------------------*/
  .m-special-buybtn {
    position: fixed;
    bottom: 0;
    z-index: 3;
  }
  .m-special-buybtn .unit .inner .btn {
    width: 18rem;
  }
  .slick03 .slick-slide {
    padding: 0em;
  }

}

.m-special-movie .unit .inner iframe {
 width: min(100% - 2rem, 1360px);   
 display: block;
    width: 100%;
    margin: auto;
    position: relative;
    z-index: 1;
}
ul.note {
	list-style-type: none;
	margin-left:12px;
}
ul.note li:before {
	content: '※';
	margin-left:-12px;
}

ul.note li{
text-align: justify;
display: block;
}

.txt_white {
    color: #ffffff!important;
}