/* ======================================================================
   Productlayouts (product card) — Cohort 6 (Sterling Editorial — luxe monochrome)
   Ported from design-library T6 (public/productlayouts/t6.html).
   Cohort identity: Playfair Display serif title, 4:5 portrait media,
   monochrome ink-on-cream palette, hairline border-on-hover only, sharp
   corners (2px), discount chip top-left, feature badge BOTTOM-left,
   visual ★★★★★ rating with ink fill, hairline-divider CTA stack with
   uppercase tracked buttons. Italic struck-through old price.
   Bootstrap variables threaded for body/border/danger; ink/cream tones
   kept hardcoded for cohort identity.
   ====================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700&display=swap');

.productlayouts-6-card {
    --pl6-bg: #f8f7f4;
    --pl6-surface: var(--bs-body-bg, #ffffff);
    --pl6-ink: var(--bs-body-color, #14181c);
    --pl6-ink-soft: var(--bs-secondary-color, #6a6e75);
    --pl6-line: var(--bs-border-color, #d8d4cd);
    --pl6-accent: #1a1d22;
    --pl6-cream: #ece8df;
    --pl6-danger: var(--bs-danger, #b13a2a);

    position: relative;
    background: transparent;
    border: 1px solid transparent;
    border-radius: 2px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: border-color .3s ease, transform .35s ease;
}
.productlayouts-6-card:hover {
    border-color: var(--pl6-line);
    transform: translateY(-2px);
}

/* SIGNATURE: 4:5 portrait media frame */
.productlayouts-6-media {
    position: relative;
    display: block;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: var(--pl6-cream);
    border-radius: 2px;
    text-decoration: none;
}
.productlayouts-6-img,
.productlayouts-6-img-primary,
.productlayouts-6-img-secondary {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity .55s ease, transform .8s ease;
}
.productlayouts-6-img-secondary { opacity: 0; }

.productlayouts-6-card-swap:has(.productlayouts-6-img-secondary):hover .productlayouts-6-img-primary {
    opacity: 0;
    transform: scale(1.04);
}
.productlayouts-6-card-swap:has(.productlayouts-6-img-secondary):hover .productlayouts-6-img-secondary {
    opacity: 1;
    transform: scale(1.04);
}
.productlayouts-6-card:not(.productlayouts-6-card-swap):hover .productlayouts-6-img-primary,
.productlayouts-6-card-swap:not(:has(.productlayouts-6-img-secondary)):hover .productlayouts-6-img-primary {
    transform: scale(1.04);
}

/* ---------- Discount chip (top-left, sharp ink rectangle) ---------- */
.productlayouts-6-discount-chip {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 2;
    background: var(--pl6-ink);
    color: #fff;
    padding: 5px 10px;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    border-radius: 0;
    line-height: 1.1;
}

/* ---------- Status badge (stacks below discount when both present) ---------- */
.productlayouts-6-status-badge {
    position: absolute;
    left: 14px;
    z-index: 2;
    background: rgba(255,255,255,0.96);
    color: var(--pl6-ink);
    padding: 4px 10px;
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    border: 1px solid var(--pl6-line);
    border-radius: 0;
    line-height: 1.1;
}
.productlayouts-6-card:has(.productlayouts-6-discount-chip) .productlayouts-6-status-badge { top: 46px; }
.productlayouts-6-card:not(:has(.productlayouts-6-discount-chip)) .productlayouts-6-status-badge { top: 14px; }
.productlayouts-6-status-badge.is-pre,
.productlayouts-6-status-badge.is-coming { background: var(--pl6-cream); color: var(--pl6-ink); border-color: var(--pl6-ink); }
.productlayouts-6-status-badge.is-out    { background: var(--pl6-line);  color: var(--pl6-ink-soft); border-color: var(--pl6-ink-soft); }

/* ---------- Feature badge (BOTTOM-left in media — Sterling signature) ---------- */
.productlayouts-6-feature-badge {
    position: absolute;
    bottom: 14px;
    left: 14px;
    z-index: 2;
    background: rgba(255,255,255,0.96);
    color: var(--pl6-ink);
    padding: 5px 10px;
    font-size: .65rem;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    border: none;
    border-radius: 0;
    line-height: 1.1;
}

/* ---------- Quick actions (top-right column) ---------- */
.productlayouts-6-quick {
    position: absolute;
    top: 14px;
    right: 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 3;
    opacity: 0;
    transform: translateX(8px);
    transition: opacity .25s ease, transform .25s ease;
}
.productlayouts-6-card:hover .productlayouts-6-quick {
    opacity: 1;
    transform: translateX(0);
}
@media (max-width: 575.98px) {
    .productlayouts-6-quick { opacity: 1; transform: none; }
}
.productlayouts-6-quick-btn {
    width: 34px;
    height: 34px;
    flex-shrink: 0;
    border-radius: 999px;
    background: rgba(255,255,255,0.95);
    border: 1px solid var(--pl6-line);
    color: var(--pl6-ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    line-height: 0;
    text-decoration: none;
    transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.productlayouts-6-quick-btn:hover {
    background: var(--pl6-ink);
    color: #fff;
    border-color: var(--pl6-ink);
}
.productlayouts-6-quick-btn > svg,
.productlayouts-6-quick-btn > a > svg { display: block; }

/* Wishlist heart — toggled by wishlist.js via aria-pressed. */
.productlayouts-6-quick-btn .product-wishlist-heart-outline { display: block; }
.productlayouts-6-quick-btn .product-wishlist-heart-filled  { display: none; color: var(--bs-danger, var(--pl6-danger)); }
.productlayouts-6-quick-btn[aria-pressed="true"] .product-wishlist-heart-outline { display: none; }
.productlayouts-6-quick-btn[aria-pressed="true"] .product-wishlist-heart-filled  { display: block; }
.product-wishlist-btn[aria-pressed="true"] {
    background: var(--pl6-ink);
    color: var(--pl6-cream);
    border-color: var(--pl6-ink);
}

/* ---------- Body ---------- */
.productlayouts-6-body {
    padding: 14px 0 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1 1 auto;
}
.productlayouts-6-brand {
    font-size: .66rem;
    font-weight: 600;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--pl6-ink-soft);
    text-decoration: none;
    align-self: flex-start;
}
.productlayouts-6-brand:hover { color: var(--pl6-ink); }

.productlayouts-6-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.3;
    margin: 0;
    color: var(--pl6-ink);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.6em;
}
.productlayouts-6-title a {
    color: inherit;
    text-decoration: none;
    transition: color .2s ease;
}
.productlayouts-6-title a:hover { color: var(--pl6-ink-soft); }

/* Visual ★★★★★ rating with ink fill */
.productlayouts-6-rating {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .72rem;
    color: var(--pl6-ink-soft);
}
.productlayouts-6-stars {
    font-size: 0.92rem;
    line-height: 1;
    letter-spacing: 2px;
    background: linear-gradient(90deg, var(--pl6-ink) var(--rating, 100%), #cfc9bc var(--rating, 100%));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* ---------- Price (serif new + italic struck old) ---------- */
.productlayouts-6-price {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin-top: 4px;
    flex-wrap: wrap;
}
.productlayouts-6-price-from {
    font-size: .7rem;
    color: var(--pl6-ink-soft);
    font-weight: 500;
    letter-spacing: .1em;
    text-transform: uppercase;
}
.productlayouts-6-price-new {
    font-family: 'Playfair Display', Georgia, serif;
    color: var(--pl6-ink);
    font-size: 1.1rem;
    font-weight: 600;
}
.productlayouts-6-price-old {
    color: var(--pl6-ink-soft);
    font-size: .85rem;
    text-decoration: line-through;
    font-style: italic;
}

/* ---------- Social proof line ---------- */
.productlayouts-6-social-proof {
    margin: 4px 0 0;
    font-size: .68rem;
    color: var(--pl6-ink-soft);
    letter-spacing: .08em;
    text-transform: uppercase;
}

/* ---------- CTAs (hairline-divider stack + uppercase tracked) ---------- */
.productlayouts-6-cta {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--pl6-line);
}
.productlayouts-6-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 38px;
    padding: 0 14px;
    font-size: .72rem;
    font-weight: 600;
    border-radius: 0;
    line-height: 1.1;
    border: 1px solid var(--pl6-ink);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: .18em;
    cursor: pointer;
    white-space: nowrap;
    transition: background .25s ease, color .25s ease;
}
.productlayouts-6-btn-outline {
    background: transparent;
    color: var(--pl6-ink);
}
.productlayouts-6-btn-outline:hover {
    background: var(--pl6-ink);
    color: var(--pl6-cream);
}
.productlayouts-6-btn-primary {
    background: var(--pl6-ink);
    color: var(--pl6-cream);
}
.productlayouts-6-btn-primary:hover {
    background: var(--pl6-ink-soft);
    color: var(--pl6-cream);
}
.productlayouts-6-btn-disabled {
    background: var(--pl6-line);
    color: var(--pl6-ink-soft);
    border-color: var(--pl6-ink-soft);
    cursor: default;
}

@media (max-width: 575.98px) {
    .productlayouts-6-title { font-size: 1rem; }
    .productlayouts-6-discount-chip { font-size: .6rem; padding: 3px 7px; letter-spacing: .08em; }
    .productlayouts-6-feature-badge { font-size: .58rem; padding: 3px 7px; letter-spacing: .08em; }
    .productlayouts-6-btn { letter-spacing: .12em; font-size: .68rem; height: 36px; }
}
