@charset "utf-8";


@import url('html5reset-1.6.1.css');

@media print{
  body::after,#t-mv:before{ display:none; }
}

:root {
  --tra1:.4s cubic-bezier(0.215, 0.61, 0.355, 1);
  --tra2:.8s cubic-bezier(0.215, 0.61, 0.355, 1);
}

*{ box-sizing: border-box; }
html{ height: 100%;  }
body{
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  color: #5b5656;
  line-height: 1.7;
  font-size: 90%;
  overflow: visible;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
  letter-spacing:0.1em;
  text-align: justify;
  text-justify: inter-ideograph;
  -webkit-font-smoothing: subpixel-antialiased;
  background-color: #fff;
  word-wrap: break-word;
  min-height: 100vh;
}
.en{ font-family: "Roboto", serif; font-weight: 300; font-style: italic; }

body::after {
      content: '';
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color:#fff; 
      z-index: 9999; 
      pointer-events: none; 
      opacity: 0; 
      transition: .5s .5s;
}
body.fadeout::after {
      opacity: 1;
      transition: opacity .5s ease;
}


.ball-scale > div {
  background-color: #fff;
  width: 15px;
  height: 15px;
  border-radius: 100%;
  margin: 2px;
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
  display: inline-block;
  height: 60px;
  width: 60px;
  -webkit-animation: ball-scale 1s 0s ease-in-out infinite;
          animation: ball-scale 1s 0s ease-in-out infinite; }

.ball-scale-random {
  width: 37px;
  height: 40px; }
  .ball-scale-random > div {
    background-color: #fff;
    width: 15px;
    height: 15px;
    border-radius: 100%;
    margin: 2px;
    -webkit-animation-fill-mode: both;
            animation-fill-mode: both;
    position: absolute;
    display: inline-block;
    height: 30px;
    width: 30px;
    -webkit-animation: ball-scale 1s 0s ease-in-out infinite;
            animation: ball-scale 1s 0s ease-in-out infinite; }
    .ball-scale-random > div:nth-child(1) {
      margin-left: -7px;
      -webkit-animation: ball-scale 1s 0.2s ease-in-out infinite;
              animation: ball-scale 1s 0.2s ease-in-out infinite; }
    .ball-scale-random > div:nth-child(3) {
      margin-left: -2px;
      margin-top: 9px;
      -webkit-animation: ball-scale 1s 0.5s ease-in-out infinite;
              animation: ball-scale 1s 0.5s ease-in-out infinite; }
@-webkit-keyframes ball-scale {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0); }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0; } }

@keyframes ball-scale {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0); }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0; } }


img{
  margin: 0;
  padding: 0;
  vertical-align: bottom;
  line-height: 0;
  max-width: 100%;
  height: auto;
  backface-visibility: hidden;
  image-rendering: -webkit-optimize-contrast;
}

a{
  text-decoration: none;
  color: #5b5656;
}
a:hover{
  text-decoration: underline;
}







h2.pro-tit{ font-weight:300; font-style: italic; letter-spacing:0.1em; color:#000; font-size:40px; margin-bottom:.7em; }
a.t-link{ min-width:12em; margin:0 auto; letter-spacing:0.2em; color:#848080; background-color:#aba9a9; display:inline-block; padding:.6em 1.5em; font-size:14px; position:relative; transition:.3s; }
a.t-link.ja{ letter-spacing:0.05em; font-weight:bold; }
a.t-link b{ font-weight:300; font-size:140%; }
a.t-link.type2{ background-color:#fff;  min-width:18em; padding:.3em .3em .5em; border:1px solid #fff; }
a.t-link span{ position: relative; z-index: 3;  }
a.t-link:hover{ text-decoration:none; color:#fff;  }
a.t-link:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background:  #848080;
  width: 100%;
  height: 100%;
  transition: transform .3s;
  transform: scale(0, 1);
  transform-origin: left top;
}
a.t-link:hover:before{
  transform-origin:right top;
  transform:scale(1, 1);
}

#foot-nav{ background-color:#fff; text-align:center; position:relative; z-index:1; padding-top:3em; }
ul.linkbtn{ width:270px; margin:0 auto; font-size:75%; }
#foot-nav ul{ width:300px; margin:0 auto 10em; }
#foot-nav ul a,ul.linkbtn a{ background-color:#efedec; display:block; padding:1em; font-size:140%; letter-spacing:0.2em; margin-bottom:1.5em; position:relative; font-family: "EB Garamond", serif; }
ul.linkbtn a{ background-color:#fff; }
#foot-nav ul a span,ul.linkbtn a span{ position: relative; z-index: 2; transition:.5s; }
#foot-nav ul a:before,ul.linkbtn a:before{ content:""; width:0; height:100%; position:absolute; left:0; top:0; transition:.5s cubic-bezier(0.215, 0.61, 0.355, 1); background-color:#554440; }
#foot-nav ul a:hover,ul.linkbtn a:hover{ color:#fff; }
#foot-nav ul a:hover:before,ul.linkbtn a:hover:before{ width:100%; }

footer {
  background: #fff;
  padding: 10em 0;
  position:relative; z-index:1;
  text-align: center;
  font-size: 10px;
}

footer .fSns {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 200px;
  margin: 0 auto 4em;
}
footer .fSns li{
  display: inline-block;
  box-sizing: border-box;
  padding: 0 8%;
}
footer .fSns li a{ transition:var(--tra1); width:1.3rem; height:1.3rem; display:block; background-size:cover; }
footer .fSns li a:hover{ opacity:.7; }
footer .fSns li a.instagram{background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA1MTIgNTEyIj48cGF0aCBkPSJNMzcwLjkgNkgxNDEuMUM2Ni42IDYgNiA2Ni42IDYgMTQxLjF2MjI5LjhDNiA0NDUuNCA2Ni42IDUwNiAxNDEuMSA1MDZoMjI5LjhjNzQuNSAwIDEzNS4xLTYwLjYgMTM1LjEtMTM1LjFWMTQxLjFDNTA2IDY2LjYgNDQ1LjQgNiAzNzAuOSA2em05NC43IDM2NC45YzAgNTIuMi00Mi41IDk0LjctOTQuNyA5NC43SDE0MS4xYy01Mi4yIDAtOTQuNy00Mi41LTk0LjctOTQuN1YxNDEuMWMwLTUyLjIgNDIuNS05NC43IDk0LjctOTQuN2gyMjkuOGM1Mi4yIDAgOTQuNyA0Mi41IDk0LjcgOTQuN3YyMjkuOHoiLz48cGF0aCBkPSJNMzY3LjkgMjM4LjZjLTMuNi0yNC0xNC41LTQ1LjctMzEuNi02Mi44LTE3LjEtMTcuMS0zOC45LTI4LjEtNjIuOC0zMS42LTEwLjktMS42LTIyLTEuNi0zMi45IDAtMjkuNiA0LjQtNTUuOCAyMC4xLTczLjYgNDQuMXMtMjUuMiA1My42LTIwLjkgODMuMmM0LjQgMjkuNiAyMC4xIDU1LjggNDQuMSA3My42IDE5LjUgMTQuNSA0Mi43IDIyLjEgNjYuNiAyMi4xIDUuNSAwIDExLjEtLjQgMTYuNy0xLjIgMjkuNi00LjQgNTUuOC0yMC4xIDczLjYtNDQuMSAxNy44LTI0LjIgMjUuMi01My43IDIwLjgtODMuM3pNMjY3LjUgMzI2Yy0xOSAyLjgtMzcuOS0xLjktNTMuMi0xMy4zLTE1LjQtMTEuNC0yNS40LTI4LjEtMjguMi00Ny4xLTIuOC0xOSAxLjktMzcuOSAxMy4zLTUzLjIgMTEuNC0xNS40IDI4LjEtMjUuNCA0Ny4xLTI4LjIgMy41LS41IDctLjggMTAuNS0uOHM3IC4zIDEwLjUuOGMzMS41IDQuNyA1NS44IDI5IDYwLjQgNjAuNCA1LjggMzktMjEuMyA3NS42LTYwLjQgODEuNHpNMzk2LjcgMTE1LjNjLTMuOC0zLjgtOS01LjktMTQuMy01LjktNS4zIDAtMTAuNSAyLjItMTQuMyA1LjktMy44IDMuOC01LjkgOS01LjkgMTQuM3MyLjIgMTAuNSA1LjkgMTQuM2MzLjggMy44IDkgNS45IDE0LjMgNS45IDUuMyAwIDEwLjUtMi4yIDE0LjMtNS45IDMuOC0zLjggNS45LTkgNS45LTE0LjMgMC01LjMtMi4yLTEwLjUtNS45LTE0LjN6Ii8+PC9zdmc+);}
footer .fSns li a.facebook{ background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2MTIgNjEyIj48cGF0aCBkPSJNMzI1LjcgNjA0LjVWMzA1LjhoOTguNWwxNS42LTk5SDMyNS43di00OS42YzAtMjUuOCA4LjUtNTAuNSA0NS41LTUwLjVoNzQuMVY4SDM0MC4yYy04OC40IDAtMTEyLjYgNTguMi0xMTIuNiAxMzguOXY1OS45aC02MC43djk5aDYwLjd2Mjk4LjZoOTguMXYuMXoiLz48L3N2Zz4=); }
footer .fSns li a.line{background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0NTUuNyA0NTUuNyI+PHBhdGggZD0iTTQ0OC42IDE4Ni40QzQ0My4zIDkzIDM0Ni41IDE4LjcgMjI3LjggMTguNyAxMDUuNyAxOC43IDYuNyA5Ny40IDYuNyAxOTQuNWMwIDg5LjMgODMuNiAxNjMgMTkxLjkgMTc0LjMgNi42LjcgMTEuNCA2LjcgMTAuNyAxMy4zbC00LjYgNDEuNWMtMSA5LjQgOC43IDE2LjMgMTcuMiAxMi4yIDkxLjUtNDQuMiAxNDYuMy04OS42IDE3OC45LTEyOSA1LjktNy4yIDI1LjMtMzQuMyAyOS4zLTQxLjUgOC40LTE1LjEgMTQuMi0zMS40IDE2LjktNDguNCAxLTUuMyAxLjUtOS44IDEuNy0xMy40LjUtNS44LjEtMTQuNC0uMS0xNy4xem0tMzA4LjQgNjYuNEg5NC45Yy02LjIgMC0xMS4zLTUuMS0xMS4zLTExLjN2LTg1LjRjMC02LjIgNS4xLTExLjMgMTEuMy0xMS4zczExLjMgNS4xIDExLjMgMTEuM3Y3NC4xaDMzLjljNi4yIDAgMTEuMyA1LjEgMTEuMyAxMS4zLjEgNi4yLTUgMTEuMy0xMS4yIDExLjN6bTQ0LjYtOC45YzAgNC45LTQgOC44LTguOCA4LjhoLTQuOWMtNC45IDAtOC44LTQtOC44LTguOHYtOTAuM2MwLTQuOSA0LTguOCA4LjgtOC44aDQuOWM0LjkgMCA4LjggNCA4LjggOC44djkwLjN6TTI5MCAyNDFjMCA2LjMtNS4xIDExLjgtMTEuNCAxMS44LTMgMC01LjctMS4yLTcuNy0zLjEtLjctLjYtNDYuNS02MC4xLTQ2LjUtNjAuMXY1MS44YzAgNi4yLTUuMSAxMS4zLTExLjMgMTEuMy02LjIgMC0xMS4zLTUuMS0xMS4zLTExLjN2LTg0LjljMC02LjIgNC43LTExLjUgMTAuOS0xMS44IDMuNS0uMSA2LjcgMS40IDguOSAzLjguNy44IDQ1LjkgNTkuNyA0NS45IDU5LjdWMTU2YzAtNi4yIDUuMS0xMS4zIDExLjMtMTEuMyA2LjIgMCAxMS4zIDUuMSAxMS4zIDExLjN2ODV6bTczLjUtMTAuOWM2LjIgMCAxMS4zIDUuMSAxMS4zIDExLjMgMCA2LjItNS4xIDExLjMtMTEuMyAxMS4zaC00NS4yYy02LjIgMC0xMS4zLTUuMS0xMS4zLTExLjNWMTU2YzAtNi4yIDUuMS0xMS4zIDExLjMtMTEuM2g0NS4yYzYuMiAwIDExLjMgNS4xIDExLjMgMTEuMyAwIDYuMi01LjEgMTEuMy0xMS4zIDExLjNoLTMzLjl2MjAuMWgzMy45YzYuMiAwIDExLjMgNS4xIDExLjMgMTEuMyAwIDYuMi01LjEgMTEuMy0xMS4zIDExLjNoLTMzLjl2MjAuMWgzMy45eiIvPjwvc3ZnPg==);}
footer .fSns li a.tiktok{ background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iODAwIiBoZWlnaHQ9IjgwMCIgdmlld0JveD0iMCAwIDUxMiA1MTIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTQxMi4xOSAxMTguNjZhMTA5LjI3IDEwOS4yNyAwIDAgMS05LjQ1LTUuNSAxMzIuODcgMTMyLjg3IDAgMCAxLTI0LjI3LTIwLjYyYy0xOC4xLTIwLjcxLTI0Ljg2LTQxLjcyLTI3LjM1LTU2LjQzaC4xQzM0OS4xNCAyMy45IDM1MCAxNiAzNTAuMTMgMTZoLTgyLjQ0djMxOC43OGMwIDQuMjggMCA4LjUxLS4xOCAxMi42OSAwIC41Mi0uMDUgMS0uMDggMS41NiAwIC4yMyAwIC40Ny0uMDUuNzF2LjE4YTcwIDcwIDAgMCAxLTM1LjIyIDU1LjU2IDY4LjggNjguOCAwIDAgMS0zNC4xMSA5Yy0zOC40MSAwLTY5LjU0LTMxLjMyLTY5LjU0LTcwczMxLjEzLTcwIDY5LjU0LTcwYTY4LjkgNjguOSAwIDAgMSAyMS40MSAzLjM5bC4xLTgzLjk0YTE1My4xNCAxNTMuMTQgMCAwIDAtMTE4IDM0LjUyIDE2MS43OSAxNjEuNzkgMCAwIDAtMzUuMyA0My41M2MtMy40OCA2LTE2LjYxIDMwLjExLTE4LjIgNjkuMjQtMSAyMi4yMSA1LjY3IDQ1LjIyIDguODUgNTQuNzN2LjJjMiA1LjYgOS43NSAyNC43MSAyMi4zOCA0MC44MkExNjcuNTMgMTY3LjUzIDAgMCAwIDExNSA0NzAuNjZ2LS4ybC4yLjJjMzkuOTEgMjcuMTIgODQuMTYgMjUuMzQgODQuMTYgMjUuMzQgNy42Ni0uMzEgMzMuMzIgMCA2Mi40Ni0xMy44MSAzMi4zMi0xNS4zMSA1MC43Mi0zOC4xMiA1MC43Mi0zOC4xMmExNTguNDYgMTU4LjQ2IDAgMCAwIDI3LjY0LTQ1LjkzYzcuNDYtMTkuNjEgOS45NS00My4xMyA5Ljk1LTUyLjUzVjE3Ni40OWMxIC42IDE0LjMyIDkuNDEgMTQuMzIgOS40MXMxOS4xOSAxMi4zIDQ5LjEzIDIwLjMxYzIxLjQ4IDUuNyA1MC40MiA2LjkgNTAuNDIgNi45di04MS44NGMtMTAuMTQgMS4xLTMwLjczLTIuMS01MS44MS0xMi42MXoiLz48L3N2Zz4=); }
footer .fSns li a.pinterest{background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2MTIgNjEyIj48cGF0aCBkPSJNNTQ1LjIgMjE0LjZDNTQ1LjIgMTA3LjEgNDU2IDcgMzIwLjUgNyAxNTEuOCA3IDY2LjggMTMwLjQgNjYuOCAyMzMuNGMwIDYyLjMgMjMuMSAxMTcuOCA3Mi43IDEzOC40IDguMSAzLjQgMTUuNC4xIDE3LjgtOSAxLjYtNi40IDUuNS0yMi40IDcuMi0yOS4xIDIuNC05LjEgMS41LTEyLjMtNS4xLTIwLjItMTQuMy0xNy4zLTIzLjQtMzkuNS0yMy40LTcxLjEgMC05MS41IDY3LjEtMTczLjUgMTc0LjctMTczLjUgOTUuMyAwIDE0Ny43IDU5LjUgMTQ3LjcgMTM4LjggMCAxMDQuNS00NS4zIDE5Mi43LTExMi42IDE5Mi43LTM3LjIgMC02NC45LTMxLjMtNTYtNjkuOCAxMC42LTQ1LjkgMzEuMy05NS41IDMxLjMtMTI4LjYgMC0yOS42LTE1LjYtNTQuNC00Ny45LTU0LjQtMzggMC02OC41IDQwLjEtNjguNSA5My44IDAgMzQuMiAxMS40IDU3LjMgMTEuNCA1Ny4zcy0zOC45IDE2OC4xLTQ1LjcgMTk3LjVjLTYuMiAyNi44LTcuMSA1Ni4zLTYuMyA4MS4xIDIuNiAyMi4zIDI0LjIgNDAuNSA0MyAxNiAxMy4yLTIxLjUgMjcuNC00OC43IDM0LjctNzUuOSA0LjQtMTYuMSAyNS05OS42IDI1LTk5LjYgMTIuMyAyNCA0OC40IDQ1LjIgODYuNyA0NS4yIDExNC4zLS4xIDE5MS43LTEwNi4zIDE5MS43LTI0OC40eiIvPjwvc3ZnPg==);}



.sp{ display:none; }
.ssp{ display:none; }
@media screen and (max-width: 1440px) {
  body{ font-size: 1.05vw; }
}
@media screen and (max-width: 1240px) {
  body{ font-size: 1.1vw; }
}
@media screen and (max-width: 810px) {
  body{ font-size: 1.6vw; }
  .sp{ display:block; }
  .pc{ display:none; }
  #foot-nav{ padding-top:8em; }
  ul.linkbtn{ font-size:70%; }
}
@media screen and (max-width: 600px) {
  body{ font-size: 2.5vw; letter-spacing:0.01em; }
  .ppc{ display:none; }
  .ssp{ display:block; }
  #foot-nav ul,ul.linkbtn{ width:70%; }

}


.t-conts{ background-color:#fff; position:relative; z-index:1; padding:2em 0; }
.t-conts > a{ max-width:1600px; width: 90%; margin: 0 auto;  display: block; position:relative; color: #000; transition:var(--tra1);} 
.t-conts > a:hover .img img{ transform:scale(1.1); }
.t-conts > a:hover{ color:#fff; }
.t-conts > a:hover .txt h3 img{ filter:brightness(0) invert(1); }
.t-conts .img{ overflow:hidden; }
.t-conts .img img{ transition:var(--tra1); transform:scale(1.1); opacity:0; }
.t-conts .play .img img{ transform:scale(1); opacity:1; }
.t-conts .txt{ position: absolute; font-size: 140%; right: 3em; top: 50%; transform: translateY(-50%); letter-spacing:0.1em; text-align:right; }
.t-conts .play .txt{ opacity:1; }
.t-conts .txt h3{ margin:1em 0 0; }
.t-conts .txt h3 img{ height:3em; width:auto; transition:var(--tra1); }
.t-conts .txt p{ font-size:110%; }
.t-conts .txt p.tp2{ font-size:120%; }
.t-conts .txt p.tp3{ font-size:80%; margin-top:1em; font-weight:500; }

.t-conts#mv{ padding:0; color: #000; }
.t-conts#mv .txt{ font-size:140%; }

.u-conts{ margin:10em auto; width:90%; text-align:center; }
.u-conts.style2{ margin-top:20em; }
.u-conts .txt{ max-width:1000px; margin:0 auto; }
.u-conts .txt h2{ margin-bottom:4em; }
.u-conts .txt h2 img{ height:3em; width:auto; }
.u-conts .txt h2 span{ display:block; margin-top:1em; }
.u-conts .txt h2 span img{ height:2.2em;}
.u-conts .txt h3{ font-size:120%; margin-bottom:1em; font-weight:500; }
.u-conts .txt h4{ margin-bottom:.6em;  font-weight:500; }
.u-conts .txt p{ margin-bottom:4em; font-size:90%; line-height:2.2; }
.u-conts .txt .item-txt{ font-size:90%; }


.u-conts video{ max-width:540px; width:80%; }
.u-conts .ph{  margin:6em auto;  }
.u-conts .ph li{ display:flex; gap:2em; width:70%; }
.u-conts .ph .slide{ position:relative; }
.u-conts .ph .slide img:first-child{ position:absolute; left:0; top:0; width:100%; z-index: 3; animation:fade-ph 5s linear infinite;  }


.u-conts .ph .ph1-3 > div,
.u-conts .ph .ph2-1 > div{ position:relative; }
.u-conts .ph .ph1-3 img,
.u-conts .ph .ph2-1 img{ position:relative; z-index: 2; }
.u-conts .ph li.ph1c{ justify-content:center; flex-direction: row-reverse; width: 60%; margin-left: 13%; }
.u-conts .ph li.ph1c .ph1-1{ margin-top:30em; }
.u-conts .ph li.ph2c{  margin:2em auto; }
.u-conts .ph li.ph2c .ph2-2{ margin-top:-20em; }
.u-conts .ph li.ph3c{ justify-content:center; margin:2em auto; width:76%; }
.u-conts .ph li.ph3c .ph3-2{ margin-top:-3.5em; }
.u-conts .ph li.ph4c{ justify-content:center; width:30%; margin:-5em auto 0; }
.u-conts .ph li.ph4c .ph4-1{ transform:translateX(25%); position:relative; }
.u-conts .ph .ph4-1 img{ position:relative; z-index: 2; }

.u-conts .ph.row li{ flex-direction:row-reverse; }
.u-conts .ph.row li.ph1c{ margin-left: 28%; flex-direction:row; }
.u-conts .ph.row li.ph4c .ph4-1{ transform:translateX(-35%); }
.u-conts .price{ font-weight:500; }
.u-conts .price a{ display:inline-block; margin:0 1.5em; }


.u-conts .ph li.ph4c .ph4-1:before,
.u-conts .ph li.ph4c .ph4-1:after {
  content: "";
  display: block;
  position: absolute;
  background-color: #000;
  top: 0;
  pointer-events: none;
  z-index: 3;
}
.u-conts .ph li.ph4c .ph4-1:before {
  left: 0;
  width: 0;
  height: 3px;
}
.u-conts .ph li.ph4c .ph4-1:after {
  right: 0;
  width: 3px;
  height: 0;
}
.u-conts .ph li.ph4c.play .ph4-1:before {
  width: 100%;
  transition: width 0.15s 0.3s linear;
}
.u-conts .ph li.ph4c.play .ph4-1:after {
  height: 100%;
  transition: height 0.15s 0.45s linear;
}
.u-conts .ph li.ph4c.play .ph4-1 span:before {
  width: 100%;
  transition: width 0.15s 0.6s linear;
}
.u-conts .ph li.ph4c.play .ph4-1 span:after {
  height: 100%;
  transition: height 0.15s .75s linear;
}
.u-conts .ph li.ph4c .ph4-1 span:before,
.u-conts .ph li.ph4c .ph4-1 span:after {
  content: "";
  display: block;
  position: absolute;
  background-color: #000;
  bottom: 0;
  pointer-events: none;
  z-index: 3;
}
.u-conts .ph li.ph4c .ph4-1 span:before {
  right: 0;
  width: 0;
  height: 3px;
}
.u-conts .ph li.ph4c .ph4-1 span:after {
  left: 0;
  width: 3px;
  height: 0;
}

.u-conts .ph li.ph4c .ph4-1.c1:before,.u-conts .ph li.ph4c .ph4-1.c1:after,
.u-conts .ph li.ph4c .ph4-1.c1 span:before,.u-conts .ph li.ph4c .ph4-1.c1 span:after { background-color: #fff5a4; }
.u-conts .ph li.ph4c .ph4-1.c2:before,.u-conts .ph li.ph4c .ph4-1.c2:after,
.u-conts .ph li.ph4c .ph4-1.c2 span:before,.u-conts .ph li.ph4c .ph4-1.c2 span:after { background-color: #F4D9ED; }
.u-conts .ph li.ph4c .ph4-1.c3:before,.u-conts .ph li.ph4c .ph4-1.c3:after,
.u-conts .ph li.ph4c .ph4-1.c3 span:before,.u-conts .ph li.ph4c .ph4-1.c3 span:after { background-color: #F4D9ED; }
.u-conts .ph li.ph4c .ph4-1.c4:before,.u-conts .ph li.ph4c .ph4-1.c4:after,
.u-conts .ph li.ph4c .ph4-1.c4 span:before,.u-conts .ph li.ph4c .ph4-1.c4 span:after { background-color: #d8ecfa; }
.u-conts .ph li.ph4c .ph4-1.c5:before,.u-conts .ph li.ph4c .ph4-1.c5:after,
.u-conts .ph li.ph4c .ph4-1.c5 span:before,.u-conts .ph li.ph4c .ph4-1.c5 span:after { background-color: #cee1f1; }
.u-conts .ph li.ph4c .ph4-1.c6:before,.u-conts .ph li.ph4c .ph4-1.c6:after,
.u-conts .ph li.ph4c .ph4-1.c6 span:before,.u-conts .ph li.ph4c .ph4-1.c6 span:after { background-color: #e49a57; }


.txt.ef h3,
.txt.ef h4,.txt.ef p{ opacity:0; }
.u-conts.ef video{ opacity:0; }
.txt.play h3{ animation:fade-effect var(--tra2) .3s forwards; }
.txt.play h4,
.txt.play p{ animation:fade-effect var(--tra2) .6s forwards; }
.u-conts.play video{ animation:bt-effect var(--tra2) .6s forwards; }


.u-conts .ph li .ph1-3 > div:before,
.u-conts .ph li .ph2-1 > div:before{ transform:scale(.1);  }
.u-conts .ph li.play .ph1-3 > div:before,
.u-conts .ph li.play .ph2-1 > div:before{ animation:scale-effect var(--tra1) forwards; }
.u-conts .ph li .ph4-1:before{ opacity:0;  }
.u-conts .ph li.play .ph4-1:before{ animation:border-effect ease .2s .4s forwards; }

.ph li .left,.ph li .right,.ph li .bt{ opacity:0; }
.ph li.play .left{ animation:left-effect var(--tra1) forwards; }
.ph li.play .right{ animation:right-effect var(--tra1)  forwards; }
.ph li.play .bt{ animation:bt-effect var(--tra1) forwards; }

@keyframes fade-ph {
  0% {opacity: 1;  }
  6% {opacity: 0; }
  50% {opacity: 0;  }
  56% {opacity: 1; }
}

@keyframes fade-effect {
  0% {opacity: 0;  }
  100% {opacity: 1; }
}
@keyframes bt-effect {
  0% {opacity: 0; transform:translateY(3em);  }
  100% {opacity: 1; transform:translateY(0); }
}
@keyframes left-effect {
  0% {opacity: 0; transform:translateX(-5em);  }
  100% {opacity: 1; transform:translateX(0); }
}
@keyframes right-effect {
  0% {opacity: 0; transform:translateX(5em);  }
  100% {opacity: 1; transform:translateX(0); }
}
@keyframes scale-effect {
  0% { transform:scale(.1);  }
  100% {  transform:scale(1.0); }
}
@keyframes border-effect {
  0% { border-width:0; opacity: 0;  }
  100% {  border-width:5px; opacity: 1; }
}

.lo-nav{ max-width:1000px; margin:15em auto 10em; width:90%; text-align:center; }
.lo-nav h2{ width:70%; margin:0 auto 5em; }
.lo-nav li{ position:relative; margin-bottom:2em; }
.lo-nav li a{ color:#fff; display:block; }
.lo-nav li a:hover{animation: shine .8s; text-decoration: none; }
.lo-nav li .txt{ font-size: 110%; position:absolute; top: 50%; transform: translateY(-50%); right: 5%; width:100%; text-align:right; }
.lo-nav li .txt span{ display:block; margin:0 auto .5em; font-size:130%; text-shadow:3px 3px 3px rgba(0, 0, 0, .7); }
.lo-nav li .txt img{ height:3em; width:auto; filter:brightness(0) invert(1) drop-shadow(2px 2px 3px rgba(0, 0, 0, .5)); }



@media screen and (max-width: 810px) {

  .t-conts > a{ width: 90%;} 
  .t-conts#mv .txt { font-size: 120%; transform:translateY(0); top:10%; }
  .u-conts .ph li { width: 100%; }
  
  .u-conts .ph li.ph1c{ width: 90%; margin-left: 0; }
  .u-conts .ph li.ph1c .ph1-1{ margin-top:22em; }
  .u-conts .ph li.ph2c .ph2-2{ margin-top:-15em; }
  .u-conts .ph li.ph3c{ margin:2em 0 0 -3%; width:106%; }
  .u-conts .ph li.ph3c .ph3-2{ margin-top:-4em; }
  .u-conts .ph li.ph4c{ width:50%; margin:-3em auto 0; }
  .u-conts .ph.row li.ph1c{ margin-left: 10%; }
  .u-conts .ph.row li.ph4c .ph4-1{ transform:translateX(-15%); }
  

  @keyframes bt-effect {
  0% {opacity: 0; transform:translateY(2em);  }
  100% {opacity: 1; transform:translateY(0); }
  }
  @keyframes left-effect {
    0% {opacity: 0; transform:translateX(-3em);  }
    100% {opacity: 1; transform:translateX(0); }
  }
  @keyframes right-effect {
    0% {opacity: 0; transform:translateX(3em);  }
    100% {opacity: 1; transform:translateX(0); }
  }
  @keyframes scale-effect {
    0% { transform:scale(.1);  }
    100% {  transform:scale(1.0); }
  }
  @keyframes border-effect {
    0% { border-width:0; opacity: 0;  }
    100% {  border-width:3px; opacity: 1; }
  }

}
@media screen and (max-width: 600px) {
  .t-conts{ padding:1em 0; }
  .t-conts > a{ color:#fff; }
  .t-conts > a .txt h3 img{ filter:brightness(0) invert(1) drop-shadow(2px 2px 3px rgba(0, 0, 0, .5)) !important; height:2.5em; }
  .t-conts .txt{ right: 2em; font-size: 90%; text-shadow:2px 2px 3px rgba(0, 0, 0, .5); }
  .t-conts#mv .txt { font-size: 130%; right:auto; left:5%; width: 90%; text-align:left; bottom:5%; top:auto; color:#fff; }
  .t-conts#mv .txt h3 img { filter:brightness(0) invert(1) drop-shadow(2px 2px 3px rgba(0, 0, 0, .5)); }
  .shiny .u-conts .ph li.ph4c .ph4-1{ margin-top:1.2em; }


  .u-conts{ margin:5em auto; }
  .u-conts.style2{ margin-top:10em; }
  .u-conts .price a{ display: block; font-size:110%; }
  .lo-nav{ margin:10em auto 6em; }
  .lo-nav h2{ width:90%; margin:0 auto 3em; }
  .lo-nav li .txt span{ font-size:110%; }
  .lo-nav li .txt img{ height:2em; }

  .u-conts .ph li { display:block; width: 90%; }
  
  .u-conts .ph li.ph1c{  margin: 2em auto 0; z-index:2; position:relative; }
  .u-conts .ph li.ph1c .ph1-1{ margin:2em 0 0 35%; width:70%; }
  .u-conts .ph li.ph2c{ margin-top:-2em; }
  .u-conts .ph li.ph2c .ph2-1{ width:70%; margin-left:-5%; }
  .u-conts .ph li.ph2c .ph2-2{ margin:2em 0 0 0; }
  .u-conts .ph li.ph3c{ margin:0 auto; width:90%; }
  .u-conts .ph li.ph3c .ph3-1{ margin:2em auto 0; width:80%; }
  .u-conts .ph li.ph3c .ph3-2{ margin-top:2em; }
  .u-conts .ph li.ph4c{ width:60%; margin:-2em auto 0; }
  .u-conts .ph li.ph4c .ph4-1 { transform: translateX(15%); }
  .u-conts .ph.row li.ph1c{ margin-left: auto; }
  .u-conts .ph.row li.ph1c .ph1-1{ margin-left:-5%; }
  .u-conts .ph.row li.ph2c .ph2-1{ margin-left:35%; }
  

  
}



.linkbtn{
  background:#c5c5c5;
  
  position:relative;
  font-size:1.2em;
  padding:1em 2em 1.1em;
  cursor:pointer;
  outline:none;
  display: block;
  text-align: center;
  margin: 2em auto;
  font-weight: 500;
  width: 20em;
}
.linkbtn.wh{ background-color:#fff; border: 1px solid #2f343b; }
.linkbtn:hover{
  animation: shine .8s;
  text-decoration: none;
}
@keyframes shine {
  0% { opacity: 1; }
  10% { opacity: 0.2;}
  100% { opacity: 1; }
}


.newWin{ display: inline-block; width: 8px; height: 7px; border: 1px solid #595757; position:relative; top: -2px; margin: 0 5px; }
.newWin:before,.newWin:after{ content: "";  position:absolute; bottom: -4px; right: -4px; background-color: #595757; }
.newWin:before{ width: 1px; height: 7px; }
.newWin:after{ width: 8px; height: 1px; }
.newWin.wh{ border: 1px solid #fff; }
.newWin.wh:before,.newWin.wh:after{ background-color: #fff; }

.newWin2{ position:relative; display: block; }
.newWin2:before,.newWin2:after{ content: "";  position:absolute; width: 7px; height: 5px; right: 13px; top: 10px; border: 1px solid #595757; z-index: 2; }
.newWin2:before{  }
.newWin2:after{ right: 10px; top: 14px; border-width: 0 1px 1px 0;  }

a.alqha{ transition: all .6s cubic-bezier(0.33, 1, 0.68, 1); display: block; }
a.alqha:hover{ opacity:0.5; }

.ef{ opacity:0; }
.ef.play{ animation:fade-effect var(--tra1) forwards; }


ul.notes {
  display: table;
  width: 100%;
  margin: 0;
  padding-left: 0;
}
ul.notes li {
  list-style: none;
  font-size: 85%;
  line-height: 1.6;
  color: #777;
  margin-top: .3em;
}
ul.notes li span:first-child {
  display: table-cell;
  vertical-align: top;
  white-space: nowrap;
  padding-right: 0.5em;
}
ul.notes li span {
  display: table-cell;
  vertical-align: top;
}


#pagetop{ position: fixed; z-index: 11; right: -100px; bottom: 30px; transition: all .3s; opacity: 0.7; }
body.on #pagetop{ right: 30px;  }
#pagetop:hover{ transform:translate(0,-5px); opacity: 1; }

a[href^="tel:"]:hover { cursor: default; text-decoration: none; }
.menu-trigger{ display: none; }








/* ボックス内dloatｖalear */
.cf:after,#product .detail:after,#product > dl:after {
	content: ".";
	display: block;
	visibility: hidden;
	clear: both;
	height: 0;
}
.cf,#product .detail,#product > dl {display: inline-block;}
/* Hides from macIE \*/
* html .cf,* html #product .detail,* html #product > dl {height: 1%;}
.cf,#product .detail,#product > dl {display: block;}
/* End hide from macIE */

sup{ font-size: 70%; margin-top: -2em; display: inline-block;}
.fontP1{ font-size: 110%;}
.fontP2{ font-size: 120%;}
.fontP3{ font-size: 130%;}
.fb{ font-weight: bold;}
.fl { float: left !important; }
.fr { float: right !important; }
.tac{ text-align: center !important;}
.tal{ text-align: left !important;}
.tar{ text-align: right !important;}

.fc01{ color:  #006bb5; }


/* margin-top */
.mt0{margin-top: 0px !important;}
.mt1{margin-top: 1px !important;}
.mt2{margin-top: 2px !important;}
.mt3{margin-top: 3px !important;}
.mt4{margin-top: 4px !important;}
.mt5{margin-top: 5px !important;}
.mt7{margin-top: 7px !important;}
.mt10{margin-top: 10px !important;}
.mt15{margin-top: 15px !important;}
.mt20{margin-top: 20px !important;}
.mt30{margin-top: 30px !important;}
.mt40{margin-top: 40px !important; }
.mt50{margin-top: 50px !important; }
.mt100{margin-top: 100px !important; }
.mt150{margin-top: 150px !important; }

/* margin-right */
.mr1{margin-right: 1px !important;}
.mr2{margin-right: 2px !important;}
.mr3{margin-right: 3px !important;}
.mr4{margin-right: 4px !important;}
.mr5{margin-right: 5px !important;}
.mr8{margin-right: 8px !important;}
.mr10{margin-right: 10px !important;}
.mr15{margin-right: 15px !important;}
.mr20{margin-right: 20px !important;}
.mr70{margin-right: 70px !important;}

/* margin-bottom */
.mb0{margin-bottom: 0px !important;}
.mb1{margin-bottom: 1px !important;}
.mb2{margin-bottom: 2px !important;}
.mb3{margin-bottom: 3px !important;}
.mb4{margin-bottom: 4px !important;}
.mb5{margin-bottom: 5px !important;}
.mb10{margin-bottom: 10px !important;}
.mb15{margin-bottom: 15px !important;}
.mb20{margin-bottom: 20px !important;}
.mb30{margin-bottom: 30px !important;}
.mb50{margin-bottom: 50px !important;}
.mb80{margin-bottom: 80px !important;}

/* margin-left */
.ml1{margin-left: 1px !important;}
.ml2{margin-left: 2px !important;}
.ml3{margin-left: 3px !important;}
.ml4{margin-left: 4px !important;}
.ml5{margin-left: 5px !important;}
.ml10{margin-left: 10px !important;}
.ml15{margin-left: 15px !important;}
.ml20{margin-left: 20px !important;}

/* padding-top */
.pt0{padding-top: 0px !important;}
.pt1{padding-top: 1px !important;}
.pt2{padding-top: 2px !important;}
.pt3{padding-top: 3px !important;}
.pt4{padding-top: 4px !important;}
.pt5{padding-top: 5px !important;}
.pt10{padding-top: 10px !important;}
.pt15{padding-top: 15px !important;}
.pt20{padding-top: 20px !important;}
.pt50{padding-top: 50px !important;}

/* padding-right */
.pr1{padding-right: 1px !important;}
.pr2{padding-right: 2px !important;}
.pr3{padding-right: 3px !important;}
.pr4{padding-right: 4px !important;}
.pr5{padding-right: 5px !important;}
.pr10{padding-right: 10px !important;}
.pr15{padding-right: 15px !important;}
.pr20{padding-right: 20px !important;}

/* padding-bottom */
.pb0{padding-bottom: 0px !important;}
.pb1{padding-bottom: 1px !important;}
.pb2{padding-bottom: 2px !important;}
.pb3{padding-bottom: 3px !important;}
.pb4{padding-bottom: 4px !important;}
.pb5{padding-bottom: 5px !important;}
.pb10{padding-bottom: 10px !important;}
.pb15{padding-bottom: 15px !important;}
.pb20{padding-bottom: 20px !important;}
.pb80{padding-bottom: 80px !important;}

/* padding-left */
.pl1{padding-left: 1px !important;}
.pl2{padding-left: 2px !important;}
.pl3{padding-left: 3px !important;}
.pl4{padding-left: 4px !important;}
.pl5{padding-left: 5px !important;}
.pl10{padding-left: 10px !important;}
.pl15{padding-left: 15px !important;}
.pl20{padding-left: 20px !important;}


