/* ============================================================
   VentoBags — urun-detay.css
   Ürün detay sayfasına özel stiller.
   Bu dosya style.css'i miras alır, onunla çakışmaz.
   style.css'in altına eklemek isterseniz bu bloğu yapıştırın.
   ============================================================ */


/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb {
  /* Navbar'ın altından başlar */
  padding-top: calc(var(--navbar-height) + var(--space-md));
  padding-bottom: var(--space-sm);
  background-color: var(--color-cream);
}

.breadcrumb__inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;      /* Uzun sayfa adları mobilde kırılsın */
  gap: 0.35rem;
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
}

.breadcrumb__inner a {
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.breadcrumb__inner a:hover {
  color: var(--color-rose);
}

.breadcrumb__inner [aria-current="page"] {
  color: var(--color-brown-dark);
  font-weight: 500;
  /* Uzun isimlerin taşmasını engelle */
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 40ch;
}

.breadcrumb__sep {
  color: var(--color-border);
  flex-shrink: 0;
}


/* ============================================================
   ÜRÜN SHOWCASE ANA LAYOUT
   ============================================================ */
.pd-main {
  /* Navbar yüksekliği breadcrumb'da hesaplandı, burada sıfır */
  min-height: 100vh;
}

.pd-showcase {
  padding-bottom: var(--space-3xl);
  background-color: var(--color-cream);
}

.pd-showcase__inner {
  display: grid;
  /* İki eşit kolon: sol galeri, sağ bilgi */
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: start;
  padding-top: var(--space-lg);
}


/* ============================================================
   SOL KOLON: GALERİ
   ============================================================ */
.pd-gallery {
  /* Sticky: sağ kolon scroll ederken görsel sabit kalır */
  position: sticky;
  top: calc(var(--navbar-height) + var(--space-md));
  /* Tüm sol kolonu kaplasın */
  width: 100%;
}

/* -----------------------------------------------
   ANA GÖRSEL SAHNESI (Zoom alanı)
   ----------------------------------------------- */
.pd-gallery__stage {
  position: relative;
  width: 100%;
  /* Kare oran — çanta fotoğrafları için ideal */
  aspect-ratio: 1 / 1;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background-color: var(--color-beige);
  cursor: crosshair;
  /* Zoom aktifken imleci değiştirme */
  user-select: none;
  -webkit-user-select: none;
  /* Lens, stage sınırlarının dışına taşabilir */
  /* Not: overflow:hidden lens'i kesmemeli, ama
     taşmaları gizlemesi için bırakıyoruz.
     Lens stage'in tam içinde konumlanır. */
}

/* Mobilde crosshair kaldır */
@media (max-width: 768px) {
  .pd-gallery__stage {
    cursor: default;
  }
}

.pd-gallery__main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  /* Görsel değişiminde yumuşak geçiş */
  transition: opacity 0.25s ease;
  /* Zoom sırasında görsel kaymasını engelle */
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-user-drag: none;
}

/* Zoom ipucu */
.pd-gallery__zoom-hint {
  position: absolute;
  bottom: var(--space-sm);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0.4em 0.9em;
  background: rgba(250,247,242,0.88);
  backdrop-filter: blur(8px);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  white-space: nowrap;
  pointer-events: none;
  /* Zoom başlayınca JS ile hide edilir */
  transition: opacity 0.3s ease;
}

/* Mobilde ipucu gizle */
@media (max-width: 768px) {
  .pd-gallery__zoom-hint {
    display: none;
  }
}


/* -----------------------------------------------
   BÜYÜTEÇ LENSİ
   ----------------------------------------------- */
.pd-zoom-lens {
  position: absolute;
  /* Boyutlar JS'te de kullanılan LENS_SIZE sabiti ile eşleşmeli */
  width: 160px;
  height: 160px;
  border-radius: var(--radius-sm);

  /* Kare keskin kenarlı çerçeve */
  border: 2px solid rgba(255,255,255,0.9);
  box-shadow:
    0 0 0 1px rgba(78,56,40,0.18),       /* Dış çerçeve */
    0 8px 32px rgba(78,56,40,0.22),      /* Derinlik gölgesi */
    inset 0 0 0 1px rgba(255,255,255,0.4); /* İç parlaklık */

  /* Arka plan: büyütülmüş görsel (JS tarafından ayarlanır) */
  background-repeat: no-repeat;

  /* Başlangıçta gizli */
  display: none;

  /* Diğer elementlerin üzerinde */
  z-index: 10;

  /* İmlecin lens üzerinde olması için */
  pointer-events: none;

  /* Lens belirme animasyonu */
  animation: lensAppear 0.15s ease both;
}

@keyframes lensAppear {
  from { opacity: 0; transform: scale(0.92); }
  to   { opacity: 1; transform: scale(1); }
}


/* -----------------------------------------------
   THUMBNAIL SATIRI
   ----------------------------------------------- */
.pd-gallery__thumbs {
  display: flex;
  gap: var(--space-xs);
  margin-top: var(--space-sm);
  /* Mobilde yatay scroll */
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  /* Kaydırma çubuğunu gizle */
  scrollbar-width: none;
  padding-bottom: 2px; /* Alt gölge kesilmesin */
}

.pd-gallery__thumbs::-webkit-scrollbar {
  display: none;
}

.pd-gallery__thumb {
  flex-shrink: 0;
  width: 76px;
  height: 76px;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 2px solid transparent;
  padding: 0;
  cursor: pointer;
  transition: border-color var(--transition-base), opacity var(--transition-fast);
  background: none;
}

.pd-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
}

.pd-gallery__thumb:hover {
  opacity: 0.85;
}

.pd-gallery__thumb.active {
  border-color: var(--color-brown-dark);
}

/* Mobilde thumblar daha küçük */
@media (max-width: 480px) {
  .pd-gallery__thumb {
    width: 62px;
    height: 62px;
  }
}


/* ============================================================
   SAĞ KOLON: ÜRÜN BİLGİLERİ
   ============================================================ */
.pd-info {
  padding-top: var(--space-xs);
}

.pd-info__category {
  display: block;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-rose);
  margin-bottom: var(--space-xs);
}

.pd-info__title {
  font-family: var(--font-serif);
  font-size: clamp(var(--fs-xl), 3.5vw, var(--fs-3xl));
  font-weight: 500;
  line-height: 1.15;
  color: var(--color-brown-dark);
  margin-bottom: var(--space-sm);
  /* Uzun başlıklar taşmasın */
  overflow-wrap: break-word;
  word-break: break-word;
}

/* Değerlendirme satırı */
.pd-info__rating {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  margin-bottom: var(--space-md);
  flex-wrap: wrap;
}

.pd-stars {
  display: flex;
  gap: 1px;
  color: var(--color-rose);
  font-size: var(--fs-md);
  line-height: 1;
}

.pd-stars--sm {
  font-size: var(--fs-sm);
  color: var(--color-rose);
}

.pd-star { color: var(--color-border); }
.pd-star.filled { color: var(--color-rose); }
.pd-star.half {
  position: relative;
  color: var(--color-border);
}
.pd-star.half::before {
  content: '★';
  position: absolute;
  left: 0;
  width: 50%;
  overflow: hidden;
  color: var(--color-rose);
}

.pd-info__review-count {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
}

/* Fiyat blok */
.pd-info__price-block {
  display: flex;
  align-items: baseline;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-bottom: var(--space-md);
}

.pd-info__price {
  font-family: var(--font-serif);
  font-size: clamp(var(--fs-xl), 3vw, var(--fs-2xl));
  font-weight: 700;
  color: var(--color-brown-dark);
  letter-spacing: -0.02em;
}

.pd-info__price-note {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  font-weight: 500;
}

/* Ayraç çizgisi */
.pd-divider {
  border: none;
  border-top: 1px solid var(--color-border);
  margin-block: var(--space-md);
}

/* Ürün açıklaması */
.pd-info__desc {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: 1.85;
  margin-bottom: var(--space-md);
  /* Uzun kelimeler taşmasın */
  overflow-wrap: break-word;
  word-break: break-word;
}

/* Özellik listesi */
.pd-info__features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: var(--space-md);
}

.pd-info__features li {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  /* Flex çocukların kırılmasını sağla */
  flex-wrap: wrap;
}

.pd-info__features li svg {
  flex-shrink: 0;
  color: var(--color-rose);
}

/* Seçenek grubu (renk, adet) */
.pd-info__option-group {
  margin-bottom: var(--space-md);
}

.pd-info__option-label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-brown-dark);
  margin-bottom: var(--space-xs);
}

.pd-info__option-label strong {
  font-weight: 700;
  color: var(--color-rose);
}

/* Renk swatch'ları */
.pd-color-swatches {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.pd-swatch {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: var(--swatch-color);
  border: 2px solid transparent;
  box-shadow: 0 0 0 1px var(--color-border);
  cursor: pointer;
  transition: all var(--transition-base);
  flex-shrink: 0;
}

.pd-swatch:hover {
  transform: scale(1.15);
}

.pd-swatch.active {
  border-color: var(--color-brown-dark);
  box-shadow: 0 0 0 1px var(--color-brown-dark);
}

/* Adet seçici */
.pd-quantity {
  display: inline-flex;
  align-items: center;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  overflow: hidden;
  /* Buton metninin overflow taşmaması için */
  flex-shrink: 0;
}

.pd-quantity__btn {
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-lg);
  font-weight: 300;
  color: var(--color-brown-dark);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background-color var(--transition-fast);
  /* Metin seçilmesin */
  user-select: none;
  -webkit-user-select: none;
  flex-shrink: 0;
}

.pd-quantity__btn:hover {
  background-color: var(--color-beige);
}

.pd-quantity__val {
  min-width: 36px;
  text-align: center;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--color-brown-dark);
}

/* Aksiyon butonları satırı */
.pd-info__actions {
  display: flex;
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
  flex-wrap: wrap;     /* Mobilde alt satıra geçer */
}

.pd-add-to-cart {
  flex: 1;
  /* En az genişlik: buton metnini kesmez */
  min-width: 160px;
  gap: 0.5rem;
  /* Aktif/loading durumu */
  transition: all var(--transition-base);
}

.pd-add-to-cart.loading {
  opacity: 0.7;
  pointer-events: none;
}

.pd-add-to-cart.success {
  background-color: #5a8a65;
}

/* Favoriler butonu */
.pd-wishlist-btn {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-brown-dark);
  background: transparent;
  cursor: pointer;
  flex-shrink: 0;
  transition: all var(--transition-base);
}

.pd-wishlist-btn:hover,
.pd-wishlist-btn.active {
  border-color: var(--color-rose);
  color: var(--color-rose);
  background-color: var(--color-rose-light);
}

.pd-wishlist-btn.active svg {
  fill: var(--color-rose);
}

/* Sepete eklendi toast */
.pd-cart-toast {
  font-size: var(--fs-xs);
  font-weight: 500;
  color: #5a8a65;
  min-height: 1.2em;
  transition: opacity 0.3s ease;
}

/* Kargo bilgi satırları */
.pd-info__shipping {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.pd-shipping-item {
  display: flex;
  align-items: flex-start;  /* Uzun metin için üstten hizala */
  gap: 0.6rem;
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  flex-wrap: wrap;
}

.pd-shipping-item svg {
  flex-shrink: 0;
  color: var(--color-tan);
  margin-top: 1px;
}

.pd-shipping-item span {
  overflow-wrap: break-word;
  word-break: break-word;
}


/* ============================================================
   ÜRÜN DETAY SEKMELERİ
   ============================================================ */
.pd-details {
  padding-block: var(--space-2xl);
  background-color: var(--color-warm-white);
  border-top: 1px solid var(--color-border);
}

.pd-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-xl);
  /* Mobilde yatay scroll */
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.pd-tabs::-webkit-scrollbar {
  display: none;
}

.pd-tab {
  padding: var(--space-sm) var(--space-lg);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-text-muted);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  white-space: nowrap;  /* Sekme başlıkları tek satırda */
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

.pd-tab:hover {
  color: var(--color-brown-dark);
}

.pd-tab.active {
  color: var(--color-brown-dark);
  border-bottom-color: var(--color-brown-dark);
  font-weight: 600;
}

.pd-tab-panel {
  animation: tabFadeIn 0.3s ease both;
}

@keyframes tabFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.pd-tab-content {
  max-width: 720px;
}

.pd-tab-content h3 {
  font-family: var(--font-serif);
  font-size: var(--fs-lg);
  font-weight: 500;
  color: var(--color-brown-dark);
  margin-bottom: var(--space-sm);
  margin-top: var(--space-md);
}

.pd-tab-content h3:first-child {
  margin-top: 0;
}

.pd-tab-content p {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: 1.9;
  margin-bottom: var(--space-sm);
  overflow-wrap: break-word;
  word-break: break-word;
}

.pd-material-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-bottom: var(--space-md);
}

.pd-material-list li {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  padding-left: var(--space-md);
  position: relative;
  overflow-wrap: break-word;
  word-break: break-word;
}

.pd-material-list li::before {
  content: '–';
  position: absolute;
  left: 0;
  color: var(--color-tan);
}

/* Değerlendirme özeti */
.pd-review-summary {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-lg);
  background-color: var(--color-beige);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}

.pd-review-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
}

.pd-review-number {
  font-family: var(--font-serif);
  font-size: var(--fs-3xl);
  font-weight: 700;
  color: var(--color-brown-dark);
  line-height: 1;
}

/* Yorum kartları */
.pd-reviews {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.pd-review-card {
  padding: var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-cream);
}

.pd-review-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
  flex-wrap: wrap;
}

.pd-review-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background-color: var(--color-beige-mid);
  color: var(--color-brown-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: var(--fs-sm);
  flex-shrink: 0;
}

.pd-review-card__header div:nth-child(2) {
  flex: 1;
  min-width: 0;  /* Flex shrink için */
}

.pd-review-card__header strong {
  display: block;
  font-size: var(--fs-sm);
  color: var(--color-brown-dark);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pd-review-card__header time {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
}

.pd-review-card p {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: 1.75;
  overflow-wrap: break-word;
  word-break: break-word;
}


/* ============================================================
   İLGİLİ ÜRÜNLER
   ============================================================ */
.pd-related {
  padding-block: var(--space-3xl);
  background-color: var(--color-cream);
}

/* İlgili ürünler grid'inde max 3 kolon */
.pd-related__grid {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  max-width: 960px;
  margin-inline: auto;
}


/* ============================================================
   RESPONSİVE — Tablet (1024px altı)
   ============================================================ */
@media (max-width: 1024px) {
  .pd-showcase__inner {
    /* İki kolonu eşitleme: görseller için biraz küçült */
    gap: var(--space-lg);
  }

  /* Sticky gallery tablet'te daha az yapışık */
  .pd-gallery {
    position: static;
  }
}


/* ============================================================
   RESPONSİVE — Mobil (768px altı)
   Ürün görseli üstte, bilgiler altta
   ============================================================ */
@media (max-width: 768px) {
  .pd-showcase__inner {
    /* TEK KOLON — görsel üstte, bilgi altta */
    grid-template-columns: 1fr;
    gap: var(--space-md);
    padding-top: var(--space-sm);
  }

  .pd-gallery {
    position: static;   /* Sticky mobilde kaldırıldı */
    width: 100%;
  }

  .pd-gallery__stage {
    /* Mobilde kare değil 4:3 oran daha iyi görünür */
    aspect-ratio: 4 / 3;
    border-radius: var(--radius-lg);
    /* Mobilde cursor normal */
    cursor: default;
  }

  .pd-info__title {
    font-size: var(--fs-xl);
  }

  .pd-info__price {
    font-size: var(--fs-xl);
  }

  .pd-tabs {
    gap: 0;
  }

  .pd-tab {
    padding: var(--space-sm) var(--space-md);
    font-size: var(--fs-xs);
  }

  .pd-review-card__header {
    gap: var(--space-xs);
  }
}


/* ============================================================
   RESPONSİVE — Küçük Mobil (480px altı)
   ============================================================ */
@media (max-width: 480px) {
  /* Breadcrumb taşmalarını önle */
  .breadcrumb__inner {
    font-size: 11px;
  }

  .breadcrumb__inner [aria-current="page"] {
    max-width: 24ch;
  }

  .pd-gallery__stage {
    aspect-ratio: 3 / 2;
    border-radius: var(--radius-md);
  }

  .pd-info__actions {
    gap: var(--space-xs);
  }

  .pd-add-to-cart {
    min-width: 0;     /* Küçük ekranlarda flex:1 yeterli */
    font-size: var(--fs-xs);
    padding: 0.85em 1.4em;
  }

  .pd-wishlist-btn {
    width: 46px;
    height: 46px;
  }

  .pd-review-summary {
    flex-direction: column;
    text-align: center;
    padding: var(--space-md);
  }

  .pd-related__grid {
    grid-template-columns: 1fr;
  }
}
