@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Londrina+Solid:wght@100;300;400;900&family=Murecho:wght@100..900&display=swap');
html {
 font-size: 62.5%;
}
body {
 font-family: "Murecho", "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, Arial, sans-serif;
 letter-spacing: 0.075em;
 font-weight: 600;
 color: #241C1C;
 font-size: 1.6rem;
 line-height: 1.7;
 overflow-x: clip;
}
a {
 display: block;
 transition: .2s;
 text-decoration: none;
 color: #fcfcfc;
}
img {
 display: block;
 width: 100%;
 height: auto;
 /*pointer-events: none;*/
 -webkit-touch-callout: none;
 -webkit-user-select: none;
 -moz-touch-callout: none;
 -moz-user-select: none;
 user-select: none;
 /*image-rendering: -webkit-optimize-contrast;*/
}
em {
 display: inline-block;
 font-size: 80%;
 font-weight: inherit;
}
span {
 font-weight: inherit;
}
small {
 font-weight: inherit;
 font-size: 70%;
}
.mfp-bg {
 opacity: 0;
 -webkit-transition: all 0.15s ease-out;
 -moz-transition: all 0.15s ease-out;
 transition: all 0.15s ease-out;
}
.mfp-bg.mfp-ready {
 opacity: 0.8;
}
.mfp-bg.mfp-removing {
 opacity: 0;
}
.mfp-wrap .mfp-content {
 opacity: 0;
 -webkit-transition: all 0.15s ease-out;
 -moz-transition: all 0.15s ease-out;
 transition: all 0.15s ease-out;
}
.mfp-wrap.mfp-ready .mfp-content {
 opacity: 1;
}
.mfp-wrap.mfp-removing .mfp-content {
 opacity: 0;
}
.mfp-content {
 box-sizing: border-box;
 padding: 2% 5%;
 
 text-align: center;
}
.mfp-content .popup {
    position: relative;
    max-width: 100rem;
    text-align: center;
    margin: 0 auto;
}
.mfp-content .popup a {
 display: block;
 width: 100%;
 height: 100%;
 position: relative;
 top: 0;
 left: 0;
 z-index: 2;
 text-align: center;
}
.mfp-content .popup img {
    max-height: 90vh;
    width: auto;
    max-width: 0 auto;
    display: inline-block;
    text-align: center;
}
.box {
 opacity: 0;
}
.caution {
 padding-top: 1em;
 font-size: 1.2rem;
 line-height: 1.5;
}
ul.caution li {
 text-indent: -1em;
 padding-left: 1em;
}
.sp {
 display: none !important;
}
.pc {
 display: block;
}
.tLeft {
 text-align: left !important;
}
.drawer-hamburger {
 display: block;
}
#wrapper {
 position: relative;
}
#wrapper.lower {
 height: 100%;
 padding-left: 30rem;
}
article {
 position: relative;
 z-index: 5;
 width: 100%;
 box-sizing: content-box;
}
section {
 position: relative;
 width: 100%;
 z-index: 5;
 text-align: center;
}
.inner {
 position: relative;
 margin: 0 auto;
 z-index: 5;
 width: 100%;
 max-width: 1280px;
 padding: 0 5%;
 text-align: center;
 display: block;
}
.en {
 font-family: 'Londrina Solid', sans-serif;
 letter-spacing: 0;
}
.secTtl {
 position: relative;
 z-index: 15;
 line-height: 1.1;
 text-align: center;
 color: #fff;
 display: inline-block;
 font-size: 10rem;
 letter-spacing: 0;
}
.secTtl .en {
 font-family: 'Londrina Solid', sans-serif;
 line-height: 1;
 display: inline-block;
 color: #1a0b08;
 position: relative;
}
.secTtl .en:first-letter {
 font-size: 160%;
}
.secTtl em {
 position: absolute;
 color: #1a0b08;
 top: 0.6em;
 right: 0;
 font-size: 37%;
 font-weight: 800;
}
.secTtl em small {
 display: block;
 font-weight: 800;
 font-size: 45%;
}
.yt {
 position: relative;
 width: 100%;
 padding-top: 56.25%;
 margin: 0 auto;
}
.yt iframe, .yt .yt_video {
 position: absolute;
 top: 0;
 right: 0;
 width: 100%;
 height: 100%;
 overflow: hidden;
}
.yt_video img {
 width: 100%;
 height: auto;
 position: absolute;
 top: 50%;
 left: 50%;
 transform: translateY(-50%) translateX(-50%);
 -webkit- transform: translateY(-50%) translateX(-50%);
}
.yt_video::before {
 position: absolute;
 content: "";
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
 opacity: 0.9;
 transition: 0.2s;
 background: url("../images/icon_yt_red.svg") no-repeat;
 background-size: cover;
 width: 68px;
 height: 48px;
 z-index: 2;
}
.yt_video img:hover {
 cursor: pointer;
 width: 100%;
 height: auto;
 box-sizing: border-box;
}
.yt_video:hover::before {
 background: url("../images/icon_yt_bk.svg") no-repeat;
 background-size: cover;
 opacity: 0.8;
}
.btn a {
 background: #ef834a;
 color: #f5f9f0;
 display: inline-block;
 padding: 0.5em 5rem 0.4em 3rem;
 position: relative;
 font-size: 100%;
 border-radius: 20rem;
 line-height: 1.2;
 text-align: left;
 box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
}
.btn a:hover {
 background: #ea5006 !important;
}
.btn.online a:hover {
 background: #2938A4 !important;
}
.btn a:after {
 content: "";
 position: absolute;
 margin: auto;
 top: 0;
 bottom: 0;
 right: 1.3rem;
 width: 4px;
 height: 4px;
 border-top: 2px solid #ef834a;
 border-right: 2px solid #ef834a;
 transform: rotate(45deg);
 transition: .2s;
}
.btn a:hover:after {
 border-top: 2px solid #ea5006 !important;
 border-right: 2px solid #ea5006 !important;
}
.btn.online a:hover:after {
 border-top: 2px solid #2938A4 !important;
 border-right: 2px solid #2938A4 !important;
}
.btn a:before {
 content: "";
 position: absolute;
 margin: auto;
 top: 0;
 bottom: 0;
 right: 0.75rem;
 width: 16px;
 height: 16px;
 border-radius: 50%;
 background: #f5f9f0;
}
.btn.disable a {
 background: #aaa !important;
 pointer-events: none !important;
}
.btn.disable a:after {
 border-top: 2px solid #aaa !important;
 border-right: 2px solid #aaa !important;
}
.btn.fany a {
 color: #f5f9f0;
 background: rgb(248, 175, 84);
 background: linear-gradient(90deg, rgba(248, 175, 84, 1) 0%, rgba(224, 43, 53, 1) 50%, rgba(189, 92, 155, 1) 100%);
}
.btn.fany a:after {
 border-top: 2px solid rgba(189, 92, 155, 1);
 border-right: 2px solid rgba(189, 92, 155, 1);
}
.btn.fany.disable a {
 /*box-shadow: 4px 4px 0 #aaa;
 -webkit-box-shadow: 4px 4px 0 #aaa;*/
}
.btn.pia a {
 background: #4D7FD6 !important;
 /*box-shadow: 4px 4px 0 #3763B1 !important;
 -webkit-box-shadow: 4px 4px 0 #3763B1 !important;*/
}
.btn.pia a:after {
 border-top: 2px solid #4D7FD6 !important;
 border-right: 2px solid #4D7FD6 !important;
}
.btn.pia a:hover {
 background: #2B66CC !important;
 color: #fef1e9 !important;
}
.btn.l-tike a {
 background: #3091CF !important;
 /*box-shadow: 4px 4px 0 #1E71A7 !important;
 -webkit-box-shadow: 4px 4px 0 #1E71A7 !important;*/
}
.btn.l-tike a:after {
 border-top: 2px solid #3091CF !important;
 border-right: 2px solid #3091CF !important;
}
.btn.l-tike a:hover {
 background: #0074be !important;
 color: #fef1e9 !important;
}
.btn.eplus a {
 background: #f16baa !important;
 /*box-shadow: 4px 4px 0 #C84D87 !important;
 -webkit-box-shadow: 4px 4px 0 #C84D87 !important;*/
}
.btn.eplus a:after {
 border-top: 2px solid #f16baa !important;
 border-right: 2px solid #f16baa !important;
}
.btn.eplus a:hover {
 background: #EC3F90 !important;
 color: #fef1e9 !important;
}
.btn.asoview a {
 background: #f44336 !important;
}
.btn.asoview a:hover {
 background: #D93226 !important;
}
.btn.pia.disable a, .btn.l-tike.disable a, .btn.eplus.disable a, .btn.asoview.disable a {
 /*box-shadow: 4px 4px 0 #aaa !important;
 -webkit-box-shadow: 4px 4px 0 #aaa !important;*/
 background: #aaa !important;
}
.btn.pia.disable a:after, .btn.l-tike.disable a:after, .btn.eplus.disable a:after, .btn.asoview.disable a:after {
 border-top: 2px solid #aaa !important;
 border-right: 2px solid #aaa !important;
}
.btn.soldOut a {
 pointer-events: none !important;
 color: rgba(255, 255, 255, 0.2) !important;
}
.btn.soldOut:before {
 content: "SOLD OUT";
 font-family: "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, Arial, sans-serif;
 display: block;
 width: 100%;
 position: absolute;
 left: 0;
 top: 50%;
 transform: translateY(-50%);
 z-index: 5;
 font-size: 1.3rem;
 text-align: center;
 line-height: 1;
 color: rgba(84, 84, 84, 0.90);
 letter-spacing: 0.05em;
}
.btn.soldOut a:befor {
 opacity: 0.2 !important;
}
.btn.soldOut a:after {
 width: 100% !important;
 height: 100% !important;
 left: 0;
 right: 0;
 background-color: #F7F6ED !important;
 border: none !important;
 transform: none !important;
}
/*.btn.fany.soldOut a,
.btn.pia.soldOut a,
.btn.l-tike.soldOut a,
.btn.eplus.soldOut a { 
 box-shadow: 4px 4px 0 #ccc !important;
 -webkit-box-shadow: 4px 4px 0 #ccc !important;
}*/
.cs {
 font-family: 'Rammetto One', sans-serif;
 font-size: 110%;
 display: block;
 background: #f8ed20;
 line-height: 1.1;
 padding: 2.5rem 0.25em 2.35rem;
}
header {
 position: fixed;
 z-index: 1000;
 top: 0;
 left: 0;
 height: 100%;
 width: 30rem;
 background: url("../images/bg_postar.png") repeat #eae7c4;
 background-size: auto 120%;
 border-right: solid 5px #dfaf52;
 padding: 3.5% 1rem;
}
header h1 {
 margin-bottom: 2em;
}
header nav ul li a {
 display: block;
 position: relative;
 font-size: 3rem;
 font-family: 'Londrina Solid', sans-serif;
 line-height: 1;
 font-weight: normal;
 color: #1a0b08;
 text-align: left;
 padding: 0.25em 0.25em 0.25em 2.2em;
}
header nav ul li a:before {
 content: "";
 position: absolute;
 margin: auto;
 top: 0;
 bottom: 0;
 right: 1.6rem;
 width: 0.7em;
 height: 0.7em;
 border-radius: 50%;
 background: #1a0b08;
}
header nav ul li a:after {
 content: "";
 position: absolute;
 margin: auto;
 top: 0;
 bottom: 0;
 right: 2.4rem;
 width: 5px;
 height: 5px;
 border-top: 3px solid #eae7c4;
 border-right: 3px solid #eae7c4;
 transform: rotate(45deg);
 transition: .2s;
}
header .sns {
 display: flex;
 align-items: center;
 justify-content: center;
 margin-top: 2em;
}
header .sns li {
 flex: 1 0 2.4rem;
 max-width: 2.4rem;
 margin: 0 1.5rem 0 0;
}
header .sns li:last-child {
 flex: 1 0 4.7rem;
 max-width: 4.7rem;
}
main {
 position: relative;
 z-index: 5;
 overflow: auto;
}
#note {
 padding: 5% 0;
 background: #ececec;
 border-bottom: solid 5px #dfaf52;
}
#note .inner {
 display: flex;
 justify-content: center;
}
#note .secTtl {
 font-size: 7rem;
 margin-bottom: 0.25em;
 display: inline-block;
}
#note .secTtl em {
 top: 0.5em;
 right: 2.9em;
}
#note .inner .card {
 display: block;
 text-align: center;
 padding-left: 5%;
}
#note .inner h3 {
 font-weight: bold;
 font-size: 1.2rem;
 margin: 1em 0 0.5em;
 letter-spacing: 0.05em;
 text-align: center;
}
#note .inner h3:first-of-type {
 margin: 0 0 0.5em;
}
#note .inner ul {
 display: inline-block;
 text-align: left;
 font-size: 1.4rem;
 font-weight: 500;
 letter-spacing: 0.015em;
}
#note .inner ul li {
 position: relative;
 line-height: 1.6;
 margin-bottom: 0.4em;
 padding-left: 0.8em;
 font-weight: 500;
}
#note .inner ul li:before {
 content: "";
 width: 5px;
 height: 5px;
 background: #1a0b08;
 border-radius: 50%;
 position: absolute;
 top: 0.65em;
 left: 0;
 opacity: 0.4;
}
#note .inner p {
 font-size: 1.3rem;
 line-height: 1.6;
 letter-spacing: 0.05em;
}
#pagetop {
 position: fixed;
 bottom: 1.5rem;
 right: 1rem;
 z-index: 99;
}
#pagetop a {
 box-sizing: border-box;
 display: block;
 width: 70px;
 height: 70px;
 border: solid 6px #ea5006;
 border-radius: 50%;
 /*box-shadow: 0 3px 10px rgb(0 0 0 / 16%);*/
}
#pagetop a:after {
 content: "";
 display: block;
 position: absolute;
 top: 50%;
 left: 50%;
 width: 80px;
 height: 80px;
 background-color: #ea5006;
 border-radius: 50%;
 transform: translate(-50%, -50%) scale(0, 0);
 transition: transform ease 0.2s;
}
#pagetop a:hover:after {
 transform: translate(-50%, -50%) scale(1.05, 1.05);
}
#pagetop a:before {
 content: "";
 position: absolute;
 z-index: 10;
 top: 55%;
 left: 50%;
 width: 20px;
 height: 20px;
 border-style: solid;
 border-color: #ea5006;
 border-width: 6px 0 0 6px;
 transform: translate(-50%, -50%) rotate(45deg);
 transition: border-color ease 0.1s;
}
#pagetop a:hover:before {
 border-color: #fff;
}
footer {
 position: relative;
 z-index: 10;
 background: #fff;
 text-align: center;
}
footer .archives {
 text-align: center;
 background: #f0844a;
 padding: 3.5% 1.5rem 5%;
 border-bottom: solid 5px #dfaf52;
}
footer .archives .secTtl {
 margin-bottom: 2rem;
 font-size: 7rem;
}
footer .archives .secTtl em {
 right: 1.6em;
 top: 0.5em;
}
footer .archives ul {
 font-size: 0;
 letter-spacing: -0.4em;
 display: block;
 text-align: center;
 margin: 0 auto;
}
footer .archives ul li {
 margin: 0 0.5rem 1.0rem;
 display: inline-block;
}
footer .archives ul li a {
 display: inline-block;
 font-size: 1.5rem;
 line-height: 2;
 padding: 0.5em 1em;
 font-weight: bold;
 position: relative;
 color: #fff;
 background: #222;
 white-space: nowrap;
 border-radius: 5px;
}
footer .archives ul li a:hover {
 color: #ffe765;
}
footer .flex {
 display: flex;
 justify-content: space-between;
 align-items: flex-start;
 padding: 5rem 1.5rem;
 max-width: 1080px;
 margin: 0 auto;
}
footer .op {
 position: relative;
 z-index: 2;
 padding-right: 2.5rem;
 flex: 1 0 50%;
}
footer .op p {
 font-size: 1.3rem;
 text-align: left;
 margin: 2.25rem 0 0.5rem;
}
footer .op dl {
 display: flex;
 align-items: center;
 margin-bottom: 0.75rem;
}
footer .op dl dt {
 padding-right: 1.75em;
 flex: 1 0 11em;
 max-width: 11em;
}
footer .op dt span {
 display: block;
 font-size: 1.3rem;
 line-height: 1;
 background: #e94820;
 color: #fff;
 padding: 1em 0.5em 1em 1em;
 position: relative;
 border-radius: 0 3px 3px 0;
}
footer .op dt span:after {
 content: "";
 display: block;
 width: 0;
 height: 0;
 border-style: solid;
 border-top: 1.5em solid transparent;
 border-bottom: 1.5em solid transparent;
 border-left: 1.0em solid #e94820;
 border-right: 0;
 position: absolute;
 top: 50%;
 transform: translateY(-50%);
 right: calc(-1em + 1px);
}
footer .op dd {
 flex: 1 0 calc(100% - 3rem - 11em);
 max-width: calc(100% - 3rem - 11em);
 text-align: left;
 font-size: 1.4rem;
 line-height: 1.3;
}
footer .op dd img {
 display: inline-block;
 height: 2em;
 width: auto;
}
footer .contact {
 position: relative;
 z-index: 2;
 text-align: right;
 display: flex;
 justify-content: flex-end;
 padding-left: 2.5rem;
}
footer .contact dt {
 padding-right: 1.75em;
}
footer .contact dt span {
 display: inline-block;
 font-size: 1.4rem;
 line-height: 1;
 background: #e94820;
 color: #fff;
 padding: 1em 0.5em 1em 1em;
 position: relative;
 border-radius: 0 3px 3px 0;
}
footer .contact dt span:after {
 content: "";
 display: block;
 width: 0;
 height: 0;
 border-style: solid;
 border-top: 1.5em solid transparent;
 border-bottom: 1.5em solid transparent;
 border-left: 1.0em solid #e94820;
 border-right: 0;
 position: absolute;
 top: 50%;
 transform: translateY(-50%);
 right: calc(-1em + 1px);
}
footer .contact dd {
 text-align: center;
}
footer .contact dd span {
 display: inline-block;
 background: #444;
 color: #fff;
 font-size: 1.7rem;
 line-height: 1;
 font-weight: bold;
 padding: 0.35em 0.5em;
}
footer .contact dd em {
 display: block;
 font-size: 70%;
 font-weight: normal;
}
footer .sns ul {
 display: flex;
 align-items: center;
 justify-content: center;
}
footer .sns ul li {
 flex: 1 0 2.7rem;
 max-width: 2.7rem;
 margin: 0 1.35rem;
}
footer .sns ul li:last-child {
 flex: 1 0 5rem;
 max-width: 5rem;
}
footer .sns ul li a {
 opacity: 0.8;
}
footer .sns ul li a:hover {
 opacity: 1;
 transform: scale(1.2);
}
footer .fNav {
 display: block;
 margin: 3rem 0 0;
 text-align: center;
}
footer .fNav li {
 display: inline-block;
 font-size: 1.3rem;
 margin: 0 0.5em;
}
footer .fNav li a {
 color: #666464;
 position: relative;
 display: flex;
 align-items: center;
}
footer .fNav li a:before {
 content: "●";
 display: inline-block;
 font-size: 80%;
 color: #6c6c6c;
 opacity: 0.6;
 padding-right: 0.25em;
}
footer .fNav li a:hover {
 text-decoration: underline;
}
footer .cr {
 padding: 3.5rem 0 2.5rem;
 font-size: 80%;
 opacity: 0.7;
}
.soldOutComment {
 display: inline-block;
 margin: 0.5rem auto 0;
 line-height: 1.4;
 padding: 0.5em 1.2em;
 border-radius: 0.5rem;
 background-image: linear-gradient(126deg, #fbacbc, #ffa3ac);
 font-size: 1.4rem;
 position: relative;
 z-index: 5;
 font-weight: bold;
}
.soldOutComment em {
 display: block;
 font-size: 90%;
}
@media screen and (max-width: 999px) {
 .sp {
  display: block !important;
 }
 .pc {
  display: none !important;
 }
 .mfp-content {
  box-sizing: border-box;
  padding: 5% 10%;
 }
 .mfp-content .popup {
  background: url("../images/spring2025_popup_sp.jpg") no-repeat;
  background-size: cover;
  width: 100%;
  padding-top: 100%;
 }
 .mfp-content .popup a {
  position: absolute;
 }
 .mfp-content .popup img {
      width: 100% !important;
      height: auto !important;
}
 #wrapper.lower {
  padding-left: 0;
 }
 .inner {
  padding: 0 1.5rem;
 }
 .secTtl {
  font-size: 5rem;
 }
 .cs {
  font-size: 1.4rem;
  padding: 1.5rem 0.25em 1.35rem;
 }
 header {
  display: none;
 }
 header .back a {
  font-size: 1.3rem;
 }
 #note {
  border-bottom: solid 3px #dfaf52;
 }
 #note .inner {
  display: block;
 }
 #note .secTtl {
  font-size: 4rem;
 }
 #note .inner .card {
  padding-left: 0;
 }
 #pagetop {
  display: none !important;
 }
 footer .inner {
  display: block;
  padding: 0 1.5rem;
 }
 footer .archives {
  border-bottom: solid 3px #dfaf52;
 }
 footer .archives .secTtl {
  margin-bottom: 0.25em;
  font-size: 4rem;
 }
 footer .archives ul li a {
  padding: 0.5em 0.75em;
  font-size: 1.2rem;
  display: block;
  white-space: nowrap;
 }
 footer .flex {
  display: block;
  padding: 3rem 1.5rem;
 }
 footer .op {
  padding: 0 0 1.5rem;
 }
 footer .op dt {
  padding-right: 1.2em;
 }
 footer .op dt span {
  font-size: 1.2rem;
 }
 footer .op dd {
  font-size: 1.2rem;
 }
 footer .contact {
  text-align: left;
  justify-content: flex-start;
  padding: 0;
 }
 footer .contact dt {
  padding-right: 1.2em;
 }
 footer .contact dt span {
  font-size: 1.2rem;
  white-space: nowrap;
 }
 footer .contact dd span {
  font-size: 1.6rem;
  padding: 0.35em 0.5em;
  white-space: nowrap;
 }
 footer .sns ul {
  justify-content: center;
 }
 footer .sns ul li {
  margin: 0 1rem;
 }
 footer .sns ul li a:hover {
  transform: scale(1);
 }
 footer .fNav {
  text-align: center;
 }
 footer .fNav li a:hover {
  text-decoration: none;
 }
 footer .cr {
  padding: 2rem 0;
  text-align: center;
 }
 .soldOutComment {
  display: block;
  margin: 0 auto;
  padding: 0.5em;
  font-size: 1.3rem;
  white-space: nowrap;
 }
 .soldOutComment em {
  font-size: 80%;
 }
}
/* ================= Animation ================= */
.fadeUp {
 animation-name: fadeUpAnime;
 animation-duration: 0.6s;
 animation-fill-mode: forwards;
 opacity: 0;
}
@keyframes fadeUpAnime {
 from {
  opacity: 0;
  transform: translateY(-50px);
 }
 to {
  opacity: 1;
  transform: translateY(0);
 }
}