/* =============================================================
   HC Shop — WooCommerce Stylesheet  v1.0.0
   ============================================================= */

/* ── Product Card ─────────────────────────────────────────────────────── */
.hcs-product-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    border: 1.5px solid var(--gray-100);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: var(--transition);
    position: relative;
}
.hcs-product-card:hover {
    border-color: var(--gray-200);
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
}
.hcs-product-card--service { border-left: 3px solid var(--success); }
.hcs-product-card--out-of-stock { opacity: 0.72; }
.hcs-product-card--out-of-stock:hover { transform: none; }

/* Image */
.hcs-product-card__image-wrap {
    position: relative;
    overflow: hidden;
    aspect-ratio: 400 / 320;
    background: var(--gray-50);
}
.hcs-product-card__image {
    width: 100%; height: 100%;
    object-fit: contain;
    padding: 12px;
    transition: transform 0.35s ease;
    background: var(--white);
}
.hcs-product-card:hover .hcs-product-card__image { transform: scale(1.04); }

.hcs-product-card__badges {
    position: absolute; top: 12px; left: 12px;
    display: flex; flex-direction: column; gap: 6px; z-index: 2;
}
/* VD member pill — top-right corner of image */
.hcs-product-card__vd-pill {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--primary);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: var(--radius-full);
    line-height: 1.4;
    white-space: nowrap;
    letter-spacing: 0.3px;
}
.hcs-product-card__vd-pill i { font-size: 9px; }
.badge-vd { background: var(--primary); color: var(--white); }
.badge-sale { background: var(--primary-dark); color: var(--white); }
.badge-out-of-stock { background: var(--gray-200); color: var(--gray-600); }

.hcs-product-card__overlay {
    position: absolute; inset: 0;
    background: rgba(13, 27, 62, 0.52);
    display: flex; align-items: center; justify-content: center;
    gap: 10px;
    opacity: 0; transition: opacity 0.25s; z-index: 3;
}
.hcs-product-card:hover .hcs-product-card__overlay { opacity: 1; }
.hcs-product-card__overlay-btn {
    width: 42px; height: 42px;
    border-radius: 50%;
    background: var(--white); color: var(--navy);
    display: flex; align-items: center; justify-content: center;
    font-size: 15px;
    transform: translateY(8px); transition: var(--transition);
    padding: 0; text-decoration: none;
}
.hcs-product-card:hover .hcs-product-card__overlay-btn { transform: translateY(0); }
.hcs-product-card__overlay-btn:hover { background: var(--primary); color: var(--white); }
.hcs-product-card__overlay-btn--video { background: var(--navy); color: var(--white); }
.hcs-product-card__overlay-btn--video:hover { background: var(--primary); color: var(--white); }

.hcs-product-card__overlay-btn {
    background: var(--white); color: var(--navy);
    padding: 10px 20px; border-radius: var(--radius-full);
    font-size: 13px; font-weight: 600;
    display: flex; align-items: center; gap: 7px;
    transform: translateY(8px); transition: var(--transition);
}
.hcs-product-card:hover .hcs-product-card__overlay-btn { transform: translateY(0); }
.hcs-product-card__overlay-btn:hover { background: var(--primary); color: var(--white); }

/* Body */
.hcs-product-card__body {
    padding: 14px 16px 10px;
    flex: 1;
    display: flex; flex-direction: column; gap: 6px;
}
.hcs-product-card__category {
    font-size: 11px; font-weight: 700; color: var(--primary);
    text-transform: uppercase; letter-spacing: 0.8px;
}
.hcs-product-card__category:hover { color: var(--primary-dark); }
.hcs-product-card__title {
    font-size: 14px; font-weight: 600; line-height: 1.4; color: var(--navy); margin: 0;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.hcs-product-card__title-link { color: inherit; }
.hcs-product-card__title-link:hover { color: var(--primary); }

.hcs-product-card__specs {
    display: flex; flex-direction: column; gap: 4px;
    padding: 8px 10px;
    background: var(--gray-50); border-radius: var(--radius-sm); border: 1px solid var(--gray-100);
}
.hcs-product-card__spec { display: flex; justify-content: space-between; font-size: 12px; gap: 8px; }
.hcs-product-card__spec-label { color: var(--gray-500); flex-shrink: 0; }
.hcs-product-card__spec-value { color: var(--gray-800); font-weight: 500; text-align: right; }

/* Price */
.hcs-product-card__price-wrap { margin-top: auto; padding-top: 8px; }
.hcs-price { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; line-height: 1.3; }
.hcs-price__regular { font-size: 18px; font-weight: 700; color: var(--navy); }
.hcs-price__vd  { font-size: 20px; font-weight: 800; color: var(--primary-dark); }
.hcs-price__sale { font-size: 20px; font-weight: 800; color: var(--primary-dark); } /* see override below */
.hcs-price__original { font-size: 13px; color: var(--gray-400); text-decoration: line-through; }
.hcs-price__badge--vd {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 10px; font-weight: 700; letter-spacing: 0.4px;
    background: var(--primary-light); color: var(--primary-dark);
    padding: 3px 8px; border-radius: var(--radius-full);
}
.hcs-price__badge--sale {
    font-size: 11px; font-weight: 700;
    background: var(--danger-light); color: var(--danger);
    padding: 3px 8px; border-radius: var(--radius-full);
}
.hcs-price__service { font-size: 15px; font-weight: 700; color: var(--success); }
/* Video link moved to image overlay — hide if it appears in body */
.hcs-product-card__video-link { display: none !important; }

/* Footer */
.hcs-product-card__footer {
    padding: 12px 18px 16px;
    display: flex; align-items: center; gap: 10px;
    border-top: 1px solid var(--gray-100);
}
/* WooCommerce injects a "View cart" anchor (.added_to_cart.wc-forward) after the
   button on AJAX add. We hide it — our own toast notification handles this UX.
   Without this rule the link renders unstyled, wraps to 2 lines, and looks broken. */
.hcs-product-card__footer .added_to_cart.wc-forward,
.hcs-product-card__footer a.added_to_cart {
    display: none !important;
}
.hcs-product-card__btn { flex: 1; justify-content: center; font-size: 13px; padding: 10px 16px; }
.hcs-add-to-cart.is-loading { opacity: 0.75; pointer-events: none; }
.hcs-add-to-cart.is-added { background: var(--success) !important; border-color: var(--success) !important; }
.hcs-product-card__wishlist {
    width: 38px; height: 38px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm);
    color: var(--gray-400); font-size: 15px; background: transparent; cursor: pointer;
    transition: var(--transition);
}
.hcs-product-card__wishlist:hover,
.hcs-product-card__wishlist[aria-pressed="true"] {
    border-color: var(--danger); color: var(--danger); background: var(--danger-light);
}

/* ── Product Grid ──────────────────────────────────────────────────────── */
.hcs-product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 24px;
    align-items: start;
}
.hcs-product-grid.is-loading { opacity: 0.45; pointer-events: none; transition: opacity 0.2s; }
.hcs-no-products { grid-column: 1 / -1; text-align: center; padding: 60px 20px; color: var(--gray-500); }
.hcs-no-products i { font-size: 48px; color: var(--gray-200); display: block; margin-bottom: 16px; }

/* ── Shop Layout ───────────────────────────────────────────────────────── */
.hcs-shop-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 32px;
    align-items: start;
    padding: 32px 0 80px;
}
.hcs-shop-sidebar {
    position: sticky;
    top: calc(var(--header-h) + 20px);
    max-height: calc(100vh - var(--header-h) - 40px);
    overflow-y: auto;
    scrollbar-width: thin; scrollbar-color: var(--gray-200) transparent;
}

/* ── Filter ────────────────────────────────────────────────────────────── */
.hcs-filter { background: var(--white); border: 1.5px solid var(--gray-100); border-radius: var(--radius-lg); overflow: hidden; }
.hcs-filter__header { display: flex; justify-content: space-between; align-items: center; padding: 18px 20px; border-bottom: 1px solid var(--gray-100); }
.hcs-filter__title { font-size: 15px; font-weight: 700; color: var(--navy); display: flex; align-items: center; gap: 8px; }
.hcs-filter__clear { font-size: 12px; color: var(--primary); cursor: pointer; font-weight: 500; background: none; border: none; padding: 0; }
.hcs-filter__clear:hover { color: var(--primary-dark); }
.hcs-filter__section { padding: 18px 20px; border-bottom: 1px solid var(--gray-100); }
.hcs-filter__section:last-child { border-bottom: none; }
.hcs-filter__section-title { font-size: 12px; font-weight: 700; color: var(--gray-500); text-transform: uppercase; letter-spacing: 0.8px; margin-bottom: 14px; display: flex; justify-content: space-between; align-items: center; cursor: pointer; }
.hcs-filter__section-title i { font-size: 11px; transition: transform 0.2s; }
.hcs-filter__section.is-collapsed .hcs-filter__section-title i { transform: rotate(-90deg); }
.hcs-filter__section.is-collapsed .hcs-filter__options { display: none; }
.hcs-filter__options { display: flex; flex-direction: column; gap: 10px; }
.hcs-filter__option { display: flex; align-items: center; gap: 10px; cursor: pointer; font-size: 14px; color: var(--gray-700); }
.hcs-filter__option:hover { color: var(--primary); }
.hcs-filter__option input[type="checkbox"] { width: 16px; height: 16px; border-radius: 4px; accent-color: var(--primary); cursor: pointer; flex-shrink: 0; }
.hcs-filter__option-count { margin-left: auto; font-size: 11px; color: var(--gray-400); background: var(--gray-100); padding: 1px 7px; border-radius: var(--radius-full); }
.hcs-filter__price-inputs { display: flex; gap: 8px; align-items: center; margin-bottom: 14px; width: 100%; box-sizing: border-box; }
.hcs-filter__price-input { flex: 1; min-width: 0; width: 0; height: 36px; border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 0 8px; font-size: 13px; text-align: center; box-sizing: border-box; }
.hcs-filter__price-input:focus { outline: none; border-color: var(--primary); }
.hcs-filter__price-sep { color: var(--gray-400); font-size: 13px; flex-shrink: 0; }
.hcs-filter__apply { width: 100%; margin-top: 14px; }

/* ── Shop Toolbar ──────────────────────────────────────────────────────── */
.hcs-shop-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; flex-wrap: wrap; gap: 12px; }
.hcs-shop-toolbar__count { font-size: 14px; color: var(--gray-500); }
.hcs-shop-toolbar__count strong { color: var(--navy); }
.hcs-shop-toolbar__sort { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--gray-600); }
.hcs-shop-toolbar__sort select {
    height: 36px; padding: 0 30px 0 12px;
    border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm);
    font-size: 13px; font-family: var(--font); color: var(--gray-900); background: var(--white);
    cursor: pointer; appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 10px center;
}
.hcs-shop-toolbar__sort select:focus { outline: none; border-color: var(--primary); }
.hcs-filter-toggle { display: none; }

/* ── WooCommerce Overrides ─────────────────────────────────────────────── */
.woocommerce-breadcrumb,
.woocommerce-result-count,
.woocommerce-ordering { display: none; }
.woocommerce button.button, .woocommerce input.button, .woocommerce a.button {
    background: var(--primary) !important; color: var(--white) !important;
    border-radius: var(--radius) !important; font-family: var(--font) !important;
    font-weight: 600 !important; font-size: 14px !important;
    padding: 12px 24px !important; border: none !important; transition: var(--transition) !important;
}
.woocommerce button.button:hover, .woocommerce a.button:hover {
    background: var(--primary-dark) !important; transform: translateY(-1px) !important;
}
.woocommerce-message, .woocommerce-info {
    border-top-color: var(--primary) !important; background: var(--primary-light) !important; color: var(--navy) !important;
}
.woocommerce-error { border-top-color: var(--danger) !important; background: var(--danger-light) !important; }

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .hcs-shop-layout { grid-template-columns: 240px 1fr; gap: 24px; }
}
@media (max-width: 768px) {
    .hcs-shop-layout { grid-template-columns: 1fr; }
    .hcs-shop-sidebar {
        position: fixed; top: 0; left: -100%;
        width: min(320px, 90vw); height: 100vh; max-height: 100vh;
        background: var(--white); z-index: 1200; padding: 20px;
        box-shadow: var(--shadow-xl);
        transition: left 0.35s cubic-bezier(0.4, 0, 0.2, 1);
        overflow-y: auto;
    }
    .hcs-shop-sidebar.is-open { left: 0; }
    .hcs-filter-toggle { display: flex !important; }
    .hcs-product-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
}
@media (max-width: 480px) {
    .hcs-product-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
    .hcs-product-card__body { padding: 12px 14px 10px; }
    .hcs-product-card__footer { padding: 10px 14px 12px; }
    .hcs-product-card__specs { display: none; }
}

/* ── Skeleton loading cards (replaces faint overlay) ─────────────────────── */
.hcs-product-card--skeleton {
    pointer-events: none;
    cursor: default;
}
.hcs-product-card--skeleton:hover {
    transform: none;
    box-shadow: none;
    border-color: var(--gray-100);
}
.hcs-product-card--skeleton .hcs-product-card__image-wrap {
    background: var(--gray-100);
}

/* "Show more" link in filter */
.hcs-filter__show-more {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    color: var(--primary);
    font-weight: 500;
    margin-top: 8px;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: color 0.15s;
}
.hcs-filter__show-more:hover { color: var(--primary-dark); }

/* Filter section title keyboard focus */
.hcs-filter__section-title:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* ── EQUAL CARD HEIGHTS FIX ──────────────────────────────────────────────────
   The grid must use align-items:stretch so all cards in a row are the same height.
   The card uses flex-column so image stays on top, footer stays at bottom.
   This fixes the "card body/footer above image" bug too.
   ─────────────────────────────────────────────────────────────────────────── */
.hcs-product-grid {
    align-items: stretch; /* overrides the earlier align-items:start */
}

.hcs-product-card {
    height: 100%; /* fill the grid cell fully */
}

/* Brand + Model row on card */
.hcs-product-card__meta-row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    padding: 2px 0;
}
.hcs-product-card__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    line-height: 1.3;
    min-width: 0;
}
.hcs-product-card__meta-item + .hcs-product-card__meta-item::before {
    content: '·';
    color: var(--gray-300);
    margin-right: 3px;
}
.hcs-product-card__meta-label {
    color: var(--gray-400);
    font-weight: 500;
    flex-shrink: 0;
}
.hcs-product-card__meta-value {
    color: var(--gray-600);
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100px;
}
/* VD % tag inline — only visible to members/admins */
.hcs-product-card__vd-tag {
    display: inline-flex;
    align-items: center;
    font-size: 10px;
    font-weight: 700;
    color: var(--primary-dark);
    background: var(--primary-light);
    border: 1px solid rgba(232,99,26,.2);
    border-radius: var(--radius-full);
    padding: 1px 7px;
    white-space: nowrap;
}

/* ── Product card: star ratings — CSS-only, no text ─────────────────────── */
.hcs-product-card__rating {
    display: flex;
    align-items: center;
    gap: 5px;
    min-height: 16px;
}

/* CSS star widget — empty stars via ::before, filled via inner span width */
.hcs-star-rating {
    display: inline-block;
    position: relative;
    font-size: 16px;
    line-height: 1;
    /* 5 empty star outlines */
}
.hcs-star-rating::before {
    content: '★★★★★';
    color:#E8631A;
    letter-spacing: 1px;
}
/* Filled stars — clipped to the rating percentage */
.hcs-star-rating > span {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    white-space: nowrap;
}
.hcs-star-rating > span::before {
    content: '★★★★★';
    color:#E8631A;
    letter-spacing: 1px;
}
/* Empty state: faded all-empty stars */
.hcs-star-rating--empty::before {
    color: #ddd !important;
    
}

.hcs-product-card__rating-count {
    font-size: 11px;
    color: var(--gray-400);
    font-weight: 500;
    line-height: 1;
}


/* Remove any WooCommerce ::before content arrows that may still appear */
.woocommerce ul.products li.product .button::before,
.woocommerce ul.products li.product .button::after,
.woocommerce a.button::before,
.woocommerce button.button::before {
    content: none !important;
    display: none !important;
}

/* Fix mobile card layout - ensure flex column order is correct */
@media (max-width: 640px) {
    .hcs-product-card {
        display: flex;
        flex-direction: column;
    }

    .hcs-product-card__image-wrap {
        order: 0; /* image always first */
        flex-shrink: 0;
    }

    .hcs-product-card__body {
        order: 1;
    }

    .hcs-product-card__footer {
        order: 2;
        margin-top: auto;
    }

    /* Smaller grid on mobile */
    .hcs-product-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }

    /* Hide specs and meta on very small cards */
    .hcs-product-card__specs,
    .hcs-product-card__meta-row {
        display: none;
    }

    .hcs-product-card__body {
        padding: 10px 12px 8px;
        gap: 5px;
    }

    .hcs-product-card__footer {
        padding: 8px 12px 10px;
    }

    .hcs-product-card__btn {
        font-size: 12px;
        padding: 8px 10px;
    }

    .hcs-product-card__wishlist {
        width: 34px;
        height: 34px;
        font-size: 13px;
    }
}

@media (max-width: 380px) {
    .hcs-product-grid {
        grid-template-columns: 1fr; /* single column on tiny screens */
    }
}

/* ══════════════════════════════════════════════════════════════════════════
   PHASE 6 — Product Card Fixes
   ══════════════════════════════════════════════════════════════════════════ */

/* Title: always 1 line, truncated with ellipsis */
.hcs-product-card__title {
    font-size: 14px;
    font-weight: 600;
    line-height: 1.4;
    color: var(--navy);
    margin: 0;
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Category: clearly labelled with "In" prefix */
.hcs-product-card__category {
    font-size: 11px;
    font-weight: 600;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    display: inline-flex;
    align-items: center;
    gap: 3px;
}
.hcs-product-card__category-prefix {
    color: var(--gray-400);
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
    font-size: 10px;
}

/* overlay-btn defined in base card block above */

/* Badges: always top-left, consistent position */
.hcs-product-card__badges {
    position: absolute;
    top: 10px;
    left: 10px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    z-index: 2;
}
.badge {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: var(--radius-full);
    line-height: 1.4;
    white-space: nowrap;
}

/* Price: sale price larger, was-price clearly visible */
.hcs-price__sale { /* consolidated at bottom of file with !important */ }
.hcs-price__original {
    font-size: 14px;
    color: var(--gray-400);
    text-decoration: line-through;
    font-weight: 400;
}
.hcs-price__regular {
    font-size: 18px;
    font-weight: 700;
    color: var(--navy);
}

/* ══════════════════════════════════════════════════════════════════════════
   PHASE 6 — Single Product Page
   ══════════════════════════════════════════════════════════════════════════ */

.hcs-single-product { padding: 0 0 80px; }

.hcs-single-product__main {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
    padding: 24px 0 48px;
}

/* ── Gallery column ────────────────────────────────────── */
.hcs-single-product__gallery-col {
    position: relative;
}

.hcs-single-product__sale-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 5;
    background: var(--primary);
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    padding: 4px 10px;
    border-radius: var(--radius-full);
}

/* Main image container */
.hcs-single-product__main-image {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1.5px solid var(--gray-100);
    background: var(--gray-50);
    aspect-ratio: 1 / 1;
}

.hcs-single-product__zoom-link {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
}

.hcs-single-product__main-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 16px;
    transition: opacity 0.2s;
}

.hcs-single-product__zoom-hint {
    position: absolute;
    bottom: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: rgba(255,255,255,0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    color: var(--gray-500);
    opacity: 0;
    transition: opacity 0.2s;
}
.hcs-single-product__zoom-link:hover .hcs-single-product__zoom-hint { opacity: 1; }

/* Gallery nav arrows */
.hcs-gallery-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.92);
    border: 1px solid var(--gray-200);
    color: var(--navy);
    font-size: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 4;
    transition: var(--transition);
    box-shadow: var(--shadow-sm);
}
.hcs-gallery-nav:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.hcs-gallery-nav--prev { left: 10px; }
.hcs-gallery-nav--next { right: 10px; }

/* Thumbnail strip — horizontal scrollable row */
.hcs-single-product__thumbs {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: thin;
    scrollbar-color: var(--gray-200) transparent;
    padding-bottom: 4px;
}
.hcs-single-product__thumb {
    flex-shrink: 0;
    width: 68px;
    height: 68px;
    border-radius: var(--radius-sm);
    border: 2px solid var(--gray-200);
    overflow: hidden;
    cursor: pointer;
    background: var(--gray-50);
    padding: 0;
    transition: border-color 0.15s;
    scroll-snap-align: start;
}
.hcs-single-product__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 4px;
}
.hcs-single-product__thumb:hover { border-color: var(--gray-400); }
.hcs-single-product__thumb.is-active { border-color: var(--primary); }

/* ── Info panel ────────────────────────────────────────── */
.hcs-single-product__cat {
    font-size: 11px;
    font-weight: 700;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    display: inline-block;
    margin-bottom: 8px;
}
.hcs-single-product__title {
    font-size: clamp(20px, 2.2vw, 30px);
    font-weight: 800;
    color: var(--navy);
    line-height: 1.25;
    margin-bottom: 16px;
}
.hcs-single-product__meta {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 12px 14px;
    background: var(--gray-50);
    border-radius: var(--radius-sm);
    border: 1px solid var(--gray-100);
    margin-bottom: 18px;
}
.hcs-single-product__meta-row {
    display: flex;
    gap: 10px;
    align-items: center;
    font-size: 14px;
}
.hcs-single-product__meta-label {
    color: var(--gray-500);
    font-weight: 500;
    min-width: 52px;
}
.hcs-single-product__meta-value {
    color: var(--navy);
    font-weight: 600;
}

/* ── Single product price block ────────────────────────── */
.hcs-single-product__price-wrap { margin-bottom: 14px; }

.hcs-sp-price { display: flex; flex-direction: column; gap: 6px; }
.hcs-sp-price__row { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }

.hcs-sp-price__current {
    font-size: 32px;
    font-weight: 800;
    color: var(--navy);
    line-height: 1;
}
.hcs-sp-price--sale .hcs-sp-price__current { color: var(--primary-dark); }
.hcs-sp-price--vd  .hcs-sp-price__current { color: var(--primary-dark); }

.hcs-sp-price__was {
    font-size: 16px;
    color: var(--gray-400);
    text-decoration: line-through;
    font-weight: 400;
}

.hcs-sp-price__badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: var(--radius-full);
}
.hcs-sp-price__badge--sale { background: var(--primary-light); color: var(--primary-dark); }
.hcs-sp-price__badge--vd   { background: var(--primary-light); color: var(--primary-dark); }

.hcs-sp-price__enquire { font-size: 16px; font-weight: 600; color: var(--gray-500); }

/* Stock badge */
.hcs-single-product__stock { margin-bottom: 18px; }
.hcs-stock-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    padding: 5px 12px;
    border-radius: var(--radius-full);
}
.hcs-stock-badge--in  { background: var(--success-light); color: var(--success); }
.hcs-stock-badge--out { background: var(--danger-light);  color: var(--danger);  }

/* WC add to cart button */
.hcs-single-product__cart-form .single_add_to_cart_button {
    background: var(--primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--radius) !important;
    font-family: var(--font) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    padding: 14px 32px !important;
    transition: var(--transition) !important;
    cursor: pointer !important;
}
.hcs-single-product__cart-form .single_add_to_cart_button:hover {
    background: var(--primary-dark) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(232,99,26,.38) !important;
}
.single_add_to_cart_button::before { content: none !important; }
.hcs-single-product__cart-form .quantity input {
    width: 70px;
    height: 48px;
    text-align: center;
    border: 1.5px solid var(--gray-200);
    border-radius: var(--radius-sm);
    font-size: 16px;
    font-family: var(--font);
}

/* ── Short description ─────────────────────────────────── */
.hcs-short-desc {
    background: var(--gray-50);
    border-left: 3px solid var(--primary);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    padding: 14px 16px;
    margin-bottom: 16px;
    font-size: 14px;
    line-height: 1.7;
    color: var(--gray-700);
}
.hcs-short-desc p { margin-bottom: 6px; }
.hcs-short-desc p:last-child { margin-bottom: 0; }
.hcs-short-desc ul, .hcs-short-desc ol {
    padding-left: 18px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.hcs-short-desc ul { list-style: disc; }
.hcs-short-desc ol { list-style: decimal; }

/* ── Key specs table ───────────────────────────────────── */
.hcs-single-product__specs { margin: 20px 0 0; }
.hcs-single-product__specs-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 7px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.hcs-specs-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.hcs-specs-table tr { border-bottom: 1px solid var(--gray-100); }
.hcs-specs-table tr:last-child { border-bottom: none; }
.hcs-specs-table__label {
    padding: 8px 12px 8px 0;
    color: var(--gray-500);
    font-weight: 500;
    width: 40%;
    vertical-align: top;
}
.hcs-specs-table__value {
    padding: 8px 0;
    color: var(--gray-800);
    font-weight: 500;
}

/* ── Video + Trust ─────────────────────────────────────── */
.hcs-single-product__video-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-top: 16px;
    font-size: 14px;
    font-weight: 600;
    color: var(--info);
    transition: color .15s;
}
.hcs-single-product__video-btn:hover { color: var(--navy); }

.hcs-single-product__trust {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--gray-100);
    font-size: 12px;
    color: var(--gray-500);
}
.hcs-single-product__trust span { display: flex; align-items: center; gap: 5px; }
.hcs-single-product__trust i { color: var(--primary); }

/* ── Tabs (WooCommerce) ────────────────────────────────── */
.hcs-single-product__tabs { padding: 0 0 40px; }

.woocommerce-tabs ul.tabs {
    display: flex;
    gap: 0;
    padding: 0;
    margin: 0;
    border-bottom: 2px solid var(--gray-100);
    list-style: none;
}
.woocommerce-tabs ul.tabs li { margin: 0; background: none; border: none; }
.woocommerce-tabs ul.tabs li a {
    display: block;
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 600;
    color: var(--gray-500);
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: color .15s, border-color .15s;
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
    color: var(--primary);
    border-bottom-color: var(--primary);
}
.woocommerce-tabs .panel {
    padding: 24px 0;
    font-size: 15px;
    color: var(--gray-700);
    line-height: 1.8;
}

/* Description tab: add structure to plain text blocks */
.woocommerce-Tabs-panel--description h1,
.woocommerce-Tabs-panel--description h2,
.woocommerce-Tabs-panel--description h3 {
    font-size: 16px;
    font-weight: 700;
    color: var(--navy);
    margin: 16px 0 6px;
}
.woocommerce-Tabs-panel--description p { margin-bottom: 10px; }
.woocommerce-Tabs-panel--description ul,
.woocommerce-Tabs-panel--description ol {
    padding-left: 20px;
    margin-bottom: 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.woocommerce-Tabs-panel--description ul { list-style: disc; }

/* Additional information tab: clean table with formatted attribute names */
.woocommerce-Tabs-panel--additional_information table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.woocommerce-Tabs-panel--additional_information th,
.woocommerce-Tabs-panel--additional_information td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--gray-100);
    text-align: left;
    vertical-align: top;
}
.woocommerce-Tabs-panel--additional_information th {
    width: 35%;
    color: var(--gray-500);
    font-weight: 500;
    background: var(--gray-50);
}
.woocommerce-Tabs-panel--additional_information td {
    color: var(--gray-800);
    font-weight: 500;
}
.woocommerce-Tabs-panel--additional_information tr:last-child th,
.woocommerce-Tabs-panel--additional_information tr:last-child td {
    border-bottom: none;
}

/* ── Related products section ──────────────────────────── */
.hcs-single-product__related { padding: 0 0 40px; }
.hcs-single-product__related-title {
    font-size: 22px;
    font-weight: 800;
    color: var(--navy);
    margin-bottom: 24px;
}

/* ── Responsive ────────────────────────────────────────── */
@media (max-width: 900px) {
    .hcs-single-product__main { grid-template-columns: 1fr; gap: 28px; }
    .hcs-sp-price__current { font-size: 26px; }
}
@media (max-width: 480px) {
    .hcs-single-product__thumb { width: 56px; height: 56px; }
    .hcs-sp-price__current { font-size: 22px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   PHASE 6.1 — Checkout Page Fixes
   ══════════════════════════════════════════════════════════════════════════ */

/* Fix order summary in checkout - product name was wrapping character by character */
.wc-block-order-summary-item__description,
.wc-block-components-order-summary-item__name,
.wc-block-components-order-summary-item__description {
    word-break: normal !important;
    overflow-wrap: anywhere !important;
    hyphens: auto !important;
    max-width: 100% !important;
}

/* Checkout overall polish */
.wc-block-checkout__main,
.woocommerce-checkout {
    font-family: var(--font);
}

/* WC blocks checkout form fields */
.wc-block-components-text-input input,
.wc-block-components-select select,
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select {
    border: 1.5px solid var(--gray-200) !important;
    border-radius: var(--radius-sm) !important;
    font-family: var(--font) !important;
    font-size: 14px !important;
    padding: 10px 14px !important;
    transition: border-color 0.15s !important;
}
.wc-block-components-text-input input:focus,
.woocommerce-checkout .form-row input:focus {
    border-color: var(--primary) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px var(--primary-light) !important;
}

/* Order summary sidebar in checkout blocks */
.wc-block-order-summary-item__image img {
    border-radius: var(--radius-sm);
    border: 1px solid var(--gray-100);
    object-fit: contain;
    background: var(--gray-50);
}

/* ══════════════════════════════════════════════════════════════════════════
   PHASE 6.1 — Order Received (Thankyou) Page
   ══════════════════════════════════════════════════════════════════════════ */

.hcs-thankyou { max-width: 960px; margin: 0 auto; padding: 40px 0 80px; }

.hcs-thankyou__hero {
    text-align: center;
    padding: 48px 24px 40px;
    background: var(--gray-50);
    border-radius: var(--radius-xl);
    border: 1.5px solid var(--gray-100);
    margin-bottom: 32px;
}
.hcs-thankyou__icon {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: var(--success-light);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px;
    font-size: 32px; color: var(--success);
}
.hcs-thankyou__icon--pending { background: var(--warning-light); color: var(--warning); }
.hcs-thankyou__title { font-size: 28px; font-weight: 800; color: var(--navy); margin-bottom: 8px; }
.hcs-thankyou__sub   { font-size: 15px; color: var(--gray-500); }

.hcs-thankyou__meta-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--gray-100);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 32px;
}
.hcs-thankyou__meta-item {
    background: var(--white);
    padding: 18px 20px;
    display: flex; flex-direction: column; gap: 4px;
}
.hcs-thankyou__meta-label { font-size: 11px; font-weight: 700; color: var(--gray-400); text-transform: uppercase; letter-spacing: 0.6px; }
.hcs-thankyou__meta-value { font-size: 16px; font-weight: 700; color: var(--navy); }

.hcs-thankyou__cols {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 24px;
    align-items: start;
}

.hcs-thankyou__section-title {
    font-size: 15px; font-weight: 700; color: var(--navy);
    margin-bottom: 16px;
    display: flex; align-items: center; gap: 8px;
}

/* Order items list */
.hcs-thankyou__items {
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 0;
}
.hcs-thankyou__item {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--gray-100);
}
.hcs-thankyou__item:last-child { border-bottom: none; }
.hcs-thankyou__item-img {
    position: relative; flex-shrink: 0;
    width: 56px; height: 56px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--gray-100);
    overflow: visible;
    background: var(--gray-50);
}
.hcs-thankyou__item-img img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
.hcs-thankyou__item-qty {
    position: absolute; top: -6px; right: -6px;
    width: 20px; height: 20px;
    background: var(--navy); color: #fff;
    border-radius: 50%; font-size: 11px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
}
.hcs-thankyou__item-info { flex: 1; min-width: 0; }
.hcs-thankyou__item-name { display: block; font-size: 14px; font-weight: 600; color: var(--navy); }
.hcs-thankyou__item-sku  { display: block; font-size: 12px; color: var(--gray-400); margin-top: 2px; }
.hcs-thankyou__item-price { font-size: 14px; font-weight: 700; color: var(--navy); flex-shrink: 0; }

/* Totals */
.hcs-thankyou__totals {
    border: 1.5px solid var(--gray-100);
    border-top: none;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    overflow: hidden;
}
.hcs-thankyou__total-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 12px 16px;
    font-size: 14px; color: var(--gray-600);
    border-top: 1px solid var(--gray-100);
}
.hcs-thankyou__total-row--discount { color: var(--success); }
.hcs-thankyou__total-row--grand {
    font-size: 16px; font-weight: 800; color: var(--navy);
    background: var(--gray-50);
}

/* Side column */
.hcs-thankyou__address {
    background: var(--gray-50);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    padding: 16px 18px;
    font-size: 14px; color: var(--gray-600);
    line-height: 1.7;
    font-style: normal;
    margin-bottom: 20px;
}
.hcs-thankyou__address a { color: var(--primary); }

.hcs-thankyou__actions {
    display: flex; flex-direction: column; gap: 10px;
}
.hcs-thankyou__actions .btn { justify-content: center; width: 100%; }

@media (max-width: 768px) {
    .hcs-thankyou__meta-strip { grid-template-columns: 1fr 1fr; }
    .hcs-thankyou__cols { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════════════════
   PHASE 6.1 — Single Product Page Fixes
   ══════════════════════════════════════════════════════════════════════════ */

/* Add to cart form: gap between qty and button */
.hcs-single-product__cart-form .cart {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
    margin-bottom: 0 !important;
}
.hcs-single-product__cart-form .quantity {
    margin: 0 !important;
}

/* Wishlist button on single product page */
.hcs-single-product__wishlist-wrap {
    display: flex;
    align-items: center;
    margin-top: 12px;
}
/* Override the card wishlist fixed-size styles on product page */
.hcs-single-product__wishlist-btn.hcs-product-card__wishlist {
    width: auto !important;
    height: auto !important;
    border-radius: var(--radius-sm) !important;
    padding: 9px 16px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
    white-space: nowrap !important;
    color: var(--gray-600) !important;
    border: 1.5px solid var(--gray-200) !important;
    background: transparent !important;
    font-family: var(--font) !important;
    cursor: pointer;
    transition: var(--transition);
}
.hcs-single-product__wishlist-btn.hcs-product-card__wishlist:hover,
.hcs-single-product__wishlist-btn.hcs-product-card__wishlist[aria-pressed="true"] {
    border-color: var(--danger) !important;
    color: var(--danger) !important;
    background: var(--danger-light) !important;
}

/* Short description: break onto separate lines instead of one long block */
.hcs-short-desc {
    background: var(--gray-50);
    border-left: 3px solid var(--primary);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    padding: 14px 16px;
    margin-bottom: 16px;
    font-size: 14px;
    line-height: 1.7;
    color: var(--gray-700);
}
.hcs-short-desc p { margin-bottom: 6px; }
.hcs-short-desc p:last-child { margin-bottom: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   PHASE 6.1 — WC Notices (added to cart) — proper placement, not overlapping
   ══════════════════════════════════════════════════════════════════════════ */

.woocommerce-notices-wrapper {
    position: sticky;
    top: calc(var(--header-h) + 8px);
    z-index: 200;
    margin-bottom: 16px;
}
.woocommerce-message {
    border-radius: var(--radius-lg) !important;
    border-top: none !important;
    border-left: 4px solid var(--success) !important;
    background: var(--white) !important;
    box-shadow: var(--shadow-md) !important;
    padding: 14px 20px !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    color: var(--navy) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}
.woocommerce-message .button {
    margin-left: auto !important;
    flex-shrink: 0 !important;
    padding: 8px 16px !important;
    font-size: 13px !important;
}
.woocommerce-info {
    border-left: 4px solid var(--info) !important;
    background: var(--white) !important;
    border-top: none !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-md) !important;
    color: var(--navy) !important;
}

/* ══════════════════════════════════════════════════════════════════════════
   PHASE 6.1 — Product price order fix (was-price first, sale second)
   ══════════════════════════════════════════════════════════════════════════ */
.hcs-price.hcs-price--sale {
    flex-direction: row;
    align-items: baseline;
    gap: 8px;
}
/* Crossed-out original price: more visible */
.hcs-price__original {
    font-size: 13px;
    color: var(--gray-400);
    text-decoration: line-through;
    font-weight: 400;
    order: 1;
}
.hcs-price__sale { order: 2; } /* color/size consolidated at bottom */

/* ══════════════════════════════════════════════════════════════════════════
   Cart Toast Notification
   ══════════════════════════════════════════════════════════════════════════ */

#hcs-cart-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    opacity: 0;
    transition: opacity 0.3s ease, transform 0.3s ease;
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--navy);
    color: #fff;
    padding: 14px 20px;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    font-size: 14px;
    font-family: var(--font);
    z-index: 9999;
    min-width: 280px;
    max-width: 90vw;
    white-space: nowrap;
}
#hcs-cart-toast.is-visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}
.hcs-cart-toast__icon {
    color: var(--success);
    font-size: 18px;
    flex-shrink: 0;
}
.hcs-cart-toast__msg {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: rgba(255,255,255,0.9);
}
.hcs-cart-toast__btn {
    background: var(--primary);
    color: #fff !important;
    padding: 6px 14px;
    border-radius: var(--radius-sm);
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background 0.15s;
    text-decoration: none;
}
.hcs-cart-toast__btn:hover { background: var(--primary-dark); }
.hcs-cart-toast__close {
    background: none;
    border: none;
    color: rgba(255,255,255,0.5);
    font-size: 18px;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    flex-shrink: 0;
    transition: color 0.15s;
}
.hcs-cart-toast__close:hover { color: #fff; }

/* ══════════════════════════════════════════════════════════════════════════
   Checkout Order Summary — fix product description overflow
   ══════════════════════════════════════════════════════════════════════════ */

/* Hide the short description / meta that WC Blocks appends in order summary */
.wc-block-components-order-summary-item__description,
.wc-block-order-summary-item__description {
    display: none !important;
}

/* Fix product name wrapping in narrow column */
.wc-block-components-order-summary-item__name,
.wc-block-order-summary-item__name {
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--navy) !important;
    line-height: 1.4 !important;
}

/* Order summary image */
.wc-block-components-order-summary-item__image,
.wc-block-order-summary-item__image {
    width: 48px !important;
    height: 48px !important;
    border-radius: var(--radius-sm) !important;
    object-fit: contain !important;
    background: var(--gray-50) !important;
    border: 1px solid var(--gray-100) !important;
    flex-shrink: 0 !important;
}

/* Prices in summary */
.wc-block-components-order-summary-item__individual-prices,
.wc-block-order-summary-item__individual-prices {
    font-size: 12px !important;
    color: var(--gray-400) !important;
}

/* Place order button */
.wc-block-components-checkout-place-order-button,
.wc-block-checkout__place-order button {
    background: var(--primary) !important;
    color: #fff !important;
    border-radius: var(--radius) !important;
    font-family: var(--font) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    padding: 16px 32px !important;
    width: 100% !important;
    border: none !important;
    cursor: pointer !important;
    transition: var(--transition) !important;
}
.wc-block-components-checkout-place-order-button:hover {
    background: var(--primary-dark) !important;
}

/* ══════════════════════════════════════════════════════════════════════════
   Order Received — fix duplicate WC default table appearing below ours
   ══════════════════════════════════════════════════════════════════════════ */

/* Hide the WC default order details table that renders below our custom template */
.woocommerce-order-overview,
.woocommerce-order { display: none; }
.hcs-thankyou ~ .woocommerce-order-overview,
.hcs-thankyou ~ .woocommerce-order { display: none !important; }

/* ══════════════════════════════════════════════════════════════════════════
   MY ACCOUNT — Full Redesign
   ══════════════════════════════════════════════════════════════════════════ */

/* Page layout: sidebar + content */
.hcs-account-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 32px;
    align-items: start;
    padding: 32px 0 80px;
}

/* ── Sidebar nav ───────────────────────────────────────────────────────── */
.hcs-account-sidebar {
    position: sticky;
    top: calc(var(--header-h) + 20px);
}
.hcs-account-nav {
    background: var(--white);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.hcs-account-nav__item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 13px 18px;
    font-size: 14px;
    font-weight: 500;
    color: var(--gray-600);
    border-left: 3px solid transparent;
    transition: var(--transition-fast);
    text-decoration: none;
    border-bottom: 1px solid var(--gray-100);
}
.hcs-account-nav__item:last-child { border-bottom: none; }
.hcs-account-nav__item i {
    width: 16px;
    text-align: center;
    color: var(--gray-400);
    flex-shrink: 0;
    transition: color 0.15s;
}
.hcs-account-nav__item:hover {
    color: var(--primary);
    background: var(--primary-light);
    border-left-color: var(--primary);
}
.hcs-account-nav__item:hover i { color: var(--primary); }
.hcs-account-nav__item.is-active {
    color: var(--primary);
    background: var(--primary-light);
    border-left-color: var(--primary);
    font-weight: 600;
}
.hcs-account-nav__item.is-active i { color: var(--primary); }
.hcs-account-nav__item[data-logout="1"]:hover {
    color: var(--danger);
    background: var(--danger-light);
    border-left-color: var(--danger);
}
.hcs-account-nav__item[data-logout="1"]:hover i { color: var(--danger); }

/* ── Dashboard greeting ────────────────────────────────────────────────── */
.hcs-account-dashboard { display: flex; flex-direction: column; gap: 24px; }

.hcs-account-greeting {
    display: flex;
    align-items: center;
    gap: 16px;
    background: linear-gradient(135deg, var(--navy) 0%, #1a2d5a 100%);
    border-radius: var(--radius-lg);
    padding: 24px 28px;
    color: #fff;
}
.hcs-account-greeting__img {
    width: 56px; height: 56px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.3);
    flex-shrink: 0;
}
.hcs-account-greeting__text { flex: 1; }
.hcs-account-greeting__name {
    font-size: 18px; font-weight: 700; color: #fff; margin-bottom: 2px;
}
.hcs-account-greeting__email { font-size: 13px; color: rgba(255,255,255,0.6); }
.hcs-account-greeting__edit {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 12px; font-weight: 600;
    background: rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.85);
    padding: 7px 14px;
    border-radius: var(--radius-full);
    border: 1px solid rgba(255,255,255,0.2);
    white-space: nowrap;
    transition: background 0.15s;
}
.hcs-account-greeting__edit:hover { background: rgba(255,255,255,0.22); color: #fff; }

/* ── Stats strip ───────────────────────────────────────────────────────── */
.hcs-account-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--gray-100);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.hcs-account-stat {
    background: var(--white);
    padding: 18px 20px;
    display: flex; flex-direction: column; gap: 4px;
}
.hcs-account-stat__num {
    font-size: 22px; font-weight: 800; color: var(--navy);
    display: block;
}
.hcs-account-stat__num .woocommerce-Price-amount { font-size: inherit; font-weight: inherit; }
.hcs-account-stat__label {
    font-size: 12px; color: var(--gray-500); font-weight: 500;
}

/* ── Quick nav cards ───────────────────────────────────────────────────── */
.hcs-account-nav-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.hcs-account-nav-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    background: var(--white);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: var(--transition);
}
.hcs-account-nav-card:hover {
    border-color: var(--gray-200);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}
.hcs-account-nav-card__icon {
    width: 40px; height: 40px; border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; flex-shrink: 0;
}
.hcs-account-nav-card__body { flex: 1; min-width: 0; }
.hcs-account-nav-card__title {
    display: block; font-size: 13px; font-weight: 600; color: var(--navy);
}
.hcs-account-nav-card__sub {
    display: block; font-size: 11px; color: var(--gray-400); margin-top: 2px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.hcs-account-nav-card__arrow { color: var(--gray-300); font-size: 11px; flex-shrink: 0; }
.hcs-account-nav-card--logout:hover { border-color: var(--danger-light); }

/* ── Section header ────────────────────────────────────────────────────── */
.hcs-account-section-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 14px;
}
.hcs-account-section-title {
    font-size: 15px; font-weight: 700; color: var(--navy);
    display: flex; align-items: center; gap: 8px; margin: 0;
}
.hcs-account-see-all {
    font-size: 13px; font-weight: 500; color: var(--primary);
    display: flex; align-items: center; gap: 5px;
}
.hcs-account-see-all:hover { color: var(--primary-dark); }

/* ── Recent orders list ────────────────────────────────────────────────── */
.hcs-account-orders-list {
    background: var(--white);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.hcs-account-order {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--gray-100);
}
.hcs-account-order:last-child { border-bottom: none; }
.hcs-account-order__img {
    width: 48px; height: 48px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--gray-100);
    background: var(--gray-50);
    overflow: hidden; flex-shrink: 0;
    position: relative;
}
.hcs-account-order__img img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
.hcs-account-order__more {
    position: absolute; bottom: -4px; right: -4px;
    background: var(--navy); color: #fff;
    font-size: 10px; font-weight: 700;
    padding: 1px 5px; border-radius: var(--radius-full);
}
.hcs-account-order__info { flex: 1; min-width: 0; }
.hcs-account-order__num  { display: block; font-size: 13px; font-weight: 600; color: var(--navy); }
.hcs-account-order__date { display: block; font-size: 11px; color: var(--gray-400); margin-top: 2px; }
.hcs-account-order__mid  { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.hcs-account-order__total { font-size: 14px; font-weight: 700; color: var(--navy); }
.hcs-account-order__actions { display: flex; gap: 8px; flex-shrink: 0; }

/* Order status badges */
.hcs-account-order__status {
    display: inline-block;
    font-size: 11px; font-weight: 700;
    padding: 3px 9px; border-radius: var(--radius-full);
    white-space: nowrap;
}
.hcs-order-status--processing { background: var(--info-light);    color: var(--info); }
.hcs-order-status--completed  { background: var(--success-light); color: var(--success); }
.hcs-order-status--pending    { background: var(--warning-light); color: var(--warning); }
.hcs-order-status--on-hold    { background: var(--warning-light); color: var(--warning); }
.hcs-order-status--cancelled  { background: var(--danger-light);  color: var(--danger); }
.hcs-order-status--refunded   { background: var(--gray-100);      color: var(--gray-500); }

/* ── Track Order page ──────────────────────────────────────────────────── */
.hcs-track-order { display: flex; flex-direction: column; gap: 24px; }

.hcs-track-order__form { background: var(--gray-50); border-radius: var(--radius-lg); padding: 20px; border: 1.5px solid var(--gray-100); }
.hcs-track-order__field label { display: block; font-size: 13px; font-weight: 600; color: var(--navy); margin-bottom: 8px; }
.hcs-track-order__input-row { display: flex; gap: 10px; }
.hcs-track-order__input-row input {
    flex: 1; height: 44px; border: 1.5px solid var(--gray-200);
    border-radius: var(--radius-sm); padding: 0 14px;
    font-size: 15px; font-family: var(--font);
}
.hcs-track-order__input-row input:focus { outline: none; border-color: var(--primary); }

.hcs-track-order__error {
    background: var(--danger-light); color: var(--danger);
    padding: 14px 18px; border-radius: var(--radius-lg);
    font-size: 14px; font-weight: 500;
    display: flex; align-items: center; gap: 8px;
}

.hcs-track-order__result {
    background: var(--white); border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg); overflow: hidden;
}
.hcs-track-order__header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 16px 20px; border-bottom: 1px solid var(--gray-100);
    font-size: 14px; color: var(--navy);
}
.hcs-track-order__date { display: block; font-size: 12px; color: var(--gray-400); margin-top: 2px; font-weight: 400; }

/* Progress tracker */
.hcs-track-progress {
    display: flex; align-items: center;
    padding: 28px 24px;
    border-bottom: 1px solid var(--gray-100);
    overflow-x: auto;
}
.hcs-track-progress__step {
    display: flex; flex-direction: column; align-items: center; gap: 8px;
    flex-shrink: 0;
}
.hcs-track-progress__circle {
    width: 44px; height: 44px; border-radius: 50%;
    border: 2px solid var(--gray-200);
    background: var(--white);
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; color: var(--gray-300);
    transition: all 0.3s;
}
.hcs-track-progress__step.is-done .hcs-track-progress__circle {
    background: var(--success); border-color: var(--success); color: #fff;
}
.hcs-track-progress__step.is-current .hcs-track-progress__circle {
    background: var(--primary); border-color: var(--primary); color: #fff;
    box-shadow: 0 0 0 4px var(--primary-light);
}
.hcs-track-progress__label {
    font-size: 11px; font-weight: 600; color: var(--gray-400);
    text-align: center; white-space: nowrap;
}
.hcs-track-progress__step.is-done .hcs-track-progress__label,
.hcs-track-progress__step.is-current .hcs-track-progress__label { color: var(--navy); }

.hcs-track-progress__line {
    flex: 1; height: 2px; background: var(--gray-200); min-width: 40px; margin: 0 4px; margin-bottom: 28px;
}
.hcs-track-progress__line.is-done { background: var(--success); }

.hcs-track-order__items {
    padding: 16px 20px;
    display: flex; flex-direction: column; gap: 12px;
    border-bottom: 1px solid var(--gray-100);
}
.hcs-track-order__item {
    display: flex; align-items: center; gap: 12px; font-size: 14px;
}
.hcs-track-order__item img {
    width: 44px; height: 44px; object-fit: contain;
    border-radius: var(--radius-sm); border: 1px solid var(--gray-100);
    background: var(--gray-50); padding: 4px; flex-shrink: 0;
}
.hcs-track-order__item div { flex: 1; }
.hcs-track-order__item strong { display: block; font-weight: 600; color: var(--navy); }
.hcs-track-order__item span { color: var(--gray-400); font-size: 12px; }
.hcs-track-order__footer { padding: 14px 20px; }

/* ── WC default account content (orders table, edit-account form, etc.) ─ */
.hcs-account-content .woocommerce-MyAccount-content { padding: 0; }

/* Orders table */
.woocommerce-orders-table {
    width: 100%; border-collapse: collapse;
    font-size: 14px;
    background: var(--white);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.woocommerce-orders-table th {
    background: var(--gray-50); padding: 12px 16px;
    font-size: 11px; font-weight: 700; color: var(--gray-500);
    text-transform: uppercase; letter-spacing: 0.5px;
    border-bottom: 1px solid var(--gray-100);
    text-align: left;
}
.woocommerce-orders-table td {
    padding: 14px 16px; border-bottom: 1px solid var(--gray-100);
    color: var(--gray-700); vertical-align: middle;
}
.woocommerce-orders-table tr:last-child td { border-bottom: none; }
.woocommerce-orders-table .woocommerce-button { font-size: 12px !important; padding: 6px 14px !important; }

/* Edit account form */
.woocommerce-EditAccountForm .form-row { margin-bottom: 16px; }
.woocommerce-EditAccountForm label { display: block; font-size: 13px; font-weight: 600; color: var(--navy); margin-bottom: 6px; }
.woocommerce-EditAccountForm input[type="text"],
.woocommerce-EditAccountForm input[type="email"],
.woocommerce-EditAccountForm input[type="password"] {
    width: 100%; height: 44px; border: 1.5px solid var(--gray-200);
    border-radius: var(--radius-sm); padding: 0 14px;
    font-size: 14px; font-family: var(--font);
    transition: border-color 0.15s;
}
.woocommerce-EditAccountForm input:focus { outline: none; border-color: var(--primary); }

/* ── Fix: page.php wraps WC account in entry-content with max-width:760px
   That traps the sidebar+content layout causing overflow on all tabs. ── */
.woocommerce-account .entry-content {
    max-width: none !important;
    font-size: inherit !important;
    line-height: inherit !important;
    color: inherit !important;
}

/* Responsive — aligned with consolidated block at bottom of file */
@media (max-width: 900px) {
    .hcs-account-layout { grid-template-columns: 1fr; }
    .hcs-account-sidebar { position: static; }
    .hcs-account-nav { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; scrollbar-width: none; border-radius: var(--radius-lg); }
    .hcs-account-nav::-webkit-scrollbar { display: none; }
    .hcs-account-nav__item { flex: 0 0 auto; min-width: 72px; border-left: none; border-bottom: 3px solid transparent; justify-content: center; }
    .hcs-account-nav__item.is-active { border-bottom-color: var(--primary); border-left: none; }
    .hcs-account-nav-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
    .hcs-account-stats { grid-template-columns: 1fr 1fr; }
    .hcs-account-nav-grid { grid-template-columns: 1fr 1fr; }
    .hcs-account-order { flex-wrap: wrap; }
    .hcs-account-order__actions { width: 100%; }
}

/* ── Empty Cart Page ──────────────────────────────────────────────────────── */
.hcs-empty-cart {
    text-align: center;
    padding: 60px 20px 40px;
}

.hcs-empty-cart__icon {
    width: 80px;
    height: 80px;
    background: var(--gray-100);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    color: var(--gray-400);
    margin: 0 auto 20px;
}

.hcs-empty-cart__title {
    font-size: 22px;
    font-weight: 800;
    color: var(--navy);
    margin-bottom: 10px;
}

.hcs-empty-cart__text {
    font-size: 15px;
    color: var(--gray-500);
    margin-bottom: 24px;
}

/* "New in store" suggestions grid */
.hcs-empty-cart__suggestions {
    margin-top: 56px;
    text-align: left;
}

.hcs-empty-cart__suggestions-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--navy);
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.hcs-empty-cart__suggestions-title i {
    color: var(--primary);
    font-size: 18px;
}

/* ════════════════════════════════════════════════════════════════════════
   PHASE 7 FIXES
   ════════════════════════════════════════════════════════════════════════ */

/* Sale price: use brand orange, not danger red.
   Red implies error/problem. Orange matches the brand and still stands out. */
.hcs-price__sale {
    font-size: 20px !important;
    font-weight: 800 !important;
    color: var(--primary-dark) !important;
}

/* Was-price: smaller, clearly secondary */
.hcs-price__original {
    font-size: 13px !important;
    color: var(--gray-400) !important;
    text-decoration: line-through !important;
    font-weight: 400 !important;
}

/* Ensure sale layout: sale price first (big), was-price second (small) */
.hcs-price--sale {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

/* Remove WC default "Sale!" badge — we show our own % badge */
.woocommerce-badge, .onsale { display: none !important; }

/* Ensure equal card heights on the homepage grid too */
.hcs-product-grid {
    align-items: stretch;
}
.hcs-product-grid > li {
    display: flex;
    flex-direction: column;
}
.hcs-product-grid > li > .hcs-product-card {
    flex: 1;
    height: 100%;
}

/* ── Short description: clean aligned text, no indent ─────────────────────── */
.hcs-short-desc p {
    text-indent: 0 !important;
    text-align: left !important;
}
/* Description tab (full description) */
.woocommerce-Tabs-panel--description p {
    text-indent: 0 !important;
    text-align: left !important;
    margin-bottom: 10px;
}
.woocommerce-Tabs-panel--description {
    text-align: left !important;
}

/* ── Empty cart page: hide WC block default empty message before ours ──────── */
/* When our hook fires after woocommerce_cart_is_empty, we don't want duplicate
   empty messages. The WC block renders its own "Your cart is empty" heading. */
.wp-block-woocommerce-empty-cart-block .wc-empty-cart-message {
    /* Keep WC's message — our grid appends below it */
    margin-bottom: 0;
}

/* Suggestions section spacing */
.hcs-empty-cart__suggestions {
    margin-top: 48px;
    padding-top: 0;
    text-align: left;
}
.hcs-empty-cart__suggestions-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--navy);
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.hcs-empty-cart__suggestions-title i { color: var(--primary); }

/* Ensure product grid works inside cart page */
.hcs-empty-cart__suggestions .hcs-product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 16px;
}

   CART COUNT BADGE — always in DOM, hidden via class when 0
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-cart-count--hidden {
    display: none !important;
}
/* Ensure badge is visible when count > 0 */
.hcs-cart-count:not(.hcs-cart-count--hidden) {
    display: flex !important;
    align-items: center;
    justify-content: center;
}


/* ═══════════════════════════════════════════════════════════════════════════
   WISHLIST TOAST — bottom-right notification
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-wishlist-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(80px);
    background: var(--white);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    box-shadow: 0 8px 32px rgba(13,27,62,.14);
    padding: 13px 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--gray-800);
    z-index: 9999;
    opacity: 0;
    transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
    min-width: 260px;
    max-width: 90vw;
    pointer-events: none;
}
.hcs-wishlist-toast.is-visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    pointer-events: auto;
}
.hcs-wishlist-toast__icon { font-size: 18px; flex-shrink: 0; }
.hcs-wishlist-toast__msg  { flex: 1; line-height: 1.4; }
.hcs-wishlist-toast__close {
    background: none; border: none; cursor: pointer;
    color: var(--gray-400); font-size: 12px; padding: 4px;
    flex-shrink: 0; border-radius: var(--radius-sm);
    transition: color .15s;
}
.hcs-wishlist-toast__close:hover { color: var(--gray-700); }


/* ═══════════════════════════════════════════════════════════════════════════
   EMPTY CART — make "New in store" cards match shop page
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-empty-cart {
    text-align: center;
    padding: 60px 20px 40px;
}
.hcs-empty-cart__icon {
    width: 80px; height: 80px;
    background: var(--gray-100);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 32px; color: var(--gray-400);
    margin: 0 auto 20px;
}
.hcs-empty-cart__title {
    font-size: 22px; font-weight: 700; color: var(--navy); margin-bottom: 8px;
}
.hcs-empty-cart__text {
    font-size: 15px; color: var(--gray-500); margin-bottom: 24px;
}
/* Suggestions section */
.hcs-empty-cart__suggestions { margin-top: 48px; padding-top: 32px; border-top: 1.5px solid var(--gray-100); }
.hcs-empty-cart__suggestions-title {
    font-size: 18px; font-weight: 700; color: var(--navy);
    margin-bottom: 24px;
    display: flex; align-items: center; gap: 8px;
}
.hcs-empty-cart__suggestions-title i { color: var(--primary); }
/* Use the same grid as shop page */
.hcs-empty-cart__suggestions .hcs-product-grid {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

/* ═══════════════════════════════════════════════════════════════════════════
   SLIDE-OUT MINI CART
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-mini-cart {
    position: fixed;
    top: 0; right: 0;
    width: min(420px, 100vw);
    height: 100vh;
    background: var(--white);
    box-shadow: -8px 0 48px rgba(13,27,62,.18);
    z-index: 1300;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    overflow: hidden;
}
.hcs-mini-cart.is-open {
    transform: translateX(0);
}
.hcs-mini-cart__overlay {
    position: fixed;
    inset: 0;
    background: rgba(13,27,62,.45);
    z-index: 1299;
    opacity: 0;
    pointer-events: none;
    transition: opacity .35s ease;
    backdrop-filter: blur(2px);
}
.hcs-mini-cart__overlay.is-visible {
    opacity: 1;
    pointer-events: auto;
}

/* Header bar */
.hcs-mini-cart__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1.5px solid var(--gray-100);
    background: var(--white);
    flex-shrink: 0;
}
.hcs-mini-cart__title {
    font-size: 17px;
    font-weight: 700;
    color: var(--navy);
    display: flex;
    align-items: center;
    gap: 9px;
    margin: 0;
}
.hcs-mini-cart__title i { color: var(--primary); font-size: 16px; }
.hcs-mini-cart__close {
    width: 36px; height: 36px;
    border-radius: var(--radius-sm);
    border: 1.5px solid var(--gray-200);
    background: var(--white);
    color: var(--gray-600);
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 14px;
    transition: var(--transition-fast);
}
.hcs-mini-cart__close:hover {
    background: var(--gray-100);
    color: var(--navy);
    border-color: var(--gray-300);
}

/* Scrollable body */
.hcs-mini-cart__body {
    flex: 1;
    overflow-y: auto;
    padding: 0;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--gray-200) transparent;
}

/* WooCommerce mini cart styles inside our panel */
.hcs-mini-cart .woocommerce-mini-cart { list-style: none; padding: 0; margin: 0; }
.hcs-mini-cart .woocommerce-mini-cart__empty-message {
    text-align: center;
    padding: 48px 24px;
    color: var(--gray-500);
    font-size: 14px;
}
.hcs-mini-cart .woocommerce-mini-cart-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 16px 24px;
    border-bottom: 1px solid var(--gray-100);
}
.hcs-mini-cart .woocommerce-mini-cart-item img {
    width: 72px; height: 72px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    border: 1px solid var(--gray-100);
    flex-shrink: 0;
}
.hcs-mini-cart .woocommerce-mini-cart-item a:not(.remove_from_cart_button) {
    font-size: 14px;
    font-weight: 600;
    color: var(--navy);
    display: block;
    margin-bottom: 4px;
    line-height: 1.4;
}
.hcs-mini-cart .woocommerce-mini-cart-item a:not(.remove_from_cart_button):hover { color: var(--primary); }
.hcs-mini-cart .woocommerce-mini-cart-item .quantity {
    font-size: 13px;
    color: var(--gray-500);
}
.hcs-mini-cart .woocommerce-mini-cart-item .woocommerce-Price-amount {
    font-size: 15px;
    font-weight: 700;
    color: var(--primary-dark);
}
.hcs-mini-cart .woocommerce-mini-cart-item .remove_from_cart_button {
    margin-left: auto;
    color: var(--gray-300);
    font-size: 18px;
    line-height: 1;
    flex-shrink: 0;
    transition: color .15s;
    align-self: center;
}
.hcs-mini-cart .woocommerce-mini-cart-item .remove_from_cart_button:hover { color: var(--danger); }

/* Total + buttons at the bottom */
.hcs-mini-cart .woocommerce-mini-cart__total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    background: var(--gray-50);
    border-top: 1.5px solid var(--gray-100);
    font-size: 15px;
    font-weight: 700;
    color: var(--navy);
}
.hcs-mini-cart .woocommerce-mini-cart__total .woocommerce-Price-amount {
    color: var(--primary-dark);
    font-size: 18px;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 16px 24px 24px;
    background: var(--white);
    border-top: 1px solid var(--gray-100);
    flex-shrink: 0;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons a {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 13px 20px;
    border-radius: var(--radius);
    font-size: 14px;
    font-weight: 700;
    text-align: center;
    transition: var(--transition);
    gap: 8px;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .button:first-child {
    background: var(--white);
    border: 1.5px solid var(--gray-200);
    color: var(--navy);
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .button:first-child:hover {
    border-color: var(--primary);
    color: var(--primary);
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .checkout {
    background: var(--primary);
    color: #fff;
    border: none;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .checkout:hover {
    background: var(--primary-dark);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(232,99,26,.35);
}

/* Cart trigger button — same style as other icon buttons */
button.hcs-nav__icon-btn { background: none; border: none; cursor: pointer; }


/* ═══════════════════════════════════════════════════════════════════════════
   FILTER SIDEBAR — subcategory indentation
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-filter__option--child {
    padding-left: 20px !important;
}
.hcs-filter__option--child span:first-of-type {
    color: var(--gray-500);
    font-size: 12.5px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   FILTER SIDEBAR — ACCORDION CATEGORY GROUPS
   ═══════════════════════════════════════════════════════════════════════════ */

.hcs-filter__cat-group { margin-bottom: 2px; }

/* Parent row: label + expand button side by side */
.hcs-filter__cat-parent {
    display: flex;
    align-items: center;
    gap: 0;
}
.hcs-filter__cat-parent .hcs-filter__option {
    flex: 1;
    margin-bottom: 0;
}

/* The ▶ expand toggle button */
.hcs-filter__cat-toggle {
    width: 28px; height: 28px;
    background: none; border: none; cursor: pointer;
    color: var(--gray-400); font-size: 10px;
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: color .15s, background .15s, transform .2s;
}
.hcs-filter__cat-toggle:hover { color: var(--primary); background: var(--primary-light); }
.hcs-filter__cat-group.is-open .hcs-filter__cat-toggle {
    transform: rotate(90deg);
    color: var(--primary);
}

/* Children: hidden by default, slide open */
.hcs-filter__cat-children {
    display: none;
    padding-left: 16px;
    border-left: 2px solid var(--gray-100);
    margin-left: 18px;
    margin-top: 2px;
}
.hcs-filter__cat-group.is-open .hcs-filter__cat-children {
    display: block;
}

/* Child option: slightly smaller, muted color */
.hcs-filter__option--child span:first-of-type {
    font-size: 12.5px;
    color: var(--gray-600);
}
.hcs-filter__option--child:hover span:first-of-type { color: var(--primary); }


/* ═══════════════════════════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE — ALL PAGES
   Fixes: mobile shop 1-col clipping, homepage cards, header overlap, 
          single product stacking, account page, checkout
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Base container safety ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
body { overflow-x: hidden; }
.container { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 20px; }
img { max-width: 100%; height: auto; }

/* ── Header mobile ─────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .hcs-topbar { display: none; }
    .hcs-nav__menu { display: none; }
    .hcs-nav__cta  { display: none; }
    .hcs-hamburger { display: flex !important; }
    .hcs-nav__inner { height: 60px; }
    .container { padding: 0 16px; }
}

/* ── Shop layout ───────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .hcs-shop-layout { grid-template-columns: 220px 1fr; gap: 20px; }
}
@media (max-width: 768px) {
    .hcs-shop-layout { grid-template-columns: 1fr; }
    .hcs-shop-sidebar {
        position: fixed; top: 0; left: -100%;
        width: min(320px, 92vw); height: 100vh;
        background: var(--white); z-index: 1200;
        padding: 20px 16px; overflow-y: auto;
        box-shadow: 4px 0 32px rgba(13,27,62,.18);
        transition: left .3s cubic-bezier(.4,0,.2,1);
    }
    .hcs-shop-sidebar.is-open { left: 0; }
    .hcs-filter-toggle { display: flex !important; }
    .hcs-product-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    .hcs-shop-toolbar {
        flex-wrap: wrap;
        gap: 10px;
    }
}
@media (max-width: 480px) {
    .hcs-product-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
    }
    .hcs-product-card__body { padding: 10px 12px 8px !important; gap: 4px !important; }
    .hcs-product-card__footer { padding: 8px 12px 10px !important; }
    .hcs-product-card__specs { display: none !important; }
    .hcs-product-card__meta { display: none !important; }
    .hcs-product-card__meta-row { display: none !important; }
    .hcs-product-card__title { font-size: 12px !important; }
    .hcs-price__regular, .hcs-price__main, .hcs-price__sale, .hcs-price__vd {
        font-size: 14px !important;
    }
    .hcs-product-card__btn { font-size: 12px !important; padding: 8px !important; }
    .hcs-product-card__wishlist { width: 34px !important; height: 34px !important; }
    .hcs-price__was, .hcs-price__original { font-size: 11px !important; }
}

/* ── Homepage hero ─────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .hcs-hero__inner { grid-template-columns: 1fr !important; }
    .hcs-hero__stats { grid-template-columns: repeat(4,1fr) !important; }
    .hcs-featured-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media (max-width: 768px) {
    .hcs-hero { padding: 48px 0 40px !important; }
    .hcs-hero__title { font-size: clamp(26px, 6vw, 42px) !important; }
    .hcs-hero__stats { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
    .hcs-featured-grid { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
    .hcs-hero__actions { flex-direction: column !important; }
    .hcs-hero__actions .btn { width: 100% !important; justify-content: center !important; }
}
@media (max-width: 480px) {
    .hcs-hero__stat-num { font-size: 20px !important; }
    .hcs-hero__trust { gap: 10px !important; font-size: 11px !important; }
    .hcs-categories-track { gap: 10px !important; }
    .hcs-category-card { flex: 0 0 160px !important; }
    .hcs-featured-grid { grid-template-columns: 1fr !important; }
    .hcs-why-grid { grid-template-columns: 1fr !important; }
}

/* ── Category carousel (no overflow clip on mobile) ───────────────────── */
.hcs-categories-track-wrap { overflow: hidden; }
.hcs-categories-track {
    display: flex;
    gap: 16px;
    transition: transform .35s cubic-bezier(.4,0,.2,1);
}
@media (max-width: 768px) {
    .hcs-categories-track {
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 4px;
    }
    .hcs-categories-track::-webkit-scrollbar { display: none; }
    .hcs-category-card { scroll-snap-align: start; }
    .hcs-browse-nav { display: none !important; } /* hidden on mobile — swipe instead */
}

/* ── Single product ────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .hcs-single-product__main {
        grid-template-columns: 1fr !important;
        gap: 24px !important;
    }
}
@media (max-width: 600px) {
    .hcs-single-product__main-img { max-height: 300px; object-fit: contain; }
    .hcs-single-product__thumbs { gap: 6px !important; }
    .hcs-single-product__thumb { width: 52px !important; height: 52px !important; }
    .hcs-single-product__title { font-size: 20px !important; }
    .woocommerce-tabs ul.tabs { flex-wrap: wrap; }
    .woocommerce-tabs ul.tabs li a { padding: 10px 14px !important; font-size: 13px !important; }
    .woocommerce-Tabs-panel--additional_information table { font-size: 13px !important; }
}

/* ── Account layout — aligned with consolidated block at bottom of file ── */
@media (max-width: 768px) {
    .hcs-account-layout {
        grid-template-columns: 1fr !important;
    }
    .hcs-account-sidebar { position: static !important; }
    /* nowrap + horizontal scroll — prevents items wrapping to 2nd row */
    .hcs-account-nav { flex-direction: row; flex-wrap: nowrap !important; overflow-x: auto !important; scrollbar-width: none !important; }
    .hcs-account-nav::-webkit-scrollbar { display: none !important; }
    .hcs-account-nav__item {
        flex: 0 0 auto !important;
        min-width: 72px !important;
        justify-content: center; text-align: center;
        border-left: none !important;
        border-bottom: 3px solid transparent !important;
        padding: 10px 12px !important;
        white-space: nowrap !important;
    }
    .hcs-account-nav__item.is-active {
        border-bottom-color: var(--primary) !important;
    }
    .hcs-account-nav__item span { display: block !important; font-size: 10px !important; }
    .hcs-account-nav__item i { width: auto !important; font-size: 15px !important; }
}

/* ── Checkout ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .woocommerce-cart .woocommerce,
    .woocommerce-checkout .col2-set {
        grid-template-columns: 1fr !important;
    }
    .woocommerce-checkout #order_review { margin-top: 24px; }
}

/* ── Mini cart mobile ──────────────────────────────────────────────────── */
@media (max-width: 480px) {
    .hcs-mini-cart { width: 100vw !important; }
}

/* ── Empty cart suggestions grid ─────────────────────────────────────────*/
.hcs-empty-cart__suggestions .hcs-product-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
}
@media (max-width: 600px) {
    .hcs-empty-cart__suggestions .hcs-product-grid {
        grid-template-columns: 1fr 1fr !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE PRODUCT — TABS REDESIGN
   Description / Additional Info / Reviews shown as proper styled tabs
   ═══════════════════════════════════════════════════════════════════════════ */

/* Tab container */
.hcs-single-product__tabs {
    padding: 48px 0 40px;
    border-top: 1.5px solid var(--gray-100);
}

/* Tab nav bar */
.woocommerce-tabs ul.tabs {
    display: flex !important;
    gap: 0 !important;
    padding: 0 !important;
    margin: 0 0 0 !important;
    border-bottom: 2px solid var(--gray-100) !important;
    list-style: none !important;
    flex-wrap: wrap;
}
.woocommerce-tabs ul.tabs li {
    margin: 0 !important;
    background: none !important;
    border: none !important;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce-tabs ul.tabs li a {
    display: block !important;
    padding: 13px 22px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--gray-500) !important;
    border-bottom: 2.5px solid transparent !important;
    margin-bottom: -2px !important;
    transition: color .15s, border-color .15s !important;
    white-space: nowrap;
    text-decoration: none !important;
    background: none !important;
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
    color: var(--primary) !important;
    border-bottom-color: var(--primary) !important;
}
.woocommerce-tabs ul.tabs li.active { background: none !important; }

/* Panel content */
.woocommerce-tabs .panel {
    padding: 28px 0 !important;
    font-size: 14px !important;
    color: var(--gray-700) !important;
    line-height: 1.8 !important;
}

/* Description tab typography */
.woocommerce-Tabs-panel--description > h2:first-child { display: none; } /* hide WC's auto "Description" h2 */
.woocommerce-Tabs-panel--description h2,
.woocommerce-Tabs-panel--description h3 {
    font-size: 16px; font-weight: 700; color: var(--navy); margin: 18px 0 8px;
}
.woocommerce-Tabs-panel--description p { margin-bottom: 12px; }
.woocommerce-Tabs-panel--description ul,
.woocommerce-Tabs-panel--description ol {
    padding-left: 20px; margin-bottom: 12px;
}
.woocommerce-Tabs-panel--description ul { list-style: disc; }
.woocommerce-Tabs-panel--description ol { list-style: decimal; }
.woocommerce-Tabs-panel--description li { margin-bottom: 4px; }

/* Description: if it's plain-text (no HTML), wrap in a styled card */
.hcs-short-desc {
    background: var(--gray-50);
    border: 1px solid var(--gray-100);
    border-radius: var(--radius);
    padding: 16px 20px;
    font-size: 14px;
    color: var(--gray-700);
    line-height: 1.75;
}

/* Additional information table — styled like a spec sheet */
.woocommerce-Tabs-panel--additional_information > h2 { display: none; }
.woocommerce-Tabs-panel--additional_information .woocommerce-product-attributes {
    width: 100%;
    border-collapse: collapse;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1.5px solid var(--gray-100);
}
.woocommerce-Tabs-panel--additional_information .woocommerce-product-attributes th {
    text-align: left !important;
    padding: 11px 18px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--gray-600) !important;
    background: var(--gray-50) !important;
    border-bottom: 1px solid var(--gray-100) !important;
    width: 36% !important;
    text-transform: capitalize !important;
    vertical-align: top !important;
}
.woocommerce-Tabs-panel--additional_information .woocommerce-product-attributes td {
    padding: 11px 18px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--gray-800) !important;
    border-bottom: 1px solid var(--gray-100) !important;
    vertical-align: top !important;
}
.woocommerce-Tabs-panel--additional_information .woocommerce-product-attributes tr:last-child th,
.woocommerce-Tabs-panel--additional_information .woocommerce-product-attributes tr:last-child td {
    border-bottom: none !important;
}
.woocommerce-Tabs-panel--additional_information .woocommerce-product-attributes tr:nth-child(even) th,
.woocommerce-Tabs-panel--additional_information .woocommerce-product-attributes tr:nth-child(even) td {
    background: var(--white);
}

/* Reviews tab */
.woocommerce-Tabs-panel--reviews > h2 { display: none; }
.woocommerce-Reviews .comment-reply-title,
.woocommerce-Reviews #reply-title {
    font-size: 18px; font-weight: 700; color: var(--navy); margin-bottom: 20px;
}
.woocommerce-Reviews #review_form_wrapper {
    background: var(--gray-50);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    padding: 28px;
    margin-top: 24px;
}
.woocommerce-Reviews #review_form .comment-form-rating label,
.woocommerce-Reviews .comment-form label {
    font-size: 13px; font-weight: 600; color: var(--gray-700); display: block; margin-bottom: 6px;
}
.woocommerce-Reviews .comment-form-comment textarea,
.woocommerce-Reviews .comment-form input[type="text"],
.woocommerce-Reviews .comment-form input[type="email"] {
    width: 100%; border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm);
    padding: 10px 14px; font-family: var(--font); font-size: 14px; color: var(--gray-900);
    transition: border-color .15s;
}
.woocommerce-Reviews .comment-form-comment textarea:focus,
.woocommerce-Reviews .comment-form input:focus {
    outline: none; border-color: var(--primary);
}
.woocommerce-Reviews #submit {
    background: var(--primary) !important; color: #fff !important;
    border: none !important; border-radius: var(--radius) !important;
    padding: 11px 24px !important; font-family: var(--font) !important;
    font-size: 14px !important; font-weight: 700 !important;
    cursor: pointer !important; transition: background .15s !important;
}
.woocommerce-Reviews #submit:hover { background: var(--primary-dark) !important; }

/* No reviews yet message */
.woocommerce-Reviews .woocommerce-noreviews {
    color: var(--gray-500); font-size: 14px; padding: 20px 0;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE PRODUCT TABS — JS-powered, like Elementor tabs widget
   ═══════════════════════════════════════════════════════════════════════════ */

/* Tab container with border */
.hcs-single-product__tabs {
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin: 40px 0;
}

/* Tab nav bar */
.woocommerce-tabs ul.tabs {
    display: flex !important;
    gap: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border-bottom: 1.5px solid var(--gray-100) !important;
    list-style: none !important;
    background: var(--gray-50);
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
}
.woocommerce-tabs ul.tabs::-webkit-scrollbar { display: none; }
.woocommerce-tabs ul.tabs li {
    margin: 0 !important;
    background: none !important;
    border: none !important;
    flex-shrink: 0;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce-tabs ul.tabs li a {
    display: flex !important;
    align-items: center;
    padding: 14px 22px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--gray-500) !important;
    border-bottom: 2.5px solid transparent !important;
    margin-bottom: -1.5px !important;
    transition: color .15s, border-color .15s, background .15s !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    background: none !important;
}
.woocommerce-tabs ul.tabs li.active a {
    color: var(--primary) !important;
    border-bottom-color: var(--primary) !important;
    background: var(--white) !important;
}
.woocommerce-tabs ul.tabs li a:hover {
    color: var(--primary) !important;
    background: var(--white) !important;
}

/* Panels */
.woocommerce-tabs .panel {
    padding: 28px 28px 32px !important;
    font-size: 14px !important;
    color: var(--gray-700) !important;
    line-height: 1.8 !important;
    background: var(--white);
}


/* ═══════════════════════════════════════════════════════════════════════════
   MINI CART ALIGNMENT FIX
   Items, quantity, price, remove button all in a clean row
   ═══════════════════════════════════════════════════════════════════════════ */

.hcs-mini-cart .woocommerce-mini-cart-item {
    display: grid !important;
    grid-template-columns: 72px 1fr auto !important;
    grid-template-rows: auto auto !important;
    gap: 0 14px !important;
    padding: 16px 20px !important;
    border-bottom: 1px solid var(--gray-100) !important;
    align-items: center !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item img {
    width: 72px !important; height: 72px !important;
    object-fit: cover !important;
    border-radius: var(--radius-sm) !important;
    border: 1px solid var(--gray-100) !important;
    grid-row: 1 / 3 !important;
    grid-column: 1 !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item a:not(.remove_from_cart_button) {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--navy) !important;
    line-height: 1.4 !important;
    grid-column: 2 !important;
    grid-row: 1 !important;
    display: block !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item .quantity {
    font-size: 12px !important;
    color: var(--gray-500) !important;
    grid-column: 2 !important;
    grid-row: 2 !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item .remove_from_cart_button {
    grid-column: 3 !important;
    grid-row: 1 / 3 !important;
    color: var(--gray-300) !important;
    font-size: 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important; height: 28px !important;
    border-radius: 50% !important;
    transition: color .15s, background .15s !important;
    margin-left: 0 !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item .remove_from_cart_button:hover {
    color: var(--danger) !important;
    background: var(--danger-light) !important;
}
/* Quantity × price on same row */
.hcs-mini-cart .woocommerce-mini-cart-item .quantity .woocommerce-Price-amount {
    font-weight: 700 !important;
    color: var(--primary-dark) !important;
}

/* Buttons: full width, checkout is orange, view cart is outlined */
.hcs-mini-cart .woocommerce-mini-cart__buttons {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    padding: 16px 20px 20px !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px 16px !important;
    border-radius: var(--radius) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-align: center !important;
    transition: var(--transition) !important;
    text-decoration: none !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .button:first-child {
    background: var(--white) !important;
    border: 1.5px solid var(--gray-200) !important;
    color: var(--navy) !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .button:first-child:hover {
    border-color: var(--primary) !important;
    color: var(--primary) !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .checkout {
    background: var(--primary) !important;
    border: none !important;
    color: #fff !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .checkout:hover {
    background: var(--primary-dark) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   FEATURED PRODUCTS GRID — RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */

/* Default: 4-column grid */
.hcs-featured-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    align-items: stretch;
}
.hcs-featured-grid__item { display: flex; flex-direction: column; }
.hcs-featured-grid__item .hcs-product-card { flex: 1; height: 100%; }

@media (max-width: 1100px) {
    .hcs-featured-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 800px) {
    .hcs-featured-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (max-width: 480px) {
    .hcs-featured-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   LOGIN / REGISTER — CUSTOM TEMPLATE (form-login.php)
   Complete redesign with toggle panels
   ═══════════════════════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE NAV — OFF CANVAS IMPROVEMENTS
   ═══════════════════════════════════════════════════════════════════════════ */

/* Nav menu list items */
.hcs-mobile-nav__menu {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
}
.hcs-mobile-nav__menu li { margin: 0 !important; }
.hcs-mobile-nav__menu li a {
    display: flex !important;
    align-items: center !important;
    color: rgba(255,255,255,.85) !important;
    padding: 14px 0 !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
    text-decoration: none !important;
    transition: color .15s, padding-left .15s !important;
    letter-spacing: .1px !important;
}
.hcs-mobile-nav__menu li a:hover,
.hcs-mobile-nav__menu li.current-menu-item > a {
    color: var(--primary) !important;
    padding-left: 8px !important;
}
/* Mobile nav header area */
.hcs-mobile-nav::before {
    content: 'Menu';
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255,255,255,.1);
}
/* Overlay */
.hcs-mobile-nav__overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(2px);
    z-index: 1099;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
}
.hcs-mobile-nav__overlay.is-visible {
    opacity: 1;
    pointer-events: auto;
}


/* ═══════════════════════════════════════════════════════════════════════════
   FILTER SIDEBAR — PRICE RANGE + CLEAR LINK
   ═══════════════════════════════════════════════════════════════════════════ */

/* Price range: stacked (min on top, max below) with dash between */
.hcs-filter__price-row {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.hcs-filter__price-sep {
    text-align: center;
    color: var(--gray-400);
    font-size: 13px;
    font-weight: 600;
    line-height: 1;
}
.hcs-filter__price-row input[type="number"] {
    width: 100%;
    border: 1.5px solid var(--gray-200);
    border-radius: var(--radius-sm);
    padding: 9px 12px;
    font-family: var(--font);
    font-size: 14px;
    color: var(--gray-800);
    background: var(--gray-50);
    transition: border-color .15s;
    -moz-appearance: textfield;
}
.hcs-filter__price-row input[type="number"]::-webkit-inner-spin-button,
.hcs-filter__price-row input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.hcs-filter__price-row input:focus {
    outline: none;
    border-color: var(--primary);
    background: var(--white);
}

/* Clear all filters link */
.hcs-filter__clear-wrap {
    padding: 16px 0 8px;
    text-align: center;
    border-top: 1px solid var(--gray-100);
    margin-top: 8px;
}
.hcs-filter__clear-link {
    font-size: 12px;
    color: var(--gray-400);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    transition: color .15s;
}
.hcs-filter__clear-link:hover { color: var(--danger); }


/* ═══════════════════════════════════════════════════════════════════════════
   ACCOUNT PAGES — Orders / Addresses / Account Details / Wishlist
   Style all the currently unstyled WC content areas
   ═══════════════════════════════════════════════════════════════════════════ */

/* Section heading used on subpages */
.hcs-account-section-head {
    font-size: 20px;
    font-weight: 800;
    color: var(--navy);
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--gray-100);
}

/* ── Orders table ─────────────────────────────────── */
.woocommerce-account .woocommerce-orders-table,
.woocommerce-orders-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.woocommerce-orders-table th {
    text-align: left;
    padding: 10px 14px;
    background: var(--gray-50);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--gray-500);
    border-bottom: 1.5px solid var(--gray-100);
}
.woocommerce-orders-table td {
    padding: 14px;
    border-bottom: 1px solid var(--gray-100);
    color: var(--gray-700);
    vertical-align: middle;
}
.woocommerce-orders-table tr:hover td { background: var(--gray-50); }
.woocommerce-orders-table .button {
    background: none !important;
    border: 1.5px solid var(--primary) !important;
    color: var(--primary) !important;
    border-radius: var(--radius-sm) !important;
    padding: 6px 14px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: background .15s, color .15s !important;
    text-decoration: none !important;
    display: inline-block !important;
}
.woocommerce-orders-table .button:hover {
    background: var(--primary) !important;
    color: #fff !important;
}

/* Empty orders state (image 9) */
.woocommerce-account .woocommerce-Message,
.woocommerce-info {
    background: var(--white) !important;
    border: 1.5px solid var(--gray-100) !important;
    border-top: 3px solid var(--primary) !important;
    border-radius: var(--radius) !important;
    padding: 24px 20px !important;
    font-size: 14px !important;
    color: var(--gray-600) !important;
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
}
.woocommerce-account .woocommerce-Message::before,
.woocommerce-info::before { display: none !important; }
.woocommerce-account .woocommerce-Message .button,
.woocommerce-info .button {
    background: var(--primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--radius-sm) !important;
    padding: 10px 20px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
}

/* ── Addresses ────────────────────────────────────── */
.woocommerce-account .woocommerce-Addresses {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
@media (max-width: 600px) {
    .woocommerce-account .woocommerce-Addresses { grid-template-columns: 1fr; }
}
.woocommerce-account .woocommerce-Address {
    background: var(--white);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    padding: 24px;
}
.woocommerce-account .woocommerce-Address h3 {
    font-size: 15px;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--gray-100);
    display: flex;
    align-items: center;
    gap: 8px;
}
.woocommerce-account .woocommerce-Address address {
    font-style: normal;
    font-size: 14px;
    color: var(--gray-600);
    line-height: 1.8;
}
.woocommerce-account .woocommerce-Address .edit {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    font-weight: 600;
    color: var(--primary);
    text-decoration: none;
    margin-top: 12px;
    padding: 6px 12px;
    border: 1.5px solid var(--primary);
    border-radius: var(--radius-sm);
    transition: background .15s, color .15s;
}
.woocommerce-account .woocommerce-Address .edit:hover {
    background: var(--primary);
    color: #fff;
}

/* ── Account Details form ─────────────────────────── */
.woocommerce-account .woocommerce-EditAccountForm .form-row,
.woocommerce-account .woocommerce-form .form-row {
    margin-bottom: 18px;
}
.woocommerce-account .woocommerce-EditAccountForm label,
.woocommerce-account .woocommerce-form label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--gray-700) !important;
    display: block !important;
    margin-bottom: 6px !important;
}
.woocommerce-account .woocommerce-EditAccountForm input[type="text"],
.woocommerce-account .woocommerce-EditAccountForm input[type="email"],
.woocommerce-account .woocommerce-EditAccountForm input[type="password"] {
    width: 100% !important;
    border: 1.5px solid var(--gray-200) !important;
    border-radius: 10px !important;
    padding: 11px 14px !important;
    font-family: var(--font) !important;
    font-size: 14px !important;
    color: var(--gray-900) !important;
    background: var(--gray-50) !important;
    transition: border-color .15s, box-shadow .15s !important;
}
.woocommerce-account .woocommerce-EditAccountForm input:focus,
.woocommerce-account .woocommerce-form input:focus {
    outline: none !important;
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(232,99,26,.1) !important;
    background: var(--white) !important;
}
/* Password change fieldset */
.woocommerce-account fieldset {
    border: 1.5px solid var(--gray-100) !important;
    border-radius: var(--radius) !important;
    padding: 20px !important;
    margin: 24px 0 !important;
}
.woocommerce-account fieldset legend {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--navy) !important;
    padding: 0 8px !important;
}
/* Save button */
.woocommerce-account .woocommerce-EditAccountForm button[type="submit"],
.woocommerce-account .woocommerce-form button[type="submit"],
.woocommerce-account .button[name="save_account_details"] {
    background: var(--primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 12px 28px !important;
    font-family: var(--font) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: background .2s !important;
}
.woocommerce-account .woocommerce-EditAccountForm button[type="submit"]:hover {
    background: var(--primary-dark) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   WISHLIST ACCOUNT PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-account-wishlist { padding: 4px 0 40px; }
.hcs-account-wishlist__note {
    font-size: 13px;
    color: var(--gray-400);
    background: var(--gray-50);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    margin-bottom: 24px;
    display: flex;
    align-items: flex-start;
    gap: 8px;
}
.hcs-wishlist-grid {
    margin-top: 0;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
    gap: 20px !important;
}
@media (max-width: 768px) {
    .hcs-wishlist-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
}
@media (max-width: 400px) {
    .hcs-wishlist-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }
}


/* ═══════════════════════════════════════════════════════════════════════════
   HC SHOP v1.9.1 — CONSOLIDATED RESPONSIVE FIXES
   Replaces all previous scattered mobile overrides.
   Single source of truth for all breakpoints.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── PRODUCT GRID — BASE (desktop) ──────────────────────────────────────────
   Restore correct auto-fill on desktop. Previous blocks corrupted this.       */

.hcs-product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 24px;
    align-items: stretch;
}

/* Shop page content area: 3 cols when sidebar (280px) is beside it */
@media (min-width: 769px) {
    .hcs-shop-content .hcs-product-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }
}

/* Wide desktop: 4 cols on homepage/standalone sections (no sidebar) */
@media (min-width: 1200px) {
    .hcs-shop-content .hcs-product-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    section .hcs-product-grid,
    .hcs-showcase-block__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ── PRODUCT GRID — TABLET (768–1024px) ────────────────────────────────────── */

@media (max-width: 1024px) {
    .hcs-shop-layout {
        grid-template-columns: 220px 1fr;
        gap: 20px;
    }
}

@media (max-width: 900px) {
    section .hcs-product-grid,
    .hcs-showcase-block__grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* ── PRODUCT GRID — MOBILE (≤768px) ────────────────────────────────────────
   Sidebar goes off-canvas. Grid becomes 2 columns.                            */

@media (max-width: 768px) {

    /* Layout: single column, sidebar off-canvas */
    .hcs-shop-layout {
        grid-template-columns: 1fr !important;
        gap: 0 !important;
        padding: 16px 0 48px !important;
    }

    /* ALL product grids: 2 columns */
    .hcs-product-grid,
    .hcs-shop-content .hcs-product-grid,
    section .hcs-product-grid,
    .hcs-showcase-block__grid,
    .hcs-empty-cart__suggestions .hcs-product-grid,
    .hcs-wishlist-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }

    /* ── Card adjustments for narrow 2-col layout ── */

    /* Title: 2 lines so text is readable on small cards */
    .hcs-product-card__title {
        white-space: normal !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
        font-size: 12px !important;
        line-height: 1.35 !important;
        /* reserve 2-line height so all cards in a row stay same height */
        min-height: calc(12px * 1.35 * 2) !important;
    }

    /* Shorter image: cards are narrow, tall images waste space */
    .hcs-product-card__image-wrap {
        aspect-ratio: 4 / 3 !important;
    }

    /* Body: tighter padding */
    .hcs-product-card__body {
        padding: 8px 10px 4px !important;
        gap: 3px !important;
    }

    /* Hide specs, meta, video on mobile — not enough space */
    .hcs-product-card__specs,
    .hcs-product-card__meta-row,
    .hcs-product-card__video-link {
        display: none !important;
    }

    /* Category label: tiny */
    .hcs-product-card__category {
        font-size: 9px !important;
        letter-spacing: 0.3px !important;
    }

    /* Price */
    .hcs-price__sale,
    .hcs-price__vd,
    .hcs-price__main,
    .hcs-product-card .woocommerce-Price-amount {
        font-size: 14px !important;
        font-weight: 700 !important;
    }
    .hcs-price__original,
    .hcs-product-card del .woocommerce-Price-amount {
        font-size: 11px !important;
    }

    /* Footer: icon-only Add to Cart button + small wishlist */
    .hcs-product-card__footer {
        padding: 7px 10px 9px !important;
        gap: 7px !important;
        align-items: stretch !important;
    }

    .hcs-product-card__btn {
        flex: 1 !important;
        font-size: 13px !important;
        padding: 9px 10px !important;
        justify-content: center !important;
        gap: 6px !important;
    }

    /* Hide "Add to Cart" text on mobile — icon only saves space */
    .hcs-product-card__btn .hcs-add-to-cart__text {
        display: none !important;
    }
    .hcs-product-card__btn i {
        margin: 0 !important;
        font-size: 14px !important;
    }

    .hcs-product-card__wishlist {
        width: 36px !important;
        height: 36px !important;
        flex-shrink: 0 !important;
        font-size: 14px !important;
        align-self: stretch !important;
        border-radius: var(--radius-sm) !important;
    }

    /* Shop toolbar: stack vertically */
    .hcs-shop-toolbar {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 8px !important;
        margin-bottom: 12px !important;
    }
    .hcs-shop-toolbar__sort,
    .hcs-sort-select { width: 100% !important; }

    /* Show filter toggle button */
    .hcs-filter-toggle {
        display: flex !important;
    }
}

/* Small phones ≤400px */
@media (max-width: 400px) {
    .hcs-product-grid,
    .hcs-shop-content .hcs-product-grid,
    section .hcs-product-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }
    .hcs-product-card__body { padding: 7px 8px 3px !important; }
    .hcs-product-card__footer { padding: 6px 8px 8px !important; }
    .hcs-product-card__title { font-size: 11px !important; }
    .hcs-price__sale, .hcs-price__vd, .hcs-price__main { font-size: 13px !important; }
}

/* ── SIDEBAR — OFF-CANVAS ON MOBILE ─────────────────────────────────────────  */

@media (max-width: 768px) {
    .hcs-shop-sidebar {
        position: fixed !important;
        top: 0 !important;
        left: -100% !important;
        width: min(320px, 92vw) !important;
        height: 100vh !important;
        max-height: 100vh !important;
        overflow-y: auto !important;
        background: var(--white) !important;
        z-index: 1200 !important;
        padding: 20px 16px 40px !important;
        box-shadow: 4px 0 32px rgba(13, 27, 62, 0.2) !important;
        transition: left 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    }
    .hcs-shop-sidebar.is-open {
        left: 0 !important;
    }
    #hcs-filter-overlay {
        position: fixed !important;
        inset: 0 !important;
        background: rgba(13, 27, 62, 0.45) !important;
        z-index: 1199 !important;
        opacity: 0 !important;
        pointer-events: none !important;
        transition: opacity 0.25s ease !important;
    }
    #hcs-filter-overlay.is-visible {
        opacity: 1 !important;
        pointer-events: auto !important;
    }
}

@media (min-width: 769px) {
    .hcs-shop-sidebar {
        position: sticky !important;
        top: calc(var(--header-h, 72px) + 20px) !important;
        left: auto !important;
        width: auto !important;
        height: auto !important;
        max-height: none !important;
        overflow-y: visible !important;
        box-shadow: none !important;
        padding: 0 !important;
        transition: none !important;
    }
    .hcs-filter-toggle { display: none !important; }
}

/* ── NAVIGATION HEADER — MOBILE ─────────────────────────────────────────────  */

@media (max-width: 768px) {
    .hcs-nav__menu,
    .hcs-nav__cta,
    .hcs-topbar { display: none !important; }

    .hcs-hamburger { display: flex !important; }

    .hcs-nav__inner {
        height: 60px !important;
        padding: 0 16px !important;
    }
    .hcs-nav__actions { gap: 4px !important; }
    .hcs-nav__icon-btn {
        width: 36px !important;
        height: 36px !important;
        font-size: 15px !important;
    }
}

@media (max-width: 400px) {
    .hcs-nav__inner { padding: 0 12px !important; }
    .hcs-nav__icon-btn { width: 32px !important; height: 32px !important; font-size: 14px !important; }
    .hcs-logo__sub { display: none !important; }
    .hcs-logo__text { font-size: 14px !important; }
    .hcs-logo__icon { width: 32px !important; height: 32px !important; font-size: 12px !important; }
    .hcs-cart-count { width: 16px !important; height: 16px !important; font-size: 9px !important; }
}

/* ── MINI CART — MOBILE ─────────────────────────────────────────────────────  */

@media (max-width: 480px) {
    .hcs-mini-cart {
        width: 100vw !important;
        right: 0 !important;
        left: 0 !important;
        border-radius: 0 !important;
    }
}

/* ── HOMEPAGE HERO — MOBILE ─────────────────────────────────────────────────  */

@media (max-width: 768px) {
    .hcs-hero { padding: 48px 0 40px !important; }
    .hcs-hero__inner { grid-template-columns: 1fr !important; gap: 28px !important; }
    .hcs-hero__title { font-size: clamp(24px, 6vw, 38px) !important; }
    .hcs-hero__actions { flex-direction: column !important; gap: 10px !important; }
    .hcs-hero__actions .btn { width: 100% !important; justify-content: center !important; }
    .hcs-hero__stats { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    .hcs-hero__trust { flex-wrap: wrap !important; gap: 8px !important; font-size: 11px !important; }
}

@media (max-width: 480px) {
    .hcs-hero__stat-num { font-size: 20px !important; }
    .hcs-featured-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    .hcs-why-grid { grid-template-columns: 1fr !important; }
}

/* ── SINGLE PRODUCT PAGE — MOBILE ───────────────────────────────────────────  */

@media (max-width: 768px) {
    .hcs-single-product__main {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
        padding: 16px 0 32px !important;
    }
    .hcs-single-product__title { font-size: clamp(18px, 5vw, 24px) !important; }
}

@media (max-width: 480px) {
    .hcs-single-product__thumbs { gap: 6px !important; }
    .hcs-single-product__thumb { width: 52px !important; height: 52px !important; }
    .woocommerce-tabs ul.tabs { flex-wrap: wrap !important; }
    .woocommerce-tabs ul.tabs li a { padding: 10px 12px !important; font-size: 13px !important; }
}

/* ── MY ACCOUNT DASHBOARD — MOBILE ──────────────────────────────────────────
   Screenshot shows: nav items cut off, greeting overflows, stats wrap wrong   */

@media (max-width: 900px) {
    /* ── Layout: true flex column, no grid blowout ── */
    .hcs-account-layout {
        display: flex !important;
        flex-direction: column !important;
        gap: 16px !important;
        padding: 16px 0 48px !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }
    .hcs-account-sidebar {
        position: static !important;
        top: auto !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }
    .hcs-account-content {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }

    /* Nav: horizontal scrollable tab bar */
    .hcs-account-nav {
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scrollbar-width: none !important;
        -webkit-overflow-scrolling: touch !important;
        gap: 0 !important;
        border-radius: var(--radius-lg) !important;
        width: 100% !important;
    }
    .hcs-account-nav::-webkit-scrollbar { display: none !important; }

    .hcs-account-nav__item {
        flex: 0 0 auto !important;
        min-width: 72px !important;
        flex-direction: column !important;
        gap: 4px !important;
        padding: 10px 12px !important;
        border-left: none !important;
        border-bottom: 3px solid transparent !important;
        justify-content: center !important;
        align-items: center !important;
        text-align: center !important;
        font-size: 10px !important;
        white-space: nowrap !important;
    }
    .hcs-account-nav__item i {
        width: auto !important;
        font-size: 15px !important;
        margin: 0 !important;
    }
    .hcs-account-nav__item span { display: block !important; }
    .hcs-account-nav__item.is-active {
        border-bottom-color: var(--primary) !important;
        border-left: none !important;
        background: var(--gray-50) !important;
    }

    /* Quick nav grid: 2 col */
    .hcs-account-nav-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
    }

    /* Stats row: prevent overflow */
    .hcs-account-stats {
        overflow-x: auto !important;
        scrollbar-width: none !important;
    }
    .hcs-account-stats::-webkit-scrollbar { display: none !important; }

    /* Recent orders table: don't blow out */
    .hcs-account-orders-list { overflow-x: hidden !important; }
    .hcs-account-order {
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    .hcs-account-order__actions {
        width: 100% !important;
        justify-content: flex-start !important;
    }
}

@media (max-width: 600px) {
    /* Greeting card: stack avatar + text, make Edit Profile full-width */
    .hcs-account-greeting {
        flex-wrap: wrap !important;
        gap: 12px !important;
        padding: 18px 16px !important;
        align-items: flex-start !important;
    }
    .hcs-account-greeting__text {
        flex: 1 1 calc(100% - 56px - 12px) !important;
        min-width: 0 !important;
    }
    .hcs-account-greeting__name {
        font-size: 16px !important;
        word-break: break-word !important;
    }
    .hcs-account-greeting__email {
        font-size: 12px !important;
        word-break: break-all !important;
        overflow-wrap: anywhere !important;
    }
    .hcs-account-greeting__edit {
        width: 100% !important;
        justify-content: center !important;
        margin-top: 4px !important;
    }

    /* Stats: 3 items → always 1 row, allow wrapping */
    .hcs-account-stats {
        grid-template-columns: repeat(3, 1fr) !important;
    }
    .hcs-account-stat {
        padding: 12px 10px !important;
    }
    .hcs-account-stat__num {
        font-size: 16px !important;
    }
    .hcs-account-stat__num .woocommerce-Price-amount {
        font-size: 14px !important;
    }
    .hcs-account-stat__label {
        font-size: 10px !important;
    }

    /* Nav grid: 2 cols */
    .hcs-account-nav-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 8px !important;
    }
    .hcs-account-nav-card {
        padding: 12px 10px !important;
        gap: 8px !important;
    }
    .hcs-account-nav-card__icon {
        width: 34px !important;
        height: 34px !important;
        font-size: 14px !important;
    }
    .hcs-account-nav-card__title { font-size: 12px !important; }
    .hcs-account-nav-card__sub { font-size: 10px !important; }
    .hcs-account-nav-card__arrow { display: none !important; }

    /* Account orders list */
    .hcs-account-order {
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    .hcs-account-order__actions {
        width: 100% !important;
        justify-content: flex-start !important;
    }
}

@media (max-width: 400px) {
    /* Stats: stack to 1 col on tiny phones if total spent value is long */
    .hcs-account-stats {
        grid-template-columns: 1fr 1fr !important;
    }
    /* Nav cards: single column */
    .hcs-account-nav-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ── CONTAINER — GLOBAL PADDING ─────────────────────────────────────────────  */

@media (max-width: 768px) {
    .container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
}
@media (max-width: 400px) {
    .container {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }
}

/* ── PREVENT HORIZONTAL SCROLL ──────────────────────────────────────────────  */

@media (max-width: 768px) {
    html, body { max-width: 100% !important; overflow-x: hidden !important; }
    .hcs-header, .hcs-nav, .hcs-footer, .hcs-hero { overflow-x: hidden !important; }
}
/* ═══════════════════════════════════════════════════════════════════════════
   VD / MEMBER PRICING — Product Card Badge (improved)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Main VD price layout */
.hcs-price--vd {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

/* The member final price — most prominent */
.hcs-price__vd {
    font-size: 20px;
    font-weight: 800;
    color: var(--primary-dark);
    line-height: 1.1;
}

/* Strikethrough original */
.hcs-price--vd .hcs-price__original {
    font-size: 12px;
    color: var(--gray-400);
    text-decoration: line-through;
    line-height: 1;
}

/* Sale price shown above VD price (when product has BOTH sale + VD) */
.hcs-price--vd .hcs-price__sale {
    font-size: 13px;
    font-weight: 600;
    color: var(--gray-600);
    line-height: 1;
}

/* "Member X% off" badge */
.hcs-price__badge--vd {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(232, 99, 26, 0.1);
    color: var(--primary-dark);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.3px;
    padding: 3px 8px;
    border-radius: 20px;
    border: 1px solid rgba(232, 99, 26, 0.25);
    width: fit-content;
    margin-top: 2px;
}
.hcs-price__badge--vd i { color: var(--primary); }

/* Mobile: smaller vd price */
@media (max-width: 480px) {
    .hcs-price__vd { font-size: 16px !important; }
    .hcs-price__badge--vd { font-size: 9px !important; padding: 2px 6px !important; }
}

/* Login prompt for guests */
.hcs-vd-login-prompt {
    font-size: 11px;
    color: var(--gray-400);
    margin-top: 4px;
    display: block;
}
.hcs-vd-login-prompt a { color: var(--primary); }


/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE PRODUCT — VD price badge highlight
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-sp-price__badge--vd {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(232, 99, 26, 0.1);
    color: var(--primary-dark);
    font-size: 12px;
    font-weight: 700;
    padding: 6px 14px;
    border-radius: 20px;
    border: 1.5px solid rgba(232, 99, 26, 0.3);
    margin-top: 8px;
}
.hcs-sp-price__badge--vd i { color: var(--primary); font-size: 11px; }

/* ═══════════════════════════════════════════════════════════════════════════
   WISHLIST TOAST — bottom-center notification
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-wishlist-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(80px);
    background: var(--white);
    border: 1.5px solid var(--gray-100);
    border-radius: var(--radius-lg);
    box-shadow: 0 8px 32px rgba(13,27,62,.14);
    padding: 12px 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--gray-800);
    z-index: 9999;
    opacity: 0;
    transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
    min-width: 240px;
    max-width: 90vw;
    pointer-events: none;
}
.hcs-wishlist-toast.is-visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    pointer-events: auto;
}
.hcs-wishlist-toast__icon { font-size: 18px; flex-shrink: 0; }
.hcs-wishlist-toast__msg  { flex: 1; line-height: 1.4; }
.hcs-wishlist-toast__close {
    background: none; border: none; cursor: pointer;
    color: var(--gray-400); font-size: 12px; padding: 4px;
    border-radius: var(--radius-sm); transition: color .15s;
}
.hcs-wishlist-toast__close:hover { color: var(--gray-700); }


/* ═══════════════════════════════════════════════════════════════════════════
   CART TOAST
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-cart-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--navy);
    color: #fff;
    border-radius: var(--radius-lg);
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
    z-index: 9998;
    opacity: 0;
    transition: transform .35s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
    min-width: 280px;
    max-width: 90vw;
    box-shadow: 0 8px 32px rgba(13,27,62,.25);
    pointer-events: none;
}
.hcs-cart-toast.is-visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    pointer-events: auto;
}
.hcs-cart-toast__icon { color: #4ade80; font-size: 18px; flex-shrink: 0; }
.hcs-cart-toast__msg  { flex: 1; line-height: 1.4; }
.hcs-cart-toast__btn {
    background: var(--primary);
    color: #fff !important;
    border-radius: var(--radius-sm);
    padding: 6px 14px;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
    text-decoration: none !important;
    flex-shrink: 0;
}
.hcs-cart-toast__btn:hover { background: var(--primary-dark); }
.hcs-cart-toast__close {
    background: none; border: none; cursor: pointer;
    color: rgba(255,255,255,.5); font-size: 14px;
    padding: 4px; flex-shrink: 0;
}
.hcs-cart-toast__close:hover { color: #fff; }

/* ═══════════════════════════════════════════════════════════════════════════
   FILTER LOADING STATE
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-product-grid.is-loading {
    opacity: 0.45;
    pointer-events: none;
    transition: opacity 0.2s;
    position: relative;
}
.hcs-product-grid.is-loading::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.4);
    border-radius: var(--radius);
}

/* ═══════════════════════════════════════════════════════════════════════════
   VD MEMBER DISCOUNT — product card + single product badge refinements
   ═══════════════════════════════════════════════════════════════════════════ */

/* Card: VD price row */
.hcs-price--vd {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.hcs-price__vd {
    font-size: 18px;
    font-weight: 800;
    color: var(--primary-dark);
    line-height: 1.2;
}
.hcs-price__badge--vd {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--primary-light);
    color: var(--primary-dark);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.3px;
    padding: 3px 8px;
    border-radius: 50px;
    border: 1px solid rgba(232,99,26,.2);
    width: fit-content;
    margin-top: 2px;
}
.hcs-price__badge--vd i { font-size: 10px; }

/* Single product: VD price badge  */
.hcs-sp-price__badge--vd {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--primary-light);
    color: var(--primary-dark);
    border: 1.5px solid rgba(232,99,26,.25);
    border-radius: var(--radius);
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 700;
    margin-top: 6px;
    width: fit-content;
}
.hcs-sp-price__badge--vd i { font-size: 12px; }

/* Login prompt for guests (hcs_vd_login_prompt) */
.hcs-vd-login-prompt {
    font-size: 12px;
    color: var(--gray-400);
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 5px;
}
.hcs-vd-login-prompt a {
    color: var(--primary);
    font-weight: 600;
    text-decoration: none;
}
.hcs-vd-login-prompt a:hover { text-decoration: underline; }


/* ═══════════════════════════════════════════════════════════════════════════
   CART COUNT BADGE — definitive always-in-DOM rules
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-cart-count {
    position: absolute;
    top: -4px;
    right: -6px;
    min-width: 18px;
    height: 18px;
    background: var(--primary);
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    border-radius: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
    line-height: 1;
    z-index: 2;
    pointer-events: none;
}
.hcs-cart-count--hidden {
    display: none !important;
}
/* Parent button must be relative for badge positioning */
.hcs-cart-trigger,
button.hcs-nav__icon-btn.hcs-cart-trigger {
    position: relative;
}


/* ═══════════════════════════════════════════════════════════════════════════
   CART TOAST — add-to-cart success notification
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-cart-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--navy);
    color: #fff;
    border-radius: var(--radius-lg);
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
    font-weight: 500;
    z-index: 9999;
    opacity: 0;
    transition: transform .35s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
    min-width: 280px;
    max-width: 90vw;
    pointer-events: none;
    box-shadow: 0 8px 32px rgba(0,0,0,.3);
}
.hcs-cart-toast.is-visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    pointer-events: auto;
}
.hcs-cart-toast__icon { color: #22c55e; font-size: 18px; flex-shrink: 0; }
.hcs-cart-toast__msg  { flex: 1; line-height: 1.4; }
.hcs-cart-toast__btn  {
    background: var(--primary);
    color: #fff;
    border-radius: var(--radius-sm);
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background .15s;
}
.hcs-cart-toast__btn:hover { background: var(--primary-dark); }
.hcs-cart-toast__close {
    background: none;
    border: none;
    cursor: pointer;
    color: rgba(255,255,255,.5);
    font-size: 13px;
    padding: 4px;
    flex-shrink: 0;
}
.hcs-cart-toast__close:hover { color: #fff; }


/* ═══════════════════════════════════════════════════════════════════════════
   CART TOTALS — VD member discount row
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-cart-vd-saving th {
    font-size: 14px;
    font-weight: 600;
    color: var(--primary-dark);
    padding: 8px 0;
}
.hcs-cart-vd-saving td { padding: 8px 0; }
.hcs-cart-vd-saving__amount {
    font-size: 16px;
    font-weight: 800;
    color: var(--primary-dark);
    display: block;
}
.hcs-cart-vd-saving__note {
    font-size: 11px;
    color: var(--gray-400);
    display: block;
    margin-top: 2px;
}

/* ── Mini cart VD badge ──────────────────────────────────────────────────── */
.hcs-mini-cart-vd-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    font-weight: 700;
    color: var(--primary-dark);
    background: var(--primary-light);
    border-radius: 50px;
    padding: 2px 7px;
    margin-top: 4px;
    margin-left: 0;
}
.hcs-mini-cart-vd-badge i { font-size: 9px; }

/* ── Mini cart item layout — cleaner grid ────────────────────────────────── */
.hcs-mini-cart .woocommerce-mini-cart-item {
    display: grid !important;
    grid-template-columns: 64px 1fr 24px !important;
    grid-template-rows: auto auto !important;
    gap: 0 12px !important;
    padding: 14px 20px !important;
    align-items: start !important;
    border-bottom: 1px solid var(--gray-100) !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item img {
    grid-column: 1 !important;
    grid-row: 1 / 3 !important;
    width: 64px !important;
    height: 64px !important;
    object-fit: cover !important;
    border-radius: var(--radius-sm) !important;
    border: 1px solid var(--gray-100) !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item > a:not(.remove_from_cart_button) {
    grid-column: 2 !important;
    grid-row: 1 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--navy) !important;
    line-height: 1.4 !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item .quantity {
    grid-column: 2 !important;
    grid-row: 2 !important;
    font-size: 12px !important;
    color: var(--gray-500) !important;
    margin-top: 4px !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item .remove_from_cart_button {
    grid-column: 3 !important;
    grid-row: 1 / 3 !important;
    font-size: 16px !important;
    color: var(--gray-300) !important;
    align-self: center !important;
    transition: color .15s !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item .remove_from_cart_button:hover {
    color: var(--danger) !important;
}

/* ── Mini cart quantity format: show "2 × $8,990.00" ──────────────────── */
.hcs-mini-cart .woocommerce-mini-cart-item .quantity {
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
    flex-wrap: wrap !important;
}
.hcs-mini-cart .woocommerce-mini-cart-item .quantity .woocommerce-Price-amount {
    font-weight: 700 !important;
    color: var(--primary-dark) !important;
    font-size: 14px !important;
}

/* ── Mini cart total section ─────────────────────────────────────────────── */
.hcs-mini-cart .woocommerce-mini-cart__total {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 14px 20px !important;
    background: var(--gray-50) !important;
    border-top: 1.5px solid var(--gray-100) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--navy) !important;
}
.hcs-mini-cart .woocommerce-mini-cart__total .woocommerce-Price-amount {
    font-size: 18px !important;
    color: var(--primary-dark) !important;
}

/* ── Mini cart buttons: side by side ─────────────────────────────────────── */
.hcs-mini-cart .woocommerce-mini-cart__buttons {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    padding: 14px 20px 20px !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px !important;
    border-radius: var(--radius) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    transition: var(--transition) !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .button:first-child {
    background: var(--white) !important;
    border: 1.5px solid var(--gray-200) !important;
    color: var(--navy) !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .button:first-child:hover {
    border-color: var(--primary) !important;
    color: var(--primary) !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .checkout {
    background: var(--primary) !important;
    border: none !important;
    color: #fff !important;
}
.hcs-mini-cart .woocommerce-mini-cart__buttons .checkout:hover {
    background: var(--primary-dark) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ORDERS PAGE — clean table styling
   ═══════════════════════════════════════════════════════════════════════════ */

/* WC orders table container */
.woocommerce-orders-table__wrapper { overflow-x: auto; }

.woocommerce-orders-table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 14px !important;
    background: var(--white) !important;
    border: 1.5px solid var(--gray-100) !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
}
.woocommerce-orders-table thead {
    background: var(--gray-50) !important;
}
.woocommerce-orders-table th {
    text-align: left !important;
    padding: 12px 16px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    color: var(--gray-500) !important;
    border-bottom: 1.5px solid var(--gray-100) !important;
    white-space: nowrap !important;
}
.woocommerce-orders-table td {
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--gray-100) !important;
    color: var(--gray-700) !important;
    vertical-align: middle !important;
}
.woocommerce-orders-table tr:last-child td { border-bottom: none !important; }
.woocommerce-orders-table tr:hover td { background: var(--gray-50) !important; }

/* Order number link */
.woocommerce-orders-table .woocommerce-orders-table__cell-order-number a {
    font-weight: 700 !important;
    color: var(--navy) !important;
}
.woocommerce-orders-table .woocommerce-orders-table__cell-order-number a:hover {
    color: var(--primary) !important;
}

/* Status badges */
.woocommerce-orders-table .woocommerce-orders-table__cell-order-status mark {
    background: var(--gray-100) !important;
    color: var(--gray-700) !important;
    padding: 4px 10px !important;
    border-radius: 50px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}
.woocommerce-orders-table mark.order-status-completed { background: #dcfce7 !important; color: #15803d !important; }
.woocommerce-orders-table mark.order-status-processing { background: #dbeafe !important; color: #1d4ed8 !important; }
.woocommerce-orders-table mark.order-status-pending { background: #fef9c3 !important; color: #854d0e !important; }
.woocommerce-orders-table mark.order-status-cancelled,
.woocommerce-orders-table mark.order-status-failed { background: var(--danger-light) !important; color: var(--danger) !important; }

/* View button */
.woocommerce-orders-table .woocommerce-button {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    background: none !important;
    border: 1.5px solid var(--primary) !important;
    color: var(--primary) !important;
    border-radius: var(--radius-sm) !important;
    padding: 6px 14px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: background .15s, color .15s !important;
    text-decoration: none !important;
}
.woocommerce-orders-table .woocommerce-button:hover {
    background: var(--primary) !important;
    color: #fff !important;
}

/* "No order" info box */
.woocommerce-account .woocommerce-Message,
.woocommerce-account .woocommerce-info {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    background: var(--white) !important;
    border: 1.5px solid var(--gray-100) !important;
    border-left: 4px solid var(--primary) !important;
    border-radius: var(--radius) !important;
    padding: 20px !important;
    font-size: 14px !important;
    color: var(--gray-600) !important;
}
.woocommerce-account .woocommerce-Message::before,
.woocommerce-account .woocommerce-info::before { display: none !important; }
.woocommerce-account .woocommerce-Message .button,
.woocommerce-account .woocommerce-info .button {
    background: var(--primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--radius-sm) !important;
    padding: 10px 20px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PRODUCT CARD — height equalisation (VD vs non-VD cards)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Reserve vertical space for VD badge so all cards in the same row
   have the same price area height, preventing unequal card heights. */
.hcs-product-card__price-wrap {
    /* min-height removed — was causing empty gap below price area */
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE — filter toggle + hamburger fixes
   ═══════════════════════════════════════════════════════════════════════════ */

/* Show filter toggle button on mobile */
@media (max-width: 768px) {
    .hcs-filter-toggle { display: flex !important; }
    .hcs-shop-sidebar {
        position: fixed !important;
        top: 0 !important;
        left: -100% !important;
        width: min(320px, 92vw) !important;
        height: 100vh !important;
        background: var(--white) !important;
        z-index: 1200 !important;
        padding: 20px 16px 40px !important;
        overflow-y: auto !important;
        box-shadow: 4px 0 32px rgba(13,27,62,.18) !important;
        transition: left .3s cubic-bezier(.4,0,.2,1) !important;
    }
    .hcs-shop-sidebar.is-open { left: 0 !important; }
}

/* Hamburger always visible on mobile — prevent clipping */
@media (max-width: 768px) {
    .hcs-header, .hcs-nav { overflow: visible !important; }
    .hcs-nav__inner {
        overflow: visible !important;
        padding: 0 14px !important;
    }
    .hcs-hamburger { display: flex !important; flex-shrink: 0 !important; }
    .hcs-nav__menu, .hcs-nav__cta { display: none !important; }
}
@media (max-width: 420px) {
    .hcs-nav__inner { padding: 0 10px !important; gap: 4px !important; }
    .hcs-nav__icon-btn { width: 34px !important; height: 34px !important; }
    .hcs-logo__text { font-size: 14px !important; }
    .hcs-logo__sub { display: none !important; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   WISHLIST TOAST — cleanup duplicate styles
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-wishlist-toast {
    position: fixed !important;
    bottom: 80px !important; /* above cart toast */
    left: 50% !important;
    transform: translateX(-50%) translateY(80px) !important;
    background: var(--white) !important;
    border: 1.5px solid var(--gray-100) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: 0 8px 32px rgba(13,27,62,.14) !important;
    padding: 12px 16px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 14px !important;
    color: var(--gray-800) !important;
    z-index: 9998 !important;
    opacity: 0 !important;
    transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s ease !important;
    min-width: 240px !important;
    max-width: 90vw !important;
    pointer-events: none !important;
}
.hcs-wishlist-toast.is-visible {
    transform: translateX(-50%) translateY(0) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   LOGIN / REGISTER PAGE — REDESIGNED v2.0 (split layout)
   The brand panel on the left replaces the WC page title, so we hide it.
   Left: navy branding panel. Right: form with toggle.
   Fully responsive: stacks on mobile.
   ═══════════════════════════════════════════════════════════════════════════ */


/* ── Hide WC page title on login page — brand panel replaces it ────────────── */
.woocommerce-account:not(.logged-in) h1.page-title,
.woocommerce-account:not(.logged-in) h1.entry-title,
.woocommerce-account:not(.logged-in) .page-title {
    display: none !important;
}
.woocommerce-account:not(.logged-in) .hcs-breadcrumb {
    display: none !important;
}

/* ════════════════════════════════════════════════════════════════════════════
   LOGIN / REGISTER — Centred card layout (v3.0)
   Single card, max 480px, toggle pill (Login / Register).
   NO left branding panel — clean minimal form only.
   ════════════════════════════════════════════════════════════════════════════ */

.hcs-auth-wrap {
    max-width: 480px;
    width: 100%;
    margin: 40px auto 80px;
    background: var(--white);
    border-radius: 20px;
    box-shadow: 0 8px 48px rgba(13,27,62,.12);
    padding: 36px 36px 32px;
    box-sizing: border-box;
}

/* ── Toggle pill ──────────────────────────────────────────────────────────── */
.hcs-auth-toggle {
    display: flex;
    background: var(--gray-100);
    border-radius: var(--radius-full);
    padding: 4px;
    margin-bottom: 28px;
    position: relative;
    z-index: 10;
}
.hcs-auth-toggle__btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 9px 16px;
    border: none;
    border-radius: var(--radius-full);
    background: transparent;
    color: var(--gray-500);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
}
.hcs-auth-toggle__btn.is-active {
    background: var(--white);
    color: var(--navy);
    box-shadow: 0 2px 8px rgba(0,0,0,.10);
}
.hcs-auth-toggle__btn i { font-size: 12px; }

/* ── Panel visibility ─────────────────────────────────────────────────────── */
.hcs-auth-panel {
    display: none;
}
.hcs-auth-panel.is-active {
    display: block;
}

/* ── Panel header: icon + title + sub + divider ───────────────────────────── */
.hcs-auth-panel__header {
    text-align: center;
    margin-bottom: 24px;
}
.hcs-auth-panel__icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    margin: 0 auto 14px;
}
.hcs-auth-panel__icon--login {
    background: rgba(232,99,26,.12);
    color: var(--primary);
}
.hcs-auth-panel__icon--register {
    background: rgba(13,27,62,.08);
    color: var(--navy);
}
.hcs-auth-panel__title {
    font-size: 22px;
    font-weight: 800;
    color: var(--navy);
    margin: 0 0 6px;
    line-height: 1.2;
}
.hcs-auth-panel__sub {
    font-size: 13.5px;
    color: var(--gray-500);
    margin: 0;
}
.hcs-auth-panel__divider {
    width: 36px;
    height: 3px;
    background: var(--primary);
    border-radius: 2px;
    margin: 14px auto 0;
}
#hcs-panel-login .hcs-auth-panel__divider { background: var(--primary); }
#hcs-panel-register .hcs-auth-panel__divider { background: var(--navy); }

/* ── Form groups ──────────────────────────────────────────────────────────── */
.hcs-form-group {
    margin-bottom: 16px;
}
.hcs-form-group label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 13px;
    font-weight: 600;
    color: var(--gray-700);
    margin-bottom: 6px;
}
.hcs-form-group label .required { color: var(--primary); }
.hcs-form-group__label-link {
    font-size: 12px;
    font-weight: 500;
    color: var(--primary);
    text-decoration: none;
}
.hcs-form-group__label-link:hover { text-decoration: underline; }

/* Input wrapper with icon */
.hcs-form-group__input-wrap {
    position: relative;
    width: 100%;
    /*display: flex;*/
    /*align-items: center;*/
}
.hcs-form-group__icon {
    position: absolute;
    left: 13px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--gray-400);
    font-size: 14px;
    pointer-events: none;
    z-index: 1;
}
.hcs-form-group__input-wrap input[type="text"],
.hcs-form-group__input-wrap input[type="email"],
.hcs-form-group__input-wrap input[type="password"] {
    width: 100%;
    padding: 11px 14px 11px 38px;
    border: 1.5px solid var(--gray-200);
    border-radius: var(--radius-md);
    font-size: 14px;
    color: var(--gray-800);
    background: var(--gray-50);
    transition: border-color .2s, box-shadow .2s;
    box-sizing: border-box;
    outline: none;
}
.hcs-form-group__input-wrap input:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(232,99,26,.10);
    background: var(--white);
}

/* Password field: extra right padding for the eye toggle */
.hcs-form-group__input-wrap input[type="password"] {
    padding-right: 40px;
}
.hcs-form-group__pw-toggle {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--gray-400);
    font-size: 14px;
    padding: 0;
    line-height: 1;
    z-index: 2;
}
.hcs-form-group__pw-toggle:hover { color: var(--gray-600); }

/* Remember me / checkbox row */
.hcs-form-group--inline {
    margin-bottom: 20px;
}
.hcs-form-group__checkbox-label {
    display: flex !important;
    align-items: center !important;
    gap: 8px;
    font-size: 13px;
    font-weight: 500;
    color: var(--gray-600);
    cursor: pointer;
    justify-content: flex-start !important;
}
.hcs-form-group__checkbox-label input[type="checkbox"] {
    width: 15px;
    height: 15px;
    accent-color: var(--primary);
    flex-shrink: 0;
}

/* Submit button */
.hcs-auth-submit {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 13px 24px;
    border: none;
    border-radius: var(--radius-md);
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: var(--transition);
    margin-bottom: 16px;
}
.hcs-auth-submit--login {
    background: var(--primary);
    color: var(--white);
}
.hcs-auth-submit--login:hover { background: var(--primary-dark); }
.hcs-auth-submit--register {
    background: var(--navy);
    color: var(--white);
}
.hcs-auth-submit--register:hover { background: #0a1530; }

/* Switch hint below button */
.hcs-auth-panel__switch-hint {
    text-align: center;
    font-size: 13px;
    color: var(--gray-500);
    margin: 0;
}
.hcs-auth-panel__switch-hint a {
    color: var(--primary);
    font-weight: 600;
    text-decoration: none;
}
.hcs-auth-panel__switch-hint a:hover { text-decoration: underline; }

/* WC error notices inside form */
.hcs-auth-panel .woocommerce-error,
.hcs-auth-panel .woocommerce-message,
.hcs-auth-panel .woocommerce-info {
    margin: 0 0 16px;
    border-radius: var(--radius-md);
    font-size: 13px;
}

/* Note below form (terms etc.) */
.hcs-auth-panel__note {
    font-size: 12px;
    color: var(--gray-400);
    text-align: center;
    margin-top: 16px;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 560px) {
    .hcs-auth-wrap {
        margin: 16px auto 40px;
        padding: 24px 18px 20px;
        border-radius: 16px;
    }
    .hcs-auth-panel__title { font-size: 19px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PRODUCT CARD — equal heights + price section alignment
   ═══════════════════════════════════════════════════════════════════════════ */

/* Card uses flex column; price-wrap pushes to bottom via margin-top:auto */
.hcs-product-card {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
}
.hcs-product-card__body {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}
/* Price section — no min-height so short prices don't leave blank space */
.hcs-product-card__price-wrap {
    margin-top: auto !important;
    padding-top: 6px !important;
}
/* Footer always at bottom */
.hcs-product-card__footer {
    margin-top: 0 !important;
    flex-shrink: 0 !important;
}

/* Price row: left-aligned, wrap cleanly */
.hcs-price {
    display: flex !important;
    align-items: baseline !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
}
/* VD price below sale/regular — column layout */
.hcs-price--vd {
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
    align-items: flex-start !important;
}
.hcs-price__vd {
    font-size: 18px !important;
    font-weight: 800 !important;
    color: var(--primary-dark) !important;
    line-height: 1.2 !important;
}
.hcs-price__badge--vd {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    background: var(--primary-light) !important;
    color: var(--primary-dark) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 3px 8px !important;
    border-radius: 50px !important;
    border: 1px solid rgba(232,99,26,.2) !important;
    width: fit-content !important;
    margin-top: 2px !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE PRODUCT PAGE — price + VD alignment
   ═══════════════════════════════════════════════════════════════════════════ */
.hcs-sp-price__wrap {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: flex-start;
}
.hcs-sp-price__row {
    display: flex;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;
}


/* ═══════════════════════════════════════════════════════════════════════════
   MINI CART — force items to always show (not cached/empty)
   ═══════════════════════════════════════════════════════════════════════════ */
/* Ensure mini cart body scrolls and shows content */
.hcs-mini-cart__body {
    flex: 1 !important;
    overflow-y: auto !important;
    min-height: 60px !important;
}
/* Loading spinner while fragments refresh */
.hcs-mini-cart__body.is-loading::after {
    content: '';
    display: block;
    width: 28px; height: 28px;
    border: 3px solid var(--gray-100);
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: hcs-spin .7s linear infinite;
    margin: 40px auto;
}
@keyframes hcs-spin { to { transform: rotate(360deg); } }


/* ═══════════════════════════════════════════════════════════════════════════
   WC SHOP NOTICES — hide on shop page (toast handles feedback)
   ═══════════════════════════════════════════════════════════════════════════ */
.woocommerce-shop .woocommerce-info,
.woocommerce-shop .woocommerce-message,
.woocommerce-shop .woocommerce-error,
.woocommerce-notices-wrapper:empty { display: none !important; }

/* ── Auth submit buttons (hcs-auth-wrap system) ─────────────────────────────
   These are used by woocommerce/myaccount/form-login.php v3.0
   The .hcs-auth-submit base styles are already above; these add the colours. */
.hcs-auth-submit--login {
    background: var(--primary, #e8631a) !important;
    color: #fff !important;
}
.hcs-auth-submit--login:hover {
    background: var(--primary-dark, #c5521a) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 20px rgba(232,99,26,.3) !important;
}
.hcs-auth-submit--register {
    background: var(--navy, #0d1b3e) !important;
    color: #fff !important;
}
.hcs-auth-submit--register:hover {
    background: #162347 !important;
    transform: translateY(-1px) !important;
}

/* ── Address edit forms (billing + shipping) ─────────────────────────────────
   Styles the WC address edit page inputs, labels, select2 dropdowns.
   The base label/input rules for EditAccountForm above don't cover these. */
.woocommerce-account .woocommerce-address-fields .form-row-first,
.woocommerce-account .woocommerce-address-fields .form-row-last {
    display: inline-block !important;
    width: calc(50% - 8px) !important;
    box-sizing: border-box !important;
    vertical-align: top !important;
}
.woocommerce-account .woocommerce-address-fields .form-row-first {
    margin-right: 8px !important;
}
.woocommerce-account .woocommerce-address-fields .form-row-wide {
    width: 100% !important;
    display: block !important;
}
.woocommerce-account .woocommerce-address-fields input[type="text"],
.woocommerce-account .woocommerce-address-fields input[type="email"],
.woocommerce-account .woocommerce-address-fields input[type="tel"],
.woocommerce-account .woocommerce-address-fields select {
    width: 100% !important;
    border: 1.5px solid var(--gray-200) !important;
    border-radius: 10px !important;
    padding: 10px 14px !important;
    font-family: var(--font) !important;
    font-size: 13.5px !important;
    color: var(--gray-900) !important;
    background: var(--gray-50) !important;
    box-sizing: border-box !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: border-color .15s !important;
}
.woocommerce-account .woocommerce-address-fields input:focus,
.woocommerce-account .woocommerce-address-fields select:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(232,99,26,.1) !important;
    background: var(--white) !important;
}
.woocommerce-account .woocommerce-address-fields label {
    font-size: 12.5px !important;
    font-weight: 600 !important;
    color: var(--gray-700) !important;
    display: block !important;
    margin-bottom: 6px !important;
}
.woocommerce-account .woocommerce-address-fields abbr[title] {
    color: var(--primary) !important;
    text-decoration: none !important;
}
.woocommerce-account .woocommerce-address-fields button[type="submit"],
.woocommerce-account .woocommerce-address-fields .button {
    background: var(--primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 12px 28px !important;
    font-family: var(--font) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    margin-top: 8px !important;
    transition: background .2s !important;
}
.woocommerce-account .woocommerce-address-fields button[type="submit"]:hover {
    background: var(--primary-dark) !important;
}
.woocommerce-account .select2-container .select2-selection--single {
    height: 42px !important;
    border: 1.5px solid var(--gray-200) !important;
    border-radius: 10px !important;
    background: var(--gray-50) !important;
}
.woocommerce-account .select2-container .select2-selection--single .select2-selection__rendered {
    line-height: 42px !important;
    padding: 0 14px !important;
    font-size: 13.5px !important;
    color: var(--gray-900) !important;
}
.woocommerce-account .select2-container .select2-selection--single .select2-selection__arrow {
    top: 8px !important;
}
@media (max-width: 540px) {
    .woocommerce-account .woocommerce-address-fields .form-row-first,
    .woocommerce-account .woocommerce-address-fields .form-row-last {
        width: 100% !important;
        display: block !important;
        margin-right: 0 !important;
    }
}

/* ── Safety: overlays never block interaction unless explicitly activated ─────
   Prevents stuck overlay from freezing the page (e.g. after a JS error or
   page-cached state where the overlay class didn't get cleaned up). */
.hcs-mini-cart__overlay:not(.is-visible),
.hcs-mobile-nav__overlay:not(.is-visible) {
    pointer-events: none !important;
    opacity: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PRODUCT CARD PRICE — FINAL CANONICAL RULES
   One consistent size for ALL cards. Overrides all previous scattered rules.
   Layout:
     Guest/no discount:   [Price]
     Sale only:           [Sale Price]  ~~[Original]~~
     Member (VD):         [Sale Price]  ~~[Original]~~   (row 1)
                          Member [VD Price]               (row 2, members only)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Base price row ──────────────────────────────────────────────────────── */
.hcs-product-card__price-wrap .hcs-price {
    display: flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
}

/* Regular price (no discount) */
.hcs-product-card__price-wrap .hcs-price__regular {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--navy) !important;
    line-height: 1.2 !important;
}

/* Sale price — same size as regular, orange */
.hcs-product-card__price-wrap .hcs-price__sale {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--primary-dark) !important;
    line-height: 1.2 !important;
}

/* Original / was-price — always smaller, crossed out */
.hcs-product-card__price-wrap .hcs-price__original {
    font-size: 12px !important;
    font-weight: 400 !important;
    color: var(--gray-400) !important;
    text-decoration: line-through !important;
    line-height: 1.2 !important;
}

/* ── VD (member) price layout ─────────────────────────────────────────────
   Row 1: sale/original prices (same as non-member row above)
   Row 2: "Member $X" — second line, slightly smaller, with label
   ─────────────────────────────────────────────────────────────────────── */
.hcs-product-card__price-wrap .hcs-price--vd {
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
    align-items: flex-start !important;
}

/* Row 1 inside VD: the sale or original prices — same row layout */
.hcs-product-card__price-wrap .hcs-price--vd .hcs-price__sale,
.hcs-product-card__price-wrap .hcs-price--vd .hcs-price__original {
    /* inherits from above */
}

/* Row 2: Member final price */
.hcs-product-card__price-wrap .hcs-price__vd {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--primary-dark) !important;
    line-height: 1.2 !important;
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
}
/* "Member" label before VD price — injected via ::before */
.hcs-product-card__price-wrap .hcs-price__vd::before {
    content: 'Member' !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    color: var(--primary) !important;
    background: var(--primary-light) !important;
    border-radius: var(--radius-full) !important;
    padding: 1px 6px !important;
    letter-spacing: 0.2px !important;
}

/* Remove old badge since label is now ::before */
.hcs-product-card__price-wrap .hcs-price__badge--vd {
    display: none !important;
}

/* Price enquire / service */
.hcs-product-card__price-wrap .hcs-price__service,
.hcs-product-card__price-wrap .hcs-price__enquire {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--success) !important;
}

/* ── Mobile: slightly smaller ────────────────────────────────────────────── */
@media (max-width: 768px) {
    .hcs-product-card__price-wrap .hcs-price__regular,
    .hcs-product-card__price-wrap .hcs-price__sale,
    .hcs-product-card__price-wrap .hcs-price__vd {
        font-size: 14px !important;
    }
    .hcs-product-card__price-wrap .hcs-price__original {
        font-size: 11px !important;
    }
}

/* Row 1 inside VD block: sale + original on same line */
.hcs-product-card__price-wrap .hcs-price__row1 {
    display: flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
}

/* Account nav: cart item count badge */
.hcs-account-nav__cart-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    background: var(--primary);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    border-radius: 50px;
    padding: 0 4px;
    margin-left: 4px;
    line-height: 1;
}

/* ═══════════════════════════════════════════════════════════════════════════
   WC NATIVE STAR RATING — single product page + reviews
   WooCommerce outputs .star-rating with a span for the filled portion.
   The text ("Rated 5 out of 5") is in an accessible <span> inside — we hide it.
   ═══════════════════════════════════════════════════════════════════════════ */

/* Base: empty star outline row */
.star-rating {
    display: inline-block;
    position: relative;
    font-size: 26px !important;
    line-height: 1;
    white-space: nowrap;
    overflow: hidden;
    width: 5.3em;
}
/* Empty star row */
.star-rating::before {
    content: "★★★★★";
    color: #ddd;
    letter-spacing: 1px;
    display: block;
}
/* Filled stars — clip to rating % */
.star-rating > span {
    display: block;
    overflow: hidden;
    position: absolute;
    top: 0; left: 0;
    white-space: nowrap;
}
.star-rating > span::before {
    content: "★★★★★";
    color: #f59e0b;
    letter-spacing: 1px;
    display: block;
}
/* Hide inner accessibility text (the number) */
.star-rating > span > span { display: none; }

/* Review star rating: slightly larger */
.woocommerce-product-rating .star-rating { font-size: 18px; margin-right: 6px; }

/* ── Review form: star selector ─────────────────────────────────────────── */
/* WC outputs: <p class="stars"><a class="star-1">1</a>...<a class="star-5">5</a></p>
   WC's own JS adds class="active" to selected star and "selected" to <p>
   We use the RTL sibling trick: stars laid out RTL so hover fills left stars too */
#respond p.stars {
    display: flex;
    flex-direction: row; /* RTL so CSS row-revrse ~ sibling selector works left→right */
    justify-content: flex-start;
    gap: 0;
    margin-bottom: 12px;
}
#respond p.stars a {
    display: inline-block;
    font-size: 0; /* hide text */
    color: #ddd;
    text-decoration: none;
    transition: color 0.1s;
    cursor: pointer;
    padding: 0 2px;
}
#respond p.stars a::before {
    content: '★';
    font-size: 26px;
    color: inherit;
    display: inline-block;
}
/* Hover: fill hovered star AND all stars to its LEFT (which are its ~ siblings in RTL) */
#respond p.stars a:hover,
#respond p.stars a:hover ~ a { color: #f59e0b; }
/* Selected: WC adds .active to clicked star */
#respond p.stars.selected a.active,
#respond p.stars.selected a.active ~ a { color: #f59e0b; }
/* Unselected stars after active */
#respond p.stars.selected a { color: #ddd; }
#respond p.stars.selected a.active,
#respond p.stars.selected a.active ~ a { color: #f59e0b; }

/* Review item: "Rated X out of 5" text — show stars instead */
.woocommerce-review__rating .star-rating { font-size: 20px; }

/* Single product page rating row (below title) */
.woocommerce-product-rating {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    font-size: 1.5rem;
    color: #E8631A;
}
/*.woocommerce-product-rating a { color: var(--primary); font-weight: 500; }*/

/* Single product: Add to Cart button loading + added states */
.hcs-single-product__cart-form .single_add_to_cart_button.loading {
    opacity: 0.75 !important;
    pointer-events: none !important;
    position: relative !important;
}
.hcs-single-product__cart-form .single_add_to_cart_button.loading::after {
    content: '';
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    width: 16px; height: 16px;
    border: 2px solid rgba(255,255,255,.4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: hcs-spin .7s linear infinite;
}
.hcs-single-product__cart-form .single_add_to_cart_button.added {
    background: var(--success) !important;
    border-color: var(--success) !important;
}
/* Hide WC's default "View cart →" link that appears after adding */
.hcs-single-product__cart-form .added_to_cart.wc-forward {
    display: none !important;
}
.hcs-star-rating {
    display: inline-block;
    position: relative;
    font-size: 1.2rem;
    line-height: 1;
    white-space: nowrap;
    overflow: hidden;
    width: 5.3em;
}
.hcs-star-rating::before {
    content: "★★★★★";
    color: #E8631A;
    letter-spacing: 1px;
    display: block;
}
.hcs-star-rating > span {
    display: block;
    overflow: hidden;
    position: absolute;
    top: 0; left: 0;
    white-space: nowrap;
}
.hcs-star-rating > span::before {
    content: "★★★★★";
    color: #E8631A;
    letter-spacing: 1px;
    display: block;
}
/*.hcs-star-rating--empty::before { color: var(--gray-100); }*/

/* ── Empty cart: hide WC Blocks default product grid ────────────────────────
   WC Blocks hardcodes woocommerce/product-new block inside wp-block-woocommerce-empty-cart-block.
   It renders li.wc-block-grid__product which ignores our PHP hooks entirely.
   We hide it and show our own grid injected via JS (see woo-hooks.php footer script).
   ─────────────────────────────────────────────────────────────────────────── */
.wp-block-woocommerce-empty-cart-block .wc-block-grid__products {
    display: none !important;
}
.wp-block-woocommerce-empty-cart-block .wp-block-product-new,
.wp-block-woocommerce-empty-cart-block .wc-block-product-new {
    display: none !important;
}
/* Our injected grid */
.hcs-empty-cart-injected {
    margin-top: 32px;
}
.hcs-empty-cart-injected h3 {
    font-size: 20px;
    font-weight: 700;
    color: var(--navy, #0d1b3e);
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 8px;
}
