/**
 * Shopify Companion – Card styling (grid layout in pe-shop-grid.css).
 * Modern, polished look with refined typography and shadows.
 * Colors use Kadence Global Palette (var(--global-palette1)).
 */

/* Typography – modern system stack */
.pe-shop-root {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Card: refined radius, layered shadows, subtle border */
.pe-card,
.pe-product-card,
.pe-grid-card {
    border-radius: 12px;
    box-shadow:
        0 1px 3px rgba(0, 0, 0, 0.04),
        0 4px 12px rgba(0, 0, 0, 0.06),
        0 0 0 1px rgba(0, 0, 0, 0.03);
    overflow: hidden;
    background: var(--global-palette9, #fff);
    transition: box-shadow 0.35s ease, transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.pe-card:hover,
.pe-product-card:hover,
.pe-grid-card:hover {
    box-shadow:
        0 4px 12px rgba(0, 0, 0, 0.06),
        0 12px 32px rgba(0, 0, 0, 0.1),
        0 0 0 1px rgba(0, 0, 0, 0.04);
    transform: translateY(-6px);
}

.pe-card__image-wrap,
.pe-product-card__image-wrap,
.pe-grid-card__image-wrap {
    position: relative;
    padding-bottom: 100%;
    overflow: hidden;
    border-radius: 12px 12px 0 0;
    cursor: pointer;
    background: #f8f9fa;
}

/* Product Badge: top-left of image */
.pe-card__badges {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.pe-card__badge,
.pe-grid-card__badge {
    display: inline-block;
    min-width: 7.5em;
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-align: center;
    background: var(--global-palette9, #fff);
    color: var(--global-palette1, #2c6dff);
    border-radius: 4px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

a.pe-card__badge,
a.pe-grid-card__badge {
    text-decoration: none;
}
a.pe-card__badge:hover,
a.pe-grid-card__badge:hover {
    text-decoration: underline;
}

/* Financing Available – badge/button style, left-aligned */
.pe-card__financing {
    display: inline-block;
    padding: 0.35rem 0.65rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
    background: #22c55e;
    color: #fff;
    border-radius: 6px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
}
.pe-card__financing:hover {
    background: #16a34a;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}
.pe-card__actions,
.pe-grid-card__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

/* Quick View: appears only on hover */
.pe-card__quick-view {
    position: absolute;
    bottom: 0.75rem;
    left: 50%;
    transform: translateX(-50%) translateY(100%);
    z-index: 2;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--global-palette9, #fff);
    background: var(--global-palette1, #2c6dff);
    border-radius: 6px;
    text-decoration: none;
    opacity: 0;
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
}

.pe-card:hover .pe-card__quick-view {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* Hover zoom on product images */
.pe-card__image-wrap .pe-card__img,
.pe-product-card__image-wrap .pe-product-card__img,
.pe-grid-card__image-wrap .pe-card__img,
.pe-grid-card__image-wrap .pe-grid-card__img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.pe-card__image-wrap:hover .pe-card__img,
.pe-product-card__image-wrap:hover .pe-product-card__img,
.pe-grid-card__image-wrap:hover .pe-card__img,
.pe-grid-card__image-wrap:hover .pe-grid-card__img {
    transform: scale(1.07);
}

.pe-card__image-wrap .pe-card__img--placeholder,
.pe-product-card__image-wrap .pe-product-card__img--placeholder,
.pe-grid-card__image-wrap .pe-card__img--placeholder,
.pe-grid-card__image-wrap .pe-grid-card__img--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Zoom hint overlay on hover */
.pe-card__image-wrap::after,
.pe-grid-card__image-wrap::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, transparent 40%, rgba(0,0,0,0.03) 100%);
    opacity: 0;
    transition: opacity 0.35s ease;
    pointer-events: none;
}

.pe-card__image-wrap:hover::after,
.pe-grid-card__image-wrap:hover::after {
    opacity: 1;
}

/* Card main content (grid view: stacked, equal-height layout) */
.pe-card__main {
    padding: 0 1rem 1rem;
}

/* Equal-height: main grows, info flexes, price/actions align at bottom */
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-card__main,
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-grid-card__main {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-card__info,
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-grid-card__info {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

/* Header (title) grows to push bottom content down */
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-card__header,
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-grid-card__header {
    flex: 1;
}

/* Bottom section (excerpt, pricing, actions) stays at bottom */
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-card__bottom,
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-grid-card__bottom {
    flex-shrink: 0;
}

.pe-card__info {
    min-width: 0;
}

.pe-card__title,
.pe-product-card__title,
.pe-grid-card__title {
    font-size: 1.05rem;
    font-weight: 600;
    line-height: 1.35;
    margin: 0.85rem 0 0;
    padding: 0;
    letter-spacing: -0.01em;
}

.pe-card__price,
.pe-product-card__price,
.pe-grid-card__price {
    margin: 0.25rem 0 0;
    padding: 0;
}

/* Push pricing section to bottom of card */
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-card__pricing,
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-grid-card__pricing {
    margin-top: auto;
}

.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-card__price,
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-grid-card__price {
    margin-top: 0;
}

.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-card__actions,
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-grid-card__actions {
    flex-shrink: 0;
}

.pe-card__title a,
.pe-product-card__title a,
.pe-grid-card__title a {
    text-decoration: none;
    color: inherit;
    transition: color 0.2s ease;
}

.pe-card__title a:hover,
.pe-product-card__title a:hover,
.pe-grid-card__title a:hover {
    text-decoration: underline;
}

/* Price: large, bold, Kadence primary accent */
.pe-card__price,
.pe-product-card__price,
.pe-grid-card__price {
    color: var(--global-palette1, #2c6dff);
    font-weight: 700;
    font-size: 1.25rem;
    letter-spacing: -0.02em;
}

/* Sale price (red), was price (struck) */
.pe-card__price-sale,
.pe-grid-card__price-sale {
    color: #c0392b;
}

.pe-card__price-was,
.pe-grid-card__price-was {
    text-decoration: line-through;
    color: var(--global-palette5, #999);
    font-size: 0.9em;
    font-weight: 500;
}

/* Variant options – clickable pills */
.pe-card__variants,
.pe-grid-card__variants {
    margin: 0.35rem 0 0;
    padding: 0;
    font-size: 0.8rem;
    color: var(--global-palette5, #6c757d);
    line-height: 1.5;
}

.pe-card__variant-label,
.pe-grid-card__variant-label {
    font-weight: 500;
    margin-right: 0.25rem;
}

.pe-card__variant-pills {
    display: inline;
}

.pe-card__variant-opt,
.pe-grid-card__variant-opt {
    display: inline-block;
    margin: 0 0.25rem 0.25rem 0;
    padding: 0.2rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--global-palette3, #1b202c);
    background: #f0f0f1;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 4px;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.pe-card__variant-opt:hover,
.pe-grid-card__variant-opt:hover {
    background: #e8e8ea;
    border-color: var(--global-palette1, #2c6dff);
}

.pe-card__variant-opt.is-selected,
.pe-grid-card__variant-opt.is-selected {
    background: var(--global-palette1, #2c6dff);
    color: #fff;
    border-color: var(--global-palette1, #2c6dff);
}

.pe-card__btn,
.pe-card__btn--view {
    margin: 0.75rem 0 0;
    text-align: center;
}

.pe-card__actions {
    margin-top: 0.5rem;
}

.pe-card__buy {
    margin: 0.5rem 0 0;
    padding: 0;
}

/* Card buttons */
.pe-card__btn,
.pe-card__btn--view,
.pe-product-card__btn,
.pe-grid-card__btn {
    display: inline-block;
    padding: 0.55rem 1.1rem;
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none;
    transition: background-color 0.25s ease, color 0.25s ease, transform 0.2s ease;
}

.pe-card__btn:active,
.pe-grid-card__btn:active {
    transform: scale(0.98);
}

.pe-card__buy .pe-btn-buy,
.pe-grid-card__buy .pe-btn-buy,
.pe-card__buy .pe-btn-disabled,
.pe-grid-card__buy .pe-btn-disabled {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    font-size: 0.85rem;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    border-radius: 6px;
    width: 100%;
    box-sizing: border-box;
}

.pe-card__buy .pe-btn-buy,
.pe-grid-card__buy .pe-btn-buy {
    color: var(--global-palette9, #fff);
    background: var(--global-palette1, #2c6dff);
    border: none;
    cursor: pointer;
    transition: background-color 0.25s ease, color 0.25s ease, transform 0.2s ease;
}

.pe-card__buy .pe-btn-buy .pe-btn-buy__icon,
.pe-grid-card__buy .pe-btn-buy .pe-btn-buy__icon {
    flex-shrink: 0;
}

.pe-card__buy .pe-btn-buy:hover,
.pe-grid-card__buy .pe-btn-buy:hover {
    background: var(--global-palette2, #1a5ce8);
    color: var(--global-palette9, #fff);
}

.pe-card__buy .pe-btn-buy:active,
.pe-grid-card__buy .pe-btn-buy:active {
    transform: scale(0.98);
}

.pe-card__buy .pe-btn-disabled,
.pe-grid-card__buy .pe-btn-disabled {
    color: var(--global-palette5, #6c757d);
    background: var(--global-palette8, #e9ecef);
    cursor: not-allowed;
}

.pe-card__buy .pe-btn-disabled--oos,
.pe-grid-card__buy .pe-btn-disabled--oos {
    color: #4b5563;
    background: #d1d5db;
    font-weight: 600;
}

/* ==========================================================================
   LIGHTBOX – Click to zoom product image
   ========================================================================== */
.pe-lightbox {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.pe-lightbox.is-open {
    opacity: 1;
    visibility: visible;
}

.pe-lightbox__inner {
    position: relative;
    max-width: 90vw;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
}

.pe-lightbox__img {
    max-width: 100%;
    max-height: 75vh;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.pe-lightbox__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
}

.pe-lightbox__btn {
    padding: 0.6rem 1.25rem;
    border-radius: 8px;
    font-size: 0.95rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.25s ease, color 0.25s ease;
    border: none;
    cursor: pointer;
}

.pe-lightbox__btn--close {
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
}

.pe-lightbox__btn--close:hover {
    background: rgba(255, 255, 255, 0.25);
}

.pe-lightbox__btn--view {
    background: var(--global-palette1, #2c6dff);
    color: #fff;
}

.pe-lightbox__btn--view:hover {
    background: var(--global-palette2, #1a5ae6);
}

.pe-lightbox__close-icon {
    position: absolute;
    top: -2.5rem;
    right: 0;
    width: 36px;
    height: 36px;
    padding: 0;
    border: none;
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    line-height: 1;
    transition: background 0.25s ease;
}

.pe-lightbox__close-icon:hover {
    background: rgba(255, 255, 255, 0.25);
}

/* List view: horizontal card layout */
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card,
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card {
    display: grid;
    grid-template-columns: 200px 1fr auto;
    gap: 1.5rem;
    align-items: center;
}

.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__image-wrap,
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card__image-wrap {
    padding-bottom: 0;
    height: 200px;
    grid-row: 1 / -1;
}

.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__image-wrap .pe-card__img,
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__image-wrap .pe-card__img--placeholder,
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card__image-wrap .pe-grid-card__img {
    position: relative;
    height: 100%;
}

.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__main,
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card__main {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-start;
}

.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__info,
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card__info {
    flex: 1;
    min-width: 0;
}

.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__excerpt,
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card__excerpt {
    display: block !important;
    margin: 0.5rem 0 0;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--global-palette5, #6c757d);
}

.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__actions,
.pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card__actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.75rem;
}

/* Grid view: excerpt hidden by default */
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-card__excerpt,
.pe-shop-root .pe-shop-grid__inner:not(.pe-list-view) .pe-grid-card__excerpt {
    display: none;
}

/* List view: responsive – stack on narrow screens */
@media (max-width: 640px) {
    .pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card,
    .pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card {
        grid-template-columns: 1fr;
    }

    .pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__image-wrap,
    .pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card__image-wrap {
        height: 180px;
        grid-row: auto;
    }

    .pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-card__actions,
    .pe-shop-root .pe-shop-grid__inner.pe-list-view .pe-shop-grid__item .pe-grid-card__actions {
        flex-direction: row;
        align-items: center;
    }
}
