@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*/
  --color-red: #cb0000;
  --c-blu-drk: #20365a;
  --c-red-drk: #c34098;
  --c-brw: #694A44;
  --c-brw-light: #cc9a85;
  --c-gry-bg01: #fafafa;
  /*color ddpop 2025*/
  --c-luka-base: 130 24 135;
  --c-luka-bg: 253 235 245/*234 210 226*/;
  --c-meiko-base: 162 38 44;
  --c-meiko-bg: 248 223 220/*236 218 211*/;
  --c-sz-luka-base: 151 109 127;
  --c-sz-luka-bg: 237 207 216;
  --c-sz-meiko-base: 146 91 90;
  --c-sz-meiko-bg: 224 179 185;
  /*gradietion*/
  --grd-ddpop2025-01: rgb(231 136 114 / 80%) 0%,rgb(148 80 142 / 100%) 50%, rgb(215 181 213 / 100%) 100%;
  /*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(--fs) * 4);
}
/*-------------------------------
 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 {
  color: var(--c-red-drk);
}
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) * 2) auto;
  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 {
  padding: 0;
}
.anchorlink-list a {
  padding: calc(var(--rs) * 1.6) 1.5em;
  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);
}
/*-------------------------------
 Online store link
---------------------------------*/
.link-olstore {
  width: min(94%, 72rem);
  margin: 0 auto;
  font-family: var(--ff-zenmaruG);
  text-align: center;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.link-olstore-title {
  width: 100%;
  padding: calc(var(--rs) * 1);
  font-size: calc(var(--fs) * 1.8);
  font-weight: bold;
  letter-spacing: -0.05em;
  display: none;
}
.link-olstore-btn {
  width: min(96%, 24rem);
  margin: calc(var(--fs) * 1) 2% 0;
  flex: 1 1 auto;
}
a.olstore-linkButton {
  width: min(100%,64rem);
  padding: calc(var(--fs) * 1) 1em;
  margin: 0 auto;
  background: var(--color-link-cmn);
  border-radius: calc(var(--fs) * 6);
  color: #fff;
  font-size: calc(var(--fs) * 1.6);
  line-height: 1.3;
  text-align: center;
  display: block;
  position: relative;
}
.olstore-btn-installment a.olstore-linkButton { /*分割払い色替え*/
  background: #d45a75;
  background: #ff698a;
}
a.olstore-linkButton:hover {
  color: #fff;
  filter: brightness(1.1);
}
a.olstore-linkButton small {
  margin: 0 auto;
  font-size: calc(var(--fs) * 1.3);
  display: block;
}
a.olstore-linkButton i {
  position: absolute;
  right: calc(var(--fs) * 2);
  top: calc(50% - 0.4em);
}
a.olstore-linkButton.end {
  filter: brightness(0.8);
}
a.olstore-linkButton.end i {
  display: none;
}
/*-------------------------------
 Header
---------------------------------*/
@media screen and (max-width: 959px) {
  #header .logo {
    left: 1rem;
  }
}
/*-------------------------------
 Navi _ Menu - Toggle button
---------------------------------*/
.navi_menu-toggle {
  width: calc(var(--fs) * 4);
  height: calc(var(--fs) * 4);
  cursor: pointer;
  display:block;
  position: absolute;
  right: min(3%,calc(var(--fs) * 1));
  top: calc(var(--fs) * 0);
  z-index: 20;
}
.navi_menu-toggle.on .one {
  transform :rotate(45deg) translate(calc(var(--fs) * 0.6), calc(var(--fs) * 0.6));
}
.navi_menu-toggle.on .two {
  opacity: 0;
}
.navi_menu-toggle.on .three {
  transform :rotate(-45deg) translate(calc(var(--fs) * 0.6), calc(var(--fs) * -0.6));
}
.one,
.two,
.three {
  width: 75%;
  height: 3px;
  margin: calc(var(--fs) * 0.5) auto;
  background-color: var(--color-wht);
  backface-visibility: hidden;
  transition-duration: 0.3s;
}
/*ドネルケバブメニュー*/
.navi_menu-toggle:not(.on) .two,
.navi_menu-toggle:not(.on) .three {
  margin-right: 12.5%;
}
.navi_menu-toggle:not(.on) .two {
  width: 50%;
}
.navi_menu-toggle:not(.on) .three {
  width: 60%;
}
.navi_menu-toggle::after {
  content: "MENU";
  width: 100%;
  color: var(--color-wht);
  font-size: calc(var(--fs) * 1);
  text-align: center;
  display: block;
  position: absolute;
  bottom: -4px;
  left: 0;
}
@media screen and (max-width: 959px) {
  .navi_menu-toggle {
    left: auto;
    top: calc(var(--fs) * 0.6);
  }
}
/*-------------------------------
 Navi _ Menu - Contents
---------------------------------*/
nav#Menu {
  display: none;
}
nav#NaviMenu {
  background: 
    linear-gradient(0deg, rgb(255 255 255 / 100%) 15%, rgb(255 255 255 / 0%) 100%),
    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%),
    #fff;
  ; 
  /*color: #fff;*/
  font-family: var(--ff-NtSnsJP);
}
nav#NaviMenu.navi_area-global {
  width: 100%;
  max-width: 100%;
  height: calc(100% - 4rem);
  padding: 2vmin 4% 10%;
  overflow-y: scroll;
  scrollbar-width: none;
  position: fixed;
  left: 0;
  top: 4rem;
  z-index: 11;
  display: none;
}
nav#NaviMenu.navi_area-global.open {
  display: block;
}
nav#NaviMenu hr {
  width: min(96%, 108rem);
  margin: calc(var(--rs) * 5) auto;
  border-color: rgb(var(--c-luka-base) / 100%);
  filter: opacity(0.2);
}
nav#NaviMenu hr:nth-of-type(2) {
  border-color: rgb(var(--c-meiko-base) / 100%);
}
/*-------------------------------
 overlay manu
---------------------------------*/
/*navi menu banner*/
.naviMenuBnr {
  width: min(98%, 54rem);
  margin: 2% auto 4%;
  text-align: center;
}
/*-------------------------------
 products list
---------------------------------*/
/*products thumbnail*/
.productsThumbList {
  width: min(100%, 108rem);
  margin: calc(var(--fs) * 2) auto;
  font-size: calc(var(--fs) * 1.6);
  letter-spacing: 0.01em;
  text-align: center;
  position: relative;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.prdctThumb-title {
  width: 100%;
  margin-bottom: calc(var(--fs) * 2);
  font-family: var(--ff-NtSrfJP);
  font-size: calc(var(--fs) * 3);
  font-weight: bold;
  text-align: center;
}
.prdctThumb-title small {
  margin-top: 0.5em;
  color: #b3bfbf;
  font-size: calc(var(--fs) * 1.4);
  display: inline-block;
}
.prdctThumb-title a.ddpopaboutlink {
  padding-left: 2em;
  margin-top: 1em;
  color: var(--color-link-cmn);  
  font-family: var(--ff-NtSnsJP);
  font-size: calc(var(--fs) * 1.3);
  display: inline-block;
}
/*.productsThumbList::before,
.productsThumbList::after {
  content: "";
  width: min(48%, 34rem);
  margin: 1%;
  flex: 1 1 auto;
  order: 2;
}*/
.productsThumbList a {
  
}
.productsThumbList a:hover {
  filter: opacity(0.8);
  transition: all .3s;
}
.prdctThumb-ctg {
  width: 100%;
  margin: 1% auto;
  background: rgb(255 255 255 / 30%);
  box-shadow: 0 0 10px 10px rgb(255 255 255 / 30%);
  position: relative;
  display: flex;
  flex-flow: row wrap;
}
.prdctThumb-ctg > :is(li,dd) {
  width: calc(100% / 4 - 2%);
  margin: 1%;
  margin-bottom: calc(var(--rs) * 2);
  /*box-shadow: var(--bs-cont);*/
  position: relative;
  flex: 1 1 auto;
  order: 1;
  display: flex;
  flex-flow: column nowrap;
  justify-content: space-between;
}
@media screen and (max-width: 640px) {
  .prdctThumb-ctg > :is(li,dd) {
    width: 48%;
  }
}
.prdctsThum {
  /*background: #fff;*/
  background: none;
}
.prdctsThum img {
  border-radius: calc(var(--rs) * 1);
}
.prdctsThum,
.item-pic--thumb {
  position: relative;
}
.prdctsThum-name {
  padding: 0.5em 0;
  min-height: 3em;
  /*background: var(--c-blu);*/
  background: none;
  font-weight: normal;
  line-height: 1.4;
  position: relative;
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
}
#NaviMenu .prdctsThum-name {
  /*color: #fff;*/
}
.prdctsThum-name i {
  color: var(--c-frieren-gold);
  position: absolute;
  right: 0.25em;
  top: calc(50% - 0.4em);
}
.prdctsThum-name-text {
  font-size: calc(var(--fs) * 1.6);
}
.prdctsThum-name-period {
  padding: 0.25em;
  margin-top: 0.5em;
  background: #d61979;
  color: #fff;
  font-size:  calc(var(--fs) * 1.2);
}
.prdctsThum-name-period span {
  display: inline-block;
}
.prdctsThum-name-end {
  margin-top: 0.75em;
  color: #ff76c3;
  font-size:  calc(var(--fs) * 1.2);
}
/*-------------------------------
  overlay menu _ global menu
---------------------------------*/
.naviMenu-global {
  width: min(94%, 96rem);
  margin: 0 auto;
  text-align: center;
}
.naviMenu-title {
  width: auto;
  padding: 0 2%;
  margin: 0 auto calc(var(--fs) * 3);
  color: #000;
  font-family: var(--ff-NtSrfJP);
  font-size: calc(var(--fs) * 3);
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  position: relative;
}
.naviMenu-title small {
  font-size: calc(var(--fs) * 1.4);
}
/*sns icons*/
.icbtn-snslnk {
  width: min(94%, 96rem);
  padding: 1em 0 2em;
  margin: 0 auto;
  background: linear-gradient(90deg, transparent 10%, rgb(255 255 255 / 80%) 50%, transparent 90%);
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.icbtn-cap {
  width: 100%;
  margin-bottom: 1em;
  font-family: var(--ff-NtSrfJP);
  font-size: calc(var(--fs) * 2);
  font-weight: bold;  
  text-align: center;
}
.icbtn-ic {
  margin: calc(var(--rs) * 1) 0.5em;
  font-size: calc(var(--fs) * 3);
}
/*logo collaboration*/
.pop2025-logocollabo {
  width: min(80%, 30rem);
  margin: 0 auto calc(var(--rs) * 4);
  position: relative;
  text-align: center;  
}
.logocollabo-piapro {
  display: flex;
  flex-flow: row-reverse nowrap;
  align-items: center;
  gap: 2%;
}
.logocollabo-times {
  margin: 0em auto 0.5em;
  font-size: calc(var(--fs) * 4);
  text-align: center;
}
.logocollabo-dd {
  width: 60%;
  margin: 0 auto;
}
/*------------------------------- DD LUKA 2.0 & DD MEIKO 2.0 Pre-Order Project ---------------------------------*/
div.fxblnk {
  height: 4rem;
}
/*-------------------------------
  main header
---------------------------------*/
#pop2025HeaderImg {
  background: #fbfaf8;
  text-align: center;
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 1280px) {
  #pop2025HeaderImg {
    background: #fff url("/dd/special/piapro/image/product/2025/mainImage-bg.jpg") 50% 0 / auto no-repeat;
  }
}
#pop2025MainVisual {
  /*width: min(100%,144rem);*/
  width: min(100%,128rem);
  margin: 0 auto;
  position: relative;
  display: block;
}
#pop2025MainTextCont {
  width: min(50%, 64rem);
  height: 100%;
  padding: 0 0 0 calc(var(--rs) * 5);
  font-family: var(--ff-YuMc);
  text-align: center;
  position: absolute;
  left: 50%;
  top: 0;
  container-type: inline-size;
/*background: url("/dd/special/piapro/image/product/2025/mainImage-textAlt.png") 0 0 / 100% no-repeat;*/
}
.pop2025main-header {
  width: 10.8em;
  margin: 17.5% auto 0;
  /*font-size: calc(var(--rs) * 3.8);*/
  font-size: 6.5cqw;
  line-height: 1.2;
}
.pop2025main-logo {
  width: 90%;
  margin: 3.5% auto 0;
  position: relative;
  display: block;
}
.pop2025main-logo li {
  width: 63.33%;
  margin: 0 auto;
}
.pop2025main-title {
  width: 90%;
  padding: 2% 0.5em 3% 4.5em;
  margin: 9.5% 0 0% auto;
  background: 
    linear-gradient(90deg, rgb(198 39 43 / 0%) 0%, rgb(198 39 43 / 50%) 10%, rgb(176 35 86 / 80%) 50%, rgb(150 22 130 / 80%) 100%)
    ;
  color: #fff;
  /*font-size: calc(var(--rs) * 3.8);*/
  font-size: 6.5cqw;
  font-weight: bold;
  line-height: 1.4;
  text-indent: -5.5em;
}
.pop2025main-text {
  width: 90%;
  padding: 0 0em 0 calc(var(--rs) * 2);
  margin: 5% 0 1em auto;
  /*font-size: calc(var(--rs) * 3);*/
  font-size: 5cqw;
  font-weight: bold;
  line-height: 1.45;
  letter-spacing: 0.05em;
}
.pop2025main-text b {
  position: relative;
  left: -4em;
  display: inline-block;
}
.pop2025main-text b ~ b {
  text-indent: -4em;
  left: 0;
}
.pop2025main-text span {
  display: block;
}
.pop2025main-ds {
  filter: drop-shadow(0 0 5px #fff) drop-shadow(0 0 15px #fff);
  text-shadow: 0 0 1px #fff, 0 0 5px #fff,0 0 10px #fff;
}
@media screen and (max-width: 767px) {
  #pop2025MainVisual::after {
    content: "";
    width: 100%;
    height: 30%;
    background: linear-gradient(180deg, transparent 10%, #e7ded6 90%);
    position: absolute;
    left: 0;
    bottom: 0;
  }
  #pop2025MainTextCont {
    width: 100%;
    height: auto;
    padding: calc(var(--rs) * 4) 0;
    margin: 0;
    background: #e7ded6;
    box-shadow: 0 calc(var(--rs) * -1) calc(var(--rs) * 1) #e7ded6;
    position: relative;
    left: 0;
  }
  #pop2025MainHeader {
    /*background: linear-gradient(180deg, transparent 10%, #e7ded6 60%);*/
    margin-top: calc(var(--rs) * -25);
    position: relative;
  }
  .pop2025main-header {
    margin: 0 auto;
  }
  .pop2025main-title {
    width: 100%;
    margin: calc(var(--rs) * 3) 0 0;
    background: 
      linear-gradient(90deg, rgb(198 39 43 / 30%) 0%, rgb(198 39 43 / 50%) 10%, rgb(176 35 86 / 80%) 50%, rgb(150 22 130 / 80%) 100%)
    ;
  }
  .pop2025main-logo {
    padding: 0 2%;
    margin-top: calc(var(--rs) * 1);
    display: flex;
    flex-flow: row-reverse nowrap;
    align-items: center;
  }
  .pop2025main-logo li {
    width: 48%;
    margin: 0 1%
  }
}
/*-------------------------------
 News
---------------------------------*/
main#pop2025 {
  font-family: var(--ff-NtSnsJP);
}
/*------------------------------q-
 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;
}
/*-------------------------------
 Order period
---------------------------------*/
.ddpop2025-orderPeriod {
  width: min(94%, 72rem);
  padding: calc(var(--fs) * 1);
  margin: calc(var(--fs) * 1) auto;
  background: rgb(255 255 255 / 90%);
  box-shadow: 0 1px 4px rgb(0 0 0 / 40%);
  color: #000;
  font-size: calc(var(--fs) * 1.8);
  text-align: center;
}
.orderPeriod-heading {
  padding: 0.25em;
  background: 
    linear-gradient(90deg, var(--grd-ddpop2025-01))
    ;
  color: #fff;
  font-size: 112.5%;
}
.orderPeriod-text {
  margin: 0.75em auto;
}
/*-------------------------------
  product
---------------------------------*/
.productContainer {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
}
@media screen and (max-width: 960px) {
  .productContainer {
    flex-direction: column;
  }
}
.pop2025Product {
  width: min(100%, 96rem);
  padding-bottom: 0;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-flow: column nowrap;
  justify-content: space-between;
}
.product-itemname {
  display: none;
}
/*product _ unique*/
#productLuka,
#productDrsLuka {
  margin-right: 0;
}
#productMeiko,
#productDrsMeiko {
  margin-left: 0;
}
#productLuka {
  background:  linear-gradient(180deg, rgb(var(--c-luka-bg) / 100%) 96%, transparent 100%);
}
#productMeiko {
  background: linear-gradient(180deg, rgb(var(--c-meiko-bg) / 100%) 96%, transparent 100%);
}
#productSenbonZakura {
  width: min(100%, 192rem);
  padding: 0;
  margin: 0 auto;
  background: url("/dd/special/piapro/image/product/2025/bg_drs.jpg") top center / 100% repeat;
}
@media screen and (max-width: 960px) {
  #productSenbonZakura {
    background-image: url("/dd/special/piapro/image/product/2025/bg_drs-sp.jpg");
  }
}
#productSenbonZakura .anchorlink-list a {
  color: #fff;
  text-shadow: 0 0 1px var(--c-red-drk), 0 0 2px var(--c-red-drk), 0 0 3px var(--c-red-drk), 0 2px 3px var(--c-red-drk);
  filter: drop-shadow(0px 0px 1px var(--c-red-drk));
  /*text-shadow: 0 0 1px #fff, 0 0 2px #fff, 0 0 3px #fff, 0 2px 3px rgb(0 0 0 / 30%);
  filter: drop-shadow(0px 0px 1px #fff);*/
}
#productSenbonZakura .anchorlink-list a:hover i {
  color: #fff;
}
#productDrsLuka {
  /*background: rgb(var(--c-sz-luka-bg) / 70%);*/
  background: 
    linear-gradient(180deg, rgb(105 35 100 / 50%) 90%, rgb(105 35 100 / 0%) 100%)
  ;
}
#productDrsMeiko {
  /*background: rgb(var(--c-sz-meiko-bg) / 70%);*/
  background: 
    linear-gradient(180deg, rgb(150 30 30 / 50%) 90%, rgb(150 30 30 / 0%) 100%)
  ;
}
/*product _ image*/
.product-image {
  margin: 0 0 auto;
}
.product-image figure {
  position: relative;
}
.product-catch {
  position: absolute;
  top: 0;
  container-type: inline-size;
}
#productLuka .product-catch {
  width: 50%;
  color: rgb(var(--c-luka-base) / 100%);
  text-align: left;
  left: 0;
}
#productMeiko .product-catch {
  width: min(50%, 46rem);
  color: rgb(var(--c-meiko-base) / 100%);
  text-align: right;
  right: 0;
}
.product-catch-copy,
.product-catch-read {
  font-family: var(--ff-NtSrfJP);
}
.product-catch-copy {
  padding: calc(var(--rs) * 2) 0%;
  margin-bottom: calc(var(--rs) * 1);
  color: #fff;
  /*font-size: calc(var(--rs) * 2.4);*/
  font-size: 6.5cqw;
  line-height: 1.2;
}
#productLuka .product-catch-copy {
  padding-left: 6%;
  background: linear-gradient(90deg, rgb(201 59 147 / 100%) 0%, rgb(227 139 180 / 100%) 85%, transparent 100%);
  text-shadow: 0 0 1px rgb(132 48 130 / 100%), 0 0 5px rgb(132 48 130 / 100%), 0 3px 10px rgb(132 48 130 / 100%);
}
#productMeiko .product-catch-copy {
  padding-right: calc(6% - 1em);
  background: linear-gradient(270deg, rgb(203 31 34 / 100%) 0%, rgb(241 87 94 / 100%) 70%, transparent 100%);
  text-shadow: 0 0 1px rgb(170 74 60 / 100%), 0 0 5px rgb(170 74 60 / 100%), 0 -3px 10px rgb(170 74 60 / 100%);
}
.product-catch-read {
  padding: 0 8% calc(var(--rs) * 1);
  margin-bottom: calc(var(--rs) * 1);
  border-bottom: 1px solid;
  /*font-size: calc(var(--rs) * 2.6);*/
  font-size: 5.5cqw;
  line-height: 1.3;
}
#productLuka .product-catch-read {
  padding-left: 4%;
  padding-right: 10%;
}
#productMeiko .product-catch-read {
}
.product-catch-text {
  padding: 0 8%;
  color: #000;
  font-size: calc(var(--fs) * 0.4 + var(--rs) * 1.4);
  font-size: 4cqw;
  line-height: 1.8;
}
#productLuka .product-catch-text {
  padding-left: 4%;
  padding-right: 10%;
}
#productMeiko .product-catch-text {
  padding-left: 0%;
}
@media screen and (max-width: 960px) {
  .product-catch {
    background: #fff;
    position: initial;
  }
  #productLuka .product-catch,
  #productMeiko .product-catch {
    width: 100%;
  }
  .product-catch-copy {
    width: 50%;
    position: absolute;
    top: 0%;
  }
  #productLuka .product-catch-copy {
    padding-left: 3%;
    left: 0;
  }
  #productMeiko .product-catch-copy {
    right: 0;
  }
  #productLuka .product-catch-read,
  #productLuka .product-catch-text,
  #productMeiko .product-catch-read,
  #productMeiko .product-catch-text {
    padding: 0.5em 4%;
    text-align: left;
  }
}
/*product _ text*/
.product-text {
  padding: 1em 3%;
  margin: 0 0 auto;
  text-align: left;
}
/*product points*/
.product-points {
  width: 98%;
  padding: 1em 0 1em 3%;
  margin: 0 auto auto;
  font-family: var(--ff-NtSrfJP);
  font-size: calc(var(--fs) * 1.6);
  list-style: disc;
  text-align: left;
  flex: 1 1 auto;
}
.product-points li {
  margin: 0.5em 1em;
  font-weight: bold;
}
#productLuka .product-points {
  color: rgb(var(--c-luka-base) / 100%);
}
#productMeiko .product-points {
  color: rgb(var(--c-meiko-base) / 100%);
}
/*product link box*/
.product-linkbox {
  margin: 1em auto 0;
}
.product-linkbox .link-olstore {
  
}
.link-olstore-period {
  width: 100%;
  padding: 1em;
  margin: 1em auto 0.5em;
  font-family: var(--ff-zenmaruG);  
  font-size: calc(var(--fs) * 1.6);
  line-height: 1.8;
  text-align: center;
  display: block;
}
.link-olstore-period span {
  display: inline-block;
}
/*-------------------------------
 products Senbon Zakura
---------------------------------*/
#productSZcatch {
  padding: calc(var(--rs) * 5) 0;
  text-align: left;
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: center;
}
.productSZcatch-img {
  width: min(40%, calc(var(--fs) * 18));
  margin: 0 calc(var(--rs) * 2);
}
.szCatch,.szText {
  padding: 0 calc(var(--fs) * 1);
  font-family: var(--ff-NtSrfJP);  
}
.szCatch {
  font-size: calc(var(--rs) * 1.6 + var(--fs) * 1.0);
  text-shadow: 0 0 1px rgb(255 255 255 / 100%), 0 0 3px rgb(255 255 255 / 100%);
  filter: drop-shadow(0 0 1px rgb(255 255 255 / 100%))

}
.szText {
  margin-top: 0.5em;
  color: #fff;
  font-size: calc(var(--rs) * 1.2 + var(--fs) * 0.8);
  line-height: 1.5;
  text-shadow: 0 0 1px rgb(0 0 0 / 100%), 0 0 5px rgb(0 0 0 / 80%);
  filter: drop-shadow(0 0 calc(var(--rs) * 1) rgb(0 0 0 / 80%))
}
/*product detail*/
#productSenbonZakura .product-image {
  position: relative;
}
#productSenbonZakura .product-text {
  position: absolute;
  left: 0;
  top: 0;
}

/*-------------------------------
 products list in container
---------------------------------*/
.productList-container {
  width: 100%;
  padding: calc(var(--fs) * 4) 2% calc(var(--fs) * 4);
  background: linear-gradient(180deg, #f5f5f5 80%, #fff 100%);
  text-align: center;
}
/*-------------------------------
 spec table
---------------------------------*/
.product-spec {
  width: min(94%, 94rem);
  padding: 0 2% 2%;
  margin: 0 auto auto;
  background: #fff;
  box-shadow: 0 2px 4px rgb(0 0 0 / 20%);
  flex: 1 1 auto;
}
table.specTable {
  width: 100%;
  padding-bottom: 1em;
  margin: 0 auto;
  border-bottom: 1px dashed;
  border-collapse: separate;
  border-spacing: 5px;
}
#productLuka table.specTable {
  border-color: rgb(var(--c-luka-base) / 100%);
}
#productMeiko table.specTable {
  border-color: rgb(var(--c-meiko-base) / 100%);
}
table.specTable caption {
  width: 100%;
  padding: calc(var(--fs) * 2) 0 calc(var(--fs) * 1.4);
  font-size: calc(var(--fs) * 1.8);
  font-weight: bold;
  line-height: 1.2;
  text-align: left;
  position: relative;
}
table.specTable caption
table.specTable caption span {
  display: block;
}
table.specTable caption b {
  margin: 0 0.25em;
  font-size: calc(var(--fs) * 3.0);
}
table.specTable caption small {
  font-weight: normal;
  display: inline-block;
}
#productSenbonZakura table.specTable caption b {
  font-size: calc(var(--fs) * 2.6);
}
table.specTable tr {
  padding-bottom: calc(var(--fs) * 0.5);
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-start;
  justify-content: flex-start;
}
table.specTable tr:has(td[colspan]) {
  padding-bottom: 0;
}
table.specTable th,
table.specTable td {
  padding: calc(var(--fs) * 0.5) 0;
  font-size: calc(var(--fs) * 1.6);
  font-weight: normal;
  line-height: 1.6;
}
table.specTable th {
  max-width: 15rem;
  background: var(--c-brw-light);
  color: #fff;
  font-size: calc(var(--fs) * 1.2);
  text-align: center;
  position: relative;
  flex: 0 1 25%;
}
table.specTable th:empty {
  background: none;
}
table.specTable td {
  padding-top: calc(var(--fs) * 0.2);
  flex: 1 1 80%;
}
table.specTable td:not([colspan]) {
  padding-left: 1em;
  text-align: left;
}
table.specTable td[colspan] {
  padding: 0;
  flex-basis: auto;
}
table.specTable td.spec-price {
  padding-top: 0;
  line-height: 1.2;
}
table.specTable td a.ev_att {
  font-weight: bold;
  color: var(--c-bs-red);
}
.price-tax {
  font-size: calc(var(--fs) * 2.4);
  font-weight: bold;
  vertical-align: text-top;
}
.price-tax small {
  font-size: calc(var(--fs) * 1.4);
}
.price-hontai {
  display: none;
}
/*color change _ luka*/
#productLuka table.specTable caption {
  color: rgb(var(--c-luka-base) / 100%);
}
#productLuka table.specTable th {
  background: rgb(var(--c-luka-base) / 100%);
}
/*color change _ meiko*/
#productMeiko table.specTable caption {
  color: rgb(var(--c-meiko-base) / 100%);
}
#productMeiko table.specTable th {
  background: rgb(var(--c-meiko-base) / 100%);
}
/*color change _ Senbon Zakura luka*/
#productDrsLuka table.specTable caption {
  color: rgb(var(--c-sz-luka-base) / 100%);
}
#productDrsLuka table.specTable th {
  background: rgb(var(--c-sz-luka-base) / 100%);
}
/*color change _ Senbon Zakura meiko*/
#productDrsMeiko table.specTable caption {
  color: rgb(var(--c-sz-meiko-base) / 100%);
}
#productDrsMeiko table.specTable th {
  background: rgb(var(--c-sz-meiko-base) / 100%);
}
/*base_piapro.css _ overwrite*/
ul.note-list {
  width: 100%;
  margin: 1em auto 0;
  color: #555;
  font-size: calc(var(--fs) * 1.3);
  text-align: left;
}
ul.note-list li {
  margin: 0;
}
ul.note-list li + li {
  margin-top: 0.5em;
}
/*-------------------------------
 Gallery _ overwrite
---------------------------------*/
.gallery-title {
  padding: calc(var(--fs) * 1) 2% 0;
  margin: calc(var(--rs) * 0.5) calc(var(--rs) * 1);
  color: #fff;
  font-family: var(--ff-zenmaruG);
  font-size: calc(var(--fs) * 2.8);
  font-weight: normal;
  text-align: center;
  text-shadow: 0 0 3px #000;
  filter: drop-shadow(1px 2px 3px rgb(0 0 0 / 80%));
}
/*gallery box*/
.galleryBox {
  width: min(94%, 96rem);
  padding: calc(var(--fs) * 2) 0;
  margin: auto auto 0;
  background: none;
  color: #fff;
  position: relative;
}
.item-pic {
  padding: 0;
  margin: 0 auto;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  }
.item-pic--list {
  width: calc(100% / 3 - var(--fs) * 1);
  margin: calc(var(--fs) * 0.5);
  /*border: calc(var(--rs) * 0.2) solid var(--c-frieren-blu);*/
  /*outline: 1px solid rgb(255 255 255 / 80%);*/
  filter: drop-shadow(1px 2px 3px rgb(1 173 175 / 20%));
}
.item-pic--thumb {
  width:100%;
  object-fit: contain;
}
/*-------------------------------
 spec attention
---------------------------------*/
.product-attention {
  width: min(100%, 192rem);
  padding-bottom: 1em;
  margin: 0 auto;
  position: relative;
}
#productDD .product-attention {
  /*background: linear-gradient(90deg, rgb(var(--c-luka-bg) / 100%) 0%, rgb(var(--c-luka-bg) / 100%) 50%, rgb(var(--c-meiko-bg) / 100%) 50%, rgb(var(--c-meiko-bg) / 100%) 100%);*/
}
#productSenbonZakura .product-attention {
  /*background: linear-gradient(90deg, rgb(var(--c-sz-luka-bg) / 70%) 0%, rgb(var(--c-sz-luka-bg) / 70%) 50%, rgb(var(--c-sz-meiko-bg) / 70%) 50%, rgb(var(--c-sz-meiko-bg) / 70%) 100%);*/
  /*background: linear-gradient(90deg, rgb(105 35 100 / 50%) 0%, rgb(105 35 100 / 50%)  50%, rgb(150 30 30 / 50%) 50%, rgb(150 30 30 / 50%) 100%);*/
}
@media screen and (max-width: 960px) {
  #productDD .product-attention {
    /*background: linear-gradient(180deg, rgb(var(--c-luka-bg) / 100%) 0%, rgb(var(--c-meiko-bg) / 100%) 100%);*/
  }
  #productSenbonZakura .product-attention {
    /*background: linear-gradient(180deg, rgb(var(--c-sz-luka-bg) / 70%) 0%, rgb(var(--c-sz-meiko-bg) / 70%) 100%);*/
    /*background: linear-gradient(180deg, rgb(150 30 30 / 50%) 0%, rgb(105 35 100 / 00%) 50%,  transparent 100%);*/
  }
}
.spec-att {
  width: min(94%, 72rem);
  margin: calc(var(--rs) * 4) auto;
  color: #333;
  font-size: calc(var(--fs) * 1.3);
  line-height: 1.5;
  text-align: left;
  text-shadow: 0 0 3px #fff, 0 0px 5px #fff, 0px 0px 4px rgb(255 255 255 / 60%);
}
#productSenbonZakura .spec-att {
  color: #fff;
  text-shadow: 0 0 3px rgb(0 0 0 / 50%), 0 0px 5px rgb(0 0 0 / 50%), 0px 0px 4px rgb(0 0 0 / 50%);
}
.spec-att dt {
  font-size: calc(var(--fs) * 1.5);
}
.spec-att :is(li,dd) {
  padding-left: 1em;
  margin-top: 0.5em;
  margin-right: 1em;
  display: inline-block;
  position: relative;
}
.spec-att :is(li,dd)::before {
  content: "\203B";
  position: absolute;
  left: 0;
  top: 0;
}
.spec-att a {
  padding: 0.25em 0.5em;
  background: rgb(255 255 255 / 100%);
  border-radius: 3px;
  color: #d61979;
  font-size: 87.5%;
  line-height: 1;
  text-decoration: none;
  display: inline-block;
}
.spec-att a:hover {
  filter: brightness(1.1);
}
.spec-att .att-imp {
  color: var(--c-bs-pnk);
  font-weight: bold;
}
/*-------------------------------
 Information
---------------------------------*/
#informationCont {
  width: 100%;
  padding: calc(var(--fs) * 5) 0;
  background: linear-gradient(0deg, var(--c-gry-bg01) 80%, #fff 100%);
}
#informationCont :is(.prdctThumb-title, .link-olstore-title) {
  display: none;
}
/*section elements*/
.section-title {
  width: auto;
  padding: 0 2%;
  margin: 0 auto calc(var(--fs) * 3);
  color: #000;
  font-family: var(--ff-NtSrfJP);
  font-size: calc(var(--fs) * 3);
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  position: relative;
}
.section-title small {
  color: #b3bfbf;
  font-size: calc(var(--fs) * 1.4);
}
.section-title span {
  font-size: calc(var(--fs) * 1.6);
  display: inline-block;
}
/*info container*/
.info-container {
  width: min(100%, 96rem);
  margin: calc(var(--rs) * 2) auto;
}
/*info header*/
.info-header {
  width: 104%;
  padding: 0.5em 0;
  margin: calc(var(--rs) * 4) auto calc(var(--rs) * 2);
  color: #000;
  font-family: var(--ff-NtSrfJP);
  font-size: calc(var(--fs) * 1.6 + var(--rs) * 1.2);
  line-height: 1;
  text-align: center;
  text-shadow: 0 1px 1px #fff, 0 0 5px #fff;
  filter: drop-shadow(0 0 2px #fff) drop-shadow(0 0 10px #fff);
  position: relative;
  left: -2%;
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
}
.info-header::before,
.info-header::after {
  content: "";
  width: 10%;
  height: 1px;
  margin: auto;
  flex: 1 1 auto;
}
.info-header::before {
  background: rgb(var(--c-luka-base) / 100%);
  filter: drop-shadow(0 0 2px rgb(var(--c-luka-bg) / 100%)) drop-shadow(0 0 10px rgb(var(--c-luka-bg) / 100%));
}
.info-header::after {
  background: rgb(var(--c-meiko-base) / 100%);
  filter: drop-shadow(0 0 2px rgb(var(--c-meiko-bg) / 100%)) drop-shadow(0 0 10px rgb(var(--c-meiko-bg) / 100%));
}
.info-header > span {
  margin: 0 0.25em;
  flex: 1 1 auto;
}
/*info box*/
.info-box {
  padding: 0 2%;
  margin-top: calc(var(--rs)* 4);
  color: var(--c-brw);
  text-align: left;
}
.info-title {
  padding-left: calc(var(--rs)* 1);
  margin-bottom: calc(var(--rs)* 1);
  border-left: calc(var(--rs)* 1) solid;
  font-size: calc(var(--fs)* 0.8 + var(--rs)* 1.6);
  font-weight: bold;
  color: var(--color-fr-bl);
  line-height: 1.3;
}
.info-text {
  padding: 0 calc(var(--rs)* 2);
  margin-top: 1em;
  font-size: calc(var(--fs)* 1.6);
  font-weight: bold;
  line-height: 1.8;
  text-align: left;
}
/*-------------------------------
 information _ pre-orders
---------------------------------*/
#informationCont {
  contain: paint;
}
#informationCont section {
  padding: 0 4%;
  overflow: initial;
}
.ddpop2025-orderPoint {
  width: calc(100% - 6px);
  padding: calc(var(--rs) * 1) 0.5em;
  margin: calc(var(--rs) * 4) auto calc(var(--rs) * 1);
  background: var(--c-red-drk);
  border: 2px solid #fff;
  color: #fff;
  font-size: calc(var(--fs) * 1.2 + var(--rs) * 1.2);
  font-weight: bold;
  line-height: 1.4;
  outline: 3px solid var(--c-red-drk);
  text-align: center;
  display: block;
}
.ddpop2025-orderPoint + ul.note-list {
  width: calc(100% - 2em);
  font-weight: bold;
}
/*info ancher link*/
.anchorlink-methodInfo-wrap {
  width: 100%;
  padding: 0;
  margin: calc(var(--rs) * 4) auto 0;
  container-type: scroll-state;
  position: sticky;
  top: 4rem;
  z-index: 1;
}
.anchorlink-methodInfo {
  width: min(calc(98% - 2px), calc(96rem - 2px));
  padding: 0.5em 1em;
  margin: calc(var(--fs)* 2) auto 0;
  background: #fff;
  border: 3px double var(--c-red-drk);
  font-size: calc(var(--fs) * 1.4);
  outline: 1px solid var(--c-red-drk);
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  transition: all 0.4s;
}

.anchorlink-methodInfo li {
  margin: 0.5em;
  padding-right: 1em;
  flex: 1 1 auto;
}
.anchorlink-methodInfo a {
  display: block;
}
.anchorlink-methodInfo a,
.anchorlink-methodInfo a i {
  color: var(--c-red-drk);
}
.anchorlink-methodInfo a:hover,
.anchorlink-methodInfo a:hover i {
  color: var(--color-link-cmn-hover);
  opacity: 1;
}
@media screen and (max-width: 960px) {
  .anchorlink-methodInfo {
    padding: 0.5em 2%;
    text-align: left;
    justify-content: flex-start;
  }
  .anchorlink-methodInfo li {
    min-width: 29%;
    padding-right: 0;
    flex-grow: 0;
  }
}
@container scroll-state(stuck: top) {
  .anchorlink-methodInfo {
    width: 100%;
    background: var(--c-red-drk);
    box-shadow: 0 5px 0px var(--c-gry-bg01);
    border: none;
    outline: none;
  }
  .anchorlink-methodInfo a,
  .anchorlink-methodInfo a i {
    color: #fff;
  }
  .anchorlink-methodInfo a:hover,
  .anchorlink-methodInfo a:hover i {
    color: #222;
    opacity: 1;
  }
  @media screen and (max-width: 960px) {
    .anchorlink-methodInfo {
      width: 109%;
      transform: translateX(-4%);
    }
  }
}
.anchorlink-methodInfo-dtl {
  display: flex;
  flex-flow: row nowrap;
}
.anchorlink-methodInfo-dtl > dt {
  flex: 1 0 auto;
}
/*dd pre-order project _ details*/
.ddpop2025-preorders {
  margin: calc(var(--rs) * 4) auto;
  color: var(--c-blu-drk);
}
.ddpop2025-preorders small {
  font-weight: inherit;
}
.ddpop2025-preorders div ~ div {
  margin-top: 2em;
}
.ddpop2025-preorders dt:not([class]) {
  width: fit-content;
  padding: 0.5em 1em;
  margin-left: 1%;
  background: #fff;
  border: 2px solid var(--c-red-drk);
  color: var(--c-red-drk);
  font-size: calc(var(--fs) * 1.6);
  font-weight: bold;
}
.ddpop2025-preorders dd:not([class]) {
  padding: 0.5em;
  padding-bottom: 1em;
  margin: 0.5em 1% 0;
  border-bottom: 1px dashed #b784a7;
  font-size: calc(var(--fs) * 1.8);
  line-height: 1.5;
  text-align: left;
}
.ddpop2025-preorders dd:not([class]):last-of-type {
  /*border-bottom: none;*/
  margin-bottom: calc(var(--rs) * 8);
}
.ddpop2025-preorders dd p {
  line-height: 1.5;
  position: relative;
}
.ddpop2025-preorders dd p.sm2025-schedule-text {
  margin: calc(var(--rs) * 2) auto;
}
.ddpop2025-preorders dd p.sm2025-schedule-linkbtn {
  margin: calc(var(--rs) * 2) auto;
}
.ddpop2025-preorders b {
  color: var(--color-red);
  /*text-decoration: underline;
  text-underline-offset: 2px;*/
}
.ddpop2025-preorders a[href] {
  color: #0092e2;
}
.ddpop2025-preorders a[id]:not([href]) {
  height: calc(var(--fs) * 12);
  margin-top: calc(var(--fs) * -12);
}
@media screen and (max-width: 960px) {
  .ddpop2025-preorders a[id]:not([href]) {
    height: calc(var(--fs) * 17);
    margin-top: calc(var(--fs) * -17);
  }
}

/*shop list _ japan*/
.ddpop2025-preorders a i {
  margin-left: 0.5em;
  font-size: 87.5%;
}
.shoplist-japan li {
  margin-bottom: 0.5em;
}
.shoplist-japan li > small {
  display: inline-block;
  text-indent: 0;
}
/*shop list  _ overseas*/
.shoplist-overseas dt {
  margin-bottom: 0.5em;
}
.shoplist-overseas dd {
  margin: 0.25em 0.5em;
  margin-left: 1.5em;
  display: inline-block;
}
.shoplist-overseas a::after {
  content: '\f138';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  margin-left: 0.5em;
  font-size: 87.5%;
}
/*shop list _ comon*/
.shoplist-japan > *,
.shoplist-overseas > * {
  padding-left: 1em;
  text-indent: -1em;
}

/*preorers detail*/
.order-notice {
  
}
.ddpop2025-preorders .order-notice > dd:not([class]) {
  padding: 1.25em 1em;
  padding-left: 1.5em;
  margin-top: 0;
  /*border-bottom: none;*/
  /*background: #f4f0f0;*/
  color: #222;
  font-size: calc(var(--fs) * 1.6);
  line-height: 1.6;
}
.order-notice > dd:not([class])::before {
  content: "\25C6";
  padding-right: 0.5em;
  margin-left: -1.5em;
  /*color: var(--c-red-drk);*/
}
.order-notice > dd > ul {
  width: fit-content;
  padding: 0.5em 1em;
  margin: 1em 0;
  background: #fff;
  border: 1px solid #cfcfcf;
  color: #333;
  font-size: calc(var(--fs) * 1.6);
  font-weight: bold;
  text-indent: 0;
}
.order-notice > dd > ul li {
  padding: 0.25em 0;
  /*color: var(--color-red);*/
  display: inline-block;
}
@media screen and (min-width:768px) {
  .order-notice > dd > ul li:not(:last-of-type)::after {
    content: "/";
    margin: 0 1.5em;
    color: rgb(32 54 90 / 100%);
  }
}
/*-------------------------------
 Info _ Exhibition
---------------------------------*/
.container-exhibition {
  padding: 0;
  margin: calc(var(--fs) * 2) auto;
  background: #999;
  border-top: 1px solid #999;
  position: relative;
  display: flex;
  flex-flow: row wrap;
  gap: 1px;
}
.container-exhibition::after {
  content: "";
  width: min(100%, 36rem);
  height: auto;
  background: rgb(255 255 255 / 90%);
  border-bottom: none;
  flex: 1 1 auto;
}
.exhibition-schedule {
  width: min(100%, 36rem);
  margin-bottom: -1px;
  background: #fff;
  border-bottom: 1px solid #999;
  border-collapse: separate;
  border-spacing: calc(var(--fs) * 1);
  flex: 1 1 auto;
}
.exhibition-schedule.exhibition-contFull {
  width: 100%;
}
.exhibition-schedule caption {
  padding: calc(var(--fs) * 1.2) 1em calc(var(--fs) * 0.6);
  background: #fff;
  font-size: calc(var(--fs) * 1.8);
  font-weight: bold;
  line-height: 1.2;
  text-align: left;
}
.exhibition-schedule + .exhibition-schedule caption {
  padding-top: calc(var(--fs) * 2);
}
.exhibition-schedule tr {
  padding-bottom: calc(var(--fs) * 0.5);
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-start;
  justify-content: flex-start;
}
.exhibition-head {
  padding: 0.2em 1.5em;
  border: 1px solid;
  color: #7B6164;
  flex: 0 0 auto;
}
.exhibition-cont {
  width: auto;
  padding: 0.2em 0.5em;
  font-size: calc(var(--fs) * 1.6);
  flex: 1 1 auto;
  text-align: left;
}
.exhibition-item {
  padding-left: 1.5em;
  list-style: disc;
}
.info_colBox__dtl {
  padding: calc(var(--fs) * 0.2) 0;
  font-size: calc(var(--fs) * 1.6);
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
}
.info_colBox__dl__dt {
  padding: 0.2rem 0;
  margin-right: 1em;
  font-weight: bold;
  white-space: nowrap;
  display: flex;
}
.info_colBox__dl__dt > * {
  width: 100%;
  padding: 0.2em 1.5em;
  margin: auto;
  border: 1px solid;
  color: #7B6164;
  font-size: 87.5%;
  line-height: 1.4em;
  display: block;
  text-align: center;
  flex: 1 1 auto;
}
.info_colBox__dl__dd {
  padding: 0.2rem;
  flex: 1 1 auto;
  text-align: left;
}