/**
 * File: css/commerce-product-1.0.1.css
 * Version: 1.0.1
 * Date: 2026-03-07
 * Description: Drupal Commerce product detail page styling for drivenracing.com
 *
 * Actual DOM order inside article.commerce-product:
 *   1. .field--name-field-images > .field__items > .field__item (x7)
 *      - first = hero image
 *      - second = thumbnail
 *      - rest hidden
 *   2. .product--variation-field--variation_title__60441  (variation title)
 *   3. .field--name-body                                  (description)
 *   4. .product--variation-field--variation_price__60441  (price)
 *   5. .field--name-variations                            (add-to-cart form)
 *
 * Layout goal (matches D7):
 *   - Hero image: full width
 *   - Title below hero (dark, not blue)
 *   - Thumbnail floated left, description wraps right
 *   - Price + qty + Add to Cart below
 *
 * Change log:
 * - 2026-03-07 (v1.0.1) Fix selectors to match actual DOM structure.
 *                        Variation title uses product--variation-field class.
 *                        Images wrapper is .field__items not direct children.
 * - 2026-03-07 (v1.0.0) Initial release.
 */

/* ============================================================
   CSS VARIABLES
   ============================================================ */
article.commerce-product {
  --pd-blue:      #3a7fc1;
  --pd-blue-dark: #2d6399;
  --pd-text:      #333;
  --pd-label:     #555;
  --pd-border:    #ddd;
}

/* ============================================================
   PAGE WRAPPER
   ============================================================ */
article.commerce-product {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 0 40px;
  color: #333;
}

/* ============================================================
   IMAGES
   ============================================================ */
article.commerce-product .field--name-field-images {
  margin: 0;
}

/* Hide all field__items by default */
article.commerce-product .field--name-field-images .field__items .field__item {
  display: none;
}

/* First image = full-width hero */
article.commerce-product .field--name-field-images .field__items .field__item:first-child {
  display: block;
}

article.commerce-product .field--name-field-images .field__items .field__item:first-child img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 520px;
  object-fit: cover;
  object-position: center top;
}

/* Second image = thumbnail, floated left beside description */
article.commerce-product .field--name-field-images .field__items .field__item:nth-child(2) {
  display: block;
  float: left;
  width: 200px;
  margin: 0 24px 16px 20px;
}

article.commerce-product .field--name-field-images .field__items .field__item:nth-child(2) img {
  width: 100%;
  height: auto;
  display: block;
  border: 1px solid var(--pd-border);
}

/* ============================================================
   TITLE (variation title field)
   ============================================================ */
article.commerce-product [class*="variation_title"] {
  padding: 16px 20px 8px;
  font-size: 20px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #222 !important;
}

article.commerce-product [class*="variation_title"] * {
  color: #222 !important;
  font-size: inherit !important;
}

/* ============================================================
   BODY
   ============================================================ */
article.commerce-product .field--name-body {
  padding: 0 20px;
  font-size: 14px;
  line-height: 1.65;
  color: #333;
  overflow: hidden; /* BFC — text wraps around floated thumbnail */
}

article.commerce-product .field--name-body p {
  margin: 0 0 10px;
}

/* ============================================================
   PRICE
   ============================================================ */
article.commerce-product [class*="variation_price"] {
  clear: both;
  padding: 16px 20px 0;
  font-size: 22px;
  font-weight: 700;
  color: #222 !important;
  border-top: 1px solid var(--pd-border);
  margin-top: 16px;
}

article.commerce-product [class*="variation_price"] * {
  color: #222 !important;
}

/* ============================================================
   VARIATIONS / ADD TO CART FORM
   ============================================================ */
article.commerce-product .field--name-variations {
  padding: 14px 20px 0;
  clear: both;
}

/* Attribute widgets (color/size if present) */
article.commerce-product .attribute-widgets {
  margin-bottom: 12px;
}

/* Quantity row */
article.commerce-product .field--name-quantity {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

article.commerce-product .field--name-quantity label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--pd-label);
  margin: 0;
}

article.commerce-product .field--name-quantity input[type="number"] {
  width: 60px;
  padding: 7px 8px;
  border: 1px solid var(--pd-border);
  border-radius: 3px;
  font-size: 14px;
  text-align: center;
  -moz-appearance: textfield;
}

article.commerce-product .field--name-quantity input[type="number"]::-webkit-inner-spin-button,
article.commerce-product .field--name-quantity input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
}

/* Add to Cart button */
article.commerce-product .form-actions .button--add-to-cart,
article.commerce-product .form-actions input[type="submit"],
article.commerce-product .form-actions button[type="submit"] {
  background: var(--pd-blue) !important;
  color: #fff !important;
  border: none;
  padding: 10px 28px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: 3px;
  cursor: pointer;
  transition: background 0.15s ease;
}

article.commerce-product .form-actions .button--add-to-cart:hover,
article.commerce-product .form-actions input[type="submit"]:hover,
article.commerce-product .form-actions button[type="submit"]:hover {
  background: var(--pd-blue-dark) !important;
}

/* "More" link */
article.commerce-product [class*="variation__layout_builder"] {
  display: inline-block;
  margin-top: 10px;
  font-size: 12px;
  color: var(--pd-blue);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 640px) {
  article.commerce-product .field--name-field-images .field__items .field__item:nth-child(2) {
    float: none;
    width: 160px;
    margin: 12px 0;
  }
}
