@charset "utf-8";
/* CSS: DD 巡音ルカ 2.0 & DD MEIKO 2.0*/
:root {
  /*box-shadow*/
  --bs-pic: 1px 3px 5px rgb(0 0 0 / 30%);
  /*drop-shadow*/
  --ds-cont: drop-shadow(0 0 calc(var(--rs) * 0.6) #9b8694);
  /*color*/
  --c-blu-drk: #20365a;
  --c-red-drk: #c34098;
  --c-brw: #694A44;
  --c-brw-light: #cc9a85;
  /*color sakura miku*/
  --c-skrmiku-brw: #6c3b29;
  --c-skrmiku-grn: #84cc7f;
  --c-skrmiku-pnk: #e6027d;
  --c-skrmiku-pnk02: #ffc6e0;
  --c-skrmiku-sakura: #fcddec;
  /*font-family*/
  --ff-NtSnsJP: YakuHanJP, "Noto Sans JP", sans-serif;
  --ff-NtSrfJP: YakuHanMP, "Noto Serif JP", serif;
  --ff-YuMc: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
  --ff-YuGtc: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif
  --ff-SwMc: 'Sawarabi Mincho', sans-serif;
  --ff-zenmaruG: "Zen Maru Gothic", "Noto Sans JP","sans-serif";
  /*font-size*/
  --fs: min(2.114vw,1rem);
  --rs: clamp(0.5rem, 1.042vw, 1rem);
  /*overright*/
  --color-link-cmn: #3bbaf4;
  /*header height*/
  --height-hdr: calc(var(--rs) * 12);
}
/*-------------------------------
 base
---------------------------------*/
/*link button*/
.link-btn-container {
  width: 100%;
  padding: calc(var(--fs) * 1) 0;
  margin: calc(var(--fs) * 2) auto ;
  text-align: center;
  position: relative;
}
a.link-ec-btn {
  width: min(96%, 72rem);
  padding: 1.5em 0.5em;
  margin: 0 auto;
  background: var(--color-link-cmn);
  border-radius: calc(var(--rs) * 1);
  color: #fff;
  font-size: calc(var(--fs) * 1.6);
  font-weight: normal;
  text-align: center;
  display: block;
  position: relative;
}
a:is(.pre, .end) {
  background: #555;
  color: #777;
  position: relative;
}
a:is(.pre, .end) > i {
  visibility: hidden;  
}
a:is(.pre, .end)::after {
  width: 100%;
  color: #fff;
  letter-spacing: 0.05em;
  text-align: center;
  text-shadow: 0 0 1px rgb(0 0 0 / 100%),0 0 5px rgb(0 0 0 / 100%);
  filter: drop-shadow(0 0 5px #000);
  position: absolute;
  left: 0;
  top: calc(50% - 0.8em);  
}
a.pre {
  pointer-events: none;
}
a.pre::after {
  content: "準備中";
}
a.end::after {
  content: "受付終了";
  color: #f70068;
  text-shadow: 0 1px 5px rgb(0 0 0 / 50%);
}
.link-ec-btn.ic-online::before {
  content: "";
  display: inline-block;
  margin-right: 1em;
  width: 2.5em;
  height: 2.0em;
  margin-top: -1em;
  margin-bottom: -0.5em;
  line-height: 1;
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  flex-shrink: 0;
  align-self: center;
  background-image: url(/assets/image/icons/common_ic_onlinestore-wht.svg);
}
a.linkButton {
  width: min(94%,64rem);
  padding: calc(var(--fs) * 1.8) 1.5em;
  margin: calc(var(--fs) * 4) auto calc(var(--fs) * 2);
  background: var(--color-link-cmn);
  border-radius: calc(var(--fs) * 6);
  color: #fff;
  font-size: calc(var(--fs) * 1.6);
  line-height: 1.5;
  text-shadow: 0px 0px 1px rgb(221 38 126 / 100%), 0px 1px 3px rgb(221 38 126 / 80%);
  text-align: center;
  display: block;
}
a.linkButton.linkButton-anchorLink {
  background: var(--color-link-cmn-pnk);
}
a.linkButton:hover {
  color: #fff;
  filter: brightness(1.1);
}
p:has(a.linkButton) {
  margin-top: 1.5em;
}
a[id]:not([href]) {
  height: var(--height-hdr);
  margin-top: calc(var(--height-hdr) * -1);
  display: block;
}
/*contents container*/
.cont-container {
  width: min(100%, 96rem);
  margin: 0 auto;
  position: relative;
}
.cont-container-inner {
  width: min(94%, 96rem);
  padding: calc(var(--rs) * 2) calc(var(--rs) * 1);
  margin: calc(var(--rs) * 2) auto;
  background: #fff;
  border: var(--c-brw) solid calc(var(--rs) * 0.6);
  border-radius: calc(var(--rs) * 1.2);
  color: var(--c-brw);
  position: relative;
}
/*br block*/
@media screen and (max-width:767px) {
  .br-block-sp {
    display: block;
  }
  .br-block-pc {
    display: none;
  }
}
@media screen and (min-width:768px) {
  .br-block-sp {
    display: none;
  }
  .br-block-pc {
    display: block;
  }
}
/*in page anchor link*/
.anchorlink-container {
  padding: calc(var(--fs) * 1) 2%;
  background: #fff;
  position: relative;
}
.anchorlink-list {
  width: min(94%, 88rem);
  margin: calc(var(--fs) * 3) auto calc(var(--rs) * 1);
  border-radius: 5px;
  font-family: var(--ff-zenmaruG);
  font-size: calc(var(--fs) * 1.6);
  line-height: 1.8;
  text-align: left;
  position: relative;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.anchorlink-list li {
  width: clamp(20%, calc(var(--fs) * 18), 50%);
  padding: 0;
}
.anchorlink-prdct li {
  padding-left: 1.5em;
  padding-right: 0.5em;
}
.anchorlink-list a {
  padding: calc(var(--rs) * 1.6) 0;
  display: block;
}

.anchorlink-list a i {
  color: var(--c-link-cmn);
}
.anchorlink-list a:hover,
.anchorlink-list a:hover i {
  color: var(--color-link-cmn-hover);
}
.anchorlink-info {
  padding: calc(var(--rs) * 0.8) 0;
  background: none;
}
.anchorlink-info li {
  width: clamp(20%, calc(var(--fs) * 18), 50%);
  text-align: center;
}
.anchorlink-info:not(.info-afterEvent) {
  background: var(--c-skrmiku-grn);
  /*background: var(--color-link-cmn);*/
}
.anchorlink-info:not(.info-afterEvent) a {
  text-shadow: 0px 0px 1px rgb(221 38 126 / 80%);
  filter: drop-shadow(0px 1px 2px rgb(221 38 126 / 80%));
}
.anchorlink-info:not(.info-afterEvent) a,
.anchorlink-info:not(.info-afterEvent) a i {
  color: #fff !important;
}
.anchorlink-info:not(.info-afterEvent) a:hover,
.anchorlink-info:not(.info-afterEvent) a:hover i{
  text-shadow: none;
  filter: none;
  filter: alpha(opacity=100); -moz-opacity:1; opacity:1;
}
@media screen and (max-width:767px) {
  .anchorlink-info li {
    text-align: left;
  }
}
/*-------------------------------
DD LUKA 2.0 & DD MEIKO 2.0
main
---------------------------------*/
div.fxblnk {
  height: 4rem;
}
main#prdct2025 {
  /*min-height: calc(100vh - 24rem);*/
  background:
    linear-gradient(90deg, transparent 0%, rgb(255 255 255 / 50%) calc(var(--rs) * 51.2), rgb(255 255 255 / 50%) 50%, rgb(255 255 255 / 50%) calc(var(--rs) * 102.4), transparent 100%),
    linear-gradient(192deg, transparent 64.5%, rgb(210 104 64 / 80%) 64.5%, rgb(210 104 64 / 80%) 71.5%, transparent 71.5%),
    linear-gradient(163deg, transparent 52%, rgb(215 181 213 / 100%) 52%, rgb(215 181 213 / 100%) 54%, transparent 54%),
    linear-gradient(150deg, transparent 35%, rgb(215 181 213 / 100%) 35%, rgb(215 181 213 / 100%) 39%, transparent 39%)
  ;
  color: #000;
  font-family: var(--ff-NtSrfJP);
  display: flex;
  flex-flow: column nowrap;
  align-items: center;
  justify-content: flex-end;
  position: relative;
  overflow: hidden;
}
#prdct2025ContWrapper {
  width: 100%;
  margin: 5vw auto 0;
  text-align: center;
  position: relative;
}
#prdct2025MainVisual {
  position: relative;
  right: calc(var(--rs) * -20);
}
#prdct2025MainCont {
  width: min(100%, 48rem);
  height: calc(50% + var(--rs) * 7.5);
  text-align: center;
  position: absolute;
  left: calc(50% - var(--rs) * 48);
  top: calc(50% - var(--rs) * 15);
}
.prdct2025-catch {
  width: calc(var(--rs) * 32);
  height: calc(var(--rs) * 9.5);
  margin: calc(var(--rs) * -9.5) auto calc(var(--rs) * 1) ;
  filter: drop-shadow(3px 4px 4px rgb(0 0 0 / 60%));
  position: relative;
  left: calc(var(--fs) * -12);
  
}
.prdct2025-text {
  width: min(80%, 84rem);
  padding: 0;
  margin: 1em auto;
  font-size: calc(var(--fs) * 1.8);
  font-weight: bold;
  line-height: 1.8;
  text-shadow: 0 0 1px #fff, 1px 1px 1px rgb(255 255 255 / 80%), 0 0 5px #fff;
  filter: drop-shadow(0 0 10px rgb(255 255 255 / 100%));
}
@media screen and (max-width: 1024px) {
  main#prdct2025 {
    display: flex;
    flex-flow: column wrap;
    justify-content: center;
  }
  #prdct2025ContWrapper {
    margin-top: 0;
  }
  #prdct2025MainCont {
    width: 100%;
    padding: 2em 0;
    margin: 0 auto;
    background: rgb(255 255 255 / 80%);
    position: relative;
    left: 0;
    top: 0;
  }
  #prdct2025MainVisual {
    left: 0;
  }
}
/*-------------------------------
 News
---------------------------------*/
#newsCont {
  padding: calc(var(--rs) * 2) 0 calc(var(--rs) * 4);
  background: #fff;
}
.news-title {
  color: var(--c-blu);
  font-family: var(--ff-zenmaruG);
  font-size: calc(var(--fs) * 4);
  text-align: center;
}
.news-list {
  width: min(94%, 80rem);
  margin: 1em auto 0.5em;
}
.news-list li {
  margin-bottom: 0.5em;
  font-size: calc(var(--fs) * 1.4);
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-start;
  justify-content: flex-start;
}
.news-list li time {
  padding-top: 0.05em;
  margin-right: 0.5em;
  color: #777;
  font-size: 93.75%;
}
.news-list li time::after {
  content: "-";
  margin-left: 0.5em;
}
.news-list-text {
  text-align: left;
}
.news-list-bnr {
  width: 100%;
  margin: 0.5em 0;
}
.news-list-bnr figcaption {
  padding-top: 0.5em;
}