@charset "utf-8";
/* CSS Document */
@import "/assets/css/reset.css";
@import "/assets/css/base_dd.css";
:root {
  /*box shadow*/
  --bs-cont: 0 0 calc(var(--rs) * 4) calc(var(--rs) * 1) rgb(50 50 50 / 50%);
  /*color*/
  --c-bs-red: #e65d5d;
  --c-bs-pnk: #dc2566;
  --c-bs-blu: #4f85c6;
  --c-bs-blgn: #3bb2a9;
  --c-link: #0095d9;
  --c-link-hover: #155bd4;
  --c-link-cmn: #0095d9;
  --c-link-cmn-hover: #155bd4;
  --color-wht: #fff;
  /*gradation*/
  --grd-pnk: linear-gradient(90deg, rgb(236 99 132 / 70%) 0%, rgb(236 99 132 / 70%) 100%);
  /*sasara color*/
  --sasara-pnk: #ec6384;
  --sasara-lgtblu: #e5fcff;
  /*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-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);
  /* Height */
  --height-hdr: calc(var(--rs) * 6);
  --height-menu: calc(var(--rs) * 6);
  /*width*/
  --w-cont: min(100%, 102.4rem);
  /*backgraound*/
  --bg-pnk01: #f4becb;
  --bg-pnk01-rgb: 244 190 230;
  --bg-pnk02: #f67ba1;
  --bg-pnk02-rgb: 246 123 161;
  --bg-pnk03: #ec6384;
  --bg-pnk03-rgb: 236 99 132;
  --bg-blu01: #d2e3f0;
  --bg-blu01-rgb: 210 227 240;
  --bg-blu02: #d9e9f7;
  --bg-blu02-rgb: 217 233 247;
  --bg-blu03: #6b9dc3;
  --bg-blu03-rgb: 107 157 195;
  --bg-diamond: url("/dd/special/th2/image/dddy_sasara20th/bg_pattern_diamond.png") calc(50% + var(--rs) * 1.5) calc(var(--rs) * -2) / calc(var(--rs) * 10.7) repeat;
}
html { font-size: 62.5%; }
body {
  background: 
    var(--bg-diamond),
    var(--bg-pnk01)
    ;
  color: #3f2925;
  font-size: calc(var(--fs) * 1.4);
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Arial, Helvetica, sans-serif;
  /*font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;*/
  letter-spacing: normal;
  -webkit-text-size-adjust: 100%; /* SmartPhone表示用 */
  line-height: 1.6;
}
.translationCont {
  display: none;
}
/*-------------------------------
 base
---------------------------------*/
/*anchor link*/
a {
  text-decoration: none;
  color: var(--c-link-cmn);
  }
a:hover {
  color: var(--c-link-cmn-hover);
  filter: opacity(0.8);
  transition: filter 0.2s;
}
a:focus, *:focus { outline:none; }
.fa, .fab, .fal, .far, .fas { text-indent: 0;}
a i {
  margin: 0 0.5em;
}
/* anchor link margin */
a[id]:not([href]) {
  height: calc(var(--height-hdr) + 1em);
  margin-top: calc(var(--height-hdr) * -1 - 1em);
  display: block;
  position: relative;
  z-index: -1;
}
a[id="top"]:not([href]),
a[id="itemSpec"]:not([href]),
a[id="info"]:not([href]) {
  height: var(--height-hdr);
  margin-top: calc(var(--height-hdr) * -1);
  position: relative;
  z-index: -1;
}
/*font*/
.ff-NtSnsJP { font-family: var(--ff-NtSnsJP);}
.ff-NtSrfJP { font-family: var(--ff-NtSrfJP);}
.ff-YuMc { font-family: var(--ff-YuMc);}
.ff-SwMc { font-family: var(--ff-SwMc);}
/*image*/
img {
  max-width: 100%;
  height: auto;
  max-height: 100%;
  vertical-align: bottom;
}
/*-------------------------------
 overwrite _ base_dd.css
---------------------------------*/
section,
.container {
  width: 100%;
  text-align: center;
  position: relative;
  overflow: hidden;
}
section .container {
  padding: calc(var(--rs) * 8) 0;
}
/*-------------------------------
 Header
---------------------------------*/
header {
  width:100%;
  background: rgb(255 255 255 / 90%);
  box-shadow: 0 calc(var(--rs) * 0.4) calc(var(--rs) * 0.4) rgb(50 50 50 / 10%);
  color: #fff;
  position:fixed;
  left: 0;
  top: 0;
  z-index: 30;
}
header h1 {
  display: none;
}
header .logo {
  width: calc(var(--rs) * 20);
  margin: 0;
  position: absolute;
  left: 3%;
  top: calc(var(--rs) * 1);
  pointer-events: none;
}
#headerInner {
  width: calc(var(--rs) * 102.4);
  height: var(--height-hdr);
  padding: 0;
  margin: 0 auto;
  text-align: center;
  position: relative;
}
/*--------------------------------------
 Header Navi - SNS Link Button
-----------------------------------------*/
#headerInner > .icbtn-snslnk {
  width: fit-content;
  padding: calc(var(--rs) * 1);
  margin: 0 3% 0 auto;
  text-align: center;
}
.icbtn-cap {
  width: 100%;
  font-size: calc(var(--fs) * 1.8);
  line-height: 1.2;
}
.icbtn-ic {
  margin: 0;
  display: inline-block;
  font-size: calc(var(--fs) * 2);
}
.icbtn-ic a {
  padding: 0;
  color: #fff;
  display: block;
}
/*--------------------------------------
 Header Navi - Toggle Button
-----------------------------------------*/
.navi-toggle {
  width: calc(var(--fs) * 4);
  height: calc(var(--fs) * 4);
  cursor: pointer;
  display: none;
  position: absolute;
  right: min(3%,calc(var(--fs) * 1));
  top: calc(var(--rs) * 0.2);
  z-index: 20;
}
.navi-toggle.on .one {
  transform :rotate(45deg) translate(calc(var(--fs) * 0.8), calc(var(--fs) * 0.7));
}
.navi-toggle.on .two {
  opacity: 0;
}
.navi-toggle.on .three {
  transform :rotate(-45deg) translate(calc(var(--fs) * 0.7), calc(var(--fs) * -0.7));
}
.one,
.two,
.three {
  width: 75%;
  height: 3px;
  margin: calc(var(--fs) * 0.7) auto;
  background-color: #fff;
  backface-visibility: hidden;
  transition-duration: 0.3s;
}
.navi-toggle::after {
  content: "MENU";
  width: 100%;
  color: #fff;
  font-size: calc(var(--fs) * 1);
  text-align: center;
  display: block;
  position: absolute;
  bottom: -1em;
  left: 0;
}
/*--------------------------------------
 Header Navi - switching (SNS Link & Toggle Button )
-----------------------------------------*/
@media screen and (max-width: 767px) {
  #headerInner > .icbtn-snslnk {
    display: none;
  }
  .navi-toggle {
    /*display: block;*/
  }
}
/*-------------------------------
 Header Navi - Global Menu
---------------------------------*/
nav#NaviMenu {
  width: 100%;
  height: calc(100vh - var(--height-hdr));
  padding: var(--height-hdr) 3% 3%;
  background: var(--grd-pnk);
  /*font-family: var(--ff-zenmaruG);*/
  font-family: var(--ff-Cinzel);
  overflow-y: scroll;
  scrollbar-width: none;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 20;
  transform: translateY(-120%);
  transition-duration: 0.3s;
}
/*menu global*/
.naviMenu-global {
  width: 100%;
  max-width: 128rem;
  margin: 0 auto;
  color: #fff;
  font-family: var(--ff-zenOldMin);
  font-size: calc(var(--fs) * 1.5);
  font-weight: 300;
  position: relative;
  z-index: 11;
}
.naviMenu-global > div + div {
  margin: calc(var(--rs) * 5) auto calc(var(--rs) * 10);
}
.naviMenu-global > div :has(.naviMenu-global-linkTop) {
  background: none;
}
.naviMenu-global-linkTop {
  width: min(60%, 30rem);
  margin: calc(var(--rs) * 10) auto;
  display: block;
}
.naviMenu-global-linkTop img {
  /*filter: brightness(0) invert(1);*/
}
/*navi menu open*/
nav#NaviMenu.open {
  transform: translateY(0%);
}
nav#NaviMenu.open .naviMenu-global {
  /*display: block;*/
}
nav#NaviMenu.open + main {
  filter: blur(5px);
  transition: filter 1.5s ease;
}
/*navi hr*/
.naviMenu-global + hr {
  width: min(94%, 108rem);
  margin: 0 auto calc(var(--fs) * 4);
  border-color: var(--sasara-pnk);
}
/*-------------------------------
 overlay manu
---------------------------------*/
.naviMenu-title {
  width: 100%;
  margin-bottom: calc(var(--fs) * 2);
  font-size: calc(var(--fs) * 3);
  font-weight: bold;
  text-align: center;
}
.naviMenu-title small {
  color: var(--c-frieren-gold);
  font-size: calc(var(--fs) * 1.4);
}
/*navi menu banner*/
.naviMenuBnr {
  width: min(92%, 72rem);
  margin: 2% auto 4%;
  text-align: center;
}
/*products thumbnail*/
.productsThumb {
  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;
}
/*.productsThumb::before,
.productsThumb::after {
  content: "";
  width: min(48%, 34rem);
  margin: 1%;
  flex: 1 1 auto;
  order: 2;
}*/
.productsThumb a:hover {
  filter: opacity(0.8);
  transition: all .3s;
}
.productsThumb div.prdctThumb-ctg {
  width: min(48%, 22rem);
  margin: 1%;
  position: relative;
  display: flex;
  flex-flow: column nowrap;
}
.productsThumb :is(li,dd) {
  margin-bottom: calc(var(--rs) * 2);
  /*box-shadow: var(--bs-cont);*/
  position: relative;
  flex: 1 1 auto;
  order: 1;
}
.productsThumb :is(li,dd).prdctNew::before {
  content: "";
  width: 3em;
  height: 3em;
  /*background: linear-gradient(180deg, #f00 0%, #df1414 100%);*/
  background: linear-gradient(180deg, #dccd85 0%, #cec07c 100%);
  border-radius: 50%;
  box-shadow: 1px 1px 3px rgb(50 50 50 / 20%);
}
.productsThumb :is(li,dd).prdctNew::after {
  content: "NEW";
  padding: 1em 0.25em;
  line-height: 1;
  text-shadow: 1px 1px 3px rgb(50 50 50 / 20%);
}
.productsThumb :is(li,dd).prdctNew::before,
.productsThumb :is(li,dd).prdctNew::after {
  font-size: calc(var(--fs) * 1.4);
  position: absolute;
  right: -4%;
  top: -2%;
  z-index: 1;
}
.productsThumb :is(li,dd) a {
  padding-bottom: 0.5em;
  /*background: var(--c-blu);*/
  display: block;
  overflow: hidden;
}
/*.productsThumb::after {
  content: "";
  width: min(48%, 24rem);
  height: 0;
  margin: 1%;
  flex: 1 1 auto;
}*/
.prdctsThum {
  /*background: #fff;*/
  background: none;
}
.prdctsThum img {
  border-radius: calc(var(--rs) * 1);
}
.prdctsThum-name {
  padding: 0.5em;
  min-height: 3em;
  /*background: var(--c-blu);*/
  background: none;
  color: #fff;
  font-weight: normal;
  line-height: 1.4;
  position: relative;
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
}
.prdctsThum-name i {
  color: var(--c-frieren-gold);
  position: absolute;
  right: 0.25em;
  top: calc(50% - 0.4em);
}
.prdctsThum-name small.prdctsThum-soldout {
  width: 100%;
  color: #ffff9d;
  font-size:  calc(var(--fs) * 1.2);
  text-align: center;
  display: block;
  position: absolute;
  bottom: -0.5em;
  left: 0;
}
.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);
}
@media screen and (max-width: 640px) {
  .productsThumb :is(li,dd).prdctNew {
    width: 100%;           
  }
}
/*information contents*/
.naviInfo-conts {
  width: min(98%, 88rem);
  margin: 0 auto;
}
.naviInfo-conts dd {
  background: #fff;
}
.naviInfo-conts .link-btn-container {
  margin-top: 0;
}
.naviInfo-conts .link-btn-container li {
  text-align: center;
}
/*topic contents*/
.naviTopics-conts {
  margin: calc(var(--fs) * 2) auto;
  position: relative;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.naviTopics-conts dt {
  width: 100%;
}
.naviTopics-conts :is(li,dd) {
  width: min(94%, 30rem);
  margin: 1%;
  background: var(--sasara-pnk);
  text-align: center;
  flex: 0 1 auto;
  position: relative;
}
.topics-img {
  aspect-ratio: 75 / 47;
  object-fit: cover;
}
.topics-img--ddX {
  background: #fff;
}
.topics-name {
  padding: 1em 2em 1em 0.5em;
  line-height: 1.3;
  color: #fff;
  font-weight: normal;
  position: relative;
}
@media screen and (max-width: 640px) {
  .naviTopics-conts {
    flex-direction: column;
  }
  .naviTopics-conts :is(li,dd) {
    width: 100%;
    margin: 2% 1%;
  }
  .topics-thum {
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
  }
  .topics-thum img,
  .topics-name{
    width: 50%;
  }
}
/*-------------------------------
  Main Header
---------------------------------*/
.main-header {
  padding-top: var(--height-hdr);
  background: linear-gradient(0deg, rgb(255 255 255 / 40%), rgb(255 255 255 / 40%));
  text-align: center;
  overflow: hidden;
}
.main-header-img {
  width: fit-content;
  margin: 0 auto;
}
/*-------------------------------
 local nav
---------------------------------*/
#localNavi {
  padding: 1em 2%;
  background: var(--grd-pnk);
  font-family: var(--ff-zenmaruG);
  font-weight: bold;
  container-type: inline-size;
}
.local-navi {
  width: var(--w-cont);
  padding:0 1em;
  margin: 0 auto;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.local-navi > *:not([dt]) {
  padding-left: 1em;
  margin: 0.75em 1%;
  font-size: calc(var(--fs) * 1.6);
  text-align: left;
  text-indent: -1em;
}
.local-navi i {
  margin-right: 0.5em;
}
.local-navi a {
  color: #fff;
}
.local-navi a:hover {
  filter: opacity(0.8);
}
@container (max-width: 960px) {
  .local-navi > *:not([dt]) {
    width: min(48%, 32rem);
  }
}
/*-------------------------------
 page anchor link
---------------------------------*/
.anchorlink-container {
  padding: calc(var(--fs) * 1) 2%;
  background: #fff;
  position: relative;
}
.anchorlink-list {
  width: min(96%, 88rem);
  margin: calc(var(--fs)* 1) auto calc(var(--rs)* 2);
  border-radius: 5px;
  font-family: var(--ff-NtSnsJP);
  font-size: calc(var(--fs)* 1.6);
  font-weight: bold;
  line-height: 1.8;
  text-align: left;
  position: relative;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-evenly;
}
.anchorlink-list dt {
  width: 100%;
  padding: 0 2% 0.25em;
  margin-bottom: 0.25em;
  /*background: #fee3e9;
  color: #ed1371;*/
  /*background: #f6971f;*/
  background: #f5691c;
  color: #fff;
  font-size: calc(var(--fs) * 1.8);
  font-weight: bold;
  text-align: center;
}
.anchorlink-list :is(li,dd) {
  padding: 0 1em;
  margin: 0.5em;
  line-height: 1.3;
  text-align: center;
}
.anchorlink-prdct :is(li,dd) {
  padding-left: 1.5em;
  padding-right: 0.5em;
}
.anchorlink-list a {
  padding: calc(var(--rs) * 1.6) 0;
  color: var(--sasara-pnk);
  filter: drop-shadow(0 0 5px #fff);
  display: block;
}

.anchorlink-list a i {
  color: var(--sasara-pnk);
}
.anchorlink-list a:hover,
.anchorlink-list a:hover i {
  color: var(--c-link-hover);
}
/*-------------------------------
 content
---------------------------------*/
.content-container {
  width: 100%;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.cont-inner {
  width: var(--w-cont);
  margin: calc(var(--rs) * 4) auto;
  position: relative;
}

#mdlDDdySasara20th .cont-inner {
  background: rgb(var(--bg-pnk02-rgb) / 40%);
  box-shadow: 0 calc(var(--rs) * 0.5) calc(var(--rs) * 3) calc(var(--rs) * 0.6) rgb(var(--bg-pnk03-rgb) / 70%);
}
#drsSasaraSchoolUniform.content-container {
  background: var(--bg-diamond),var(--bg-blu01);
}
#drsSasaraSchoolUniform .cont-inner {
  background: var(--bg-diamond),var(--bg-blu02);
  box-shadow: 0 calc(var(--rs) * 0.5) calc(var(--rs) * 3) calc(var(--rs) * 0.6) rgb(var(--bg-blu03-rgb) / 70%);
}
/*content _ title*/
.sctn-title {
  width: var(--w-cont);
  padding: 0 2%;
  margin: 0 auto calc(var(--rs) * 3);
  color: var(--sasara-pnk);
  font-size: calc(var(--rs) * 4.8);
  font-weight: normal;
  letter-spacing: 0.1em;
  line-height: 1.4;
  text-align: center;
  position: relative;
}
.sctn-title span {
  font-size: calc(var(--fs) * 2.4);
  display: block;
}
/*-------------------------------
 Gallery
---------------------------------*/
.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: 2px solid #fff;
  filter: drop-shadow(1px 2px 3px rgb(1 173 175 / 20%));
}
.item-pic--thumb {
  width:100%;
  object-fit: contain;
}
/*-------------------------------
 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-collapse: separate;
  border-spacing: 5px;
}
table.specTable caption {
  width: 100%;
  padding: 0 5px calc(var(--fs) * 1.4);
  font-size: calc(var(--fs) * 0.8 + var(--rs) * 1.4);
  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) * 2.8);
}
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: 7em;
  background: #555;
  border-radius: 3px;
  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: 0;
  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;
}
.hr-spec {
  width: 94%;
  margin: 1em auto 2em;
  border: none;
  border-bottom: 1px dashed var(--sasara-pnk);
}
.specLnk {
  width: 100%;
  position: relative;
  padding: 0;
  margin: 0 auto;
}
.specLnk-txt {
  width: 92%;
  margin: 0 auto calc(var(--rs) * 2);
  font-size: calc(var(--fs) * 1.5);
  text-align: center;
  position: relative;
}
a.lnkBtn-spec {
  display: block;
  width: min(48rem,50%);
  font-size: calc(var(--fs) * 1.5);
  margin: 0 auto calc(var(--rs) * 2);
}
/*link button*/
.link-btn-container {
  width: 100%;
  padding: 0;
  margin: calc(var(--fs) * 1) auto calc(var(--fs) * 2);
  text-align: center;
  position: relative;
}
a.link-ec-btn {
  width: min(92%, 64rem);
  padding: 1.5em 0.5em;
  margin: 0 auto;
  background: var(--c-link-cmn);
  border-radius: calc(var(--rs) * 1);
  color: #fff;
  font-family: var(--ff-NtSnsJP);
  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%);
}
/*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;
}
/*-------------------------------
 spec attention
---------------------------------*/
.product-attention {
  width: min(100%, 102.4rem);
  padding-bottom: 1em;
  margin: 0 auto;
  position: relative;
}
.spec-att {
  width: min(94%, 72rem);
  margin: 0 auto calc(var(--rs) * 4);
  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%);
}
.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;
}
/*-------------------------------
 Info:展示販売アンカーリンク
---------------------------------*/
.navi-middle {
	position: relative;
	width: min(100%, 96rem);
	display: flex;
	margin: -2% auto calc(var(--rs) * 4);
	padding: 0;
	justify-content: space-between;
	align-items: stretch;
	overflow-x: auto;
}
.navi-middle > li {
	flex: 1 0 auto;
	max-width: calc(100% / 2);
	font-size: calc(var(--fs) * 1.5);
}
.navi-middle > li + li {
	border-left: .1rem solid #e5e5e5;
}
.navi-middle > li a {
	display: block;
	padding: 1em;
	position: relative;
	text-align: center;
	height: 100%;
	font-weight: bold;
	background: #F4F4F4;
	border-bottom: .1rem solid #e5e5e5;
	color: #a0a0a0;
}
.navi-middle > li a:hover {
  background: #fff;
  text-decoration: none;
  color: var(--sasara-pnk);
}
.navi-middle > li.select {}
.navi-middle > li.select a {
	color: #222;
  padding-left: 0;
	pointer-events: none;
	cursor: default;
	background: #fff;
	border-color: #fff;
  position: relative;
}

.navi-middle > li a::before,
.navi-middle > li a:hover::before,
.navi-middle > li.select a::before {
	content: "◆";  
	display: inline-block;
	width: 1.5em;
	margin: -.5em 0;
	color: var(--sasara-pnk);
}
.navi-middle > li a::before {
  visibility: hidden;
}
.navi-middle > li a:hover::before,
.navi-middle > li.select a::before {
  visibility: visible;
}
.navi-middle > li:not(.select) a {
}
/*-------------------------------
 Information
---------------------------------*/
.info-container {
  padding: calc(var(--rs) * 8) 0;
  background: rgb(255 255 255 / 50%);
  position: relative;
}
.cont-container {
  position: relative;
  z-index: 1;
}
.cont-container-inner {
  width: min(100%, 96rem);
  padding: 2%;
  margin: calc(var(--rs) * 2) auto;
  background: rgb(255 255 255 / 100%);
  box-shadow: 0 3px 10px 1px rgb(50 50 50 / 50%);
  position: relative;
}
.container-infoItem {
  width: min(100%, 96rem);
  margin: calc(var(--rs) * 2) auto;
}
.info-itemHeader {
  width: 100%;
  padding: 0.5em;
  margin: calc(var(--rs) * 4) auto calc(var(--rs) * 2);
  color:var(--sasara-pnk);
  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);
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
}
.info-itemHeader > span {
  margin: 0 0.25em;
  flex: 1 1 auto;
}
.info-itemHeader::before,
.info-itemHeader::after {
  content: "";
  width: 10%;
  height: 1px;
  margin: auto;
  background: var(--sasara-pnk);
  filter: drop-shadow(0 0 2px #fff) drop-shadow(0 0 10px #fff);
  flex: 1 1 auto;
}
/*information item banner*/
.info-itemBnr {
  width: 96%;
  margin: 0 auto calc(var(--rs) * 4);
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.info-table .info-itemBnr {
  margin-bottom: 0;
}
.itemBnr-col2 {
  display: flex;
  flex-flow: row wrap;
}
.info-itemBnr li {
  margin-bottom: calc(var(--rs) * 2);
  overflow: hidden;
}
.itemBnr-col2 li {
  width: 48%;
  margin: 0 1% calc(var(--rs) * 2);
}
.bnr-box {
  background: none;
}
.bnr-box figcaption {
  padding: 0.5em;
  font-size: calc(var(--fs) * 1.6);
  text-align: center;
}
.bnr-box figcaption i {
  margin-left: 0.5em;
  font-size: 87.5%;
}
a:has(.bnr-box) {
  font-weight: bold;
}
/*information details*/
.container-info {
  
}
.container-info + .container-info {
  margin-top: calc(var(--rs) * 6);
}
.container-info hr {
  width: 98%;
  margin: calc(var(--rs) * 6) auto calc(var(--rs) * 3);
  border-bottom: none;
  border-color: #aaa;
  border-style: dashed;
  border-width: 1px;
}
.info-header {
  padding: 0.5em;
  margin-bottom: calc(var(--rs) * 2);
  background: var(--sasara-pnk);
  color: #fff;
  font-family: var(--ff-IBM-Sns);
  font-size: calc(var(--fs) * 1.6 + var(--rs) * 1.2);
  font-weight: normal;
  font-style: italic;
  line-height: 1;
  text-align: center;
}
.info-header:first-child {
  margin-bottom: 0;
}
.info-header small {
  font-size: calc(var(--fs) * 1.2 + var(--rs) * 0.4);
}
/*info description*/
.info-description {
  padding: 0.5em 3%;
  font-size: calc(var(--fs) * 1.2 + var(--rs) * 0.8);
}
.info-dscrp-list {
  width: 100%;
  position: relative;
}
.info-dscrp-list li {
  padding-left: 1em;
  margin: 0.5em 0;
  line-height: 1.3;
  text-indent: -1em;
}
/*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(--sasara-pnk);
  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;
}
/*info box _ summary table*/
.info-table {
  width: 100%;
  margin: calc(var(--rs)* 2) auto;
  border: 1px solid var(--sasara-pnk);
  border-collapse: separate;
  border-spacing: 5px;
  position: relative;
}
.info-table tr {
  padding-bottom: calc(var(--fs) * 0.5);
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-start;
  justify-content: flex-start;
}
.info-table th,
.info-table td{
  padding: calc(var(--rs) * 0.5);
  line-height: 1.6;
  text-align: left;
  position: relative;
}
.info-table th{
  width: 6.5em;
  padding-left: 0.5em;
  padding-right: 0.5em;
  background:  var(--sasara-pnk);
  color: #fff;
  font-size: calc(var(--fs) * 1.6);
  font-weight: normal;
  text-align: center;
  white-space: nowrap;
}
/*.info-table th:after {
  content: "：";
  position: absolute;
  right: -0.25em;
}*/
.info-table td {
  width: 100%;
  padding-left: 0.75em;
  font-size: calc(var(--fs) * 1.8);
}
.info-table td[colspan] {
  padding: 2% 2.5px 1px;
}
.info-table td > small {
  display: inline-block;
}
/*info box _ notice list*/
.info-table ul.note-list {
  font-size: calc(var(--fs) * 1.4);
}
/*info box _ elements*/
b.info-point {
  margin-top: -0.125em;
  margin-right: 2px;
  color: #b71a35;
  font-size: 112.5%;
  text-indent: 0;
  display: inline-block;
}
.info-eveEnd {
  color: #c22424;
  font-size: 87.5%;
  display: inline-block;
}
a.info-link {
  width: 96%;
  margin: calc(var(--rs) * 2) auto;
  text-align: center;
  display: block;
  position: relative;
}
.info-bnr {
  margin:  0 auto;
  background: #fff;
  box-shadow: var(--bs-pic);
}
.info-bnr-text {
  padding: 0.5em 1em;;
  font-size: calc(var(--fs) * 1.4);
  line-height: 1.3;
}
a.info-link-bnrEnd {
  pointer-events: none;
  cursor: none;
  position: relative;
}
a.info-link-bnrEnd .info-bnr {
  filter: brightness(0.5) blur(1px);
}
a.info-link-bnrEnd::after {
  content: "公開終了";
  width: 100%;
  color: #fff;
  font-size: calc(var(--fs)* 1.8);
  filter: drop-shadow(2px 4px 6px #000);
  text-align: center;
  display: block;
  position: absolute;
  left: 0;
  top: calc(50% - 1em);
}
/*tenpo list*/
.tenpo-list {
  margin: 0 auto;
  font-size: calc(var(--fs) * 1.6);
}
.tenpo-list > :is(li,dd) {
  display: inline-block;
}
.tenpo-list > :is(li,dd):not(:last-child)::after {
  content: " / ";
  opacity: .3;
  filter: grayscale(100%);
  display: inline-block;
  margin-left: .5em;
  margin-right: .5em;
  font-weight: normal !important;
}
/*overseas*/
.info-box.info-overseas {
  padding: 1em 2%;
  margin-top: calc(var(--rs) * 4);
  background: #f5f5f5;
}
.info-linkBtnList {
  width: 100%;
  padding: 0 1%;
  margin: calc(var(--fs) * 1) auto;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-start; 
  flex-flow: row wrap;
}
.info-linkBtnList li {
  width: min(100%, 24rem);
  max-width: 46rem;
  margin: calc(var(--fs) * 1) 1%;
  flex: 1 1 auto;
}
.info-linkBtnList li.info-linkBtnList-vsols {
  width: 98%;
  max-width: 98%;
}
.info-linkBtn {
  padding: calc(var(--fs) * 1.5) 1em;
  background: #fff;
  border-radius: 3em;
  box-shadow: 0 0 calc(var(--rs) * 0.3) rgb(50 50 50 / 50%);
  color: var(--c-link);
  font-size: calc(var(--fs) * 1.6);
  font-weight: normal;
  text-align: center;
  display: block;
  overflow: hidden;
}
.info-linkBtn:hover {
  background: var(--c-link);
  color: #fff;
}
.fa-icon-lnkBtn {
  content: "";
  width: 1em;
  height: 1em;
  margin: 0 0.1em;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 100% auto;
  font-size: 2.4em;
  vertical-align: middle;
  display: inline-block;
}
.icon-lnkBtn-onlinestore {
  background-image: url(/assets/image/icons/appicon_onlinestore.png);
}
.icon-lnkBtn-str {
  background-image: url(/assets/image/icons/common_ic_store-wht.svg);
}
.icon-lnkBtn-web {
  background-image: url(/assets/image/icons/common_ic_onlinestore-wht.svg);
}
.icon-lnkBtn-web-ovs {
  background-image: url(/assets/image/icons/common_ic_ovs_onlinestore-wht.png);
}
.icon-lnkBtn-home {
  background-image: url(/assets/image/icons/common_ic_home-wht.svg);
}
/*link button*/
.link-btn-container {
  width: 100%;
  padding: 0;
  margin: calc(var(--fs) * 1) auto calc(var(--fs) * 2);
  text-align: center;
  position: relative;
}
a.link-ec-btn {
  width: min(96%, 72rem);
  padding: 1.5em 0.5em;
  margin: 0 auto;
  background: var(--c-link-cmn);
  border-radius: calc(var(--rs) * 1);
  color: #fff;
  font-family: var(--ff-NtSnsJP);
  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%);
}
/*-------------------------------
 Information local navi
---------------------------------*/
/*販売方法ローカルナビ*/
.nav-event-anchor {
  width: min(100%,96rem);
  padding: calc(var(--rs) * 4) 0 calc(var(--rs) * 2);
  margin: 0 auto ;
  background: var(--sasara-lgtblu);
  position: relative;
  margin-left: auto;
  margin-right: auto;
}
.nav-event-innr {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  /*box-shadow: 0 .2rem .8rem 0 rgba(0, 0, 0, 0.16);*/
  font-size: calc(var(--fs) * 1.5);
}
.nav-event-anchor li {
  width: calc(100% / 3);
  text-align: center;
  position: relative;
}
.nav-event-anchor li + li:after {
  content: '';
  position: absolute;
  left: 1px;
  top: 2.4rem;
  width: 1px;
  height: calc(100% - 4.8rem);
  background: var(--sasara-pnk);
}
.nav-event-anchor li a {
  display: block;
  padding: 1rem .5rem;
}
.nav-event-anchor li a::after {
  content: "";
  position: absolute;
  bottom: 1.2rem;
  left: 50%;
  width: 1.2rem;
  height: 1.2rem;
  margin-left: -.6rem;
  border-right: 2px solid var(--sasara-pnk);
  border-bottom: 2px solid var(--sasara-pnk);
  transform: rotate(45deg);
  transition: all .3s ease-out;
}
.nav-event-anchor li a:hover {
  text-decoration: none;
}
.nav-event-anchor li a:hover::after {
  bottom: .5rem;
}
.nav-event-anchor_num {
  display: block;
  background: linear-gradient(0deg, var(--sasara-pnk) 0%, var(--sasara-pnk) 100%);
  color: #fff;
  width: 3em;
  height: 3em;
  line-height: 3em;
  text-align: center;
  margin: -1.5em auto 1em;
  border-radius: 50rem;
  font-weight: bold;
}
.nav-event-anchor_cap {
  font-size: calc(var(--fs) * 1.6);
  color: var(--sasara-pnk);
  line-height: 1.2;
  margin-bottom: 2em;
}
/*-------------------------------
 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;
}
/*-------------------------------
 copyligith
---------------------------------*/
#cmnCopy {
  padding: 2em 3%;
  background: rgb(255 255 255 / 80%);
}
/*-------------------------------
 Footer Navi _ SNS Links
---------------------------------*/
.footer-navi {
  font-size: calc(var(--fs) * 1.4);
}
/*-------------------------------
 Footer
---------------------------------*/
footer {
  background: var(--sasara-pnk);
}