@charset "UTF-8";
#lp50th ul,
#lp50th ol,
#lp50th li,
#byr ul,
#byr ol,
#byr li,
#runway-show ul,
#runway-show ol,
#runway-show li {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* =====================
   iziModal
===================== */
.iziModal * {
  width: 400px;
  margin: 0 auto;
  padding: 1px;
  font-size: 12px;
}

.iziModal * p {
  text-align: center;
  padding: 10px 10px 0 10px;
}

.iziModal * .close {
  display: none;
}

/* =====================
   SVG
===================== */
#lp50th .st0,
#open .st0 {
  fill: #ffffff;
}

#lp50th .st1,
#open .st1 {
  fill: none;
  stroke: #fff;
  stroke-width: 19.843;
  stroke-linecap: round;
}

/* =====================
   Loading
===================== */
#loading {
  background: #fff;
  width: 100%;
  height: 100%;
  position: fixed;
  inset: 0;
  z-index: 10000;
  color: #fff;
}

#open {
  background: #303030;
  background-size: cover;
  height: 100%;
  display: table;
  width: 100%;
  animation: fade 1.5s;
}

@keyframes fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
#open dl {
  padding: 0;
  display: table-cell;
  vertical-align: middle;
}

#open dt {
  overflow: hidden;
  width: 20%;
  margin: 0 auto 20px;
}

#open dt svg {
  width: 100%;
  margin-left: 0%;
  opacity: 0;
}

#open dd {
  text-align: center;
  margin: 0 auto;
  font-family: dnp-shuei-gothic-gin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 2;
  letter-spacing: 1px;
  font-size: 0.9vw;
}

/* =====================
   fade effect
===================== */
#lp50th .effect-fade {
  animation: fadeIn 1s ease 0s 1 normal;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
#lp50th {
  font-family: dnp-shuei-gothic-gin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 2;
  letter-spacing: 1px;
  font-size: 1vw;
  background: #eeeeee;
}
#lp50th .cormorant {
  font-family: cormorant-garamond, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0px;
}
#lp50th .cormorant-infant {
  font-family: "Cormorant Infant", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0px;
}
#lp50th .cormorant-Italic {
  font-family: cormorant-garamond, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0px;
}
#lp50th .jost {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
#lp50th #mainVisual {
  width: 100%;
  position: relative;
  overflow: hidden;
  background: #eeeeee;
}
#lp50th #mainVisual video {
  width: 100%;
  height: auto;
  max-width: 100%;
}
#lp50th #mainVisual .scroll-box {
  text-align: center;
  position: absolute;
  bottom: 4%;
  right: 45%;
  width: 10%;
}
#lp50th #mainVisual .scroll-box .scroll {
  position: relative;
  margin: 0 auto;
  animation-delay: 3s;
}
#lp50th #mainVisual .scroll-box .scroll p {
  color: #fff;
  letter-spacing: 2px;
}
#lp50th #mainVisual .scroll-box .scroll::before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 100px;
  background: rgba(0, 0, 0, 0.2);
  z-index: 1;
}
#lp50th #mainVisual .scroll-box .scroll::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 100px;
  background: #eeeeee;
  animation: sdl 2s cubic-bezier(1, 0, 0, 1) infinite;
  z-index: 1;
}
@keyframes sdl {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
#lp50th #readArea {
  margin: 0 auto;
  padding: 15% 10% 0 10%;
  background: #eeeeee;
}
#lp50th #readArea .ttlArea {
  margin-bottom: 8%;
}
#lp50th #readArea .ttlArea h2 {
  font-size: 7vw;
  line-height: 1;
  padding: 0;
  margin: 0;
}
#lp50th #readArea .ttlArea h2 span {
  transition:
    transform 1.1s cubic-bezier(0.32, 0.94, 0.6, 1),
    opacity 0.75s cubic-bezier(0.32, 0.94, 0.6, 1);
  will-change: auto;
  transform-origin: left bottom;
  transform: translate3d(0, 2em, 0) rotate(10deg) rotateY(120deg) rotateX(-30deg) scale(1.1);
  opacity: 0;
  display: inline-block;
}
#lp50th #readArea .ttlArea h2 span.active {
  transform: translateZ(0) !important;
  opacity: 1;
}
#lp50th #readArea .ttlArea span:nth-child(1) {
  transition-delay: 0.03s;
}
#lp50th #readArea .ttlArea span:nth-child(2) {
  transition-delay: 0.06s;
}
#lp50th #readArea .ttlArea span:nth-child(3) {
  transition-delay: 0.09s;
}
#lp50th #readArea .ttlArea span:nth-child(4) {
  transition-delay: 0.12s;
}
#lp50th #readArea .ttlArea span:nth-child(5) {
  transition-delay: 0.15s;
}
#lp50th #readArea .ttlArea span:nth-child(6) {
  transition-delay: 0.18s;
}
#lp50th #readArea .ttlArea span:nth-child(7) {
  transition-delay: 0.21s;
}
#lp50th #readArea .ttlArea span:nth-child(8) {
  transition-delay: 0.24s;
}
#lp50th #readArea .ttlArea span:nth-child(9) {
  transition-delay: 0.27s;
}
#lp50th #readArea .ttlArea span:nth-child(10) {
  transition-delay: 0.3s;
}
#lp50th #readArea .ttlArea span:nth-child(11) {
  transition-delay: 0.33s;
}
#lp50th #readArea .ttlArea span:nth-child(12) {
  transition-delay: 0.36s;
}
#lp50th #readArea .ttlArea span:nth-child(13) {
  transition-delay: 0.39s;
}
#lp50th #readArea .ttlArea span:nth-child(14) {
  transition-delay: 0.42s;
}
#lp50th #readArea .ttlArea span:nth-child(15) {
  transition-delay: 0.45s;
}
#lp50th #readArea .readArea {
  width: 60%;
  margin-left: 35%;
}
#lp50th #readArea .readArea p {
  margin-bottom: 4%;
}
#lp50th #look {
  width: 100%;
  overflow: hidden;
  position: relative;
  background: #eeeeee;
  margin-top: 230px;
}
#lp50th #look a {
  display: block;
}
#lp50th #look .loop {
  position: relative;
}
#lp50th #look .loop .all_txt {
  width: 100%;
  position: absolute;
  align-items: center;
  box-sizing: border-box;
  mix-blend-mode: difference;
  padding-top: 17%;
  z-index: 2;
}
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
#lp50th #look .loop .scroll-look .scroll_wrap {
  display: flex;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
  will-change: transform;
}
#lp50th #look .loop .scroll-look .scroll_list {
  display: flex;
  justify-content: center;
  list-style: none;
}
#lp50th #look .loop .scroll-look .scroll_list--left {
  animation: infinity-scroll-left 35s infinite linear 0.5s both;
}
#lp50th #look .loop .scroll-look .scroll_list--left li {
  flex: 0 0 auto;
  padding: 0 0.75vw;
  text-align: center;
  font-size: 3vw;
  color: #fff;
}
#lp50th #look .loop .scroll-btn .scroll_wrap {
  display: flex;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
}
#lp50th #look .loop .scroll-btn .scroll_list {
  display: flex;
  justify-content: center;
  list-style: none;
}
#lp50th #look .loop .scroll-btn .scroll_list--left {
  animation: infinity-scroll-left 25s infinite linear 0.5s both;
}
#lp50th #look .loop .scroll-btn .scroll_list--left li {
  width: 14.2857142857vw;
  text-align: center;
  display: flex;
  justify-content: space-between;
  color: #fff;
}
#lp50th #look .loop .scroll-btn .scroll_list--left li .jost {
  font-size: 0.9vw;
  display: block;
  padding: 4% 7%;
  border: 1px solid rgba(121, 119, 119, 0.5);
  border-radius: 100vmax;
  line-height: 1;
}
#lp50th #look .loop .scroll-btn .scroll_list--left li .cormorant-Italic {
  font-size: 1.5vw;
  line-height: 1;
  padding: 2% 0 0 10%;
}
#lp50th #look .pht {
  width: 65%;
}
#lp50th #look .read {
  position: absolute;
  right: 10%;
  width: 22%;
  bottom: 5%;
}
#lp50th #look .arrow {
  position: absolute;
  right: 10%;
  width: 3.5%;
  bottom: 0;
  transition: transform 0.6s ease;
}
#lp50th #look a:hover {
  color: #333;
  opacity: 1;
}
#lp50th #look a:hover .arrow {
  transform: translateX(10px);
}
#lp50th #event {
  background: #eeeeee;
  padding: 20vh 0;
  overflow: hidden;
  margin-top: 230px;
}
#lp50th #event .wrap {
  position: relative;
  color: #fff;
  /* overflow: hidden; は背景を広げたい場合は外すか、bg-layerのサイズを調整 */
}
#lp50th #event .wrap .bg-layer {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: linear-gradient(164.79deg, #a6a6a6 0%, rgba(187, 181, 154, 0.8) 73.09%, #555140 100.12%);
  transform: scale(0.8);
  border-radius: 1vw;
  will-change: transform;
  background-size: 150% 150%;
  animation: gradientMove 10s ease-in-out infinite alternate;
}
@keyframes gradientMove {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}
#lp50th #event .box {
  padding: 10% 10% 10% 10%;
  position: relative;
  z-index: 2;
}
#lp50th #event .ttlArea {
  text-align: center;
  margin-bottom: 3%;
}
#lp50th #event .ttlArea h3 {
  font-size: 6.5vw;
  line-height: 1;
  margin-bottom: 0;
}
#lp50th #event .ttlArea p {
  line-height: 1.5;
  padding: 0%;
  margin: 0;
}
#lp50th #event .readArea {
  font-size: 1.2vw;
  margin-bottom: 5%;
  text-align: center;
}
#lp50th #event .slider .item {
  margin-bottom: 5%;
}
#lp50th #event a {
  display: flex;
  display: flex;
  justify-content: space-between;
  color: #fff;
  position: relative;
  width: 90%;
  margin: 0 auto;
}
#lp50th #event a .pht {
  width: 43%;
}
#lp50th #event a .txtArea {
  width: 50%;
}
#lp50th #event a .nm {
  font-size: 4vw;
  font-weight: 500;
  line-height: 1;
  padding: 0;
  margin: 0;
  margin-bottom: 2%;
  width: 8%;
}
#lp50th #event a h4 {
  font-weight: 500;
  font-size: 1.5vw;
  margin-bottom: 2%;
  line-height: 1.5;
}
#lp50th #event a h4 span {
  font-size: 1.2vw;
}
#lp50th #event a .arrow {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 6%;
  transition: transform 0.6s ease;
}
#lp50th #event a:last-child {
  margin-bottom: 0;
}
#lp50th #event a:hover .arrow {
  opacity: 0.7;
  transform: translateX(10px);
}
#lp50th #app-section {
  padding: 15% 0;
  background: #eeeeee;
}
#lp50th #app-section .wrap {
  width: 80%;
  margin: 0 auto;
  display: flex;
  justify-content: flex-start;
}
#lp50th #app-section .contentsArea {
  width: 70%;
}
#lp50th #app-section .contentsArea h3 {
  font-size: 6.5vw;
  line-height: 1;
}
#lp50th #app-section .contentsArea .txt {
  padding-top: 10%;
  font-size: 1.2vw;
  width: 80%;
  margin-bottom: 3%;
}
#lp50th #app-section .phtsp {
  display: none;
}
#lp50th #app-section .pht {
  width: 25%;
}
#lp50th #app-section .linkBtn a {
  display: block;
  font-size: 1.1vw;
  font-weight: 600;
  padding: 3% 4%;
  width: 44%;
  border: 1px solid rgba(121, 119, 119, 0.5);
  border-radius: 100vmax;
  line-height: 1;
  position: relative;
}
#lp50th #app-section .linkBtn a img {
  width: 7%;
  position: absolute;
  right: 7%;
  top: 40%;
}
#lp50th #app-section .linkBtn a:hover {
  opacity: 0.7;
}
#lp50th #history {
  margin-top: 230px;
}
#lp50th #history .mainArea {
  position: relative;
  height: 100vh;
  overflow: hidden;
}
#lp50th #history .mainArea picture {
  display: block;
  width: 100%;
  height: 100%;
}
#lp50th #history .mainArea picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#lp50th #history .ttlArea {
  text-align: center;
  color: #fff;
  position: absolute;
  z-index: 2;
  top: 40%;
  width: 100%;
  transition: color 0.3s ease;
}
#lp50th #history .ttlArea.is-dark {
  color: #000;
}
#lp50th #history .ttlArea h3 {
  font-size: 7.5vw;
  line-height: 1;
}
#lp50th #history .wrap {
  background: #eeeeee;
  position: relative;
}
#lp50th #history .box {
  padding: 25% 0 3% 0;
  position: relative;
  z-index: 3;
}
#lp50th #history .news {
  width: 80%;
  margin: 0 auto;
  position: relative;
  z-index: 3;
}
#lp50th #history .news .year {
  font-size: 4.8vw;
  position: absolute;
  left: 0;
  top: 0;
  line-height: 1.3;
  background: #eeeeee;
  width: 16%;
  z-index: 2;
}
#lp50th #history .news .timeline-line {
  position: absolute;
  left: 5%;
  top: 0;
  bottom: 0;
  width: 1px;
  background: rgba(121, 119, 119, 0.5);
  transform-origin: top;
  transform: scaleY(0);
  z-index: 0;
}
#lp50th #history .news dl {
  border-left: 1px solid rgba(121, 119, 119, 0.12);
  margin-left: 5%;
  padding-left: 5%;
}
#lp50th #history .news dl dt {
  font-size: 2vw;
  font-weight: 600;
  padding-left: 10%;
  margin-bottom: 3%;
}
#lp50th #history .news dl dd {
  padding-left: 10%;
}
#lp50th #history .news dl dd p {
  margin-bottom: 3%;
}
#lp50th #history .news dl .pht {
  position: relative;
  padding-left: 0%;
}
#lp50th #history .news dl .pht .pht1 {
  width: 40%;
  margin-left: auto;
}
#lp50th #history .news dl .pht .pht2 {
  width: 30%;
  position: absolute;
  left: 0;
  bottom: 0;
}
#lp50th #history .news dl .pht .pht3 {
  width: 58%;
}
#lp50th #history .news:nth-child(1) {
  padding-top: 6%;
  margin-bottom: 0%;
}
#lp50th #history .news:nth-child(1) dl {
  padding: 10% 0 10% 5%;
}
#lp50th #history .news:nth-child(1) dl dd p {
  width: 70%;
}
#lp50th #history .news:nth-child(1) dl .pht {
  padding-top: 3%;
  padding-bottom: 18%;
}
#lp50th #history .news:nth-child(2) {
  padding-top: 0%;
  margin-bottom: 0%;
}
#lp50th #history .news:nth-child(2) dl {
  padding: 1.5% 0 10% 5%;
}
#lp50th #history .news:nth-child(2) dl dt {
  padding-left: 15%;
}
#lp50th #history .news:nth-child(2) dl dd {
  padding-left: 15%;
}
#lp50th #history .news:nth-child(2) dl dd p {
  width: 100%;
}
#lp50th #history .news:nth-child(2) dl .pht {
  padding-top: 3%;
  margin-left: 24%;
  width: 85%;
}
#lp50th #history .news:nth-child(3) {
  padding-top: 0%;
  margin-bottom: 0%;
}
#lp50th #history .news:nth-child(3) dl {
  padding: 1.5% 0 10% 5%;
}
#lp50th #history .news:nth-child(3) dl dt {
  padding-left: 35%;
}
#lp50th #history .news:nth-child(3) dl dd {
  padding-left: 35%;
}
#lp50th #history .news:nth-child(3) dl dd p {
  width: 100%;
}
#lp50th #history .news:nth-child(3) dl .pht {
  padding-top: 3%;
  padding-bottom: 4%;
  padding-left: 15%;
  width: 90%;
}
#lp50th #history .news:nth-child(4) {
  padding-top: 0%;
  margin-bottom: 6%;
}
#lp50th #history .news:nth-child(4) dl {
  padding: 1.5% 0 10% 5%;
}
#lp50th #history .news:nth-child(4) dl dd p {
  width: 46%;
}
#lp50th #history .news:nth-child(4) dl .pht4 {
  width: 50%;
  position: absolute;
  right: -12.5%;
  top: 8%;
}
#lp50th #linkArea {
  background: #eeeeee;
  position: relative;
  z-index: 1;
}
#lp50th #linkArea .linkBtn a {
  margin: 0 auto;
  display: block;
  font-size: 1.1vw;
  font-weight: 600;
  padding: 2% 3%;
  width: 22%;
  border: 1px solid #797777;
  border-radius: 100vmax;
  line-height: 1;
  position: relative;
}
#lp50th #linkArea .linkBtn a img {
  width: 7%;
  position: absolute;
  right: 7%;
  top: 41%;
}
#lp50th #linkArea .linkBtn a:hover {
  opacity: 0.7;
}
#lp50th #ft {
  background: #eeeeee;
  padding: 0 0 10% 0;
  margin-top: 230px;
}
#lp50th #ft dl {
  width: 40%;
  margin: 0 auto 10% auto;
  text-align: center;
}
#lp50th #ft dl dt {
  margin-bottom: 4%;
}
@keyframes infinity-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
#lp50th #ft .loop {
  position: relative;
  overflow: hidden;
}
#lp50th #ft .loop .scroll-pht .scroll_wrap {
  display: flex;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
  will-change: transform;
}
#lp50th #ft .loop .scroll-pht .scroll_list {
  display: flex;
  justify-content: center;
  list-style: none;
}
#lp50th #ft .loop .scroll-pht .scroll_list--left {
  animation: infinity-scroll 35s infinite linear 0.5s both;
}
#lp50th #ft .loop .scroll-pht .scroll_list--left li {
  width: 13.3333333333vw;
  padding: 0 0.5vw;
  text-align: center;
}
#lp50th h1,
#lp50th h2,
#lp50th h3,
#lp50th h4 {
  padding: 0;
  margin: 0;
}
#lp50th dl,
#lp50th dt,
#lp50th dd {
  margin: 0;
  padding: 0;
}
#lp50th a {
  transition: 0.3s;
  color: #333;
  text-decoration: none;
}
#lp50th a:hover {
  transition: 0.3s;
  color: #333;
  text-decoration: none;
}
#lp50th img {
  width: 100%;
}

#loadingdoor {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  pointer-events: none;
}

#loadingdoor .door {
  width: 50%;
  height: 100%;
  background: #303030; /* 扉の色 */
  transition: transform 1.2s cubic-bezier(0.77, 0, 0.18, 1);
}

#loadingdoor .door-left {
  transform-origin: left center;
}

#loadingdoor .door-right {
  transform-origin: right center;
}

#loadingdoor.open .door-left {
  transform: translateX(-100%);
}

#loadingdoor.open .door-right {
  transform: translateX(100%);
}

#looks {
  font-family: dnp-shuei-gothic-gin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 2;
  letter-spacing: 1px;
  font-size: 1vw;
  background: linear-gradient(180deg, #eeeeee 0%, #e0dac4 92.09%);
}
#looks .cormorant {
  font-family: cormorant-garamond, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0px;
}
#looks .cormorant-infant {
  font-family: "Cormorant Infant", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0px;
}
#looks .cormorant-Italic {
  font-family: cormorant-garamond, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0px;
}
#looks .jost {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
#looks .bg {
  mix-blend-mode: plus-lighter;
  position: absolute;
  left: -50%;
  top: 0;
  width: 200%;
  z-index: 0;
}
#looks #mainVisual {
  width: 100%;
  position: relative;
  overflow: hidden;
  background: url("../img/lookbook/bg_flare_pc.webp") no-repeat center bottom;
  background-size: 200vw;
  padding-bottom: 14%;
}
#looks #mainVisual .video {
  width: 40%;
  overflow: hidden;
  position: absolute;
  right: 3%;
  top: 0;
}
#looks #mainVisual .video video {
  width: 134%;
  height: auto;
  max-width: 134%;
  margin-left: -17%;
}
#looks #mainVisual .ttl {
  padding: 17% 10% 8% 10%;
}
#looks #mainVisual .ttl h1 {
  font-size: 7vw;
  line-height: 1;
  padding: 0;
  margin: 0;
  z-index: 2;
  margin-bottom: 2%;
}
#looks #mainVisual .ttl h1 span {
  transition:
    transform 1.1s cubic-bezier(0.32, 0.94, 0.6, 1),
    opacity 0.75s cubic-bezier(0.32, 0.94, 0.6, 1);
  will-change: auto;
  transform-origin: left bottom;
  transform: translate3d(0, 2em, 0) rotate(10deg) rotateY(120deg) rotateX(-30deg) scale(1.1);
  opacity: 0;
  display: inline-block;
}
#looks #mainVisual .ttl h1 span.active {
  transform: translateZ(0) !important;
  opacity: 1;
}
#looks #mainVisual .ttl span:nth-child(1) {
  transition-delay: 0.03s;
}
#looks #mainVisual .ttl span:nth-child(2) {
  transition-delay: 0.06s;
}
#looks #mainVisual .ttl span:nth-child(3) {
  transition-delay: 0.09s;
}
#looks #mainVisual .ttl span:nth-child(4) {
  transition-delay: 0.12s;
}
#looks #mainVisual .ttl span:nth-child(5) {
  transition-delay: 0.15s;
}
#looks #mainVisual .ttl span:nth-child(6) {
  transition-delay: 0.18s;
}
#looks #mainVisual .ttl span:nth-child(7) {
  transition-delay: 0.21s;
}
#looks #mainVisual .ttl span:nth-child(8) {
  transition-delay: 0.24s;
}
#looks #mainVisual .ttl span:nth-child(9) {
  transition-delay: 0.27s;
}
#looks #mainVisual .ttl span:nth-child(10) {
  transition-delay: 0.3s;
}
#looks #mainVisual .ttl span:nth-child(11) {
  transition-delay: 0.33s;
}
#looks #mainVisual .ttl span:nth-child(12) {
  transition-delay: 0.36s;
}
#looks #mainVisual .ttl span:nth-child(13) {
  transition-delay: 0.39s;
}
#looks #mainVisual .ttl span:nth-child(14) {
  transition-delay: 0.42s;
}
#looks #mainVisual .ttl span:nth-child(15) {
  transition-delay: 0.45s;
}
#looks #mainVisual .readArea {
  text-align: center;
  font-size: 1.1vw;
  margin-bottom: 20%;
}
#looks #mainVisual .pht1 {
  position: absolute;
  left: 10%;
  top: 5%;
  width: 7%;
}
#looks #mainVisual .pht2 {
  position: absolute;
  right: 0%;
  top: 38%;
  width: 10%;
}
#looks #mainVisual .pht3 {
  width: 18%;
  margin-bottom: 5%;
}
#looks #mainVisual dl {
  width: 70%;
  margin: 0 auto;
  text-align: center;
}
#looks #mainVisual dl dt {
  font-size: 3.6vw;
  line-height: 1;
  margin-bottom: 5%;
}
#looks #mainVisual dl dd ul {
  display: flex;
  justify-content: space-between;
}
#looks #mainVisual dl dd ul li {
  width: 15.5%;
}
#looks #mainVisual dl dd ul li a {
  display: block;
}
#looks #mainVisual dl dd ul li p {
  padding-top: 5%;
  font-size: 1.2vw;
}
#looks .ttlArea p {
  line-height: 1.3;
  font-size: 1.2vw;
  margin-bottom: 0%;
  padding: 0;
}
#looks .ttlArea h3 {
  font-size: 5.8vw;
  line-height: 1;
}
#looks #look1 {
  position: relative;
  margin-bottom: 20%;
}
#looks #look1 .ttlArea {
  position: absolute;
  width: 30%;
  top: 8%;
  right: 7%;
}
#looks #look1 .phtArea {
  position: relative;
}
#looks #look1 .phtArea .pht1 {
  width: 50%;
}
#looks #look1 .phtArea .pht2 {
  width: 30%;
  position: absolute;
  bottom: 0;
  right: 6%;
}
#looks #look2 {
  margin-bottom: 20%;
  position: relative;
}
#looks #look2 .ttlArea {
  width: 39%;
  position: absolute;
  left: 18%;
  top: 10%;
}
#looks #look2 .phtArea {
  overflow: hidden;
  width: 64%;
  margin: 0 auto;
}
#looks #look2 .pht1 {
  width: 59%;
  float: right;
}
#looks #look2 .pht2 {
  width: 39%;
  float: left;
  padding-top: 45%;
}
#looks #look2 .pht3 {
  width: 35%;
  float: left;
  padding: 2%;
}
#looks #look3 {
  position: relative;
}
#looks #look3 .ttlArea {
  width: 39%;
  position: absolute;
  left: 60%;
  top: 5%;
}
#looks #look3 .phtArea {
  overflow: hidden;
  position: relative;
  margin-left: 9%;
  padding-bottom: 40%;
}
#looks #look3 .phtArea .pht1 {
  width: 44%;
  float: left;
}
#looks #look3 .phtArea .pht2 {
  width: 35%;
  float: right;
  padding-top: 35%;
}
#looks #look3 .phtArea .pht3 {
  width: 23%;
  position: absolute;
  left: 30%;
  bottom: 5%;
}
#looks #look3 .pht4 {
  mix-blend-mode: soft-light;
  width: 19%;
  margin-left: 20%;
  padding: 9% 0 0 0;
}
#looks .loop {
  padding: 8% 0 10% 0;
  position: relative;
  overflow: hidden;
}
#looks {
  /* アニメーション */
}
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
#looks .scroll-look .scroll_wrap {
  display: flex;
  width: -moz-max-content;
  width: max-content; /* ← 重要 */
  animation: infinity-scroll-left 80s linear infinite;
}
#looks .scroll-look ul {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}
#looks .scroll-look li {
  flex: 0 0 auto;
  padding: 0 1vw;
  font-size: 4.8vw;
  color: #797777;
  opacity: 0.4;
  white-space: nowrap;
}
#looks #look4 {
  position: relative;
  margin-bottom: 20%;
}
#looks #look4 .ttlArea {
  width: 48%;
  margin: 0 auto 4% auto;
}
#looks #look4 .phtArea {
  width: 48%;
  margin: 0 auto;
}
#looks #look5 {
  position: relative;
  margin-bottom: 20%;
}
#looks #look5 .ttlArea {
  margin-left: 10%;
  margin-bottom: 10%;
}
#looks #look5 .pht1 {
  width: 49%;
}
#looks #look5 .pht2 {
  width: 24%;
  position: absolute;
  right: 8%;
  top: 0;
}
#looks #look6 {
  position: relative;
  margin-bottom: 20%;
}
#looks #look6 .wrap {
  width: 80%;
  display: flex;
  margin-left: 20%;
}
#looks #look6 .ttlArea {
  width: 31%;
  padding-top: 20%;
}
#looks #look6 .phtArea {
  width: 60%;
}
#looks #look6 .pht2 {
  mix-blend-mode: overlay;
  width: 19%;
  margin-left: 20%;
  padding: 9% 0 0 0;
}
#looks #icon {
  border-top: 1px solid rgba(121, 119, 119, 0.5);
  border-bottom: 1px solid rgba(121, 119, 119, 0.5);
  padding: 6% 25% 2% 25%;
}
#looks #icon h3 {
  text-align: center;
  font-weight: 400;
  font-size: 2.2vw;
  margin-bottom: 5%;
}
#looks #icon .box {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
#looks #icon .box dl {
  text-align: center;
  width: 28%;
  margin: 0 2% 5% 2%;
}
#looks #icon .box dt {
  font-size: 1vw;
  margin-bottom: 3%;
  font-weight: 400;
}
#looks #icon .box dd a {
  display: block;
}
#looks #icon .box dd a p {
  font-size: 0.8vw;
  padding-top: 3%;
}
#looks #ft {
  text-align: center;
  padding: 4% 0%;
}
#looks #ft p {
  font-size: 0.8vw;
  letter-spacing: 0;
  margin-bottom: 6%;
}
#looks #ft .linkBtn {
  width: 25%;
  margin: 0 auto;
}
#looks #ft .linkBtn a {
  display: block;
  background: rgb(250, 250, 250);
  border-radius: 100vmax;
  padding: 6% 0;
  font-size: 1.8vw;
  line-height: 1.3;
}
#looks #ft .linkBtn a span {
  font-size: 0.9vw;
  display: block;
  font-family: dnp-shuei-gothic-gin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
}
#looks #credit {
  font-weight: 400;
  letter-spacing: 0;
  padding-bottom: 15%;
}
#looks #credit dl {
  width: 20%;
  margin: 0 0 3% 41%;
}
#looks #credit dl dt {
  font-weight: normal;
  letter-spacing: 2px;
  padding-left: 36%;
}
#looks #credit dl dd table {
  width: 100%;
}
#looks #credit dl dd table th {
  font-weight: 500;
  vertical-align: top;
}
#looks #credit dl dd table td a {
  text-decoration: underline;
}
#looks #credit .box {
  width: 45%;
  display: flex;
  justify-content: space-between;
  margin-left: 31%;
}
#looks #credit .box dl {
  width: 47%;
  margin: 0;
}
#looks #credit .box dl:nth-child(1) dt {
  padding-left: 32%;
}
#looks #credit .box dl:nth-child(2) dt {
  padding-left: 32%;
}
#looks h1,
#looks h2,
#looks h3,
#looks h4 {
  padding: 0;
  margin: 0;
}
#looks dl,
#looks dt,
#looks dd {
  margin: 0;
  padding: 0;
}
#looks a {
  transition: 0.3s;
  color: #333;
  text-decoration: none;
}
#looks a:hover {
  transition: 0.3s;
  color: #333;
  text-decoration: none;
}
#looks img {
  width: 100%;
}

#byr {
  font-family: dnp-shuei-gothic-gin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 2;
  letter-spacing: 1px;
  font-size: 1vw;
  background: #eeeeee;
}
#byr .cormorant {
  font-family: cormorant-garamond, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0px;
}
#byr .cormorant-infant {
  font-family: "Cormorant Infant", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0px;
}
#byr .cormorant-Italic {
  font-family: cormorant-garamond, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0px;
}
#byr .jost {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
#byr #readArea {
  background: url("../img/byr/bg.webp") no-repeat bottom center;
  background-size: 100%;
  padding: 10% 0 15% 0;
}
#byr #readArea .wrap {
  display: flex;
  justify-content: space-between;
  width: 80%;
  margin: 0 auto 0% auto;
}
#byr #readArea .wrap p {
  margin-bottom: 3%;
  font-size: 1.1vw;
}
#byr #readArea .wrap .txt {
  width: 46%;
}
#byr #readArea .wrap .video {
  width: 40%;
}
#byr #readArea .wrap .video video {
  width: 100%;
  height: auto;
  max-width: 100%;
}
#byr #event {
  background: #eeeeee;
  padding: 20vh 0;
  overflow: hidden;
}
#byr #event .wrap {
  position: relative;
  color: #fff;
  /* overflow: hidden; は背景を広げたい場合は外すか、bg-layerのサイズを調整 */
}
#byr #event .wrap .bg-layer {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: linear-gradient(164.79deg, #a6a6a6 0%, rgba(187, 181, 154, 0.8) 73.09%, #555140 100.12%);
  transform: scale(0.8);
  border-radius: 1vw;
  will-change: transform;
  background-size: 150% 150%;
  animation: gradientMove 10s ease-in-out infinite alternate;
}
@keyframes gradientMove {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}
#byr #event .box {
  padding: 10% 10% 10% 10%;
  position: relative;
  z-index: 2;
}
#byr #event .ttlArea {
  text-align: center;
  margin-bottom: 3%;
}
#byr #event .ttlArea h3 {
  font-size: 6.5vw;
  line-height: 1;
  margin-bottom: 0;
}
#byr #event .ttlArea p {
  line-height: 1.5;
  padding: 0%;
  margin: 0;
}
#byr #event .readArea {
  font-size: 1.1vw;
  margin-bottom: 5%;
  width: 60%;
  margin: 0 auto 7% auto;
  text-align: left;
}
#byr #event .slider {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 6%;
}
#byr #event .slider .item {
  margin-bottom: 5%;
  width: 32%;
  margin: 0 0.5%;
  margin-bottom: 1%;
}
#byr #event .linkBtn a {
  margin: 0 auto;
  display: block;
  font-size: 1.1vw;
  font-weight: 600;
  padding: 2% 3%;
  width: 40%;
  border: 1px solid #797777;
  border-radius: 100vmax;
  line-height: 1;
  position: relative;
}
#byr #event .linkBtn a img {
  width: 7%;
  position: absolute;
  right: 7%;
  top: 41%;
}
#byr #event .linkBtn a:hover {
  opacity: 0.7;
}
#byr #information .wrap {
  width: 80%;
  margin: 0 auto 0% auto;
}
#byr #information .ttlArea {
  margin-bottom: 12%;
}
#byr #information .ttlArea h3 {
  font-size: 6.5vw;
  line-height: 1;
  margin-bottom: 0;
}
#byr #information .ttlArea p {
  line-height: 1.5;
  padding: 0%;
  margin: 0;
}
#byr #information ul {
  margin-left: 20%;
  width: 80%;
}
#byr #information ul li {
  padding-bottom: 7%;
  margin-bottom: 7%;
  border-bottom: 1px solid rgba(121, 119, 119, 0.5);
}
#byr #information ul li.rakuten-box {
  display: flex;
  padding: 48px;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  align-self: stretch;
  border-radius: 10px;
  background: var(--gry, #797777);
  border-bottom: none;
  margin-bottom: 0;
}
#byr #information ul li.rakuten-box h4,
#byr #information ul li.rakuten-box p {
  color: #fff;
}
#byr #information ul li.rakuten-box .linkBtn {
  width: 100%;
}
#byr #information ul li.rakuten-box .linkBtn a {
  border-color: #fff;
  color: #fff;
}
#byr #information ul li.rakuten-box .linkBtn a img {
  filter: brightness(0) invert(1);
}
#byr #information ul li h4 {
  font-size: 1.4vw;
  margin-bottom: 3%;
}
#byr #information ul li p {
  font-size: 1.1vw;
}
#byr #information ul li .linkBtn {
  padding-top: 3%;
}
#byr #information ul li .linkBtn a {
  display: block;
  font-size: 1.1vw;
  font-weight: 400;
  padding: 3% 5%;
  width: 60%;
  border: 1px solid #797777;
  border-radius: 100vmax;
  line-height: 1;
  position: relative;
  letter-spacing: 0;
}
#byr #information ul li .linkBtn a img {
  width: 7%;
  position: absolute;
  right: 7%;
  top: 41%;
}
#byr #information ul li .linkBtn a:hover {
  opacity: 0.7;
}
#byr #ft {
  text-align: center;
  padding: 4% 0% 15% 0;
}
#byr #ft .linkBtn {
  width: 25%;
  margin: 0 auto;
}
#byr #ft .linkBtn a {
  display: block;
  background: rgb(250, 250, 250);
  border-radius: 100vmax;
  padding: 6% 0;
  font-size: 1.8vw;
  line-height: 1.3;
}
#byr #ft .linkBtn a span {
  font-size: 0.9vw;
  display: block;
  font-family: dnp-shuei-gothic-gin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
}
#byr h1,
#byr h2,
#byr h3,
#byr h4 {
  padding: 0;
  margin: 0;
}
#byr dl,
#byr dt,
#byr dd {
  margin: 0;
  padding: 0;
}
#byr a {
  transition: 0.3s;
  color: #333;
  text-decoration: none;
}
#byr a:hover {
  transition: 0.3s;
  color: #333;
  text-decoration: none;
}
#byr img {
  width: 100%;
}

#lp50th .sp {
  display: none;
}

.fadeIn {
  animation-name: fadeInAnime;
  animation-duration: 2s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeInAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeDown {
  animation-name: fadeDownAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeDownAnime {
  from {
    opacity: 0;
    transform: translateY(-100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeLeft {
  animation-name: fadeLeftAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeLeftAnime {
  from {
    opacity: 0;
    transform: translateX(-100px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
.fadeRight {
  animation-name: fadeRightAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeRightAnime {
  from {
    opacity: 0;
    transform: translateX(100px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
.fadeInTrigger,
.fadeUpTrigger,
.fadeDownTrigger,
.fadeLeftTrigger,
.fadeRightTrigger {
  opacity: 0;
}

.zoomIn {
  animation-name: zoomInAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
}

@keyframes zoomInAnime {
  from {
    transform: scale(0.6);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.zoomOut {
  animation-name: zoomOutAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
}

@keyframes zoomOutAnime {
  from {
    transform: scale(1.2);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.zoomInTrigger,
.zoomOutTrigger {
  opacity: 0;
}

.blur {
  animation-name: blurAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
}

@keyframes blurAnime {
  from {
    filter: blur(10px);
    transform: scale(1.02);
    opacity: 0;
  }
  to {
    filter: blur(0);
    transform: scale(1);
    opacity: 1;
  }
}
.blurTrigger {
  opacity: 0;
}

.smooth {
  animation-name: smoothAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  transform-origin: left;
  opacity: 0;
}

@keyframes smoothAnime {
  from {
    transform: translate3d(0, 100%, 0) skewY(12deg);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0) skewY(0);
    opacity: 1;
  }
}
.smoothTrigger {
  opacity: 0;
}

.lineTrigger {
  position: relative;
  opacity: 0;
}

.lineTrigger.lineanime {
  animation-name: lineAnimeBase;
  animation-duration: 1s;
  animation-fill-mode: forwards;
}

@keyframes lineAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.lineTrigger::before,
.lineTrigger::after {
  position: absolute;
  content: "";
  width: 0;
  height: 1px;
  background: #333;
}

.line2::before,
.line2::after {
  position: absolute;
  content: "";
  width: 1px;
  height: 0;
  background: #333;
}

.lineTrigger::before {
  top: 0;
  left: 0;
}

.lineTrigger.lineanime::before {
  animation: lineAnime 0.5s linear 0s forwards;
}

.line2::before {
  top: 0;
  right: 0;
}

.lineTrigger.lineanime .line2::before {
  animation: lineAnime2 0.5s linear 0.5s forwards;
}

.lineTrigger::after {
  bottom: 0;
  right: 0;
}

.lineTrigger.lineanime::after {
  animation: lineAnime 0.5s linear 1s forwards;
}

.line2::after {
  bottom: 0;
  left: 0;
}

.lineTrigger.lineanime .line2::after {
  animation: lineAnime2 0.5s linear 1.5s forwards;
}

@keyframes lineAnime {
  0% {
    width: 0%;
  }
  100% {
    width: 100%;
  }
}
@keyframes lineAnime2 {
  0% {
    height: 0%;
  }
  100% {
    height: 100%;
  }
}
.lineTrigger.lineanime .lineinappear {
  animation: lineInnerAnime 0.5s linear 1.5s forwards;
  opacity: 0;
}

@keyframes lineInnerAnime {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.bgextend {
  animation-name: bgextendAnimeBase;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  opacity: 0;
}

@keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.bgappear {
  animation-name: bgextendAnimeSecond;
  animation-duration: 1s;
  animation-delay: 0.6s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.bgLRextend::before {
  animation-name: bgLRextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666;
}

@keyframes bgLRextendAnime {
  0% {
    transform-origin: left;
    transform: scaleX(0);
  }
  50% {
    transform-origin: left;
    transform: scaleX(1);
  }
  50.001% {
    transform-origin: right;
  }
  100% {
    transform-origin: right;
    transform: scaleX(0);
  }
}
.bgRLextend::before {
  animation-name: bgRLextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666;
}

@keyframes bgRLextendAnime {
  0% {
    transform-origin: right;
    transform: scaleX(0);
  }
  50% {
    transform-origin: right;
    transform: scaleX(1);
  }
  50.001% {
    transform-origin: left;
  }
  100% {
    transform-origin: left;
    transform: scaleX(0);
  }
}
.bgDUextend::before {
  animation-name: bgDUextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666;
}

@keyframes bgDUextendAnime {
  0% {
    transform-origin: bottom;
    transform: scaleY(0);
  }
  50% {
    transform-origin: bottom;
    transform: scaleY(1);
  }
  50.001% {
    transform-origin: top;
  }
  100% {
    transform-origin: top;
    transform: scaleY(0);
  }
}
.bgUDextend::before {
  animation-name: bgUDextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666;
}

@keyframes bgUDextendAnime {
  0% {
    transform-origin: top;
    transform: scaleY(0);
  }
  50% {
    transform-origin: top;
    transform: scaleY(1);
  }
  50.001% {
    transform-origin: bottom;
  }
  100% {
    transform-origin: bottom;
    transform: scaleY(0);
  }
}
.bgappearTrigger,
.bgUDextendTrigger,
.bgDUextendTrigger,
.bgRLextendTrigger,
.bgLRextendTrigger {
  opacity: 0;
}

.count2 {
  animation-iteration-count: 2;
}

.countinfinite {
  animation-iteration-count: infinite;
}

.delay-time05 {
  animation-delay: 0.5s;
}

.delay-time06 {
  animation-delay: 0.6s;
}

.delay-time07 {
  animation-delay: 0.7s;
}

.delay-time08 {
  animation-delay: 0.8s;
}

.delay-time09 {
  animation-delay: 0.9s;
}

.delay-time1 {
  animation-delay: 1s;
}

.delay-time15 {
  animation-delay: 1.5s;
}

.delay-time2 {
  animation-delay: 2s;
}

.delay-time25 {
  animation-delay: 2.5s;
}

.delay-time3 {
  animation-delay: 3s;
}

.change-time05 {
  animation-duration: 0.5s;
}

.change-time1 {
  animation-duration: 1s;
}

.change-time15 {
  animation-duration: 1.5s;
}

.change-time2 {
  animation-duration: 2s;
}

.change-time25 {
  animation-duration: 2.5s;
}

.change-time30 {
  animation-duration: 3s;
}

.change-time35 {
  animation-duration: 3.5s;
}

.change-time40 {
  animation-duration: 4s;
}

.change-time45 {
  animation-duration: 4.5s;
} /*# sourceMappingURL=pc_style.css.map */

/* runway-show ここから*/

#runway-show {
  font-family: dnp-shuei-gothic-gin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 2;
  letter-spacing: 1px;
  font-size: 1.1vw;
  background: #eeeeee;
}
#runway-show .cormorant {
  font-family: cormorant-garamond, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0px;
}
#runway-show .cormorant-infant {
  font-family: "Cormorant Infant", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0px;
}
#runway-show .cormorant-Italic {
  font-family: cormorant-garamond, serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0px;
}
#runway-show .jost {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

/* YouTube動画レスポンシブ対応 */
.video-responsive {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9のアスペクト比 */
  height: 0;
  overflow: hidden;
}

.video-responsive iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

#runway-show #prologue .wrap {
  width: 80%;
  margin: 0 auto 0% auto;
  padding: 15% 0;
}

#runway-show #prologue .wrap h3 {
  font-size: 1.4vw;
  margin-top: 8%;
  margin-bottom: 5%;
  text-align: center;
  line-height: 165%;
}

#runway-show #prologue .wrap .sp {
  display: none;
}

#runway-show #prologue .wrap .flex {
  width: 80%;
  margin: 0 auto 0% auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

#runway-show #collection .wrap {
  width: 80%;
  margin: 0 auto 0% auto;
  padding: 5% 0 15% 0;
}

#runway-show #collection .wrap h3 {
  text-align: center;
  font-size: 6.5vw;
  line-height: 1;
  margin-bottom: 64px;
}

/* ============================================
   Guests グリッド — PC: 5列（最終行中央揃え）
   ============================================ */

.guests-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: 0 auto;
  width: 80%;
}

.guest-item {
  flex: 0 0 calc((100% - 48px) / 5); /* 5列: gap12px × 4 = 48px */
  overflow: hidden;
  cursor: pointer;
}

.guest-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.guest-item:hover img {
  transform: scale(1.05);
}

#kol {
  margin-top: 4%;
  margin-bottom: 15%;
}

#kol .wrap h3 {
  text-align: center;
  font-size: 6.5vw;
  line-height: 1;
  margin-bottom: 64px;
}

/* ============================================
   マソンリーギャラリー — PC: 8列
   ============================================ */
#collection .masonry-block {
  display: none;
  margin-bottom: 4px;
}

#collection .masonry-block.is-visible {
  display: block;
  animation: fadeUp 0.6s ease forwards;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.masonry-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  grid-auto-rows: calc((80vw - 28px) / 8 * 1.51);
  grid-auto-flow: dense;
  gap: 4px;
  margin: 0 auto;
}

.masonry-item {
  overflow: hidden;
  cursor: pointer;
  position: relative;
}

.masonry-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.masonry-item:hover img {
  transform: scale(1.05);
}

.masonry-item.is-medium {
  grid-column: span 2;
  grid-row: span 2;
}

.masonry-item.is-large {
  grid-column: span 3;
  grid-row: span 3;
}

/* View More ボタン */
.viewmore-btn {
  text-align: center;
  margin-top: 40px;
}

.viewmore-btn button {
  background: none;
  border: none;
  color: #333;
  padding: 8px 0;
  font-size: 14px;
  letter-spacing: 1px;
  cursor: pointer;
  position: relative;
  display: inline-block;
}

/* 下線（左→右にアニメーション） */
.viewmore-btn button::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0; /* 初期は幅0 = 見えない */
  height: 1px;
  background-color: #333;
  transition: width 0.3s ease;
}

.viewmore-btn button:hover::after {
  width: 100%; /* ホバーで左→右に伸びる */
}

.viewmore-btn.is-hidden {
  display: none;
}

/* ============================================
   ギャラリーモーダル（ナビ付き）
   ============================================ */
/* モーダル開閉時のカクつき防止 */
body.modal-open {
  overflow: hidden;
}

.g-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.3s ease,
    visibility 0.3s ease;
  will-change: opacity;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.g-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

.g-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
}

.g-modal__img-wrap {
  position: relative;
  z-index: 1;
  max-width: 60vw;
  max-height: 85vh;
}

.g-modal__img-wrap img {
  max-width: 100%;
  max-height: 85vh;
  object-fit: contain;
  display: block;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.g-modal__img-wrap img.is-loaded {
  opacity: 1;
}

.g-modal__close {
  position: absolute;
  top: 20px;
  right: 30px;
  z-index: 2;
  background: none;
  border: none;
  color: #fff;
  font-size: 36px;
  cursor: pointer;
  line-height: 1;
}

.g-modal__counter {
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  color: #fff;
  font-family: "Cormorant Infant", serif;
  font-size: 14px;
  letter-spacing: 2px;
}

.g-modal__prev,
.g-modal__next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  background: none;
  border: none;
  color: #fff;
  font-size: 32px;
  cursor: pointer;
  padding: 16px;
  transition: opacity 0.3s;
}

.g-modal__prev:hover,
.g-modal__next:hover {
  opacity: 0.7;
}

.g-modal__prev {
  left: 20px;
}
.g-modal__next {
  right: 20px;
}

/* ============================================
   Backstage ループスライダー
   ============================================ */
#backstage {
  padding: 10% 0;
  overflow: hidden;
}

#backstage .wrap {
  width: 80%;
  margin: 0 auto;
}

#backstage .ttlArea h3 {
  text-align: center;
  font-size: 6.5vw;
  line-height: 1;
  margin-bottom: 64px;
}

/* スライダー共通 */
.loop-slider {
  display: flex;
  width: 100%;
  overflow: hidden;
  margin-bottom: 8px;
}

.loop-slider__track {
  display: flex;
  flex-shrink: 0;
  gap: 8px;
  padding-right: 8px;
}

/* 1段目: 右→左 */
.loop-slider--rtl .loop-slider__track {
  animation: loopRTL 60s linear infinite;
}

/* 2段目: 左→右 */
.loop-slider--ltr .loop-slider__track {
  animation: loopLTR 60s linear infinite;
}

@keyframes loopRTL {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}

@keyframes loopLTR {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}

/* 各画像 */
.loop-slider__item {
  flex-shrink: 0;
  width: 12.8vw;
  height: 17vw;
  overflow: hidden;
}

.loop-slider__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* YouTube動画レスポンシブ */
.video-responsive {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

.video-responsive iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

#runway-show #readArea {
  background: url("../img/byr/bg.webp") no-repeat bottom center;
  background-size: 100%;
  padding: 10% 0 15% 0;
}

#runway-show #readArea .wrap {
  display: flex;
  justify-content: space-between;
  width: 80%;
  margin: 0 auto 0% auto;
}

#runway-show #readArea .wrap p {
  margin-bottom: 3%;
  font-size: 1.1vw;
}
#runway-show #readArea .wrap .txt {
  width: 46%;
}
#runway-show #readArea .wrap .video {
  width: 40%;
}
#runway-show #readArea .wrap .video video {
  width: 100%;
  height: auto;
  max-width: 100%;
}
#runway-show #specialitems {
  padding: 20vh 0;
  overflow: hidden;
}
#runway-show #specialitems .wrap {
  position: relative;
  color: #fff;
  /* overflow: hidden; は背景を広げたい場合は外すか、bg-layerのサイズを調整 */
}
#runway-show #specialitems .wrap .bg-layer {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: linear-gradient(164.79deg, #a6a6a6 0%, rgba(187, 181, 154, 0.8) 73.09%, #555140 100.12%);
  transform: scale(0.8);
  border-radius: 1vw;
  will-change: transform;
  background-size: 150% 150%;
  animation: gradientMove 10s ease-in-out infinite alternate;
}
@keyframes gradientMove {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}
#runway-show #specialitems .box {
  padding: 10% 10% 10% 10%;
  position: relative;
  z-index: 2;
}
#runway-show #specialitems .ttlArea {
  text-align: center;
  margin-bottom: 3%;
}
#runway-show #specialitems .ttlArea h3 {
  font-size: 6.5vw;
  line-height: 1;
  margin-bottom: 0;
}
#runway-show #specialitems .ttlArea p {
  line-height: 1.5;
  padding: 0%;
  margin: 0;
}
#runway-show #specialitems .readArea {
  font-size: 1.1vw;
  margin-bottom: 5%;
  width: 60%;
  margin: 0 auto 7% auto;
  text-align: left;
}
#runway-show #specialitems .slider {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 6%;
}
#runway-show #specialitems .slider .item {
  margin-bottom: 5%;
  width: 32%;
  margin: 0 0.5%;
  margin-bottom: 1%;
}
#runway-show #specialitems .linkBtn a {
  margin: 0 auto;
  display: block;
  font-size: 1.1vw;
  font-weight: 600;
  padding: 2% 3%;
  width: 40%;
  border: 1px solid #797777;
  border-radius: 100vmax;
  line-height: 1;
  position: relative;
}
#runway-show #specialitems .linkBtn a img {
  width: 7%;
  position: absolute;
  right: 7%;
  top: 41%;
}
#runway-show #specialitems .linkBtn a:hover {
  opacity: 0.7;
}
#runway-show #information .wrap {
  width: 80%;
  margin: 18% auto 5% auto;
}
#runway-show #information .ttlArea {
  margin-bottom: 12%;
  text-align: center;
}
#runway-show #information .ttlArea h3 {
  font-size: 6.5vw;
  line-height: 1;
  margin-bottom: 0;
}
#runway-show #information .ttlArea p {
  line-height: 1.5;
  padding: 0%;
  margin: 0;
}

#runway-show #information .rakuten-box {
  width: 100%;
  display: flex;
  padding: 48px;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  align-self: stretch;
  border-radius: 10px;
  background: var(--gry, #797777);
  border-bottom: none;
  margin-bottom: 0;
  color: #fff;
}
#runway-show #information .rakuten-box h4 {
  text-align: center;
}
#runway-show #information .rakuten-box .linkBtn {
  width: 60%;
}
#runway-show #information .rakuten-box .linkBtn a {
  margin: 0 auto;
  border-color: #fff;
  color: #fff;
  display: flex;
  justify-content: space-between;
}
#runway-show #information .rakuten-box .linkBtn a img {
  filter: brightness(0) invert(1);
  width: 7%;
}
#runway-show #information h4 {
  font-size: 1.4vw;
  margin-bottom: 3%;
}
#runway-show #information p {
  font-size: 1.1vw;
}
#runway-show #information .linkBtn {
  padding-top: 3%;
}
#runway-show #information .linkBtn a {
  display: block;
  font-size: 1.1vw;
  font-weight: 400;
  padding: 3% 5%;
  width: 60%;
  border: 1px solid #797777;
  border-radius: 100vmax;
  line-height: 1;
  position: relative;
  letter-spacing: 0;
}
#runway-show #information ul li .linkBtn a img {
  width: 7%;
  position: absolute;
  right: 7%;
  top: 41%;
}
#runway-show #information ul li .linkBtn a:hover {
  opacity: 0.7;
}
#runway-show #ft {
  text-align: center;
  padding: 4% 0% 15% 0;
}
#runway-show #ft .linkBtn {
  width: 25%;
  margin: 0 auto;
}
#runway-show #ft .linkBtn a {
  display: block;
  background: rgb(250, 250, 250);
  border-radius: 100vmax;
  padding: 6% 0;
  font-size: 1.8vw;
  line-height: 1.3;
}
#runway-show #ft .linkBtn a span {
  font-size: 0.9vw;
  display: block;
  font-family: dnp-shuei-gothic-gin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
}
#runway-show h1,
#runway-show h2,
#runway-show h3,
#runway-show h4 {
  padding: 0;
  margin: 0;
}
#runway-show dl,
#runway-show dt,
#runway-show dd {
  margin: 0;
  padding: 0;
}
#runway-show a {
  transition: 0.3s;
  color: #333;
  text-decoration: none;
}
#runway-show a:hover {
  transition: 0.3s;
  color: #333;
  text-decoration: none;
}
#runway-show img {
  width: 100%;
}
