/* ══════════════════════════════════
   HERO — 馬賽克圖片列
══════════════════════════════════ */
.hero {
  background: var(--color-white);
  padding-top:70px;
}
.hero-tagline {
  text-align: center;
  font-size: 0.75rem;
  font-weight: 300;
  letter-spacing: 0.18em;
  color: #6a6260;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.hero-tagline .divider { color: #b0a9a4; }

.hero-track-wrap {
  overflow: hidden;
  width: 100%;
  max-width: 100vw;
}
.hero-track {
  display: flex;
  gap: 5px;
  align-items: stretch;
  height: auto;
  will-change: transform;
}
.hero-track.grabbing { cursor: grabbing; }

.hero-item {
  flex-shrink: 0;
  height: auto;
  overflow: hidden;
  background: #e8e3de;
}
.hero-item--portrait  { width: 280px; }
.hero-item--landscape { width: 400px; }
.hero-item--stack {
  width: 360px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  background: transparent;
}
.hero-item--stack .hero-cell {
  flex: 1;
  overflow: hidden;
  background: #e8e3de;
}
.hero-item--stack .hero-cell img {
  width: 100%;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover;
  display: block;
}
.hero-item img {
  width: 100%;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover;
  object-position: center top;
  display: block;
}
@media (max-width: 768px) {
  .hero-track-wrap {
    overflow: hidden;
    touch-action: pan-y;
  }

  .hero-track {
    height: 420px !important;
    align-items: stretch;
  }

  .hero-item {
    height: 100%;
  }

  .hero-item img {
    width: 100%;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center top !important;
  }

  .hero-item--stack {
    height: 100%;
  }

  .hero-item--stack .hero-cell {
    height: 50%;
  }

  .hero-item--stack .hero-cell img {
    height: 100% !important;
    object-fit: cover !important;
    object-position: center top !important;
  }
}


/* ══════════════════════════════════
   品牌介紹
══════════════════════════════════ */

.intro{
  display:grid;
  grid-template-columns:1fr 360px;
  align-items:stretch;
  background:var(--color-bg);
  padding:80px 0;
  position:relative;
}

/* 左側區塊 */

.intro-left{
  display:flex;
  flex-direction:column;
  position:relative;
}

/* 左側直線 */

.intro-left::before{
  content:'';
  position:absolute;
  left:100px;
  top:0;
  bottom:0;
  width:1px;
  background:#c0bab4;
  z-index:3;
}

/* 文字盒 */

.intro-box{
  background:var(--color-beige);
  margin:50px 0 40px 0;
  padding:56px 56px 52px 100px;
  position:relative;
  flex:1;
  z-index: 2;
}

.intro-quote{
  font-size:28px;
  font-weight:400;
  line-height:1.8;
  color:var(--color-text);
  letter-spacing:0.04em;
  text-align:center;
  margin-bottom:10px;
}

.intro-tags{
  text-align:center;
  font-size:0.68rem;
  font-weight:300;
  color:var(--color-text-lt);
  letter-spacing:0.1em;
  margin-bottom:26px;
}

.intro-body{
  font-size:16px;
  font-weight:300;
  line-height:2.2;
  padding: 0 100px;
  color:var(--color-text-md);
}

.intro-sig{
  position:absolute;
  right:280px;
  bottom: 40px;
  z-index:3;
}

.intro-sig .sig-name{
  font-family:var(--font-script);
  font-size:5.5rem;
  color:#4a4642;
  line-height:1.1;
  display:block;
  opacity:.9;
}


/* 按鈕 */

.intro-btns{
  display:flex;
  justify-content:center;
  gap:16px;
  padding:24px 0 0;
}

.btn-round{
  display:inline-block;
  padding:11px 36px;
  background:var(--color-beige);
  font-size:0.8rem;
  font-weight:300;
  letter-spacing:0.1em;
  color:var(--color-text);
  border-radius:10px;
  cursor:pointer;
  transition:0.3s;
  white-space:nowrap;
}

.btn-round:hover{
  background:#d8d4cc;
}

/* 右側照片 */

.intro-photo{
  position:relative;
  min-height:460px;
  order: 2;  /* 桌機版圖在右 */
}

.intro-left {
  order: 1;  /* 桌機版文字在左 */
}

/* 白色底板 */

.intro-photo::after{
  content:'';
  position:absolute;
  right:-40px;
  bottom:-21px;
  width:428px;
  height:454px;
  background:#fff;
}

/* 照片 */

.intro-photo img,
.intro-photo .placeholder{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  z-index:1;
}

/* RWD */

@media (max-width:860px){

  .intro-body{
    padding: 0px 16px;
  }

  .intro{
    grid-template-columns:1fr;
    padding:60px 0;
  }

  .intro-quote{
    font-size:32px;
  }

  .intro-photo{
    height:360px;
    order: 1;
  }

  .intro-left{
    order: 2;
  }

  .intro-sig .sig-label{
    color: #f3f3f3;
  }

  .intro-photo img,
  .intro-photo .placeholder{
    position:static;
    height:360px;
  }

  .intro-left{
    padding-left:0;
  }

  .intro-left::before{
    display:none;
  }

  .intro-box{
    margin:0;
    padding:40px 6%;
  }

  .intro-btns{
    padding:20px 6% 32px;
  }

}
/* ══════════════════════════════════
   共用：可滑動服務/課程區塊
══════════════════════════════════ */
.slide-section {
  background:var(--color-bg);
  padding: 48px 40px;
}
.slide-wrap {
  border: 1px solid var(--color-line);
  display: grid;
  grid-template-columns: 1fr 360px;
}

/* 桌機版：aside 排在右（HTML 順序是 aside 在前，用 order 調換） */
.slide-aside {
  order: 2;
}
.slide-scroll {
  order: 1;
}
.slide-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  cursor: grab;
  border-right: 1px solid var(--color-line);
  scrollbar-width: none;
}
.slide-scroll::-webkit-scrollbar { display: none; }
.slide-scroll.grabbing { cursor: grabbing; }
.slide-cards { display: flex; min-width: max-content; }

.slide-card {
  width: 300px;
  flex-shrink: 0;
  padding: 36px 32px 40px;
  border-right: 1px solid var(--color-line);
  display: flex;
  flex-direction: column;
}
.slide-card:last-child { border-right: none; }

.slide-card__img {
  width: 100%; height: 240px;
  overflow: hidden; margin-bottom: 24px;
}
.slide-card__img img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
  transition: transform 0.5s ease;
}
.slide-card:hover .slide-card__img img { transform: scale(1.04); }

.slide-card__title {
  font-size: 1.3rem;
  font-weight: 400;
  color: var(--color-text);
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}
.slide-card__en {
  font-family: var(--font-en);
  font-size: 0.72rem; font-weight: 300;
  color: #9a928a; letter-spacing: 0.08em;
  margin-bottom: 18px;
}
.slide-card__desc {
  font-size: 0.8rem; font-weight: 300;
  line-height: 2; color: var(--color-text-md);
  flex: 1; margin-bottom: 28px;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 30px;
  border: 1px solid #aaa49e;
  border-radius: 10px;
  font-size: 0.78rem;
  font-weight: 300;
  letter-spacing: 0.1em;
  color: var(--color-text);
  text-decoration: none;
  width: fit-content;
  transition: all .3s ease;
}
.btn-outline:hover { 
  background: var(--color-text-lt);
  color: #fff; }

/* 右側說明 */
.slide-aside {
  padding: 36px 28px 36px 32px;
  display: flex; 
  flex-direction: column;
  justify-content: center;
}
.aside-en-lg {
  font-family: var(--font-en);
  font-size: 1.8rem; 
  font-weight: 300;
  color: #ccc6c0;
  letter-spacing: 0.06em;
  line-height: 1;
  margin-bottom: 6px;
}
.aside-title {
  font-size: 1.9rem;
  font-weight: 400;
  color: var(--color-text);
  letter-spacing: 0.06em;
  margin-bottom: 28px;
}
.aside-item {
  padding-left: 14px;
  border-left: 2px solid #c8c2bc;
  margin-bottom: 22px;
}
.aside-item:last-child { margin-bottom: 0; }
.aside-item p {
  font-size: 15px;
  font-weight: 300;
  line-height: 2;
  color: var(--color-text-md);
}


@media (max-width: 860px) {
  .slide-section {
    padding: 40px 16px; }
  .slide-wrap {
     grid-template-columns: 1fr; }
  .slide-aside {
      order: 1; 
      border-bottom: 1px solid var(--color-line); }
  .slide-scroll {
    order: 2;
    border-right: none;
    overflow: visible;
    cursor: default;
  }
  .slide-cards {
    flex-direction: column;
    min-width: unset;
  }

  .slide-card {
    width: 100%; 
    border-right: none;
    border-bottom: 1px solid var(--color-line);
  }
  .slide-card__img {
    width: 100%;
    height: auto; 
    overflow: hidden;
    margin-bottom: 24px;
  }
  
  .slide-card__img img {
    width: 100%;
    height: auto;
    object-fit: unset;
    display: block;
  }
  .slide-card:last-child {
    border-bottom: none;
  }
    .intro{ 
      grid-template-columns:1fr;
      padding:60px 0;
    }

    .intro-sig .sig-name {
      color: #f3f3f3;
      padding-right: 10px;
    }
   .intro-photo{
      height:360px;
      order:1;
      position:relative;
      overflow:hidden;
    }
    .intro-left{
      order:2; padding-left:0;
    }
    .intro-photo img{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      object-fit:cover;
      object-position:center top;
    }
    .intro-sig{
      position:absolute;
      bottom:16px;
      right:16px;
      z-index:3;
    }
    .intro-left::before{
      display:none;
    }
    .intro-box{
      margin:0;
      padding:40px 6%;
    }
    .intro-btns{
      padding:20px 6% 32px; 
    }
}

/* ══════════════════════════════════
   SKIN CARE
══════════════════════════════════ */

.skincare{
  background:var(--color-bg);
}

.skincare-inner{
  display:grid;
  grid-template-columns:1fr 1px 2fr;
  min-height:520px;
}

.skincare-divider{
  background:var(--color-line);
}

/* 左側文字 */

.skincare-text{
  padding:56px 20px 56px 40px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.skincare-en{
  font-family:var(--font-en);
  font-size:3rem;
  font-weight:300;
  color:#ccc6c0;
  letter-spacing:.08em;
  line-height:1;
  margin-bottom:6px;
}

.skincare-title{
  font-size:1.5rem;
  font-weight:700;
  color:var(--color-text);
  letter-spacing:.06em;
  margin-bottom:36px;
}

.skincare-item{
  padding-left:16px;
  border-left:2px solid #c8c2bc;
  margin-bottom:28px;
}

.skincare-item:last-of-type{
  margin-bottom:40px;
}

.skincare-item p{
  font-size:.82rem;
  font-weight:300;
  line-height:2.1;
  color:var(--color-text-md);
}

/* 右側圖片 */

.skincare-photo{
  position:relative;
  overflow:visible;
  margin-right: -40px;
}

/* 主照片 (不裁切) */

.skincare-photo img{
  width:80%;
  margin-left:80px;
  display:block;
  position:relative;
  z-index:1;
}

/* 模糊底層 */
.skincare-photo::after{
  content:'';
  position:absolute;

  width:80%;
  height:100%;

  left:80px;
  top:0;

  transform:translate(-18px,18px);

  background-image:url("/images/services/skincare01.jpg");
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;

  filter:blur(2px);
  opacity:.48;

  z-index:0;
}


/* RWD */

@media (max-width:860px){

  .skincare{
    padding:0;
  }

  .skincare-inner{
    grid-template-columns:1fr;
  }

  .skincare-divider{
    display:none;
  }

  .skincare-text{
    padding:48px 6%;
  }

}

@media (max-width: 768px) {
  .hero-track { height: 260px; }
  .hero-track-wrap { 
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  
  }
}


/* ══════════════════════════════════
   推薦見證
══════════════════════════════════ */
.testimonials {
  background: var(--color-bg);
  padding: 0 0 48px;
}
.testimonials-header{
  position:relative;
  padding:60px 0;
  text-align:center;
}

/* 文字 */
.testimonials-header h2{
  position:relative;
  z-index:2;
  font-size:1.4rem;
  font-weight:400;
  letter-spacing:.06em;
  color:var(--color-text);
}
/* 上層長條 */
.testimonials-header::before{
  content:'';
  position:absolute;
  left:30%;
  top:50%;
  width:1200px;
  height:30px;
  background:#EBE9E4;
  z-index:0;
}

/* 下層長條 */
.testimonials-header::after{
  content:'';
  position:absolute;
  left:30%;
  top:60%;
  width:1000px;
  height:24px;
  background:#F4F3F0;
  transform:translate(calc(-50% - 10px),calc(-50% + 8px));
  z-index:0;
}
.testimonials-scroll {
  overflow-x: auto;
  cursor: grab;
  scrollbar-width: none;
  border-top: 1px solid #d8d4ce;
  border-bottom: 1px solid #d8d4ce;
}
.testimonials-scroll::-webkit-scrollbar { display: none; }
.testimonials-scroll.grabbing { cursor: grabbing; }
.testimonials-cards {
  display: flex;
  min-width: max-content;
}
.t-card {
  width: 420px; flex-shrink: 0;
  background: var(--color-beige);
  padding: 40px 36px 36px;
  border-right: 1px solid #d0cbc5;
  display: flex; flex-direction: column;
}
.t-card:last-child { border-right: none; }
.t-card__header {
  display: flex; align-items: baseline;
  gap: 10px; margin-bottom: 10px;
}
.t-card__name {
  font-family: var(--font-en);
  font-size: 0.95rem; font-weight: 400;
  color: var(--color-text); letter-spacing: 0.04em;
}
.t-card__divider { color: #aaa49e; }
.t-card__type {
  font-size: 0.82rem; font-weight: 400;
  color: var(--color-text); letter-spacing: 0.04em;
}
.t-card__stars {
  font-size: 1rem; letter-spacing: 0.05em;
  margin-bottom: 18px;
}
.t-card__text {
  font-size: 0.82rem; font-weight: 300;
  line-height: 2; color: var(--color-text-md);
  flex: 1; overflow: hidden;
  max-height: calc(0.82rem * 2 * 7);
  transition: max-height 0.4s ease;
}
.t-card__text.expanded { max-height: 2000px; }
.t-card__toggle {
  display: flex; align-items: center; gap: 6px;
  margin-top: 20px;
  font-size: 0.82rem; font-weight: 300;
  color: var(--color-text-md); letter-spacing: 0.06em;
  font-family: var(--font-serif);
  transition: color 0.2s;
}
.t-card__toggle:hover { color: var(--color-text); }
.t-card__toggle .chevron {
  display: inline-block;
  transition: transform 0.3s;
}
.t-card__toggle.open .chevron { transform: rotate(180deg); }


/* ══════════════════════════════════
   CTA
══════════════════════════════════ */

.cta{
  position:relative;
  background:var(--color-bg);
  padding:40px 40px;
  text-align:center;
}

/* 上層長條 */

.cta::before{
  content:'';
  position:absolute;
  left:50%;
  top:58%;
  transform:translate(-50%,-50%);
  width:100%;
  height:75px;
  background:#E9E7E2;
  z-index:0;
}
.cta__title{
  position:relative;
  z-index:2;
  font-size:1.8rem;
  font-weight:400;
  letter-spacing:.06em;
  margin-bottom:12px;
}

.cta__sub{
  position:relative;
  z-index:2;
  font-family:var(--font-en);
  font-size:.88rem;
  font-weight:300;
  letter-spacing:.12em;
  color:var(--color-text-lt);
}

@media (max-width: 768px) {
  .cta::before{
    top: 43%;
  }
}

.page-end {
  text-align: center;
  font-size: 12px;
  color: #b5aca4;
  padding-bottom: 10px;
}