@charset "utf-8";

:root {
  --pcv: / 1440 * 100vw;
  --pcp: / 1440 * 100%;
  
  --spv: / 375 * 100vw;
  --spp: / 375 * 100%;
}

/* -------------------------------------------------
  font
------------------------------------------------- */

/*
google fonts [Zen Old Mincho]
*/

@font-face {
  font-family: 'Zen Old Mincho';
  font-weight: 400;
  font-style: normal;
  src: url('../font/Zen_Old_Mincho/ZenOldMincho-Regular.ttf') format('truetype');
}
@font-face {
  font-family: 'Zen Old Mincho';
  font-weight: 500;
  font-style: normal;
  src: url('../font/Zen_Old_Mincho/ZenOldMincho-Medium.ttf') format('truetype');
}
@font-face {
  font-family: 'Zen Old Mincho';
  font-weight: 700;
  font-style: normal;
  src: url('../font/Zen_Old_Mincho/ZenOldMincho-Bold.ttf') format('truetype');
}

/* -------------------------------------------------
  reset
------------------------------------------------- */

html {
}

body {
  -webkit-text-size-adjust: 100%;
  position: relative;
}

.wrapper_ {
  overflow: visible;
}

main {
  padding: 0 0 60px;
  display: block;
  text-align: left;
  font-family: 'Zen Old Mincho', serif;
  font-weight: 500;
}

main * {
  margin: 0;
  padding: 0;
  vertical-align: top;
  box-sizing: border-box;
  line-height: 1;
  letter-spacing: 0;
}

main p,
main h2,
main h3,
main h4,
main th,
main td,
main li,
main dt,
main dd,
main figcaption {
  font-weight: 500;
}

main img {
  border: none;
  max-width: 100%;
  height: auto;
}

main iframe {
  border: none;
}

main a {
  text-decoration: none;
}
main a:hover {
  
}

main ul, main ol {
  list-style-type: none;
}

@media print, screen and (min-width:731px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

@media screen and (max-width:730px) {
  main {
    padding: 0 0 45px;
  }
}

/* -------------------------------------------------
  responsive
------------------------------------------------- */

@media print, screen and (min-width:731px) {
  .pc-none {
    display: none !important;
  }
}

@media screen and (max-width:730px) {
  .sp-none {
    display: none !important;
  }
}

/* -------------------------------------------------
  #fv
------------------------------------------------- */

#fv {
  width: 100%;
  position: sticky;
  top: 0;
  z-index: 2;
}
#fv.op0 {
  opacity: 0;
}
#fv #video {
  position: relative;
  z-index: 2;
}

#fv #video-box {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
}
#fv #video-box video {
  width: 100%;
  height: 100%;
}

#fv #video .spacer {
  width: 100%;
  display: none;
  position: relative;
  z-index: 4;
}
#fv.yoko #video .spacer.yoko {
  display: block;
}
#fv.tate #video .spacer.tate {
  display: block;
}

#fv .mask {
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 4;
}

@media print, screen and (min-width:731px) {
  #fv {
    margin-top: -70px;
    padding-top: 70px;
  }
}

@media screen and (max-width:730px) {
  #fv {
    margin-top: -42px;
    padding-top: 42px;
  }
}

/* -------------------------------------------------
  #lead
------------------------------------------------- */

#lead {
  position: relative;
  z-index: 4;
}
#lead .spacer {
  width: 100%;
  display: none;
  position: relative;
  z-index: 2;
}
#fv.yoko + #lead .spacer.yoko {
  display: block;
}
#fv.tate + #lead .spacer.tate {
  display: block;
}

#lead .texts {
  color: #fff;
  position: absolute;
  top: 50%;
  left: calc(170 var(--pcp));
  transform: translateY(-50%);
}
#lead .texts .text1 {
  display: block;
  font-weight: 400;
  font-size: calc(18 var(--pcv));
}
#lead .texts .text2 {
  margin-top: 0.3em;
  display: block;
  font-size: calc(47 var(--pcv));
  letter-spacing: -0.02em;
}
#lead .texts .text3 {
  margin-top: 1.2em;
  display: block;
  font-weight: 400;
  font-size: calc(14 var(--pcv));
  letter-spacing: 0.01em;
}
#lead .texts .text4 {
  margin-top: 0.5em;
  display: block;
  font-weight: 400;
  font-size: calc(18 var(--pcv));
  letter-spacing: 0.01em;
}
#lead .texts .desc {
  margin-top: 2.5em;
  font-size: calc(15 var(--pcv));
  line-height: calc(24 / 15);
  letter-spacing: 0.01em;
}

@media screen and (max-width:730px) {
  #lead .texts {
    width: 100%;
    left: 0;
    text-align: center;
  }
  #lead .texts .text1 {
    font-size: calc(18 var(--spv));
  }
  #lead .texts .text2 {
    margin-top: 0.4em;
    font-size: calc(42 var(--spv));
  }
  #lead .texts .text3 {
    margin-top: 1.6em;
    font-size: calc(14 var(--spv));
  }
  #lead .texts .text4 {
    font-size: calc(18 var(--spv));
  }
  #lead .texts .desc {
    margin-top: 2.5em;
    font-size: calc(15 var(--spv));
  }
}

/* -------------------------------------------------
  #under
------------------------------------------------- */

#under {
  padding-top: 32px;
  position: relative;
  z-index: 10;
  background: #fff;
}

#under .top-logo {
  width: 100%;
  text-align: center;
  position: sticky;
  top: 60px;
  z-index: 4;
  mix-blend-mode: difference;
}
#under .top-logo img {
  width: 64px;
}

@media screen and (max-width:730px) {
  #under {
    padding-top: calc(46 var(--spv));
  }
  
  #under .top-logo {
    top: 52px;
  }
  #under .top-logo img {
    width: calc(52 var(--spp));
  }
}

/* -------------------------------------------------
  #lead2
------------------------------------------------- */

#lead2 .texts .copy .large {
  font-size: calc(36 var(--pcv));
  letter-spacing: -0.02em;
  display: block;
}
#lead2 .texts .copy .small {
  margin-top: 0.8em;
  font-size: calc(15 var(--pcv));
  letter-spacing: 0.01em;
  display: block;
  font-weight: 700;
}
#lead2 .texts .desc {
  margin-top: 2.8em;
  font-size: calc(15 var(--pcv));
  letter-spacing: 0.01em;
  font-weight: 700;
  line-height: calc(33 / 15);
}

@media print, screen and (min-width:731px) {
  #lead2 {
    margin-top: 86px;
    position: relative;
  }
  #lead2 .pic {
    width: calc(1100 var(--pcp));
    margin: 0 auto;
    position: sticky;
    top: 152px;
  }
  #lead2 .pic img {
    width: 100%;
    transform-origin: right top;
    transition: transform 1s cubic-bezier(.12,.92,.31,.95);
  }
  #lead2.on .pic img {
    transform: scale(0.68);
  }
  #lead2 .texts {
    width: calc(1100 var(--pcp));
    margin: 0 auto;
    padding-bottom: 17.5vw;
  }
}

@media screen and (max-width:730px) {
  #lead2 {
    margin-top: calc(71 var(--spv));
  }
  #lead2 .texts {
    margin: calc(85 var(--spv)) 0 0 calc(30 var(--spv));
  }
  #lead2 .texts .copy .large {
    font-size: calc(36 var(--spv));
  }
  #lead2 .texts .copy .small {
    font-size: calc(15 var(--spv));
  }
  #lead2 .texts .desc {
    font-size: calc(15 var(--spv));
    line-height: calc(33 / 15);
  }
}

/* -------------------------------------------------
  #credit
------------------------------------------------- */

.credit {
  margin-top: 15px;
}
.credit li,
.credit li a {
  font-size: 11px;
  line-height: calc(19 / 11);
}
.credit li a {
  text-decoration: underline;
}

@media print, screen and (min-width:731px) {
  .credit li a:hover {
    opacity: 0.5;
  }
}

@media screen and (max-width:730px) {
  .credit {
    margin-top: calc(15 var(--spv));
  }
  .credit li,
  .credit li a {
    font-size: calc(11 var(--spv));
  }
}

/* -------------------------------------------------
  #looks
------------------------------------------------- */

#looks {
  position: relative;
  margin-top: 86px;
  z-index: 2;
}
#looks img {
  width: 100%;
}

@media print, screen and (min-width:731px) {
  #looks .col2 {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  #looks .sticky-group {
    position: sticky;
    z-index: 2;
  }
  #looks .bottom-group {
    background: #fff;
    position: relative;
    z-index: 10;
  }
}

@media screen and (max-width:730px) {
  #looks {
    margin-top: calc(71 var(--spv))
  }
}

/* -------------------------------------------------
  #block1
------------------------------------------------- */

@media print, screen and (min-width:731px) {
  #block1 .col2 {
    gap: 0 calc(100 var(--pcp));
  }
  #block1 .col2 .left {
    width: calc(550 var(--pcp));
  }
  #block1 .col2 .right {
    width: calc(450 var(--pcp));
  }
}

@media screen and (max-width:730px) {
  #block1 .col2 .left {
    width: calc(285 var(--spp));
    margin: calc(69 var(--spv)) auto 0;
  }
  #block1 .col2 .right {
    width: calc(285 var(--spp));
    margin: calc(70 var(--spv)) auto 0;
  }
}

/* -------------------------------------------------
  #block2
------------------------------------------------- */

@media print, screen and (min-width:731px) {
  #block2 .col2 {
    margin-top: 200px;
    gap: 0 calc(70 var(--pcp));
  }
  #block2 .col2 .left {
    width: calc(450 var(--pcp));
  }
  #block2 .col2 .right {
    width: calc(580 var(--pcp));
  }
}

@media screen and (max-width:730px) {
  #block2 .col2 > div {
    margin-top: calc(70 var(--spv));
  }
  #block2 .credit {
    margin-left: calc(30 var(--spp));
  }
}

/* -------------------------------------------------
  #block3
------------------------------------------------- */

#block3 .pic {
	position: relative;
}
#block3 .pic img:nth-child(2) {
	opacity: 0;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 4;
	animation: fade1 8s ease-out 0s infinite;
}

@keyframes fade1 {
	0% { opacity: 0; }
	37.5% { opacity: 0; }
	50% { opacity: 1; }
	87.5% { opacity: 1; }
	100% { opacity: 0; }
}

@media print, screen and (min-width:731px) {
  #block3 .col2 {
    margin-top: 145px;
    justify-content: space-between;
  }
  #block3 .col2 > div {
    width: calc(660 var(--pcp));
  }
  #block3 .col2 .left .credit {
    margin-left: calc(170 var(--pcv));
  }
}

@media screen and (max-width:730px) {
  #block3 .col2 > div {
    width: calc(300 var(--spp));
    margin-top: calc(70 var(--spv));
  }
  #block3 .left .credit {
    margin-left: calc(30 var(--spp));
  }
  #block3 .right {
    margin-left: calc(75 var(--spp));
  }
}

/* -------------------------------------------------
  #block4
------------------------------------------------- */

@media print, screen and (min-width:731px) {
  #block4 {
    margin-top: 170px;
  }
}

@media screen and (max-width:730px) {
  #block4 {
    margin-top: calc(70 var(--spv));
  }
}

/* -------------------------------------------------
  #block5
------------------------------------------------- */

@media screen and (max-width:730px) {
  #block5 {
    margin-top: calc(70 var(--spv));
  }
}

/* -------------------------------------------------
  #block6
------------------------------------------------- */

@media print, screen and (min-width:731px) {
  #block6 .col2 {
    margin-top: 200px;
    gap: 0 calc(70 var(--pcp));
  }
  #block6 .col2 .left {
    width: calc(450 var(--pcp));
  }
  #block6 .col2 .right {
    width: calc(580 var(--pcp));
  }
}

@media screen and (max-width:730px) {
  #block6 .col2 > div {
    width: calc(300 var(--spp));
    margin-top: calc(70 var(--spv));
  }
  #block6 .left .credit {
    margin-left: calc(30 var(--spp));
  }
  #block6 .right {
    margin-left: calc(75 var(--spp));
  }
}

/* -------------------------------------------------
  #block7
------------------------------------------------- */

@media print, screen and (min-width:731px) {
  #block7 {
    margin-top: 150px;
  }
  #block7 .pic {
    width: calc(450 var(--pcp));
    margin: 0 auto;
  }
}

@media screen and (max-width:730px) {
  #block7 {
    margin-top: calc(70 var(--spv));
  }
  #block7 .pic {
    width: calc(250 var(--spp));
    margin: 0 auto;
  }
}

/* -------------------------------------------------
  #block8
------------------------------------------------- */

@media print, screen and (min-width:731px) {
  #block8 .col2 {
    margin-top: 200px;
    gap: 0 calc(70 var(--pcp));
  }
  #block8 .col2 .left {
    width: calc(450 var(--pcp));
  }
  #block8 .col2 .right {
    width: calc(580 var(--pcp));
  }
}

@media screen and (max-width:730px) {
  #block8 .col2 > div {
    width: calc(300 var(--spp));
    margin-top: calc(70 var(--spv));
  }
  #block8 .left {
    margin-left: calc(75 var(--spp));
  }
  #block8 .right .credit {
    margin-left: calc(30 var(--spp));
  }
}

/* -------------------------------------------------
  #bottom-video-block
------------------------------------------------- */

#bottom-video-block {
  width: calc(1100 var(--pcp));
  margin: 185px auto 0;
}
#bottom-video-block #video2 {
  position: relative;
  z-index: 2;
}

#bottom-video-block #video-box2 {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 4;
}
#bottom-video-block #video-box2 video {
  width: 100%;
  height: 100%;
}

#bottom-video-block #video2 .spacer {
  width: 100%;
  display: none;
  position: relative;
  z-index: 2;
}
#bottom-video-block.yoko #video2 .spacer.yoko {
  display: block;
}
#bottom-video-block.tate #video2 .spacer.tate {
  display: block;
}

@media screen and (max-width:730px) {
  #bottom-video-block {
    width: calc(315 var(--spp));
    margin-top: calc(75 var(--spv));
  }
  
  /*
    SPビューの場合のみ、動画部分に黒バックのコントローラー等が表示され綺麗でないので、正面にポスター画像を配置。
     これをクリックすることで、SPは動画再生とする。
  */
  #bottom-video-block .sp-face {
    width: 100%;
    height: 100%;
    display: block;
    border: none;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 4;
  }
  #bottom-video-block .sp-face .play {
    width: 16vw;
    height: 16vw;
    background: rgba(255,255,255,0.8);
    display: block;
    border-radius: 50%;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
  }
  #bottom-video-block .sp-face .play::after {
    width: 0;
    height: 0;
    content: "";
    display: block;
    border-width: 4vw 0 4vw 7vw;
    border-color: transparent transparent transparent rgba(0,0,0,0.8);
    border-style: solid;
    position: absolute;
    left: 33%;
    top: 24%;
  }
}

/* -------------------------------------------------
  #block9
------------------------------------------------- */

@media print, screen and (min-width:731px) {
  #block9 {
    margin-top: 158px;
  }
  #block9 .pic {
    width: calc(1100 var(--pcp));
    margin: 0 auto;
  }
}

@media screen and (max-width:730px) {
  #block9 {
    margin-top: calc(100 var(--spv));
  }
}

/* -------------------------------------------------
  .bottom-logo
------------------------------------------------- */

.bottom-logo {
  padding-top: 60px;
  background: #fff;
  position: relative;
  z-index: 4;
}
.bottom-logo img {
  width: 115px;
  margin: 0 auto;
  display: block;
}

@media screen and (max-width:730px) {
  .bottom-logo {
    padding-top: calc(45 var(--spv));
  }
  .bottom-logo img {
    width: calc(95 var(--spv));
  }
}

/* -------------------------------------------------
  .bottom-link
------------------------------------------------- */

.bottom-link {
  padding-top: 60px;
  background: #fff;
	text-align: center;
  position: relative;
  z-index: 4;
}
.bottom-link a {
  width: 230px;
  height: 54px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  background: #E8E8E8;
  font-size: 15px;
  letter-spacing: 0.03em;
  text-decoration: underline;
}

/* -------------------------------------------------
	animation
------------------------------------------------- */

.anim {
  opacity: 0;
  transition: all 1.2s cubic-bezier(.12,.92,.31,.95);
  transform: translateY(50px);
}
.anim.to-bottom { transform: translateY(-50px); }
.anim.to-right { transform: translate(-50px,0); }
.anim.to-left { transform: translate(50px,0); }

.anim.delay01 { transition-delay: 0.1s; }
.anim.delay02 { transition-delay: 0.2s; }
.anim.delay03 { transition-delay: 0.3s; }
.anim.delay04 { transition-delay: 0.4s; }
.anim.delay05 { transition-delay: 0.5s; }
.anim.delay06 { transition-delay: 0.6s; }

#lead2 .anim {
  transition: all 2.4s cubic-bezier(.12,.92,.31,.95);
  transform: translateY(100px);
}

@media print, screen and (min-width:768px) {
  .anim.pc-delay01 { transition-delay: 0.1s; }
  .anim.pc-delay02 { transition-delay: 0.2s; }
  .anim.pc-delay03 { transition-delay: 0.3s; }
  .anim.pc-delay04 { transition-delay: 0.4s; }
  .anim.pc-delay05 { transition-delay: 0.5s; }
  .anim.pc-delay06 { transition-delay: 0.6s; }
}

@media screen and (max-width:767px) {
  .anim.sp-delay01 { transition-delay: 0.1s; }
  .anim.sp-delay02 { transition-delay: 0.2s; }
  .anim.sp-delay03 { transition-delay: 0.3s; }
  .anim.sp-delay04 { transition-delay: 0.4s; }
  .anim.sp-delay05 { transition-delay: 0.5s; }
  .anim.sp-delay06 { transition-delay: 0.6s; }
}

.anim.on {
  opacity: 1 !important;
  transform: translate(0,0) !important;
}
