/* ═══════════════════════════════════════════════════════════════
   SINGLE PRODUCT PAGE 
   ═══════════════════════════════════════════════════════════════ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700&family=DM+Sans:wght@400;500;600&display=swap');

/* ─────────────────────────────────────────────
   1. PAGE WRAPPER — reset WooCommerce layout
───────────────────────────────────────────── */
body.single-product #primary.content-area,
body.single-product main#main.site-main {
  background: var(--c-bg) !important;
  font-family: var(--font-body) !important;
  padding: 0 !important;
  margin: 0 !important;
}

body.single-product .container {
  max-width: var(--max-w) !important;
  margin-inline: auto !important;
  padding-inline: var(--space-5) !important;
}

.tutorstarter-woocommerce {
  margin-top: 0 !important;
}
/* ─────────────────────────────────────────────
   2. PRODUCT CARD — the main two-column shell
───────────────────────────────────────────── */
body.single-product #product-389.product,
body.single-product div.product {
  display: grid !important;
  grid-template-columns: 300px 1fr !important;
  grid-template-rows: auto auto !important;
  gap: var(--space-6) !important;
  align-items: start !important;
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-md) !important;
  padding: var(--space-7) !important;
  overflow: visible !important;
}

/* ─────────────────────────────────────────────
   3. PRODUCT IMAGE / PLACEHOLDER
───────────────────────────────────────────── */
body.single-product div.product .woocommerce-product-gallery,
body.single-product div.product .woocommerce-product-gallery--without-images {
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: 80% !important;
  max-width: 300px !important;
  margin: 0 !important;
}

body.single-product div.product .woocommerce-product-gallery__wrapper {
  border-radius: var(--radius-md) !important;
  overflow: hidden !important;
  background: var(--c-bg) !important;
  border: 1px solid var(--c-border) !important;
  aspect-ratio: 4 / 5 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.single-product div.product .woocommerce-product-gallery__image--placeholder,
body.single-product div.product .woocommerce-product-gallery__image--placeholder img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: var(--radius-md) !important;
  opacity: 0.55 !important;
  filter: saturate(0) !important;
}

/* ─────────────────────────────────────────────
   4. SUMMARY / META COLUMN
───────────────────────────────────────────── */
body.single-product div.product .summary.entry-summary {
  grid-column: 2 !important;
  grid-row: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-4) !important;
  padding: 0 !important;
}

/* Product title */
body.single-product div.product h1.product_title {
  font-family: var(--font-display) !important;
  font-size: clamp(1.6rem, 3vw, 2.2rem) !important;
  font-weight: 700 !important;
  color: var(--c-title) !important;
  line-height: 1.15 !important;
  margin: 0 0 var(--space-2) !important;
  letter-spacing: -0.02em !important;
}

/* Price */
body.single-product div.product p.price,
body.single-product div.product .woocommerce-Price-amount.amount {
  font-family: var(--font-display) !important;
  font-size: 1.55rem !important;
  font-weight: 700 !important;
  color: var(--c-primary) !important;
  display: block !important;
  margin: 0 !important;
}

body.single-product div.product p.price bdi {
  letter-spacing: -0.01em !important;
}


/* ─────────────────────────────────────────────
   5. QUANTITY + ADD TO CART FORM
───────────────────────────────────────────── */
body.single-product div.product form.cart {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-3) !important;
  flex-wrap: wrap !important;
  margin: var(--space-2) 0 !important;
}

/* Quantity input */
body.single-product div.product form.cart .quantity {
  display: flex !important;
  align-items: center !important;
}

body.single-product div.product form.cart input.qty {
  width: 68px !important;
  height: 48px !important;
  border: 1.5px solid var(--c-border-strong) !important;
  border-radius: var(--radius-xs) !important;
  background: var(--c-bg) !important;
  color: var(--c-title) !important;
  font-family: var(--font-body) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  text-align: center !important;
  padding: 0 var(--space-2) !important;
  box-shadow: none !important;
  outline: none !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  appearance: none !important;
  -moz-appearance: textfield !important;
}

body.single-product div.product form.cart input.qty:focus {
  border-color: var(--c-primary) !important;
  box-shadow: var(--focus-ring) !important;
}

/* Add to cart button */
body.single-product div.product form.cart button.single_add_to_cart_button,
body.single-product div.product .cart button.button.alt {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-1) !important;
  height: 48px !important;
  padding: 0 var(--space-6) !important;
  background: var(--c-primary) !important;
  color: #fff !important;
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em !important;
  border: none !important;
  border-radius: var(--radius-xs) !important;
  cursor: pointer !important;
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.22) !important;
  transition: background 0.18s, box-shadow 0.18s, transform 0.12s !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}

body.single-product div.product form.cart button.single_add_to_cart_button:hover,
body.single-product div.product .cart button.button.alt:hover {
  background: var(--c-primary-dark) !important;
  box-shadow: 0 4px 16px rgba(37, 99, 235, 0.30) !important;
  transform: translateY(-1px) !important;
}

body.single-product div.product form.cart button.single_add_to_cart_button:active {
  transform: translateY(0) !important;
  box-shadow: var(--focus-ring) !important;
}

body.single-product div.product form.cart button.single_add_to_cart_button:focus-visible {
  outline: none !important;
  box-shadow: var(--focus-ring) !important;
}

/* ─────────────────────────────────────────────
   6. PRODUCT META (category)
───────────────────────────────────────────── */
body.single-product div.product .product_meta {
  margin-top: var(--space-2) !important;
  padding-top: var(--space-3) !important;
  border-top: 1px solid var(--c-border) !important;
  font-family: var(--font-body) !important;
  font-size: 0.82rem !important;
  color: var(--c-muted) !important;
}

body.single-product div.product .product_meta span {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
}

body.single-product div.product .product_meta a {
  color: var(--c-primary) !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  transition: color 0.15s !important;
}

body.single-product div.product .product_meta a:hover {
  color: var(--c-primary-dark) !important;
  text-decoration: underline !important;
}

/* ─────────────────────────────────────────────
   7. TABS SECTION
───────────────────────────────────────────── */
body.single-product div.product .woocommerce-tabs {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  margin-top: var(--space-2) !important;
  padding-top: var(--space-5) !important;
  border-top: 1px solid var(--c-border) !important;
}

/* Tab nav */
body.single-product div.product .woocommerce-tabs ul.tabs.wc-tabs {
  display: flex !important;
  gap: var(--space-1) !important;
  padding: 0 !important;
  margin: 0 0 var(--space-5) !important;
  list-style: none !important;
}

body.single-product div.product .woocommerce-tabs ul.tabs.wc-tabs li {
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
}

body.single-product div.product .woocommerce-tabs ul.tabs.wc-tabs li::before,
body.single-product div.product .woocommerce-tabs ul.tabs.wc-tabs li::after {
  display: none !important;
  content: none !important;
}

body.single-product div.product .woocommerce-tabs ul.tabs.wc-tabs li a {
  display: block !important;
  padding: var(--space-2) var(--space-4) !important;
  font-family: var(--font-body) !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  color: var(--c-muted) !important;
  text-decoration: none !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -2px !important;
  border-radius: var(--radius-xs) var(--radius-xs) 0 0 !important;
  transition: color 0.15s, border-color 0.15s, background 0.15s !important;
}

body.single-product div.product .woocommerce-tabs ul.tabs.wc-tabs li.active a {
  color: var(--c-primary) !important;
  font-weight: 600 !important;
  border-bottom-color: var(--c-primary) !important;
  background: transparent !important;
}

/* Tab panel */
body.single-product div.product .woocommerce-tabs .woocommerce-Tabs-panel {
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
}

body.single-product div.product .woocommerce-tabs .panel h2 {
  font-family: var(--font-display) !important;
  font-size: 1.05rem !important;
  font-weight: 600 !important;
  color: var(--c-title) !important;
  margin: 0 0 var(--space-3) !important;
}

body.single-product div.product .woocommerce-tabs .panel p,
body.single-product div.product .woocommerce-tabs .panel li {
  font-family: var(--font-body) !important;
  font-size: 0.92rem !important;
  line-height: 1.7 !important;
  color: var(--c-body) !important;
}

/* ─────────────────────────────────────────────
   8. REVIEWS
───────────────────────────────────────────── */
body.single-product div.product #reviews .woocommerce-Reviews-title {
  font-family: var(--font-display) !important;
  font-size: 1.05rem !important;
  font-weight: 600 !important;
  color: var(--c-title) !important;
  margin-bottom: var(--space-3) !important;
}

body.single-product div.product p.woocommerce-noreviews {
  font-family: var(--font-body) !important;
  font-size: 0.88rem !important;
  color: var(--c-muted) !important;
  background: var(--c-bg) !important;
  border: 1px dashed var(--c-border-strong) !important;
  border-radius: var(--radius-sm) !important;
  padding: var(--space-5) !important;
  text-align: center !important;
}

/* Review form */
body.single-product div.product #review_form .comment-reply-title {
  font-family: var(--font-display) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--c-title) !important;
  display: block !important;
  margin-bottom: var(--space-4) !important;
}

body.single-product div.product #review_form label {
  font-family: var(--font-body) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: var(--c-body) !important;
  display: block !important;
  margin-bottom: var(--space-1) !important;
}

body.single-product div.product #review_form textarea,
body.single-product div.product #review_form input[type="text"],
body.single-product div.product #review_form input[type="email"] {
  width: 100% !important;
  border: 1.5px solid var(--c-border-strong) !important;
  border-radius: var(--radius-xs) !important;
  padding: var(--space-3) var(--space-4) !important;
  font-family: var(--font-body) !important;
  font-size: 0.9rem !important;
  color: var(--c-title) !important;
  background: var(--c-bg) !important;
  box-shadow: none !important;
  outline: none !important;
  resize: vertical !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  box-sizing: border-box !important;
}

body.single-product div.product #review_form textarea:focus,
body.single-product div.product #review_form input:focus {
  border-color: var(--c-primary) !important;
  box-shadow: var(--focus-ring) !important;
  background: var(--c-surface) !important;
}

body.single-product div.product #review_form #submit.submit {
  display: inline-flex !important;
  align-items: center !important;
  height: 44px !important;
  padding: 0 var(--space-6) !important;
  background: var(--c-primary) !important;
  color: #fff !important;
  font-family: var(--font-body) !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  border: none !important;
  border-radius: var(--radius-xs) !important;
  cursor: pointer !important;
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.20) !important;
  transition: background 0.18s, box-shadow 0.18s !important;
}

body.single-product div.product #review_form #submit.submit:hover {
  background: var(--c-primary-dark) !important;
  box-shadow: 0 4px 14px rgba(37, 99, 235, 0.28) !important;
}

/* Star rating */
body.single-product div.product .stars a {
  color: var(--c-accent) !important;
  font-size: 1.1rem !important;
  transition: transform 0.1s !important;
}

body.single-product div.product .stars a:hover,
body.single-product div.product .stars a.active {
  transform: scale(1.15) !important;
}

/* ─────────────────────────────────────────────
   9. RESPONSIVE — tablet ≤ 860px
───────────────────────────────────────────── */
@media (max-width: 860px) {
  body.single-product #product-389.product,
  body.single-product div.product {
    grid-template-columns: 1fr !important;
    padding: var(--space-5) !important;
    gap: var(--space-5) !important;
  }

  body.single-product div.product .woocommerce-product-gallery,
  body.single-product div.product .woocommerce-product-gallery--without-images {
    max-width: 100% !important;
    width: 100% !important;
  }

  body.single-product div.product .woocommerce-product-gallery__wrapper {
    aspect-ratio: 16 / 9 !important;
  }

  body.single-product div.product .summary.entry-summary {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }

  body.single-product div.product .woocommerce-tabs {
    grid-column: 1 !important;
    grid-row: 3 !important;
  }
}

/* ─────────────────────────────────────────────
   10. RESPONSIVE — mobile ≤ 540px
───────────────────────────────────────────── */
@media (max-width: 540px) {
  body.single-product .container {
    padding-inline: var(--space-3) !important;
  }

  body.single-product #product-389.product,
  body.single-product div.product {
    padding: var(--space-4) !important;
    border-radius: var(--radius-md) !important;
    margin: var(--space-4) 0 !important;
  }

  body.single-product div.product h1.product_title {
    font-size: 1.4rem !important;
  }

  body.single-product div.product form.cart {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  body.single-product div.product form.cart .quantity,
  body.single-product div.product form.cart input.qty {
    width: 100% !important;
  }

  body.single-product div.product form.cart button.single_add_to_cart_button {
    width: 100% !important;
    justify-content: center !important;
  }

  body.single-product div.product .woocommerce-tabs ul.tabs.wc-tabs {
    gap: 0 !important;
  }

  body.single-product div.product .woocommerce-tabs ul.tabs.wc-tabs li a {
    padding: var(--space-2) var(--space-3) !important;
    font-size: 0.85rem !important;
  }
}

/* ─────────────────────────────────────────────
   11. REDUCED MOTION
───────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  body.single-product div.product * {
    transition: none !important;
    animation: none !important;
    transform: none !important;
  }
}