@charset "UTF-8";
/* *
 *
 *  variables
 *  変数
 *
 * */
/*--------------------------------------------------------------------------
   layout
---------------------------------------------------------------------------*/
/* @PC content width
-----------------------------------------------------------------*/
/* space
-----------------------------------------------------------------*/
/*--------------------------------------------------------------------------
   headerH
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
   breakpoint
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  tranition
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
 font
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
   font-size
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  line-height
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  letter-spacing
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
   color
---------------------------------------------------------------------------*/
/* font color base */
/* *
 *
 *  mixin & function
 *  関数
 *
 * */
/*--------------------------------------------------------------------------
  media
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
   font-family
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
   txt-jp
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  pseudo
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  ico-font
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  cf
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  flexbox
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  inline-style
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
  function px-to-vw
---------------------------------------------------------------------------*/
/* *
 *
 *  2025_fall_winter.css
 *
 *
 * */
html, #page {
  background: #ffffff;
}

#main .back-archives {
  margin-top: 100px;
}

.lookbook-list {
  padding: 0 55px;
}

.lookbook-list ul {
  max-width: 880px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.lookbook-list ul li.full {
  grid-column: 1 / -1; /* span across all columns */
}

.lookbook-list ul li.half {
  grid-column: span 1; /* span one column */
}

.lookbook-list ul li.info {
  grid-column: 1 / -1; /* span across all columns */
  display: flex;
  align-items: center;
  margin-left: auto;
}
.lookbook-list ul li.info .block {
  width: 100%;
  font-size: 14px;
  border: 1px solid #231815;
}
.lookbook-list ul li.info dl {
  padding: 2px 5px;
}
.lookbook-list ul li.info dt {
  font-weight: bold;
}
.lookbook-list ul li.info .logo dd {
  padding: 1.5vw 1.9vw 2.3vw;
  text-align: center;
}
.lookbook-list ul li.info .logo dd img {
  width: 100%;
}
.lookbook-list ul li.info .tel, .lookbook-list ul li.info .address {
  display: flex;
  border-top: 1px solid #231815;
  line-height: 1;
}
.lookbook-list ul li.info .tel dt, .lookbook-list ul li.info .address dt {
  width: 7.7em;
}
.lookbook-list ul li.info .tel dd, .lookbook-list ul li.info .address dd {
  width: calc(100% - 45px);
}

.img-load {
  overflow: hidden;
  height: 0;
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  display: none;
  width: 100%;
  height: 100%;
  z-index: 6000;
  min-height: 100vh;
  overflow-y: auto;
}
.modal.js-open {
  display: flex;
}
.modal .contents {
  position: absolute;
  left: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 870px;
  padding: 0 120px;
  pointer-events: none;
}
.modal .contents-inner {
  display: flex;
  align-items: center;
  width: 100%;
  /* max-width: 1360px; */
  max-width: 1084px;
  max-height: 770px;
  margin: 0 auto;
  padding: 10px;
  background: #ffffff;
  pointer-events: auto;
}
.modal .contents .look {
  width: 500px;
}
.modal .contents .products {
  overflow: auto;
  padding: 0 0 0 10px;
  /* width: calc(100% - 500px - 70px); */
  flex: 1;
  max-height: 750px;
  height: 100%;
}
.modal .contents .products section {
  background: #ffffff;
}
.modal .contents .products section + section {
  /* margin-top: 10px; */
  margin-top: 8px;
}
.modal .contents .products h2 {
  /* padding: 5px; */
  text-align: center;
}
.modal .contents .products h2 > a > span {
  display: block;
  border: 1px solid #231815;
  padding: 4px;
}
.modal .contents .products h2 > a > span > span {
  position: relative;
  display: inline-block;
  /* font-size: 25px; */
  font-size: 18px;
  font-weight: bold;
}
.modal .contents .products h2 > a[href] > span > span:before {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 0;
  display: block;
  width: 100%;
  border-bottom: 1px solid #231815;
}
.modal .contents .products .wrap {
  display: flex;
  /* padding: 0 5px 5px; */
}
.modal .contents .products .img {
  display: flex;
  align-items: center;
  width: 239px;
  padding: 0 17px;
  border: solid #231815;
  border-width: 1px 0 1px 1px;
}
.modal .contents .products .img img {
  width: 100%;
  height: auto;
}
.modal .contents .products .info {
  /* width: calc(100% - 239px); */
  width: 100%;
  border: 1px solid #231815;
  border-block-start: none;
  padding-block: 16px;
  padding-inline: 56px;
}
.modal .contents .products .info dl {
  /* padding: 5px; */
}

.modal .contents .products .info dl + dl{
  margin-block-start: 16px;
}

.modal .contents .products .info dl:not(.feature) {
  /* border-bottom: 1px solid #231815; */
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.modal .contents .products .info dt {
  /* font-weight: bold; */
  font-size: 14px;
  line-height: 1;
  /* margin-bottom: 4px; */
}
.modal .contents .products .info dd {
  font-size: 16px;
  line-height: 1.25;
}
.modal .contents .products .info .color dd span:not(:first-child):before {
  content: ", ";
}
.modal .contents .products .info .feature dd {
  display: flex;
  align-items: center;
  padding: 13px 10px;
}
.modal .contents .products .info .feature dd ul {
  display: flex;
  height: 100%;
  flex-direction: column;
}
.modal .contents .products .info .feature dd li {
  display: flex;
  align-items: center;
  line-height: 1.2;
}
.modal .contents .products .info .feature dd li span {
  display: block;
}
.modal .contents .products .info .feature dd li .icon {
  width: 70px;
  margin-right: 24px;
}
.modal .contents .products .info .feature dd li .txt {
  width: calc(100% - 70px - 24px);
}
.modal .contents .products .info .feature dd li + li {
  margin-top: 12px;
}
.modal .contents .products .refference {
  padding: 0 5px 5px;
  font-size: 16px;
  text-align: center;
}
.modal .contents .products .refference .txt {
  border: 1px solid #231815;
  padding: 12px;
}
.modal .contents .close {
  width: 100%;
  margin-block-start: 8px;
  /* padding: 5px; */
  /* margin-left: 10px; */
  background: #ffffff;
  /* font-size: 25px; */
  font-size: 18px;
  line-height: 1;
}
.modal .contents .close .inner {
  display: flex;
  justify-content: center;
  width: 100%;
  height: 100%;
  align-items: center;
  border: 1px solid #231815;
  padding: 12px;
}
.modal .contents .close .txt {
  font-weight: bold;
}
.modal .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 870px;
  background: #231815;
  opacity: 0.3;
}

@media screen and (max-width: 1400px) {
  .modal .contents {
    padding: 0 8.6vw;
    min-height: 62.1vw;
  }
  .modal .contents-inner {
    max-height: 55vw;
    padding: 0.7vw;
  }
  .modal .contents .look {
    width: 35.7vw;
  }
  .modal .contents .products {
    width: calc(100% - 35.7vw - 70px);
    max-height: 53.6vw;
  }
  .modal .contents .products .img {
    width: 16.7vw;
    padding: 0 1.2vw;
  }
  .modal .contents .products .info {
    /* width: calc(100% - 16.7vw); */
  }
  .modal .contents .products .info .feature dd li .icon {
    width: 5vw;
    margin-right: 1.7vw;
  }
  .modal .contents .products .info .feature dd li .txt {
    width: calc(100% - 5vw - 1.7vw);
  }
}
@media screen and (max-width: 1024px) {
  .lookbook-list {
    padding: 0 36px;
  }
  .lookbook-list ul {
    grid-template-columns: 1fr 1fr;
    gap: 5px;
  }
  .lookbook-list ul li.full {
    grid-column: 1 / -1;
  }
  .lookbook-list ul li.half {
    grid-column: span 1;
  }
  .lookbook-list ul li.info {
    grid-column: 1 / -1;
    justify-content: center;
    margin: 20px auto 0;
  }
  .lookbook-list ul li.info .block {
    width: auto;
  }
  .lookbook-list ul li.info .logo dd {
    padding: 2vw 2.2vw 3.2vw;
  }
  .modal {
    position: absolute;
    padding: 0;
    overflow-y: visible;
  }
  .modal.js-open {
    display: block;
  }
  .modal .contents {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: auto;
    padding: 60px 10px;
  }
  .modal .contents-inner {
    display: block;
    max-width: 780px;
    max-height: none;
    margin: 0 auto;
    padding: 10px;
  }
  .modal .contents .look {
    width: 310px;
    margin: 0 auto;
  }
  .modal .contents .products {
    overflow-y: initial;
    width: 100%;
    max-height: none;
    padding: 10px 0 10px;
  }
  .modal .contents .products .img {
    width: 222px;
    padding: 0 10px;
  }
  /* .modal .contents .products .info {
    width: calc(100% - 222px);
  } */
  .modal .contents .products .info dl:not(.feature) {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .modal .contents .products .info dt {
    margin-bottom: 0;
  }
  .modal .contents .products .info .feature dd {
    padding: 19px 20px 20px 21px;
    min-height: 152px;
  }
  .modal .contents .products .info .feature dd li .icon {
    width: 70px;
    margin-right: 24px;
  }
  .modal .contents .close {
    width: 100%;
    margin-left: 0;
    padding: 5px;
  }
  .modal .contents .close .inner {
    justify-content: center;
  }
  .modal .contents .close .txt {
    transform: rotate(0deg) translate(0);
    line-height: 1;
    padding: 11px;
  }
  .modal .bg {
    position: fixed;
    min-height: 0;
  }
}
.cursor {
  display: none;
}

.dev-pc body {
  cursor: none !important;
}
.dev-pc body a {
  cursor: none !important;
}
.dev-pc .cursor {
  display: block;
  position: fixed;
  text-align: center;
  top: 0;
  left: 0;
  cursor: none;
  pointer-events: none;
  z-index: 100005;
  opacity: 1;
}
.dev-pc .cursor .icon {
  display: block;
  width: 20px;
  height: 27px;
  background: url("/assets/images/lookbook/common/icon_cursor.svg") no-repeat 50% 50%;
  background-size: 20px 27px;
}
.dev-pc .cursor .txt {
  position: absolute;
  top: 100%;
  left: 50%;
  padding-top: 4px;
  transform: translateX(-50%);
  display: none;
  font-size: 10px;
}
.dev-pc .cursor .y, .dev-pc .cursor .x {
  display: flex;
  justify-content: flex-start;
}
.dev-pc .cursor .y .num, .dev-pc .cursor .x .num {
  padding-left: 5px;
}
.dev-pc .cursor._load {
  opacity: 0;
}
.dev-pc .cursor._on .txt {
  display: block;
}

.lookbook-item-name {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.lookbook-item-name-arrow {
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-inline-start: 12px;
}

.lookbook-item-name-txt {
  display: inline-block;
  /* font-weight: bold; */
}

.lookbook-item-name-arrow svg {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  vertical-align: top;
}

.hero{
  padding-block-end: 120px;
  padding-inline: 55px;
}

.hero-img{
  max-width: 1400px;
  margin-inline: auto;
}

.hero-img img{
  width: 100%;
  height: auto;
}

.hero-txt{
  margin-block-start: 120px;
  font-size: 16px;
  font-style: normal;
  font-weight: 300;
  line-height: 200%;
  text-align: center;
}

.hero-txt >p + p{
  margin-top: 1.5em;
}

.hero-btn{
  margin-block-start: 80px;
  text-align: center;
}

.arw-btn{
  display: inline-block;
  border: 1px solid #000;
  padding: 10px 16px;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
}

.arw-btn > span{
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.arw-btn > span::after{
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  background: currentColor;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
}
