/**
 * NovaFolio – Mini-Cart Slide-in Panel
 *
 * @package NovaFolio
 * @since   1.3.0
 */

/* ── Overlay ────────────────────────────────────────────────────────── */

.nvf-mini-cart {
    position: fixed;
    inset: 0;
    z-index: 10000;
    pointer-events: none;
    visibility: hidden;
    transition: visibility 0s .35s;
}

.nvf-mini-cart--open {
    pointer-events: auto;
    visibility: visible;
    transition-delay: 0s;
}

.nvf-mini-cart__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .45);
    opacity: 0;
    transition: opacity .3s ease;
}

.nvf-mini-cart--open .nvf-mini-cart__overlay {
    opacity: 1;
}

/* ── Panel ──────────────────────────────────────────────────────────── */

.nvf-mini-cart__panel {
    position: absolute;
    top: 0;
    right: 0;
    width: 380px;
    max-width: 90vw;
    height: 100%;
    background: var(--nvf-bg, #fff);
    color: var(--nvf-text, #222);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    visibility: hidden;
    transition: transform .35s cubic-bezier(.4, 0, .2, 1), visibility 0s .35s;
    box-shadow: -4px 0 20px rgba(0, 0, 0, .1);
}

/* Offset for WP admin bar */
.admin-bar .nvf-mini-cart__panel {
    padding-top: 32px;
}
@media screen and (max-width: 782px) {
    .admin-bar .nvf-mini-cart__panel {
        padding-top: 46px;
    }
}

.nvf-mini-cart--open .nvf-mini-cart__panel {
    transform: translateX(0);
    visibility: visible;
    transition-delay: 0s, 0s;
}

/* ── Header ─────────────────────────────────────────────────────────── */

.nvf-mini-cart__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 20px;
    border-bottom: 1px solid var(--nvf-border, #e5e5e5);
    flex-shrink: 0;
}

.nvf-mini-cart__title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: .02em;
    text-transform: uppercase;
}

/* Close button (X) */
.nvf-mini-cart__close {
    position: relative;
    width: 28px;
    height: 28px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

.nvf-mini-cart__close span {
    position: absolute;
    left: 4px;
    top: 50%;
    width: 20px;
    height: 2px;
    background: currentColor;
    border-radius: 1px;
}

.nvf-mini-cart__close span:first-child { transform: rotate(45deg); }
.nvf-mini-cart__close span:last-child  { transform: rotate(-45deg); }

/* ── Body (scrollable items) ────────────────────────────────────────── */

.nvf-mini-cart__body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 12px 20px;
}

.nvf-mini-cart__items {
    list-style: none;
    margin: 0;
    padding: 0;
}

.nvf-mini-cart__item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--nvf-border, #eee);
    position: relative;
}

.nvf-mini-cart__item:last-child {
    border-bottom: none;
}

.nvf-mini-cart__thumb {
    flex: 0 0 60px;
    width: 60px;
}

.nvf-mini-cart__thumb img {
    width: 60px;
    height: 60px;
    object-fit: cover;
    border-radius: 4px;
    display: block;
}

.nvf-mini-cart__info {
    flex: 1 1 0;
    min-width: 0;
    padding-right: 42px;
}

.nvf-mini-cart__name {
    display: block;
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 4px;
    line-height: 1.35;
}

.nvf-mini-cart__name a {
    color: inherit;
    text-decoration: none;
}

.nvf-mini-cart__name a:hover {
    text-decoration: underline;
}

.nvf-mini-cart__qty-price {
    font-size: 13px;
    color: var(--nvf-text-muted, #777);
}

.nvf-mini-cart__remove {
    position: absolute;
    top: 8px;
    right: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    padding: 0;
    background: rgba(17, 24, 39, 0.82) !important;
    border: 1px solid rgba(17, 24, 39, 0.82) !important;
    border-radius: 50% !important;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    color: #fff !important;
    box-sizing: border-box;
    appearance: none;
    -webkit-appearance: none;
    transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.nvf-mini-cart__remove:hover,
.nvf-mini-cart__remove:focus-visible {
    background: rgba(17, 24, 39, 0.96) !important;
    border-color: rgba(17, 24, 39, 0.96) !important;
    color: #fff !important;
    box-shadow: 0 8px 18px rgba(17, 24, 39, 0.18);
    transform: translateY(-1px);
}

.nvf-mini-cart__remove:focus-visible {
    outline: 2px solid rgba(17, 24, 39, 0.18);
    outline-offset: 2px;
}

/* ── Empty state ────────────────────────────────────────────────────── */

.nvf-mini-cart__empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--nvf-text-muted, #999);
    font-size: 14px;
}

/* ── Footer (subtotal + buttons) ────────────────────────────────────── */

.nvf-mini-cart__footer {
    flex-shrink: 0;
    border-top: 1px solid var(--nvf-border, #e5e5e5);
    padding: 16px 20px 20px;
}

.nvf-mini-cart__subtotal {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 14px;
}

.nvf-mini-cart__buttons {
    display: flex;
    gap: 10px;
}

.nvf-mini-cart__btn {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    border-radius: var(--nvf-woo-shop-button-radius, var(--nvf-btn-radius, 4px));
    text-decoration: none !important;
    border-bottom: 0 !important;
    transition: background .2s, color .2s, transform .2s;
    cursor: pointer;
}

.nvf-mini-cart__btn--cart {
    background: var(--nvf-woo-shop-button-bg, var(--nvf-color-button-bg, #222));
    color: var(--nvf-woo-shop-button-text, var(--nvf-color-button-text, #fff)) !important;
}

.nvf-mini-cart__btn--cart:hover,
.nvf-mini-cart__btn--cart:focus-visible {
    background: var(--nvf-color-button-bg-hover, var(--nvf-woo-shop-button-bg, #111));
    color: var(--nvf-color-button-text-hover, var(--nvf-woo-shop-button-text, #fff)) !important;
    transform: translateY(-1px);
}

.nvf-mini-cart__btn--checkout {
    background: var(--nvf-woo-single-button-bg, var(--nvf-color-accent, #4f46e5));
    color: var(--nvf-woo-single-button-text, var(--nvf-color-on-accent, #fff)) !important;
}

.nvf-mini-cart__btn--checkout:hover,
.nvf-mini-cart__btn--checkout:focus-visible {
    background: var(--nvf-woo-single-button-bg, var(--nvf-color-accent, #4f46e5));
    color: var(--nvf-woo-single-button-text, var(--nvf-color-on-accent, #fff)) !important;
    opacity: .88;
    transform: translateY(-1px);
}

/* ── Body scroll lock ───────────────────────────────────────────────── */

body.nvf-mini-cart-open {
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════════
   WooCommerce – Empty Cart Block
   Classes: .wp-block-woocommerce-empty-cart-block
   ═══════════════════════════════════════════════════════════════════ */

.wp-block-woocommerce-empty-cart-block {
    max-width: var(--nvf-container-content, 1200px);
    margin: 0 auto;
    padding: clamp(40px, 5vw, 80px) var(--nvf-layout-padding-x, 32px);
}

/* ── Empty-cart heading (icon + text) ──────────────────────────────── */
.wp-block-woocommerce-empty-cart-block .wc-block-cart__empty-cart__title {
    font-size: clamp(1.4rem, 2.5vw, 2rem);
    font-weight: 700;
    letter-spacing: .02em;
    color: var(--nvf-color-headings, #1a1a1a);
    margin-bottom: 2rem;
}

/* ── Dots separator ────────────────────────────────────────────────── */
.wp-block-woocommerce-empty-cart-block .wp-block-separator.is-style-dots {
    border: none;
    text-align: center;
    color: var(--nvf-color-muted, #aaa);
    opacity: .5;
    margin: 0 auto 2.5rem;
    max-width: 320px;
}

/* ── "Nouveau dans la boutique" sub-heading ────────────────────────── */
.wp-block-woocommerce-empty-cart-block .wp-block-heading:not(.wc-block-cart__empty-cart__title) {
    font-size: clamp(1.05rem, 1.6vw, 1.35rem);
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--nvf-color-headings, #1a1a1a);
    margin-bottom: 1.75rem;
}

/* ── Product grid ──────────────────────────────────────────────────── */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__products {
    display: grid;
    grid-template-columns: repeat(var(--nvf-empty-cart-cols, 4), 1fr);
    gap: 1.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

@media (max-width: 1024px) {
    .wp-block-woocommerce-empty-cart-block .wc-block-grid__products {
        --nvf-empty-cart-cols: 3;
    }
}

@media (max-width: 640px) {
    .wp-block-woocommerce-empty-cart-block .wc-block-grid__products {
        --nvf-empty-cart-cols: 2;
    }
}

@media (max-width: 400px) {
    .wp-block-woocommerce-empty-cart-block .wc-block-grid__products {
        --nvf-empty-cart-cols: 1;
    }
}

/* ── Product card ──────────────────────────────────────────────────── */

/* WooCommerce Blocks injects width:calc(25%‑16px) on each li — reset it
   so the grid column controls the width instead. */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__products .wc-block-grid__product {
    width: 100% !important;
    max-width: none !important;
    flex-basis: auto !important;
    flex-shrink: 0;
}

.wp-block-woocommerce-empty-cart-block .wc-block-grid__product {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--nvf-border, rgba(0,0,0,.08));
    border-radius: var(--nvf-radius-card, 8px);
    overflow: hidden;
    transition: transform .3s ease, box-shadow .3s ease;
}

.wp-block-woocommerce-empty-cart-block .wc-block-grid__product:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 32px rgba(0,0,0,.09);
}

/* Product link / image area */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-image {
    overflow: hidden;
    aspect-ratio: 1 / 1;
    background: var(--nvf-surface-alt, #f5f5f5);
}

.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .45s cubic-bezier(.22,1,.36,1);
}

.wp-block-woocommerce-empty-cart-block .wc-block-grid__product:hover .wc-block-grid__product-image img {
    transform: scale(1.05);
}

/* On sale badge */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-onsale {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 2;
    background: var(--nvf-color-accent, #e74c3c);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 3px 9px;
    border-radius: 999px;
    pointer-events: none;
}

/* Relative positioning for badge */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-link {
    position: relative;
}

/* Title */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-title {
    padding: .6rem 1rem .2rem;
    font-size: .9rem;
    font-weight: 600;
    line-height: 1.3;
    color: var(--nvf-color-headings, #1a1a1a);
}

/* Price */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-price {
    padding: 0 1rem .65rem;
    font-size: .85rem;
    color: var(--nvf-color-muted, #666);
}

.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-price del {
    opacity: .55;
    margin-right: .3em;
}

.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-price ins {
    text-decoration: none;
    font-weight: 600;
    color: var(--nvf-color-headings, #1a1a1a);
}

/* Hide "Voir le panier" link that appears after AJAX add-to-cart
   (the mini-cart panel opening is sufficient feedback) */
.wp-block-woocommerce-empty-cart-block .added_to_cart.wc-forward {
    display: none !important;
}

/* Add to cart button */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-add-to-cart {
    margin-top: auto;
    padding: 0 1rem 1rem;
}

.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-add-to-cart .wp-block-button__link {
    display: block;
    width: 100%;
    text-align: center;
    font-size: .78rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 10px 16px;
    border-radius: var(--nvf-radius-pill, 999px);
    transition: background .2s ease, color .2s ease, transform .2s ease;
}

/* ── Accessibility: reduce motion ───────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .nvf-mini-cart,
    .nvf-mini-cart__overlay,
    .nvf-mini-cart__panel,
    .nvf-mini-cart__remove,
    .nvf-mini-cart__btn {
        transition-duration: 1ms !important;
    }
    .nvf-mini-cart--open .nvf-mini-cart__panel {
        transform: none;
    }
    .nvf-mini-cart__btn--cart:hover,
    .nvf-mini-cart__btn--cart:focus-visible,
    .nvf-mini-cart__btn--checkout:hover,
    .nvf-mini-cart__btn--checkout:focus-visible {
        transform: none;
    }
}
