@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Roboto:700,300");
@import url('https://fonts.googleapis.com/css?family=Lato:400,700,900');
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
@import url("https://use.typekit.net/mtv5kdm.css");

/*default
-------------------*/
body {
  padding: 0;
  margin: 0;
}

a:hover {/*
  opacity: 0.7;*/
  text-decoration: none;
  border: none;
  transition-duration: 1s;
}

a.disabled{
    pointer-events: none;
}

#page-footer .container {
  max-width: 1000px;
}
.container {
  width: 100%;
}
.breadcrumb {
  max-width: 100%;
  padding: 0 14.5%;
  background: #fff;
  max-width: 1000px;
  margin: 0 auto;
}


/*sp
-------------------*/
#Area {
  text-align: center;
  font-family: 'Noto Sans JP', sans-serif;
}
#Area a:hover {
  opacity: .7;
  transition: .4s;
}
section {
  padding: 0 auto 12%;
}
h2 {
  margin-bottom: 5%;
}
h3 {
  font-family: "Noto", serif;
  font-size: 1.25rem;
  font-weight: normal;
  letter-spacing: 0.1rem;
  margin-bottom: 2%;
}
p {
  margin: 0;
  font-weight: normal;
  color: #000000;
}
.pc{
  display: block;
}

.sp{
  display: none;
}


/*flex*/
.item_flx{
  display: flex;
  justify-content: space-between;
}
.item_flx > div {
    z-index: 100;
}
.coordinate_item .coordinate_flx{
  justify-content: center;
}


/*main bnr
-------------------*/
.main_bnr img {
  width: 100%;
}

.main_text p{
  text-align: center;
  font-size: 1rem;
  font-weight: bold;
  line-height: 2;
  margin-top: 50px;
  margin-bottom: 20px;
}
.main_text img{
  padding-top: 100px;
}

/*navi
-------------------*/
/* .navi_outer{
  margin: 50px auto;
  max-width: 100%;
}
.navi {
  width: 90%;
  margin: 0 auto;
  margin-top: 20px;
}
.navi li {
  margin: 4px 8px;
  display: inline-block;
} */


/* --- ナビゲーション共通 --- */
.navi_outer {
  margin: 50px auto;
  width: 95%;
  max-width: 1000px;
}

.navi {
  display: flex;
  flex-wrap: wrap;         /* 折り返しを許可 */
  justify-content: center; /* 中央寄せ */
  list-style: none;
  padding: 80px 80px 0;
  margin: 40px;
}

.navi li {
  box-sizing: border-box;
}

.navi li a img {
  width: 100%;
  height: auto;
  display: block;
}

/* --- PC表示（768px以上） --- */
@media screen and (min-width: 768px) {
  .navi li {
    width: 22%;            /* 4枚横並び */
    margin: 1%;            /* 左右に少し隙間 */
  }
}

/* --- スマホ表示（767px以下） --- */
@media screen and (max-width: 767px) {
  .navi_outer {
    margin: 30px auto;     /* スマホでは上下余白を調整 */
  }

  .navi li {
    width: 46%;            /* ★2列並び（46%×2 + 隙間で調整） */
    margin: 2%;            /* 上下左右の隙間 */
  }
}











/*background-image
-------------------*/

.bg_01{
  background-image: url("//ds-assets.s3-ap-northeast-1.amazonaws.com/ncole/sp/gw_lookbook_2026/bg_01.jpg");
  background-repeat: no-repeat;
  background-position: bottom 38% right -50%;
  background-size: 95%;
  padding: 4% 0 0;
  /* position: relative; */
}

.bg_02{
  background-image: url("//ds-assets.s3-ap-northeast-1.amazonaws.com/ncole/sp/gw_lookbook_2026/bg_02.jpg");
  background-repeat: no-repeat;
  background-position: bottom 36% left -50%;
  background-size: 95%;
  padding: 4% 0 0;
}

.bg_03{
  background-image: url("//ds-assets.s3-ap-northeast-1.amazonaws.com/ncole/sp/gw_lookbook_2026/bg_03.jpg");
  background-repeat: no-repeat;
  background-position: bottom 38% right -50%;
  background-size: 95%;
  padding: 4% 0 0;
}

.bg_04{
  background-image: url("//ds-assets.s3-ap-northeast-1.amazonaws.com/ncole/sp/gw_lookbook_2026/bg_04.jpg");
  background-repeat: no-repeat;
  background-position: bottom 38% left -50%;
  background-size: 95%;
  padding: 4% 0 0;
}




/*item_contents
-------------------*/

.item_contents{
  /* background-image: url("//ds-assets.s3-ap-northeast-1.amazonaws.com/ncole/sp/220916_hw/test/bg_01.jpg"); */
  background-repeat: no-repeat;
  background-position: right;
  background-size: contain;
  padding: 4% 0 0;
  position: relative;
}

.item_detail{
  max-width: 1100px;
  margin: 0 auto;
}
.item_txt{
  text-align: left;
  font-size: 1rem;
  font-weight: bold;
  line-height: 2;
  margin: 10% 0 5%;
  letter-spacing: 0.02rem;
}
.item_txt > p {
  max-width: 435px;
  margin-bottom: 5%;
}

.item_txt .title img{
  width: 75%;
  height: auto;
}

.item_txt .title_2 img{
  width: 90%;
  height: auto;
}

.item_txt h3 {
  font-size: 1.6rem;
  line-height:1.6em;
}

.item_txt .explain{
  margin: 5% 0 10%;
}


/* .sub_item{
  margin-top: 35%;
  margin-bottom: 0;
} */
.item_img_l{
  text-align: left;
  display: flex;
  flex-direction: column;   /* 中身を縦に並べる */
  align-items: flex-start;
}

.item_img_l img {
  margin-top: 8%;
  width: 85%;
}

/* --- 全体設定 --- */
.img_text {
  display: block;            /* PCはブロック扱いで改行を有効にする */
  margin-top: 15px;
  font-size: 0.9rem;
  color: #000;
  line-height: 1.6;
  text-align: left;
}

/* PC用の改行（スマホでは消す） */
.pc_br {
  display: block;
}

/* BUYボタンのスタイル */
.img_text a.buy_btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 25px;
  background: #000;
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  font-size: 13px;
  letter-spacing: 2px;
  margin-left: 15px;        /* テキスト（金額）との間隔 */
  vertical-align: middle;
  text-decoration: none;
}

.item_img_r{
  margin-left: 5%;
  width: 95%;
}
.item_img_c{
  position: absolute;
  bottom: 15%;
  right: 14%;
}
.item_img_c_2{
  position: absolute;
  bottom: 50%;
  right: 48%;
}
.item_img_c_3{
  position: absolute;
  bottom: 105%;
  right: 17%;
}
.bg_color{
  left: 39%;
  transform: translateX(-50%);
  width: 100vw;
  height: 18%;
  position: absolute;
  bottom: -10%;
}
.bg_color_2{
  bottom: 2%;
}
.bg_color_3{
  bottom: -3%;
}
.bg_color_4{
  bottom: -8%;
}

#ITEM04 .item_img_l img {
  width: 95%;
  height: auto;
}

/*
#ITEM04 .item_txt {
  color: #ffffff;
}
#ITEM04 .coordinate_item {
  color: #ffffff;
}
#ITEM05 .item_txt {
  color: #ffffff;
}
#ITEM05 .coordinate_item {
  color: #ffffff;
}
#ITEM06 .item_txt {
  color: #ffffff;
}
#ITEM06 .coordinate_item {
  color: #ffffff;
}
*/

/*check_btn*/
.check_btn {
  margin-top: 4%;
}
.check_btn a {
  display: block;
  width: 40%;
  margin: 0;
  padding: 1% 0;
  font-size: 0.875rem;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: normal;
  letter-spacing: 1px;
  color: #000;
  border: 3px solid #000;
  position: relative;
}
.check_btn a::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 72%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  box-sizing: border-box;
  width: 6px;
  height: 6px;
  border: 5px solid transparent;
  border-left: 8px solid #000;
}
.check_btn a:hover {
  background-color: #000;
  color: #fff;
}
.check_btn a:hover::after {
  border-left: 8px solid #fff;
  transition: .4s;
}

/* ------------------------
style_item
------------------------ */

.style_item {
  /* width: 87.3%; */
  /* max-width: 1323px; */
  margin: 0 auto;
  padding: 0 15% 5%;
}
#ITEM04 .style_item {
  margin: 0 auto;
  /* padding: 0 15% 0; */
}
.style_item h4 {
  margin: 6% 0 4%;
  color: #000;
  text-align: center;
  font-family: "Zen Old Mincho", serif;
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 2px;
}
.style_item_listwrap {
  width: 100%;
  margin: 0 auto;
}
.style_item_list {
  display: flex;
  justify-content: flex-start;
  gap: 0;
}
.style_item_list li {
  /* width: calc(( 100% - (2% * 5)) / 6 ); */
  width: auto;
}
.item_img img {
  width: 100%;
}
.item_credit {
  margin-top: 10px;
  font-size: 13px;
  line-height: calc(21 / 13);
  letter-spacing: 1px;
}
.item_credit .name {
  margin-bottom: 0;
  text-align: left;
  font-size:0.9rem;
  /* letter-spacing: -1.3px; */
}
.item_credit .price {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 17px;
  letter-spacing: 1px;
  font-size: 0.9rem;
}
.item_credit .price span {
  letter-spacing: 0;
}


/*buy_btn*/
/* a.buy_btn{
  font-size: 8pt;
  display: inline-block;
  background-color: #000;
  color: #fff;
  letter-spacing: 0.1em;
  margin-left: 5%;
  padding: 0 3%;
  line-height: 1.8;
  min-width: 30px;
  text-align: center;
  font-family: "Yu Mincho", serif;
} */

/*contents_btn
-------------------*/
.contents_btn {
  margin-bottom: 12%;
  margin-top: 7%;
}
.contents_btn a {
  display: block;
  margin: 0 auto;
  width: 41%;
  padding: 2.2% 0;
  background-color: #242424;
  color: #fff;
  font-size: 1rem;
  letter-spacing: 0.2rem;
  position: relative;
}
.contents_btn a::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 98%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  box-sizing: border-box;
  box-sizing: border-box;
  width: 5px;
  height: 5px;
  border: 5px solid transparent;
  border-left: 5px solid #ffffff;
}



@media (max-width: 1600px) {


.navi {
  width: 90%;
  margin: 0 auto;
}

/*item_contents
-------------------*/
.item_img_c_2{
  bottom: 40%;
  right: 48%;
}
.item_img_c_3{
  bottom: 71%;
  right: 11%;
}

.item_txt .title img{
  width: 60%;
  height: auto;
}

.item_txt .title_2 img{
  width: 80%;
  height: auto;
}

.style_item h4 {
  font-size: 24px;
}

/*coordinate_item
-------------------*/
/*.coordinate_item {
  padding-bottom: 10%;
}*/
}


@media (max-width: 1420px) {

.navi {
  width: 40%;
  margin: 0 auto;
}

}

@media (max-width: 1200px) {

.navi {
  width: 45%;
  margin: 0 auto;
}

/*item_contents
-------------------*/

.item_detail {
  max-width: 950px;
  margin: 0 auto;
}
.item_img_c_2{
  bottom: 5%;
  right: 47%;
}
.item_img_c_3{
  bottom: 50%;
  right: 5%;
}
.item_img_l img {
  width: 100%;
}
}




@media (max-width: 1024px) {

.navi {
  width: 50%;
  margin: 0 auto;
}

/*item_contents
-------------------*/
.item_detail {
  max-width: 860px;
  margin: 0 auto;
}
.item_img_r {
  margin: 0 1% 0 8%;
}
.item_img_c {
  right: 7%;
  bottom: 26%;
}
.bg_color {
  left: 43%;
  height: 18%;
  bottom: -3%;
}
.item_txt > p {
    /* 固定幅(435px)を解除して、親要素（画像と同じ幅）いっぱいに広げる */
    max-width: 100% !important; 
    width: 100%;
  }

/*coordinate_item
-------------------*/
/*.coordinate_item {
  padding-bottom: 10%;
}*/
}

@media (max-width: 978px) {

  .navi {
    width: 67%;
    margin: 0 auto;
  }

/*default
-------------------*/
#page-footer {
  margin: 0;
}
#page-footer .nav li {
  padding: 0;
}
#wrapper {
  padding-left: 0;
  padding-right: 0;
  overflow: hidden;
}
#page-header .navbar-inner, #page-footer .nav, #head-bar {
  padding-left: 10px;
  padding-right: 10px;
}

/*item_contents
-------------------*/
.item_detail {
  max-width: 600px;
}
.item_img_c {
  width: 35%;
}

/*contents_btn
-------------------*/
.contents_btn a {
  width: 50%;
}
}

@media screen and (max-width: 767px) {

/*sp
-------------------*/
h2 {
  margin-bottom: 9%;
}

/*sp
-------------------*/
section {
  margin: 0 auto 5%;
}

/*flex*/
.item_flx{
  display: block;
  padding-bottom: 0;
}
#nf #ITEM02 .item_flx{
  padding-bottom: 100%;
}
.pc{
  display: none;
}

.sp{
  display: block;
}


/*navi
-------------------*/
.navi_outer{
  max-width: 96%;
}
.navi {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 90%;
  margin: 0 auto;
  padding: 0;
}
.navi li {
  margin-bottom: 15px;
  width: calc((100% - 10) / 3);
}

/*item_contents
-------------------*/

.main_text {
  width: 90%;
  margin: 0 auto;
}
.item_contents {
  background-position: top;
  padding: 0 0 5%;
}

.item_detail {
  padding: 0 6%;
}
.item_txt {
  line-height: 2;
  margin-bottom: 15%;
}

.item_img_r {
  margin: 0 0 13%;
}
.item_img_l {
  width: 75%;
  margin: 0 0 13%;
}
.item_img_c {
  position: absolute;
  width: 65%;
  margin-left: 25%;
  bottom: 18%;
}
.bg_color{
  position: absolute;
  transform: translateX(0);
  left: 50%;
  transform: translateX(-50%);
  height: 15%;
  bottom: 0;
}

.item_flx.pos {
  padding-bottom: 130%;
}
.item_flx.pos .item_img_l {
  position: absolute;
  bottom: 0;
  z-index: 10;
  margin: 0 0 20%;
  width: 70%;
}

.item_img_r,
  .item_img_l {
    margin-left: 0 !important;
    margin-right: auto !important;
    float: none;
    display: block;
  }

  /* 右画像（r）：item_flx（画面幅）いっぱいに近く大きく表示 */
  .item_img_r {
    width: 100% !important;   /* 画面幅いっぱい */
    margin-bottom: 10% !important;
  }

  /* 左画像（l）：右画像より一回り小さくし、右側に余白を作る */
  .item_img_l {
    width: 80% !important;   /* ★ここでサイズを調整（rより小さく） */
    margin-bottom: 13% !important;
  }

  /* 画像自体のサイズを親要素にフィットさせる */
  .item_img_r img,
  .item_img_l img {
    width: 100% !important;
    height: auto;
    margin-top: 0;
  }

  /* テキストの左端を画像に合わせる */
  .img_text {
    width: 100%;
    text-align: left;
    display: block;
    margin-top: 10px;
    font-size: 0.85rem;
    line-height: 1.4;
  }

  .item_txt h3 {
  font-size: 1.2rem;
  line-height:1.5em;
  margin-bottom: 6%;
}

  .item_txt > p {
    max-width: 100% !important;
    width: 100%;
    /* スマホで読みやすくするために、少しだけ文字間や行間を調整（任意） */
    line-height: 1.8;
    margin-bottom: 8%; 
    font-size: 0.85rem;
  }


/* 左画像下のテキスト */
.item_img_l {
  text-align: left !important; /* 親要素の右寄せを解除 */
  align-items: flex-start !important;
}


.img_text {
  display: inline-block;  /* スマホはインライン的に扱う */
  font-size: 0.8rem;
  line-height: 1.4;
  letter-spacing: -0.01rem;
}

/* ★PC用の改行を無効化して1行に繋げる */
.pc_br {
  display: none;
}

.img_text a.buy_btn {
  width: 50px;
  height: 22px;
  font-size: 11px;
  margin-left: 0;
  margin-top: 5px;
  vertical-align: baseline;
}

.item_credit .name {
  font-size:0.8rem;
}
.item_credit .price {
  font-size: 0.8rem;
}

/* 背景画像 */
.bg_01{
  background-position: bottom 35% right;
  background-size: inherit;
}
.bg_02{
  background-position: bottom 35% left;
  background-size: inherit;
}
.bg_03{
  background-position: bottom 30% right;
  background-size: inherit;
}
.bg_04{
  background-position: bottom 31% left;
  background-size: inherit;
}

/*check_btn*/
.check_btn a {
  border: 2px solid #000;
  width: 45%;
}

/*coordinate_item
-------------------*/
.coordinate_item {
  padding: 4% 5% 8%;
}
.coordinate_item h3 {
  margin-bottom: 6%;
}

.coordinate_item .coordinate_flx {
  display: flex;
  width: 90%;
  margin: 0 auto;
  flex-wrap: wrap;
  justify-content: space-between;
}

.coordinate_item ul li {
  width: 47.5%;
  text-align: left;
  margin-bottom: 30px;
  margin-right: 0;
}

/*contents btn*/
.contents_btn a {
  width: 90%;
  padding: 14px 0;
  font-size: 0.75rem;
}
.contents_btn.red {
  margin: 1.5% 0 18%;
}

.style_item {
  /* width: 87.3%; */
  /* max-width: 1323px; */
  margin: 0 auto;
  padding: 4% 5% 8%;
}
.style_item h4 {
  margin: 6% 0;
  font-size: 1.5rem;
}

}

@media screen and (max-width: 320px){
/*item_contents
-------------------*/

/*check_btn*/
/*.check_btn a::after {
  left: 80%;
}*/
}

/* Swiper基本設定（最下部などに追加） */
.swiper-scroll {
  overflow: hidden; /* はみ出しを隠す */
  position: relative;
  width: 100%;
  max-width: 1100px;
}

.style_item_list.swiper-wrapper {
  display: flex !important; /* flexを強制 */
  flex-wrap: nowrap !important; /* 折り返しを強制禁止 */
  justify-content: flex-start !important; /* 絶対に左寄せ */
  padding: 0;
}

/* スマホ時のスライド幅 */
.swiper-scroll .swiper-slide {
  width: 70%; /* ここでお好みのサイズに */
  height: auto;
  flex-shrink: 0;
}

/* PC時の表示調整 */
@media (min-width: 768px) {
  .swiper-scroll .swiper-slide {
    width: 20%; /* PCは4枚並び */
  }
}

/* --- フローティングバナー強制リセット＆固定設定 --- */
#floating-banner {
  position: fixed !important; /* 画面に強制固定 */
  z-index: 99999 !important;  /* 最前面に強制 */
  line-height: 0;             /* 画像下の隙間を消す */
  margin: 0 !important;
  padding: 0 !important;
}

#floating-banner a, 
#floating-banner img {
  display: block;
  width: 100%;
  height: auto;
}

/* --- PC表示の制御（768px以上） --- */
@media screen and (min-width: 768px) {
  #floating-banner {
    position: fixed !important;
    top: auto !important; 
    transform: none !important; 
    bottom: 10% !important;     /* 位置はお好みで */
    right: 0 !important; 
    left: auto !important;
    width: 100px !important; 
    z-index: 99999 !important;

    /* ★ ここを調整：0.3sから0.5sに伸ばし、ease-in-outでより滑らかに */
    transition: opacity 0.5s ease-in-out, filter 0.5s ease-in-out !important;
    opacity: 1;
  }

  /* ホバー時の設定 */
  #floating-banner:hover {
    /* ★ brightness（明るさ）と opacity（透明度）を組み合わせて「ふわっ」とさせる */
    filter: brightness(1.15) !important; 
    opacity: 0.75 !important;
    cursor: pointer;
  }

  .floating-banner_pc {
    display: block !important;
    box-shadow: -2px 2px 10px rgba(0,0,0,0.15);
    border-radius: 4px 0 0 4px;
  }
  
  .floating-banner_smp {
    display: none !important;
  }
}

/* --- スマホ表示の制御（767px以下） --- */
@media screen and (max-width: 767px) {
  #floating-banner {
    bottom: 0 !important;     /* 下にピッタリ */
    left: 0 !important;       /* 左にピッタリ */
    right: 0 !important;      /* 右にピッタリ */
    width: 100% !important;   /* 横幅いっぱい */
  }
  /* PC用画像を強制非表示 */
  .floating-banner_pc {
    display: none !important;
  }
  /* スマホ用画像を表示 */
  .floating-banner_smp {
    display: block !important;
  }
}