/* =============================================================
   Shilket × Smooth T  ―  LP Stylesheet  (pixel‑refined v2.1)
   2025‑08‑06   Maintainer: Knox
   - @media クエリに "screen and" を明示
   - chips の重複定義を整理 (PC 188px / SP 140px)
=============================================================*/

:root {
  --max-width: 1200px;
}
html {
  scroll-behavior: smooth;
}
/* ------------------------------
   RESET / COMMON
--------------------------------*/
*,
*::before,
*::after {
  box-sizing: border-box;
}
body,
button,
input,
select,
textarea {
  font-family: "Noto Serif JP", "Source Han Serif", serif;
  font-feature-settings: "palt";
  margin: 0;
  color: #222;
  line-height: 1.8;
}
main {
  margin: 0 auto;
  max-width: 1200px;
}
@media screen and (max-width: 767px) {
  main {
    width: 100%;
    box-sizing: border-box;
  }
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
a {
  text-decoration: none;
  color: inherit;
}
img {
  display: block;
  max-width: 100%;
  height: auto;
}

.pc {
  display: none;
  width: 100%;
}
.sp {
  display: block;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
}

/* ------------------------------
   HERO
--------------------------------*/
.hero {
  margin-bottom: 64px;
  width: 100%;
  text-align: center;
}
.hero img {
  width: 1200px;
  text-align: center;
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .hero {
    margin-bottom: 0;
  }
}

/* ------------------------------
   INTRO
--------------------------------*/
.intro {
  max-width: 860px;
  margin: 56px auto 104px;
  text-align: center;
}
.intro .catch {
  font-size: 46px;
  font-weight: 700;
  margin-bottom: 34px;
}
.intro .sub-catch {
  font-size: 34px;
  margin-bottom: 0px;
  letter-spacing: 1px;
}
.intro .bullet_01 {
  font-size: 20px;
  line-height: 1.8;
  letter-spacing: 1.5px;
  margin-bottom: 24px;
  text-align: center;
}
.intro .bullet_02 {
  font-size: 20px;
  line-height: 1.8;
  letter-spacing: 1.5px;
  margin-bottom: 24px;
  text-align: center;
  margin-top: -4px;
}
.intro .bullet_01 li + li,
.intro .bullet_02 li + li {
  margin-top: 2px;
}
@media screen and (max-width: 767px) {
  .intro {
    margin: 11px auto 64px;
    text-align: center;
    padding: 0 20px;
  }
  .intro .catch {
    font-size: 30px;
    margin-bottom: 0px;
  }
  .intro .sub-catch {
    font-size: 24px;
    margin-bottom: -6px;
    margin-top: 14px;
    padding: 0;
  }
  .intro .bullet_01 {
    font-size: 18px;
    margin-bottom: 20px;
    text-align: center;
  }
  .intro .bullet_02 {
    font-size: 18px;
    text-align: center;
  }
}

/* ------------------------------
   lookbook
--------------------------------*/
.lookbook {
  max-width: 1070px;
  margin: 114px auto 0;
}
.lookbook .lookbook-list li:nth-child(1) {
  width: 493px;
  margin: 0 0 74px 0;
}
.lookbook .lookbook-list li:nth-child(2) {
  width: 493px;
  margin: -486px 0 0 577px;
  position: relative;
  z-index: 0;
}
.lookbook .lookbook-list li:nth-child(3) {
  width: 482px;
  margin: -179px 0 80px 140px;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .lookbook {
    max-width: 1070px;
    margin: 50px auto 0;
  }
  .lookbook .lookbook-list li:nth-child(1) {
    width: 315px;
    margin: 0 0 35px 0;
  }
  .lookbook .lookbook-list li:nth-child(2) {
    width: 315px;
    margin: 0 0 35px 60px;
  }
  .lookbook .lookbook-list li:nth-child(3) {
    width: 315px;
    margin: 0 0 80px 0;
  }
}

/* ------------------------------
   ITEM LINEUP
--------------------------------*/
.ttl_set {
  width: 100%;
  text-align: center;
  margin-top: -150px;
}

.ttl_set img {
  display: block;
  margin: 0 auto 56px;
  max-width: 400px;
  width: 40%;
}

/* PC用（デフォルトで表示） */
.chips {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin: 72px 0 125px;
  width: 100%;
  padding: 0 140px;
}

.chips .sp {
  display: none;
}

.chips .chip img {
  width: 100%;
  height: auto;
}

@media screen and (max-width: 767px) {
  .ttl_set {
    width: 100%;
    text-align: center;
    padding: 0px 20px;
  }

  .ttl_set img {
    display: block;
    margin: 250px auto -135px;
    max-width: 400px;
    width: 100%;
  }

  .chips .pc {
    display: none;
  }

  .chips {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 33px;
    margin-bottom: 108px;
    padding: 0 20px;
  }

  .chips .chip {
    width: 100%;
    max-width: 400px;
  }

  .chips .chip img {
    width: 100%;
    height: auto;
  }
}

/* ------------------------------
   FEATURES
--------------------------------*/
.features-list {
  display: flex;
  flex-direction: column;
  gap: 76px;
  align-items: center;
  margin-bottom: 112px;
}
.feature {
  display: flex;
  gap: 40px;
  max-width: 930px;
  width: 100%;
  align-items: center;
}
.feature.reverse {
  flex-direction: row-reverse;
  margin-bottom: 180px;
}
/* 画像ブロック固定幅 */
.feature .pc,
.feature .sp {
  flex: 0 0 400px;
  max-width: 400px;
  width: 400px;
}
.feature img {
  width: 100%;
}
.feature-txt {
  flex: 1 1 380px;
}
.feature-txt h3 {
  font-size: 40px;
  font-weight: 700;
  margin: 0 0 24px;
  line-height: 1.35;
  width: 380px;
}
.feature-txt p {
  font-size: 19px;
  line-height: 1.7;
  width: 380px;
}
@media screen and (max-width: 767px) {
  .feature {
    padding: 0 20px; /* ← これがないと画像が画面端まで来てしまう */
  }

  .feature .sp img {
    width: 100%;
    height: auto;
    display: block; /* ← 念のため */
  }

  .features-list {
    gap: 48px;
    margin-bottom: 80px;
  }
  .feature,
  .feature.reverse {
    flex-direction: column;
    gap: 24px;
    margin-bottom: 0;
    align-items: baseline;
    margin-top: -30px;
  }
  .feature .pc {
    display: none;
  }
  .feature .sp {
    display: block;
    width: 100%;
    max-width: 100%;
  }
  .feature-txt h3 {
    font-size: 29px;
    margin-bottom: 27px;
    padding: 0px;
    width: auto;
  }
  .feature-txt p {
    font-size: 18px;
    width: auto;
  }
  .feature .sp {
    display: block;
    width: 100%;
    max-width: 100%;
    order: 2; /* ← ここを追記！SP画像をテキストの後に */
  }

  .feature .feature-txt {
    order: 1;
    padding: 0; /* ← ここも追記！テキストを先に表示 */
  }
  .feature-txt {
    flex: 1 1 30px;
  }
  .features-list .feature.reverse:last-of-type {
    margin-top: -130px; /* ← お好みで */
  }
}

/* ------------------------------
   PRODUCTS (Swiper + Meta)
--------------------------------*/
.products {
  display: flex;
  flex-direction: column;
  gap: 145px;
  align-items: center;
  padding-bottom: 120px;
}

.product {
  display: flex;
  gap: 120px;
  max-width: 900px;
  width: 100%;
  justify-content: space-between;
  align-items: flex-start;
}
.product.reverse {
  flex-direction: row-reverse;
}

.swiper {
  width: 100%;
  max-width: 390px;
  position: relative;
}

.swiper-slide {
  width: 100%;
  height: auto;
}

.swiper-slide img {
  width: 390px;
  height: auto;
  display: block;
  object-fit: cover;
}

.swiper .swiper-pagination {
  position: static;
  margin-top: 20px;
  text-align: center;
}

.mySwiper1 .swiper-pagination-bullet,
.mySwiper2 .swiper-pagination-bullet,
.mySwiper3 .swiper-pagination-bullet,
.mySwiper4 .swiper-pagination-bullet {
  background-color: grey;
  border-radius: 0;
}

.mySwiper1,
.mySwiper2,
.mySwiper3,
.mySwiper4 {
  margin: 0;
  position: relative;
  height: auto;
}

@media screen and (max-width: 767px) {
  .product {
    flex-direction: column;
    gap: 24px;
    margin-top: -30px;
  }
  .products {
    padding-bottom: 0px;
  }
}
@media screen and (max-width: 767px) {
  .swiper-slide img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
  }
}

@media screen and (max-width: 767px) {
  .swiper,
  .swiper-wrapper,
  .swiper-slide {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }
  .mySwiper1-sp .swiper-pagination-bullet,
  .mySwiper2-sp .swiper-pagination-bullet,
  .mySwiper3-sp .swiper-pagination-bullet {
    background-color: grey;
    border-radius: 0;
  }
}

/* product info */
.product-info {
  width: 390px;
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
}
.product-info h3 {
  font-size: 30px;
  font-weight: 700;
  margin-bottom: 25px;
}
.product-info .price {
  font-size: 20px;
  margin-bottom: 20px;
}
.product-info .desc {
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 35px;
}
.product-info .color,
.product-info .silhouette {
  margin-bottom: 35px;
}
.product-info .color img,
.product-info .silhouette img {
  width: 100%;
  height: auto;
}

/* 各商品のボタン */
.btn.pc {
  text-align: center;
  margin: -76px 0 80px;
  width: 100%;
}

.btn.pc a {
  display: inline-block;
}

@media screen and (max-width: 767px) {
  .btn.sp {
    box-sizing: border-box;
    text-align: center;
    margin: -96px 0 80px;
    width: 80%;
  }
}

@media screen and (max-width: 767px) {
  .product-info {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 20px;
    box-sizing: border-box;
  }
  .product-info h3 {
    font-size: 28px;
    margin-bottom: 8px;
    padding: 0px;
    font-weight: 400;
    line-height: 35px;
  }
  .product-info .price {
    font-size: 24px;
    margin-bottom: 20px;
  }
  .product-info .desc {
    font-size: 17px;
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 767px) {
  body {
    overflow-x: hidden;
  }
}

/* ------------------------------
   CTA / FOOTER BUTTONS
--------------------------------*/
.btn-check-up {
  max-width: 450px;
  margin: 48px auto 140px;
  text-align: center;
}
.btn-check-up.sp {
  padding: 0 20px;
}
.btn-check-down {
  width: 100%;
  margin: 72px auto 120px;
  text-align: center;
}
.button-section {
  margin: 0 auto;
}
.button-row {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 48px;
}
.button-row ul {
  display: flex;
  gap: 20px;
  margin: 0 auto;
  padding: 0;
  justify-content: center;
}
.button-row li {
  list-style: none;
}
.single-button {
  margin: 0 auto 120px;
  text-align: center;
}
.single-button .pc,
.single-button .sp {
  display: block;
  text-align: center;
}

.single-button a {
  display: inline-block;
}

.single-button img {
  max-width: 480px;
  width: 100%;
  height: auto;
  margin: 0 auto;
  display: block;
}
@media screen and (max-width: 767px) {
  .button-row {
    flex-direction: column;
    gap: 16px;
    margin-bottom: 56px;
  }
  .button-row ul {
    flex-direction: column;
    align-items: center;
  }
  .single-button {
    margin-bottom: 110px;
  }
  .button-section {
    padding: 0 20px;
  }
}

/* ------------------------------
   Utilities
--------------------------------*/
.text-center {
  text-align: center;
}
.mt-0 {
  margin-top: 0 !important;
}

/* =============================================================
   End of file
=============================================================*/
