:root {
  --main: #E6A57E;
  --accent: #b97d45;
  --badge-bg: #FFF5E6;
  --swatch-outline: #e6a57e55;
}

body {
  margin: 0;
  padding: 0;
  background: #f8f8f9;
  font-family: 'Rubik', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

.hero-parallax {
  min-height: 96vh;
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  box-shadow: 0 6px 60px -12px #1f1f2840;
}
.hero-parallax::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 120px;
  background: linear-gradient(to top, #fff 65%, transparent 100%);
  z-index: 2;
}
.hero-summary-glass {
  display: inline-block;
  background: rgba(36,36,44,0.50);
  color: #fff;
  font-size: 1.32rem;
  font-weight: 500;
  padding: 20px 48px;
  border-radius: 22px;
  box-shadow: 0 2px 18px -9px #0002;
  margin: 0 auto;
  line-height: 1.67;
  min-width: 190px;
  text-align: center;
  max-width: 96vw;
  transition: background .25s;
  z-index: 3;
  position: relative;
}
.hero-scroll-hint {
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.12rem;
  color: #fff;
  opacity: 0.82;
  z-index: 4;
  animation: bounceDown 1.7s infinite;
}
@keyframes bounceDown {
  0%   { transform: translateY(0) translateX(-50%); }
  50%  { transform: translateY(18px) translateX(-50%); }
  100% { transform: translateY(0) translateX(-50%); }
}

.mockup-highlight-wrap {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  max-width: 1380px;
  margin: 0 auto;
  gap: 44px;
  padding: 56px 3vw 18px 3vw;
  min-height: 590px;
  box-sizing: border-box;
}

.mockup-slider-side,
.big-slider {
  flex: 0 0 60%;
  width: 60%;
  max-width: 820px;
  aspect-ratio: 1/1;
  border-radius: 35px;
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  box-shadow: 0 8px 34px -12px #e6a57e21;
}
@media (max-width: 1100px) {
  .mockup-highlight-wrap {
    flex-direction: column;
    gap: 26px;
    align-items: center;
    padding: 30px 0 12px;
  }
  .mockup-slider-side,
  .big-slider {
    width: 96vw;
    max-width: 98vw;
    border-radius: 18px;
  }
}

@media (max-width: 600px) {
  .mockup-slider-side,
  .big-slider {
    width: 98vw;
    max-width: 98vw;
    border-radius: 12px;
    aspect-ratio: 1/1;
  }
  .mockup-highlight-wrap {
    padding: 7vw 0 4vw;
    gap: 14px;
  }
}

.mockup-slide-side {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.65s cubic-bezier(.71,.15,.21,1);
  will-change: transform;
}
.mockup-slide-side img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1 !important;
  object-fit: cover;
  border-radius: inherit;
  cursor: zoom-in;
  display: block;
  margin: 0;
  padding: 0;
}

.slider-prev-side,
.slider-next-side {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  background: #fff;
  color: var(--main);
  border: none;
  width: 54px; height: 54px;
  border-radius: 50%;
  font-size: 2.2rem;
  cursor: pointer;
  box-shadow: 0 2px 16px -7px #ceb28a52;
  opacity: 0.93;
  z-index: 9;
  transition: background .2s;
}
.slider-prev-side:hover,
.slider-next-side:hover {
  background: #f7eee5;
}
.slider-prev-side { left: 14px; }
.slider-next-side { right: 14px; }

.showcase-aside {
  flex: 1 1 0;
  min-width: 270px;
  max-width: 430px;
  display: flex;
  flex-direction: column;
  gap: 23px;
  justify-content: flex-start;
  align-items: flex-start;
  box-sizing: border-box;
}
@media (max-width: 1100px) {
  .showcase-aside { max-width: 98vw; }
}

.showcase-quote-ornament {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 14px;
  background: #FFF8EE;
  border-radius: 12px;
  padding: 9px 16px;
  box-shadow: 0 2px 12px -6px #e6a57e23;
}
.quote-icon {
  font-size: 2.4rem;
  color: var(--main);
  line-height: 1;
  font-family: serif;
  opacity: 0.8;
}
.quote-text {
  color: #9f5e1e;
  font-size: 1.06rem;
  font-style: italic;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.highlight-stack {
  display: flex;
  flex-direction: column;
  gap: 13px;
  margin-top: 4px;
  width: 100%;
}
.highlight-cell {
  background: #fff;
  box-shadow: 0 2px 16px -10px #e6a57e15;
  border-radius: 14px;
  padding: 18px 14px;
  display: flex;
  align-items: center;
  gap: 15px;
  font-size: 1.09rem;
  font-weight: 500;
  color: #222;
  transition: box-shadow .16s, transform .15s;
}
.highlight-icon {
  font-size: 1.38rem;
  color: var(--main);
  margin-right: 2px;
  flex-shrink: 0;
  filter: grayscale(0.14) brightness(1.1);
}
.highlight-cell:hover {
  box-shadow: 0 8px 24px -8px #e6a57e27;
  transform: translateY(-2px) scale(1.021);
}
@media (max-width: 700px) {
  .highlight-cell {
    padding: 11px 8px;
    font-size: .93rem;
  }
}

.mockup-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(18,16,14,0.92);
  align-items: center;
  justify-content: center;
  transition: opacity .18s;
  animation: fadeIn .18s;
}
.mockup-lightbox img {
  max-width: 92vw;
  max-height: 92vh;
  border-radius: 25px;
  box-shadow: 0 6px 44px -16px #fff9;
  border: 8px solid #fff3;
  animation: zoomPop .22s cubic-bezier(.54,.1,.23,1);
}
@keyframes zoomPop {
  from { transform: scale(.84); opacity:0; }
  to   { transform: none;    opacity:1; }
}
.mockup-lightbox-close {
  position: fixed;
  top: 31px; right: 41px;
  color: #fff;
  font-size: 2.3rem;
  cursor: pointer;
  text-shadow: 0 2px 14px #222b;
  transition: color .12s;
  z-index: 2100;
}
.mockup-lightbox-close:hover {
  color: var(--main);
}

/* Panel container */
.info-panel-wide{
  width:100%;
  max-width:1300px;
  margin:64px auto 0;
  background:#fff;
  box-shadow:0 4px 44px -18px #e6a57e23;
  border-radius:24px;
  padding:46px clamp(16px,6vw,64px) 30px;
  font-size:1.12rem;
  box-sizing:border-box;
}

/* Tabs */
.info-tabs-wide{
  display:flex;
  gap:12px;
  margin-bottom:22px;
  flex-wrap:wrap;                 /* wrap bila sempit */
}
.info-tab-btn-wide{
  background:none;
  border:none;
  font-weight:700;
  color:#b97d45;
  font-size:clamp(.98rem,1.6vw,1.19rem);
  padding:10px 22px;
  border-radius:22px;
  cursor:pointer;
  opacity:.76;
  transition:background .12s,color .13s;
  flex:0 0 auto;
}
.info-tab-btn-wide.active,
.info-tab-btn-wide:hover{
  background:#e6a57e18;
  color:var(--main);
  opacity:1;
}

/* Tab content */
.info-tab-content-wide{
  display:none;
  opacity:0;
  transition:opacity .32s;
  font-size:clamp(.96rem,1.4vw,1.14rem);
  color:#2c2925;
  line-height:1.85;
  background:#fff;
  border-radius:14px;
  padding:22px clamp(14px,3.5vw,22px) 16px;
  box-shadow:0 4px 18px -8px #e6a57e13;
  border-left:4px solid var(--main);
  margin-bottom:14px;
  position:relative;
  z-index:1;
  overflow-wrap:anywhere;         /* cegah overflow teks */
}
.info-tab-content-wide.active{ display:block; opacity:1; animation:fadeTabIn .41s; }
.info-tab-content-wide p{ margin:0 0 11px; letter-spacing:.01em; }
.info-tab-content-wide strong{
  color:var(--accent);
  font-weight:700;
  background:#FFF5E6;
  border-radius:2.5px;
  padding:0 3px;
}

/* --- COLOR PICKER --- */
.color-picker-block{ margin:0 0 28px; padding:0; background:none; }
.color-picker-label{
  font-size:1.05rem;
  font-weight:700;
  color:#b97d45;                  /* sebelumnya putih → tak terlihat di panel putih */
  margin:10px 0 14px;
  letter-spacing:.03em;
}

/* wrapper + nav */
.color-picker-gallery-wrap{
  display:flex;
  align-items:center;
  width:100%;
  gap:8px;
  background:none;
}
.color-picker-nav{
  background:#fcf8f2;
  color:#e6a57e;
  border:none;
  border-radius:50%;
  width:40px; height:40px;
  font-size:1.6rem;
  cursor:pointer;
  box-shadow:0 1px 8px -3px #e6a57e16;
  transition:background .13s;
  display:flex; align-items:center; justify-content:center;
  flex:0 0 auto;
}
.color-picker-nav:disabled{ opacity:.45; cursor:not-allowed; }

/* grid responsif: auto-fit menyesuaikan lebar */
.color-picker-gallery{
  flex:1 1 auto;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(84px, 1fr));
  gap:18px 20px;
  width:100%;
  min-width:0;
  box-sizing:border-box;
}

/* item */
.color-picker-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  width:100%;
  padding:14px 6px 12px;
  border-radius:14px;
  background:#fff;
  border:none;
  box-shadow:0 2px 20px -13px #e6a57e19;
  cursor:pointer;
  transition:outline .22s, box-shadow .21s, background .19s;
  outline:none;
  min-height:110px;
  font-family:inherit;
}
.color-picker-item:focus-visible,
.color-picker-item.selected,
.color-picker-item:hover{
  outline:3px solid #E6A57E; outline-offset:2px;
  box-shadow:0 8px 34px -11px #e6a57e23; background:#fcf9f4; z-index:1;
}
.color-picker-item.selected{ outline:3px solid #25d366; background:#f8fff5; }

.color-picker-circle{
  width:70px; height:70px;
  border-radius:50%;
  background:var(--cpick,#e6a57e);
  margin-bottom:10px;
  box-shadow:0 3px 14px -5px #e6a57e18;
  position:relative; overflow:hidden;
}
.color-picker-circle::after{
  content:""; position:absolute; left:14%; top:12%;
  width:55%; height:26%; background:rgba(255,255,255,.35);
  border-radius:60% 50% 70% 60%; filter:blur(2px); transform:rotate(-18deg);
  pointer-events:none;
}
.color-picker-name{
  font-size:.98rem; color:#B97D45; font-weight:600; text-align:center;
  max-width:92px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  line-height:1.15; margin-bottom:1px; letter-spacing:.02em;
}
.color-picker-hex{ font-size:.72rem; color:#b3a086; margin-top:1px; letter-spacing:.03em; }

.color-picker-check{
  display:none; position:absolute; top:12px; right:12px;
  background:#25d366; color:#fff; font-size:1rem; border-radius:50%;
  width:22px; height:22px; line-height:22px; text-align:center; font-weight:bold;
  box-shadow:0 2px 8px -2px #25d3663d;
}
.color-picker-item.selected .color-picker-check{ display:block; }

/* Selected chip */
.color-picker-selected{
  margin-top:18px;
  display:flex; align-items:center; gap:12px;
  font-size:1.02rem;
  padding:14px 18px;
  border-radius:12px;
  background:#fff;
  box-shadow:0 2px 20px -10px #e6a57e33;
  min-height:52px; max-width:100%;
  border-left:6px solid var(--cpick,#da976d); border-top:2px solid #fff;
}
.color-picker-selected-label{
  color:#b97d45; font-weight:700; margin-right:6px; font-size:1rem;
}
.color-picker-selected-chip{
  display:flex; align-items:center; gap:10px;
  background:#fff8ee; border-radius:10px;
  border:2px solid var(--cpick,#e6a57e); color:#b97d45; font-weight:700;
  font-size:1.02rem; padding:8px 14px 8px 10px;
  box-shadow:0 2px 8px -5px #e6a57e24;
  max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.color-picker-selected-chip .circle{
  width:24px; height:24px; border-radius:50%; background:var(--cpick,#e6a57e);
  box-shadow:0 2px 10px -3px #e6a57e22; position:relative; flex:0 0 auto;
}
.color-picker-selected-chip .circle::after{
  content:""; position:absolute; left:18%; top:16%; width:50%; height:26%;
  background:rgba(255,255,255,.32); border-radius:55% 55% 60% 60%;
  filter:blur(1.5px); transform:rotate(-17deg);
}

/* ===== Breakpoints ===== */
@media (max-width:900px){
  .info-panel-wide{ padding:34px 4vw 24px; border-radius:16px; }
  .info-tabs-wide{ gap:8px; }
  .color-picker-gallery{ gap:16px 18px; grid-template-columns:repeat(auto-fit, minmax(72px,1fr)); }
  .color-picker-circle{ width:58px; height:58px; }
  .color-picker-name{ font-size:.92rem; max-width:78px; }
}

@media (max-width:700px){
  /* tombol tab full di 2 kolom bila perlu */
  .info-tab-btn-wide{ flex:1 1 calc(50% - 6px); text-align:center; padding:10px 14px; }
  .info-tab-content-wide{ padding:14px 4vw 10px; border-radius:10px; line-height:1.7; }

  .color-picker-gallery-wrap{ gap:6px; }
  .color-picker-nav{ width:34px; height:34px; font-size:1.3rem; }
  .color-picker-gallery{ gap:14px 14px; grid-template-columns:repeat(auto-fit, minmax(64px,1fr)); }
  .color-picker-item{ min-height:96px; padding:10px 4px 9px; }
  .color-picker-circle{ width:46px; height:46px; margin-bottom:8px; }
  .color-picker-name{ font-size:.86rem; max-width:66px; }
  .color-picker-hex{ font-size:.64rem; }
  .color-picker-selected{ padding:10px 3.5vw; gap:9px; border-radius:8px; }
  .color-picker-selected-chip{ font-size:.96rem; padding:6px 10px 6px 8px; }
}

@media (max-width:480px){
  .info-tabs-wide{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .info-tab-btn-wide{ flex:0 0 auto; }
  .color-picker-gallery{ grid-template-columns:repeat(auto-fit, minmax(58px,1fr)); gap:12px; }
  .color-picker-circle{ width:40px; height:40px; }
  .color-picker-name{ font-size:.82rem; max-width:60px; }
}

@keyframes fadeTabIn { from{opacity:0;} to{opacity:1;} }
@keyframes fadeIn    { from{opacity:0;} to{opacity:1;} }

.action-bar-sticky {
  position: sticky;
  bottom: 0; left: 0; right: 0;
  background: #fff;
  border-radius: 18px 18px 0 0;
  box-shadow: 0 -2px 30px -6px #ceb28a22;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 15px 22px 13px 24px;
  margin: 60px auto 0;
  max-width: 720px;
  flex-wrap: wrap;
  z-index: 40;
}
.action-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.action-headline {
  font-size: 1.12rem;
  font-weight: 600;
  color: var(--main);
}
.action-sub {
  font-size: .99rem;
  color: #B8C0A6;
}
.btn-primary.action-wa {
  background: #25D366;
  color: #fff;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  padding: 13px 30px 13px 18px;
  font-size: 1.12rem;
  cursor: pointer;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 11px;
  box-shadow: 0 2px 20px -6px #24d36633;
  transition: background .18s;
}
.btn-primary.action-wa:hover {
  background: #21bb5d;
}
.wa-icon {
  width: 21px; height: 21px;
  display: inline-block;
  vertical-align: middle;
  margin-right: 2px;
}

/* Section wrapper */
.serupa-section-related{
  max-width:1300px;
  margin:0 auto;
  padding:52px 6vw 34px;
  box-sizing:border-box;
}

/* Header */
.related-header{
  display:flex; align-items:center; justify-content:center;
  gap:15px; margin-bottom:16px; text-align:center;
}
.related-header .sparkle-icon{ font-size:1.6rem; color:var(--main); opacity:.9; }
.related-header h2{
  margin:0; font-size:clamp(1.05rem,2.2vw,1.28rem);
  font-weight:800; color:var(--accent); letter-spacing:.04em;
}

/* Carousel wrap */
.related-carousel-wrap{
  position:relative;
  display:flex; align-items:center; gap:12px;
}

/* Nav buttons */
.related-carousel-nav{
  background:#fff; border:1.6px solid #e6a57e55; color:#e6a57e;
  font-size:2rem; border-radius:50%; width:40px; height:40px;
  cursor:pointer; transition:background .18s, border .16s, opacity .2s, transform .15s;
  box-shadow:0 2px 8px -2px rgba(230,165,126,.12);
  flex:0 0 auto; z-index:2;
}
.related-carousel-nav:hover{ background:#fff3e3; }
.related-carousel-nav:disabled{ opacity:.35; cursor:default; }

/* Track */
.serupa-carousel{
  display:flex; gap:18px; overflow-x:auto;
  scroll-snap-type:x mandatory; scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch; scrollbar-width:none; width:100%;
}
.serupa-carousel::-webkit-scrollbar{ display:none; }

/* Card (default tablet/desktop) */
.serupa-card-related{
  background:var(--card); border-radius:var(--radius); box-shadow:var(--shadow);
  overflow:hidden; position:relative; display:flex; flex-direction:column; justify-content:flex-start;
  scroll-snap-align:center; scroll-margin:12px;
  min-width:32%; max-width:32%;
}
.serupa-card-link{ display:flex; flex-direction:column; height:100%; text-decoration:none; }

/* Image block */
.serupa-img-tilt-related{
  position:relative; overflow:hidden;
  border-radius:calc(var(--radius) - 2px) calc(var(--radius) - 2px) 0 0;
  background:#f9f9fb; aspect-ratio:4/3;
}
.serupa-img-tilt-related img{ width:100%; height:100%; object-fit:cover; display:block; }

.favorite-badge{
  position:absolute; left:0; top:0;
  background:linear-gradient(90deg,#ffd6a5,#e6a57e);
  color:#a0661e; font-size:.95rem; font-weight:700;
  padding:4px 14px 4px 12px; border-radius:0 13px 18px 0;
  box-shadow:0 2px 8px -2px rgba(230,165,126,.13); z-index:1; letter-spacing:.02em;
}

/* Info */
.serupa-info-related{
  padding:12px 12px 14px 12px; display:flex; flex-direction:column; gap:8px;
}
.serupa-info-related h4{ font-size:1.02rem; color:var(--text); margin:0; font-weight:700; letter-spacing:.1px; }
.quick-info{ font-size:.9rem; color:#8b8f83; font-weight:500; line-height:1.4; }
.quick-view-btn{
  align-self:flex-start; background:#e6a57e12; color:var(--accent);
  font-size:.95rem; font-weight:700; border:none; border-radius:8px;
  padding:6px 14px; margin-top:4px; cursor:pointer;
  transition:background .15s,color .13s, transform .1s;
  box-shadow:0 1px 6px -2px rgba(230,165,126,.06);
}
.quick-view-btn:hover{ background:#e6a57e44; color:#fff; }

/* ================== MOBILE: FULLER CARD ================== */
@media (max-width:700px){
  /* jarak ke tepi layar sangat tipis */
  .serupa-section-related{ padding:12px 2px 12px; }

  /* tombol dibuat overlay agar tidak makan lebar */
  .related-carousel-wrap{ gap:0; }
  .related-carousel-nav{
    position:absolute; top:50%; transform:translateY(-50%);
    width:36px; height:36px; font-size:1.6rem; opacity:.9;
  }
  #relPrevBtn{ left:6px; }
  #relNextBtn{ right:6px; }

  /* track tanpa gap & tanpa padding, biar kartu bisa 100% */
  .serupa-carousel{ gap:0; padding:0; }

  /* kartu hampir selebar layar (2px gutter kiri/kanan) */
  .serupa-card-related{
    scroll-snap-align:start;
    min-width:calc(100vw - 8px);
    max-width:calc(100vw - 8px);
    margin:0 2px 0 2px;       /* gutter tipis */
    border-radius:16px;
  }

  /* gambar square/cover (atur ke contain jika ingin tanpa crop) */
  .serupa-img-tilt-related{ aspect-ratio:1/1; }
  .serupa-img-tilt-related img{ object-fit:cover; }
}

/* ≥600px: 2 kartu */
@media (min-width:600px){
  .serupa-card-related{ min-width:48vw; max-width:48vw; }
  .serupa-img-tilt-related{ aspect-ratio:4/3; }
}

/* ≥900px: 3 kartu */
@media (min-width:900px){
  .serupa-card-related{ min-width:32%; max-width:32%; }
  .serupa-carousel{ gap:22px; }
}

/* ≥1200px: 4 kartu */
@media (min-width:1200px){
  .serupa-card-related{ min-width:23.5%; max-width:23.5%; }
}