/* Featured navigation */
.featured-nav { padding: .5rem 0 }

.featured-nav .featured-nav-wrapper {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
}

.featured-nav .featured-nav-list {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    list-style: none;
    padding: 0.5rem 1rem;
    margin: 0;
    min-width: min-content;
}

.featured-nav .featured-item {
    text-align: center;
    width: 96px;
    flex: 0 0 auto
}

.featured-nav .featured-link {
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem
}

    .featured-nav .featured-img {
        width: 80px;
        height: 80px;
        border-radius: 9999px;
        object-fit: cover;
        border: 1px solid var(--bs-border-color);
        /* background: var(--bs-body-bg) */
        backdrop-filter: blur(10px);
    }

.featured-nav .featured-title {
    font-size: .9rem;
    max-width: 96px
}

@media (max-width: 767.98px) {
    .featured-nav { padding: .25rem 0 }

    .featured-nav .featured-nav-list {
        justify-content: flex-start;
    }

    .featured-nav .featured-img {
        width: 64px;
        height: 64px
    }

    .featured-nav .featured-item { width: 80px }
}

/* Cart responsive layout */

:root { --cart-sticky-offset:0px  }

.cart-item-card { gap: 0.75rem }

/* Ensure images remain proportionate by default */

.cart-item-image {
    max-width: 100%;
    height: auto;
    cursor: pointer;
}

/* Cart attribute chips */

.attr-chips {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.25rem 0.5rem;
    align-items: start
}

.attr-chips span::after { content: none !important }

.attr-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    background-color: var(--bs-light);
    color: inherit;
    font-size: .875rem;
    line-height: 1.25
}

.attr-chip--accent { background-color: var(--bs-light) }

[data-bs-theme="dark"] .attr-chip,
.cart-item-card[data-bs-theme="dark"] .attr-chip { background-color: rgba(255, 255, 255, .06) }

@media (max-width: 767.98px) {
    .cart-item-card { flex-direction: column }

    .cart-item-image-col {
        width: 100%;
        padding: 0.5rem;
        height: auto !important
    }

    .cart-item-image {
        display: block;
        max-width: 100%;
        width: 100%;
        height: auto !important;
        max-height: 260px;
        object-fit: contain !important
    }

    .cart-item-content-col { padding-top: 0.25rem }

    .cart-controls-row { flex-wrap: wrap }

    .quantity-control { flex: 1 1 auto }

    .quantity-control .quantity-btn, .cart-action-btn {
        min-width: 40px;
        min-height: 40px
    }
}

@media (min-width: 768px) {
    .cart-item-card { flex-direction: row }

    .cart-item-image { max-height: 400px }
}

@media (min-width: 992px) {
    #cartSummaryCard {
        position: sticky;
        top: var(--cart-sticky-offset);
        z-index: 10
    }

    /* Increase cart item image size on desktop */
    .cart-item-image-col {
        max-width: 220px;
        max-height: 220px;
        min-width: 200px;
        min-height: 200px;
    }

    .cart-item-image { max-height: 450px; }
}

/* Cart mobile/tablet overrides to ensure stacking and no overflow */

@media (max-width: 991.98px) {
    .cart-item-card.d-flex { flex-direction: column !important }

    .cart-item-card {
        gap: 0.75rem;
        min-width: 0
    }

    .cart-item-image-col, .cart-item-content-col {
        width: 100%;
        min-width: 0
    }

    .cart-item-image-col {
        padding: 0.5rem 0.5rem 0 0.5rem;
        height: auto !important
    }

    .cart-item-image {
        display: block;
        width: 100%;
        height: auto !important;
        max-height: 260px;
        object-fit: contain !important
    }

    /* Align chips in neat columns on mobile */
    .attr-chips {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.25rem 0.5rem
    }

    .cart-controls-row {
        flex-wrap: wrap;
        gap: 0.5rem;
        justify-content: flex-start
    }

    .cart-controls-row .flex-grow-1 { display: none }

    .cart-controls-row .quantity-control { order: 0 }

    .quantity-control { flex: 1 1 140px }

    .quantity-control .quantity-input { width: 72px }

    .cart-action-btn {
        min-width: 40px;
        min-height: 40px
    }
}

/* Mobile Filters Floating Button and Drawer */

@media (max-width: 1023.98px) {
    #filterActionBar { display: none !important; }

    /* Hide legacy offcanvas trigger */
    [data-bs-target="#filtersOffcanvas"], #filtersOffcanvas { display: none !important; }
}

@media (min-width: 1024px) {
    #mobileFiltersFab, #filterDrawer, #filterDrawerBackdrop { display: none !important; }
}

.drawer-open #mobileFiltersFab,
.drawer-open .floating-total-count-container,
/* Hide selection/cart/download FABs while drawer is open */
.drawer-open #addToCollectionFab,
.drawer-open #addToCartFab,
.drawer-open #downloadSelectedFab,
/* Hide any floating actions container (e.g., chat, misc actions) */
.drawer-open .floating-actions-container { display: none !important; }

.filters-fab {
    position: fixed;
    left: 50%;
    transform: translateX(-50%);
    bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
    z-index: 1050;
    /* Glassmorphism */
    background: rgba(255, 255, 255, 0.65);
    color: var(--bs-body-color);
    border: 1px solid rgba(255, 255, 255, 0.35);
    border-radius: 999px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 6px 24px rgba(0, 0, 0, .12), inset 0 1px 0 rgba(255, 255, 255, 0.4);
    padding: 8px 12px;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}

.filters-fab.hidden { display: none !important; }

.filters-fab:focus {
    outline: 2px solid var(--bs-primary);
    outline-offset: 2px;
}

.filters-fab .fab-content {
    display: inline-flex;
    align-items: center;
}

.filters-fab .fab-badge {
    background: var(--bs-primary);
    color: #fff;
    border-radius: 999px;
    padding: .125rem .5rem;
    font-size: .75rem;
    margin-left: .25rem;
}

.filters-fab .fab-clear {
    margin-left: .5rem;
    border-radius: 999px;
    padding: 4px 10px;
    background: rgba(255, 255, 255, 0.55);
    color: var(--bs-secondary-color);
    border: 1px solid rgba(255, 255, 255, 0.35);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    text-decoration: none !important;
}

.filters-fab .fab-clear:hover, .filters-fab .fab-clear:focus {
    background: rgba(255, 255, 255, 0.7);
    text-decoration: none !important;
}

/* Dark theme adjustments for glassmorphism */

[data-bs-theme="dark"] .filters-fab {
    background: rgba(33, 36, 52, 0.6);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 6px 24px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

[data-bs-theme="dark"] .filters-fab .fab-clear {
    background: rgba(33, 36, 52, 0.55);
    border-color: rgba(255, 255, 255, 0.12);
}

[data-bs-theme="dark"] .filters-fab .fab-clear:hover,
[data-bs-theme="dark"] .filters-fab .fab-clear:focus { background: rgba(33, 36, 52, 0.7); }

.filter-drawer-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .35);
    z-index: 1060;
    opacity: 0;
    transition: opacity .25s ease;
}

.filter-drawer-backdrop.show { opacity: 1; }

.filter-drawer {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    /* Auto height to fit content instead of covering full screen */
    height: auto;
    max-height: 85vh; /* Prevent it from exceeding most of the screen */
    max-height: 85dvh; /* Dynamic viewport height - adjusts for mobile browser UI */
    max-height: 100vh; /* Fallback */
    max-height: 100dvh; /* Modern browsers */
    min-height: 50vh; /* Ensure minimum usable height */
    /* Glassmorphism */
    background: rgba(255, 255, 255, 0.7);
    color: var(--bs-body-color);
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.35);
    box-shadow: 0 -8px 24px rgba(0, 0, 0, .12), inset 0 1px 0 rgba(255, 255, 255, 0.4);
    z-index: 1070;
    transform: translateY(100%);
    transition: transform .3s ease;
    display: flex;
    flex-direction: column;
    /* Handle safe area insets */
    padding-bottom: env(safe-area-inset-bottom);
    box-sizing: border-box;
}

.filter-drawer.open { transform: translateY(0); }

/* Slide-up animation on open for extra polish */

.filter-drawer.open { animation: filterDrawerSlideUp 260ms ease-out both; }

@keyframes filterDrawerSlideUp {
    from {
        transform: translateY(8%);
        opacity: 0.85;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Dark theme glass adjustments */

[data-bs-theme="dark"] .filter-drawer {
    background: rgba(33, 36, 52, 0.7);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 -8px 24px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.filter-drawer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--bs-border-color);
}

.filter-drawer-body {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: .75rem 1rem;
    flex: 1 1 auto;
    /* Prevent scroll anchoring issues */
    overflow-anchor: none;
    /* Ensure proper scrolling on all devices */
    min-height: 0; /* Allow flex item to shrink below content size */
}

.filter-drawer-body .filter-actions { display: none !important; }

.filter-drawer-body .filter-customer-group { display: none !important; }

.filter-drawer-body .hr-customer-sep { display: none !important; }

.filter-drawer-footer {
    /* footer remains visible as body scrolls */
    display: flex;
    gap: .5rem;
    padding: .5rem;
    padding-bottom: calc(.5rem + env(safe-area-inset-bottom));
    border-top: 1px solid var(--bs-border-color);
    flex: 0 0 auto; /* Don't grow or shrink */
    /* Ensure footer doesn't interfere with scrolling */
    position: relative;
    z-index: 1;
}

.filter-drawer-footer .btn {
    height: 44px;
    flex: 1 1 0;
    margin: 0;
}

/* When filters are rendered inside the drawer, remove inner scroll caps to prevent double scroll/heights */

.filter-drawer-body .filter-fields-scrollable {
    max-height: none !important;
    min-height: 0 !important;
    overflow: visible !important;
}

/* Filter drawer specific styles - isolated from other offcanvases */

.filter-drawer {
    /* Ensure filter drawer doesn't inherit offcanvas styles */
    position: fixed !important;
    z-index: 1070 !important;
}

.filter-drawer-header {
    /* Filter drawer header specific styling */
    border-bottom: 1px solid var(--bs-border-color) !important;
    flex-shrink: 0 !important;
}

.filter-drawer-body {
    /* Filter drawer body specific styling - isolated from offcanvas-body */
    color: var(--bs-body-color) !important;
    /* Override any offcanvas-body styles that might leak */
    padding: 0.75rem 1rem !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-anchor: none !important;
    -webkit-overflow-scrolling: touch !important;
}

.filter-drawer-footer {
    /* Filter drawer footer specific styling - isolated from offcanvas-footer */
    border-top: 1px solid var(--bs-border-color) !important;
    flex: 0 0 auto !important;
    position: relative !important;
    z-index: 1 !important;
}

@media (prefers-reduced-motion: reduce) {
    .filter-drawer, .filter-drawer-backdrop { transition: none; }
}

/* Cross-browser compatibility fixes for viewport units */

@supports not (height: 100dvh) {
    .filter-drawer {
        height: auto;
        max-height: 85vh;
    }

    #mobileNavOffcanvas {
        height: 100vh;
        max-height: 100vh;
    }
}

/* iOS Safari specific fixes */

@supports (-webkit-touch-callout: none) {
    .filter-drawer {
        /* iOS Safari viewport fix */
        height: auto;
        max-height: calc(85vh - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    }

    #mobileNavOffcanvas {
        height: 100vh;
        max-height: calc(100vh - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    }

    #mobileNavOffcanvas .offcanvas-body {
        /* Fix iOS Safari scroll bounce */
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
    }
}

/* */

/* /* Android Chrome specific fixes !1! */

/* @media screen and (-webkit-min-device-pixel-ratio: 0) { */

/*   .filter-drawer, */

/*   #mobileNavOffcanvas { */

/*     /* Prevent Android Chrome address bar issues !1! */

/*     min-height: 100vh; */

/*     min-height: 100dvh; */

/*   } */

/* } */

/* =========================
   GLOBAL VARIABLES & RESET
   ========================= */

:root {
    /* Core colors */
    --bs-primary: #0d6efd;
    --bs-primary-rgb: 13,    110,    253;
    --bs-primary-lighter: #e6f0ff;
    --bs-secondary: #6c757d;
    --bs-success: #198754;
    --bs-info: #0dcaf0;
    --bs-warning: #ffc107;
    --bs-danger: #dc3545;
    --bs-light: #f8f9fa;
    --bs-dark: #212529;
    /* Light theme */
    --bs-body-bg: #f8f9fa;
    --bs-body-color: #212529;
    --bs-border-color: #dee2e6;
    --bs-card-bg: #fff;
    --bs-card-cap-bg: rgba(0, 0, 0, 0.03);
    --bs-navbar-color: rgba(0, 0, 0, 0.65);
    --bs-navbar-hover-color: rgba(0, 0, 0, 0.8);
    --bs-navbar-active-color: rgba(0, 0, 0, 1);
    --bs-input-bg: #fff;
    --bs-input-focus-bg: #fff;
    --bs-input-focus-border-color: rgba(13, 110, 253, 0.4);
    --bs-shadow-color: rgba(0, 0, 0, 0.15);
    --bs-shadow-soft: 0 5px 15px rgba(0, 0, 0, 0.05);
    --bs-shadow-medium: 0 8px 30px rgba(0, 0, 0, 0.12);
    --bs-filter-area-bg: #fff;
    --bs-panel-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    /* Compact theme variables */
    --compact-spacing-xs: 0.25rem;
    --compact-spacing-sm: 0.5rem;
    --compact-spacing-md: 0.75rem;
    --compact-spacing-lg: 1rem;
    --compact-spacing-xl: 1.5rem;
    --compact-card-radius: 0.5rem;
    --compact-btn-padding: 0.35rem 0.75rem;
    --compact-input-padding: 0.35rem 0.5rem;
    /* Style card compact variables */
    --compact-card-padding: 0.5rem;
    --compact-switch-padding: 0.25rem;
    --compact-badge-padding: 0.25rem 0.5rem;
    --compact-font-size: 0.75rem;
    --compact-swatch-height: 28px;
    --compact-spec-badge-min-width: 60px;
    /* Action bar and overlays */
    --action-btn-size: 2.5rem;
    --overlay-inset: var(--compact-spacing-sm);
}

[data-bs-theme="dark"] {
    /* Dark theme */
    --bs-body-bg: #1a1d20;
    --bs-body-color: #e9ecef;
    --bs-border-color: #343a40;
    --bs-card-bg: #212529;
    --bs-card-cap-bg: rgba(255, 255, 255, 0.05);
    --bs-navbar-color: rgba(255, 255, 255, 0.65);
    --bs-navbar-hover-color: rgba(255, 255, 255, 0.8);
    --bs-navbar-active-color: rgba(255, 255, 255, 1);
    --bs-input-bg: #343a40;
    --bs-input-focus-bg: #343a40;
    --bs-input-focus-border-color: rgba(78, 145, 255, 0.5);
    --bs-shadow-color: rgba(0, 0, 0, 0.3);
    --bs-shadow-soft: 0 5px 15px rgba(0, 0, 0, 0.2);
    --bs-shadow-medium: 0 8px 30px rgba(0, 0, 0, 0.3);
    --bs-filter-area-bg: #212529;
    --bs-panel-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
}

html { font-size: 14px; }

@media (min-width: 768px) {
    html { font-size: 16px; }
}

html {
    min-height: 100%;
    position: relative;
    scroll-behavior: smooth;
}

body {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
    margin-bottom: 100px;
    overflow-x: hidden;
    transition: background-color 0.3s ease, color 0.3s ease;
}

/* =========================
   LAYOUT & GRID
   ========================= */

.container-fluid { padding: 0 var(--compact-spacing-lg); }

/* Cart/Wishlist/Collections page container spacing to align with Styles page */

.styles-container,
.cart-container,
.wishlist-container,
.collections-container { margin-bottom: 30px; }

.row {
    margin-left: -0.5rem;
    margin-right: -0.5rem;
}

.col, .col-1, .col-10, .col-11, .col-12, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-auto, .col-lg, .col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-auto, .col-md, .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-auto, .col-sm, .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-auto, .col-xl, .col-xl-1, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-auto {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

/* =========================
   NAVBAR & HEADER
   ========================= */

.navbar {
    background-color: var(--bs-body-bg);
    border-color: var(--bs-border-color) !important;
    box-shadow: var(--bs-shadow-soft);
    padding: 0.5rem 1rem;
    position: relative;
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
    z-index: 1001;
}

.navbar-brand {
    color: var(--bs-primary);
    font-size: 1.25rem;
    font-weight: 600;
    transition: color 0.3s ease;
}

.navbar-brand:hover {
    color: var(--bs-primary);
    opacity: 0.9;
}

.navbar .nav-link {
    color: var(--bs-navbar-color) !important;
    font-weight: 500;
    padding: 0.35rem 0.75rem;
    position: relative;
    transition: color 0.2s ease;
}

.navbar .nav-link:hover { color: var(--bs-navbar-hover-color) !important; }

.navbar .nav-link.active { color: var(--bs-navbar-active-color) !important; }

.navbar .nav-link::after {
    background-color: var(--bs-primary);
    bottom: 0;
    content: '';
    height: 2px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    transition: width 0.3s ease;
    width: 0;
}

.navbar .nav-link:hover::after,
.navbar .nav-link.active::after { width: 60%; }

/* Search bar styles */

.navbar .form-control {
    background-color: var(--bs-input-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 20px;
    color: var(--bs-body-color);
    padding: 0.5rem 1rem;
    transition: all 0.3s ease;
}

.navbar .form-control:focus {
    border-color: var(--bs-input-focus-border-color);
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
}

.navbar .btn-outline-success {
    border-radius: 20px;
    padding: 0.5rem 1rem;
    transition: all 0.3s ease;
}

/* Search form styling */

.search-form .input-group {
    border-radius: 0.375rem;
    box-shadow: var(--bs-shadow-soft);
    overflow: hidden;
    transition: box-shadow 0.3s ease;
}

.search-form .input-group-text {
    background-color: var(--bs-input-bg);
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

.search-form .form-control {
    background-color: var(--bs-input-bg);
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

.search-form .input-group:focus-within { box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25); }

/* Dark theme specific search form adjustments */

[data-bs-theme="dark"] .search-form .input-group-text,
[data-bs-theme="dark"] .search-form .form-control,
[data-bs-theme="dark"] .search-form .btn { border-color: var(--bs-border-color); }

/* Theme toggle styles */

.form-check-input[type="checkbox"] {
    background-color: var(--bs-body-bg);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba(0,0,0,0.7)'/%3e%3c/svg%3e");
    background-position: left center;
    background-repeat: no-repeat;
    background-size: contain;
    border: 1px solid rgba(0, 0, 0, 0.25);
    border-radius: 1rem;
    cursor: pointer;
    height: 1.25rem;
    margin-top: 0;
    transition: background-position 0.3s ease, background-color 0.3s ease, border-color 0.3s ease;
    width: 2.5rem;
}

.form-check-input[type="checkbox"]:checked {
    background-color: var(--bs-primary);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
    background-position: right center;
    border-color: var(--bs-primary);
}

[data-bs-theme="dark"] .form-check-input[type="checkbox"]:not(:checked) {
    background-color: var(--bs-dark);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba(255,255,255,0.7)'/%3e%3c/svg%3e");
    border-color: rgba(255, 255, 255, 0.25);
}

.form-check-input:focus {
    border-color: var(--bs-input-focus-border-color);
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-primary-rgb), 0.25);
    outline: 0;
}

/* Add rotation animation for theme icon */

@keyframes rotate-icon {
    0% { transform: rotate(0deg); }

    100% { transform: rotate(360deg); }
}

.rotate-icon {
    animation: rotate-icon 0.5s ease-in-out;
    display: inline-block;
}

/* Card styling */

.card {
    background-color: var(--bs-card-bg);
    border: none;
    border-radius: var(--compact-card-radius);
    box-shadow: var(--bs-shadow-soft);
    height: 100%;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
}

.card:hover { box-shadow: var(--bs-shadow-medium); }

.card-header {
    background-color: var(--bs-card-cap-bg);
    border-bottom: 1px solid var(--bs-border-color);
    padding: 0.65rem 1rem;
}

.card-body { padding: 1rem; }

/* Counter badges styling */

#selectionBadge {
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.08);
    font-weight: 500;
    transition: all 0.3s ease;
}

#selectionBadge:hover {
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.12);
    transform: translateY(-1px);
}

[data-bs-theme="dark"] #selectionBadge { background-color: rgba(var(--bs-primary-rgb), 0.2) !important; }

/* Export and wishlist button styling */

#exportBtn,
#viewWishlist {
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
}

#exportBtn:hover:not(:disabled),
#viewWishlist:hover {
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.12);
    transform: translateY(-1px);
}

#exportBtn:disabled {
    cursor: not-allowed;
    opacity: 0.7;
}

#exportBtn:not(:disabled) { cursor: pointer; }

/* Style Card Redesign */

.style-card {
    background-color: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.375rem;
    cursor: pointer;
    overflow: hidden;
    position: relative;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
}

.style-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    transform: translateY(-3px);
}

/* Desktop Overlay Controls */

.desktop-overlay-controls {
    position: absolute;
    z-index: 10;
    padding: var(--overlay-inset) !important;
}

.desktop-checkbox-overlay {
    top: 0;
    left: 0;
    padding: inherit;
}

.desktop-wishlist-overlay {
    top: 0;
    right: 0;
    padding: 0 !important;
    margin: 0 !important;
}

/* Thorough alignment: remove intrinsic margins/paddings that offset content differently */

.desktop-checkbox-overlay .form-check {
    margin: 0 !important;
    padding: 0 !important;
}

.desktop-checkbox-overlay .form-check-input {
    margin: 0 !important; /* bootstrap adds margin-left by default */
    display: block;
}

.desktop-wishlist-overlay .desktop-wishlist-btn {
    margin: 0 !important;
    padding: 0 !important; /* rely on overlay padding for offset */
    width: 2.5rem;
    height: 2.5rem;
    box-sizing: content-box; /* keep visual inset consistent with checkbox */
}

/* Ensure equal visual inset even on hover (no shift) */

.desktop-wishlist-overlay .desktop-wishlist-btn:hover {
    transform: scale(1.1); /* visual effect only */
}

/* Desktop Checkbox Styling */

.desktop-selection-checkbox {
    width: 1.25rem !important;
    height: 1.25rem !important;
    border-radius: 0.25rem !important;
    /* border: 2px solid rgba(255, 255, 255, 0.8) !important; */
    background: rgba(255, 255, 255, 0.9) !important;
    backdrop-filter: blur(10px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    transition: all 0.2s ease;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    position: relative;
    cursor: pointer;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
}

.desktop-selection-checkbox:checked {
    background: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
    box-shadow: 0 2px 12px rgba(13, 110, 253, 0.4);
}

.desktop-selection-checkbox:checked::after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 0.75rem;
    font-weight: bold;
    line-height: 1;
}

.desktop-selection-checkbox:focus { box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25); }

/* Desktop Wishlist Button */

.desktop-wishlist-btn {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.375rem;
    border: none;
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    color: var(--bs-body-color);
    opacity: 0.7;
}

.desktop-wishlist-btn:hover {
    opacity: 1;
    transform: scale(1.1);
}

.desktop-wishlist-btn.active {
    color: var(--bs-danger);
    opacity: 1;
}

.desktop-wishlist-btn i { font-size: 1.1rem; }

/* Make desktop fullscreen button match desktop wishlist button styling */

.image-action-buttons .btn-image-fullscreen {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.375rem;
    border: none;
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    color: var(--bs-body-color);
    opacity: 0.7;
}

.image-action-buttons .btn-image-fullscreen:hover {
    opacity: 1;
    transform: scale(1.1);
}

.image-action-buttons .btn-image-fullscreen i { font-size: 1.1rem; }

[data-bs-theme="dark"] .image-action-buttons .btn-image-fullscreen { color: var(--bs-light); }

/* Desktop Content Section */

.desktop-content-section {
    padding: var(--compact-spacing-sm) !important;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

/* Desktop Content Separator */

.desktop-content-separator {
    border: none;
    border-top: 1px solid var(--bs-border-color);
    margin: 0.5rem 0;
    opacity: 0.3;
}

/* Desktop Style Info Row */

.desktop-style-info-row { margin-bottom: 0.75rem; }

.desktop-style-info { flex: 1; }

.desktop-style-number {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--bs-body-color);
    line-height: 1.2;
}

.desktop-category-name {
    font-size: 0.8rem;
    opacity: 0.7;
}

/* Desktop Price Info */

.desktop-price-info {
    text-align: right;
    min-width: 0;
}

.desktop-price-container {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.25rem;
}

.desktop-price-amount {
    font-size: 1.1rem;
    line-height: 1.2;
    color: var(--bs-success);
    font-weight: 700;
}

.desktop-price-unavailable {
    display: flex;
    align-items: center;
    font-size: 0.9rem;
    color: var(--bs-warning);
    font-weight: 500;
    padding: 0.25rem 0.5rem;
    background-color: rgba(255, 193, 7, 0.1);
    border-radius: 12px;
    border: 1px solid rgba(255, 193, 7, 0.2);
}

/* Desktop Action Buttons */

.desktop-collection-btn,
.style-card .collection-btn,
#addToCollectionFab { display: none !important; }

/* Hide collection entry points in mobile offcanvas */

@media (max-width: 991.98px) {
    .offcanvas .add-to-collection-btn,
    .offcanvas [data-bs-target="#addToCollectionModal"],
    .offcanvas [href*="AddToCollection" i] { display: none !important; }
}

/* Compact desktop action bar */

.desktop-action-buttons {
    gap: 0.4rem;
    align-items: center;
    margin-top: auto;
    /* padding-top: 0.5rem; */
    flex-wrap: wrap;
}

.desktop-action-btn {
    height: 2.25rem;
    border-radius: 8px;
    border: none;
    font-weight: 600;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1), width 0.25s ease;
    position: relative;
    overflow: hidden;
    min-width: 0;
    padding: 0.4rem 0.6rem;
    white-space: nowrap;
    box-sizing: border-box;
}

/* Normalize icon alignment */

.desktop-action-btn i {
    display: inline-block;
    line-height: 1;
    vertical-align: middle;
}

/* Label inside action buttons, hidden by default for compact look */

.desktop-action-btn .desktop-action-label {
    max-width: 0;
    opacity: 0;
    margin-left: 0; /* avoid shifting the icon when collapsed */
    transition: max-width 0.25s ease, opacity 0.2s ease;
}

/* Force-hide labels for buttons that are not expanded and not hovered */

.desktop-action-btn:not(.is-expanded):not(:hover) .desktop-action-label {
    max-width: 0 !important;
    opacity: 0 !important;
    margin-left: 0 !important;
}

/* Layout defaults: non-cart are icon-only, cart can grow */

.desktop-collection-btn,
.desktop-view-similar-btn,
.desktop-try-on-btn {
    width: 2.25rem;
    min-width: 2.25rem;
    flex: 0 0 2.25rem;
    padding-left: 0.4rem;
    padding-right: 0.4rem;
}

.desktop-add-to-cart-btn { flex: 1 1 auto; }

.desktop-add-to-cart-btn .desktop-action-label,
.desktop-add-to-cart-btn span { /* ensure existing label shows */
    max-width: 200px;
    opacity: 1;
    margin-left: 0.5rem;
}

/* Expand hovered action button, collapse others except Add to Cart */

/* When the action bar has an active hover on a button, collapse labels for others */

.desktop-action-buttons.has-hover .desktop-action-btn .desktop-action-label,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn .desktop-action-label {
    max-width: 0;
    opacity: 0;
    margin-left: 0;
}

/* Also collapse the implicit Add to Cart span label when not hovered */

.desktop-action-buttons.has-hover .desktop-add-to-cart-btn:not(:hover) span,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-add-to-cart-btn:not(:hover) span {
    max-width: 0;
    opacity: 0;
    margin-left: 0;
}

/* Hover label visibility is controlled by container-state rules below */

/* Focus-visible should expand like hover */

.desktop-action-btn:focus-visible { outline: none; }

.desktop-action-buttons.has-hover .desktop-action-btn:focus-visible .desktop-action-label,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn:focus-visible .desktop-action-label {
    max-width: 200px;
    opacity: 1;
    margin-left: 0.5rem;
}

.desktop-action-buttons.has-hover .desktop-action-btn:focus-visible,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn:focus-visible {
    width: auto;
    min-width: 2.5rem;
    flex: 1 1 auto;
    padding-left: 0.6rem;
    padding-right: 0.6rem;
}

/* Reduced motion users: minimize transitions */

@media (prefers-reduced-motion: reduce) {
    .desktop-action-btn,
    .desktop-action-btn .desktop-action-label,
    .desktop-action-buttons.has-hover .desktop-action-btn,
    .desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn { transition: none !important; }
}

/* Labels should only be visible on hover; persistent expanded width does not reveal label */

/* Ensure Add to Cart span label expands when hovered */

.desktop-add-to-cart-btn:hover span {
    max-width: 200px;
    opacity: 1;
    margin-left: 0.5rem;
}

/* Width expansion handled by container-state rules below */

/* When hovering the bar, shrink all buttons to icon-only, and let hovered one expand */

.desktop-action-buttons.has-hover .desktop-action-btn,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn {
    width: 2.25rem;
    min-width: 2.25rem;
    flex: 0 0 2.25rem;
    padding-left: 0.4rem;
    padding-right: 0.4rem;
}

.desktop-action-buttons.has-hover .desktop-action-btn:hover,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn:hover {
    width: auto;
    min-width: 2.5rem;
    flex: 1 1 auto;
    padding-left: 0.6rem;
    padding-right: 0.6rem;
}

/* Ensure hovered button shows label even when container collapses */

.desktop-action-buttons.has-hover .desktop-action-btn:hover .desktop-action-label,
.desktop-action-buttons.has-hover .desktop-action-btn.is-expanded .desktop-action-label,
.desktop-action-buttons.has-hover .desktop-action-btn.is-expanded span,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn:hover .desktop-action-label,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn.is-expanded .desktop-action-label,
.desktop-action-buttons:has(.desktop-action-btn:hover) .desktop-action-btn.is-expanded span {
    max-width: 200px;
    opacity: 1;
    margin-left: 0.5rem;
}

.desktop-action-btn:active { transform: scale(0.98); }

/* Disable hover animations on style cards */

.style-card { transition: none !important; }

.style-card:hover {
    transform: none !important;
    box-shadow: none !important;
}

.style-card:hover .style-image.image-loaded img { transform: none !important; }

.desktop-action-btn:active { transform: scale(0.98); }

/* Add to Cart Button */

.desktop-add-to-cart-btn {
    background-color: var(--bs-primary);
    border: 1px solid var(--bs-primary);
    color: #fff;
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.25);
    flex: 1;
    min-width: 120px;
}

.desktop-add-to-cart-btn:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.9);
    border-color: rgba(var(--bs-primary-rgb), 0.95);
    box-shadow: 0 4px 14px rgba(var(--bs-primary-rgb), 0.35);
    transform: translateY(-1px);
}

/* Cart Added State - Light Green */

.desktop-add-to-cart-btn.is-in-cart {
    background-color: #d4edda;
    border: 1px solid #c3e6cb;
    color: #155724;
    box-shadow: 0 2px 8px rgba(21, 87, 36, 0.25);
}

.desktop-add-to-cart-btn.is-in-cart:hover {
    background-color: #c3e6cb;
    border-color: #b8dacc;
    box-shadow: 0 4px 14px rgba(21, 87, 36, 0.35);
    transform: translateY(-1px);
}

/* Collection Button */

.desktop-collection-btn {
    background-color: var(--bs-info);
    border: 1px solid var(--bs-info);
    color: #fff;
    box-shadow: 0 2px 8px rgba(var(--bs-info-rgb), 0.25);
    width: 2.25rem;
    min-width: 2.25rem;
    flex-shrink: 0;
}

.desktop-collection-btn:hover {
    background-color: rgba(var(--bs-info-rgb), 0.9);
    border-color: rgba(var(--bs-info-rgb), 0.95);
    box-shadow: 0 4px 14px rgba(var(--bs-info-rgb), 0.35);
    transform: translateY(-1px);
}

/* View Similar Button */

.desktop-view-similar-btn {
    background-color: var(--bs-secondary);
    border: 1px solid var(--bs-secondary);
    color: #fff;
    box-shadow: 0 2px 8px rgba(108, 117, 125, 0.25);
    width: 2.25rem;
    min-width: 2.25rem;
    flex-shrink: 0;
}

.desktop-view-similar-btn:hover {
    background-color: rgba(108, 117, 125, 0.9);
    border-color: rgba(108, 117, 125, 0.95);
    box-shadow: 0 4px 14px rgba(108, 117, 125, 0.35);
    transform: translateY(-1px);
}

/* Try On Button */

.desktop-try-on-btn {
    background-color: var(--bs-warning);
    border: 1px solid var(--bs-warning);
    color: #212529; /* readable on yellow */
    box-shadow: 0 2px 8px rgba(var(--bs-warning-rgb), 0.25);
    width: 2.25rem;
    min-width: 2.25rem;
    flex-shrink: 0;
}

.desktop-try-on-btn:hover {
    background-color: rgba(var(--bs-warning-rgb), 0.9);
    border-color: rgba(var(--bs-warning-rgb), 0.95);
    box-shadow: 0 4px 14px rgba(var(--bs-warning-rgb), 0.35);
    transform: translateY(-1px);
}

.desktop-action-btn i { font-size: 1rem; }

/* Hide desktop overlays on mobile */

@media (max-width: 767.98px) {
    .desktop-overlay-controls { display: none !important; }

    .desktop-content-section { display: none !important; }
}

/* Dark theme support for desktop overlays */

[data-bs-theme="dark"] .desktop-selection-checkbox {
    background: rgba(0, 0, 0, 0.7) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
}

[data-bs-theme="dark"] .desktop-selection-checkbox:checked {
    background: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
}

[data-bs-theme="dark"] .desktop-selection-checkbox:checked::after { color: white; }

[data-bs-theme="dark"] .desktop-wishlist-btn { color: var(--bs-light); }

[data-bs-theme="dark"] .desktop-wishlist-btn:hover { opacity: 1; }

[data-bs-theme="dark"] .desktop-content-separator { border-color: rgba(255, 255, 255, 0.1); }

[data-bs-theme="dark"] .desktop-price-unavailable {
    background-color: rgba(255, 193, 7, 0.15);
    border-color: rgba(255, 193, 7, 0.3);
    color: var(--bs-warning);
}


.style-code {
    font-size: 0.75rem;
    font-weight: 600;
}

/* Selection Controls - Improved */

.selection-control {
    align-items: center;
    /* Optionally, add: */
    display: flex;
    left: 10px; /* or your preferred horizontal offset */
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2; /* if needed to appear above card content */
}

.selection-control .form-check {
    margin: 0;
    padding: 0;
}

.selection-checkbox,
.custom-checkbox,
.style-checkbox {
    -webkit-appearance: none;
    appearance: none;
    background-color: rgba(255, 255, 255, 0.9);
    border: 2px solid rgba(var(--bs-primary-rgb), 0.6);
    border-radius: 4px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
    cursor: pointer;
    height: 22px;
    margin: 0;
    padding: 0;
    position: relative;
    transition: all 0.2s ease;
    width: 22px;
}

.selection-checkbox:checked,
.custom-checkbox:checked,
.style-checkbox:checked {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.selection-checkbox:checked::after,
.custom-checkbox:checked::after,
.style-checkbox:checked::after {
    border: solid white;
    border-width: 0 2px 2px 0;
    content: "";
    height: 10px;
    left: 7px;
    position: absolute;
    top: 3px;
    transform: rotate(45deg);
    width: 5px;
}

.selection-checkbox:hover,
.custom-checkbox:hover,
.style-checkbox:hover {
    border-color: var(--bs-primary);
    transform: scale(1.1);
}

.selected-card {
    border: 2px solid var(--bs-primary);
    box-shadow: 0 5px 15px rgba(var(--bs-primary-rgb), 0.2);
}

/* Dark mode adjustments for selection */

[data-bs-theme="dark"] .selection-checkbox,
[data-bs-theme="dark"] .custom-checkbox,
[data-bs-theme="dark"] .style-checkbox {
    background-color: rgba(30, 30, 30, 0.8);
    border-color: rgba(var(--bs-primary-rgb), 0.5);
}

[data-bs-theme="dark"] .selection-checkbox:checked,
[data-bs-theme="dark"] .custom-checkbox:checked,
[data-bs-theme="dark"] .style-checkbox:checked {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.style-image {
    background-color: white;
    /* height: 220px; */
    overflow: hidden;
    position: relative;
    transition: background-color 0.3s ease;
}

/* Style number placeholder - only visible when image is loading */

.style-image::before {
    color: var(--bs-secondary);
    content: attr(data-style-no);
    font-size: 1.5rem;
    font-weight: bold;
    left: 50%;
    opacity: 0.3;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 0.3s ease;
    z-index: 0;
}

/* Hide the style number placeholder when image is loaded */

.style-image.image-loaded::before { opacity: 0; }

/* Image loading spinner */

.image-loading-spinner {
    background-color: rgba(255, 255, 255, 0.7);
    border-radius: 50%;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
    left: 50%;
    opacity: 1;
    padding: 1rem;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 0.3s ease;
    z-index: 5;
}

[data-bs-theme="dark"] .image-loading-spinner { background-color: rgba(33, 37, 41, 0.7); }

.image-loaded .image-loading-spinner {
    opacity: 0;
    pointer-events: none;
}

/* Image styling */

.style-image img {
    height: 100%;
    object-fit: contain;
    opacity: 0; /* Start with hidden image */
    padding: 0.5rem;
    transition: all 0.3s ease;
    width: 100%;
}

.style-image img.loading { opacity: 0; }

.style-image.image-loaded img { opacity: 1; }

/* Dark mode adjustments */

[data-bs-theme="dark"] .style-image { background-color: #ffffff !important; }

[data-bs-theme="dark"] .style-image::before {
    color: var(--bs-light);
    opacity: 0.15;
}

.collection-tag {
    background-color: var(--bs-primary);
    border-radius: 0 0 0 0.375rem;
    color: #fff;
    font-size: 0.7rem;
    padding: 0.2rem 0.5rem;
    position: absolute;
    right: 0;
    top: 0;
}

/* Price badge positioning and styling */

.price-badge {
    z-index: 10;
    pointer-events: none;
}

.price-badge .badge {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    border: 2px solid rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(4px);
    transition: all 0.3s ease;
}

.price-badge .badge:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .price-badge .badge {
    border-color: rgba(255, 255, 255, 0.2);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

[data-bs-theme="dark"] .price-badge .badge:hover { box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4); }

.style-specs {
    color: var(--bs-body-color);
    position: relative;
}

.spec-badges { opacity: 0.9; }

.spec-badge {
    align-items: center;
    background-color: rgba(var(--bs-primary-rgb), 0.08);
    border-radius: 0.25rem;
    color: var(--bs-primary);
    display: inline-flex;
    font-size: 0.7rem;
    padding: 0.2rem 0.5rem;
    /* Enhanced styling from redesign */
    min-width: 70px;
    font-weight: 600;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.2);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: all 0.2s ease;
}

.spec-badge:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.spec-badge-primary {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.2);
    color: var(--bs-primary);
    font-weight: 500;
}

.spec-badge-secondary {
    background-color: rgba(var(--bs-secondary-rgb), 0.1);
    border: 1px solid rgba(var(--bs-secondary-rgb), 0.2);
    color: var(--bs-secondary);
    font-weight: 500;
}

.spec-badge i {
    font-size: 0.65rem;
    margin-right: 0.25rem;
}

.style-details { margin-top: 0.5rem; }

.style-category {
    color: var(--bs-body-color);
    font-size: 0.75rem;
    font-weight: 600;
}

.style-subcategory {
    color: var(--bs-secondary);
    font-size: 0.7rem;
    margin-bottom: 0.2rem;
}

.style-metal {
    color: var(--bs-body-color);
    font-size: 0.75rem;
    font-weight: 600;
}

.style-meta {
    border-top: 1px dashed rgba(var(--bs-secondary-rgb), 0.15);
    color: var(--bs-secondary);
    font-size: 0.65rem;
    padding-top: 0.25rem;
}

/* Wishlist button redesign */

.wishlist-btn {
    background: transparent;
    border: none;
    color: var(--bs-secondary);
    cursor: pointer;
    font-size: 0.9rem;
    height: 1.5rem;
    opacity: 0.6;
    padding: 0;
    transition: transform 0.2s ease, opacity 0.2s ease, color 0.2s ease;
    width: 1.5rem;
}

.wishlist-btn:hover {
    opacity: 1;
    transform: scale(1.2);
}

.wishlist-btn.active {
    color: var(--bs-danger) !important;
    opacity: 1;
    text-shadow: 0 0 5px rgba(220, 53, 69, 0.3);
}

.wishlist-btn.active i { color: var(--bs-danger) !important; }

/* Animation styles */

.fade-in {
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}

.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

@keyframes heartBeat {
    0% { transform: scale(1); }

    15% { transform: scale(1.25); }

    30% { transform: scale(1); }

    45% { transform: scale(1.15); }

    60% { transform: scale(1); }
}

.heart-beat {
    animation: heartBeat 0.8s cubic-bezier(0.28, 0.84, 0.42, 1);
    position: relative;
    transform-origin: center;
}

@keyframes heartBeat {
    0% { transform: scale(1); }

    15% {
        filter: drop-shadow(0 0 3px rgba(220, 53, 69, 0.6));
        transform: scale(1.4);
    }

    30% { transform: scale(1); }

    45% {
        filter: drop-shadow(0 0 5px rgba(220, 53, 69, 0.7));
        transform: scale(1.3);
    }

    60% { transform: scale(1); }

    75% {
        filter: drop-shadow(0 0 2px rgba(220, 53, 69, 0.5));
        transform: scale(1.1);
    }

    100% { transform: scale(1); }
}

/* Form controls */

.form-label {
    color: var(--bs-body-color);
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 0.25rem;
}

.form-control, .form-select {
    background-color: var(--bs-input-bg);
    border-color: var(--bs-border-color);
    border-radius: 0.375rem;
    color: var(--bs-body-color);
    font-size: 0.875rem;
    padding: var(--compact-input-padding);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.form-control:focus,
.form-select:focus {
    background-color: var(--bs-input-focus-bg);
    border-color: var(--bs-input-focus-border-color);
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Modern Unified Button Styling */

.btn {
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    padding: var(--compact-btn-padding);
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    position: relative;
    overflow: hidden;
}

/* Modern glassmorphism effect for buttons */

.btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s ease;
    z-index: 1;
}

.btn:hover::before { left: 100%; }

/* Modern Primary action button styling */

.btn-primary {
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.2);
    background: linear-gradient(135deg, var(--bs-primary), rgba(var(--bs-primary-rgb), 0.9));
    border: none;
}

.btn-primary:hover {
    box-shadow: 0 8px 25px rgba(var(--bs-primary-rgb), 0.4);
    transform: translateY(-3px) scale(1.02);
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.9), var(--bs-primary));
}

.btn-primary:active {
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.15);
    transform: translateY(-1px) scale(0.98);
}

/* Button focus styling */

.btn:focus { box-shadow: 0 0 0 0.15rem rgba(var(--bs-primary-rgb), 0.25); }

/* Modern Outline button styling */

.btn-outline-primary {
    border-width: 1.5px;
    background: rgba(var(--bs-primary-rgb), 0.05);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.btn-outline-primary:hover {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.15), rgba(var(--bs-primary-rgb), 0.1));
    box-shadow: 0 8px 25px rgba(var(--bs-primary-rgb), 0.25);
    transform: translateY(-3px) scale(1.02);
    border-color: var(--bs-primary);
}

.btn-outline-primary:active {
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.15);
    transform: translateY(-1px) scale(0.98);
}

/* Danger button styling */

.btn-danger,
.btn-outline-danger { border-width: 1.5px; }

.btn-danger:hover {
    box-shadow: 0 6px 16px rgba(var(--bs-danger-rgb), 0.35);
    transform: translateY(-2px);
}

.btn-outline-danger {
    border-radius: 2rem;
    box-shadow: 0 4px 6px rgba(var(--bs-danger-rgb), 0.1);
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.btn-outline-danger:hover {
    background-color: rgba(var(--bs-danger-rgb), 0.9);
    box-shadow: 0 6px 12px rgba(var(--bs-danger-rgb), 0.2);
    transform: translateY(-2px);
}

.btn-outline-danger:active { transform: translateY(0); }

/* Success button styling */

.btn-success { box-shadow: 0 4px 12px rgba(var(--bs-success-rgb), 0.2); }

.btn-success:hover {
    box-shadow: 0 6px 16px rgba(var(--bs-success-rgb), 0.35);
    transform: translateY(-2px);
}

/* Secondary button styling */

.btn-secondary { box-shadow: 0 4px 8px rgba(var(--bs-secondary-rgb), 0.15); }

.btn-secondary:hover {
    box-shadow: 0 6px 12px rgba(var(--bs-secondary-rgb), 0.25);
    transform: translateY(-2px);
}

/* Small button styling */

.btn-sm {
    font-size: 0.8125rem;
    padding: 0.25rem 0.5rem;
}

/* =========================
   UNIFIED ICON SYSTEM
   ========================= */

/* Base icon system - consistent across all components */

.bi {
    font-size: 1rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    vertical-align: middle;
}

/* Icon size variants */

.bi-sm { font-size: 0.875rem; }

.bi-lg { font-size: 1.25rem; }

.bi-xl { font-size: 1.5rem; }

/* Modern Button with icon styling - standardized */

.btn .bi {
    margin-right: 0.375rem;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    position: relative;
    z-index: 2;
    font-size: 1rem;
}

/* Button size specific icon adjustments */

.btn-sm .bi {
    margin-right: 0.25rem;
    font-size: 0.875rem;
}

.btn-lg .bi {
    margin-right: 0.5rem;
    font-size: 1.125rem;
}

/* Icon-only buttons (no text) */

.btn:not(:has(.btn-text)) .bi {
    margin-right: 0;
    margin-left: 0;
}

/* Navigation icon consistency */

.navbar .btn.nav-link.rounded-circle i,
.theme-toggle-btn .theme-icon {
    font-size: 1.25rem;
    margin: 0;
    transition: all 0.4s ease;
}

/* Action button icon consistency */

.btn-action i,
.action-btn i {
    font-size: 1rem;
    margin: 0;
    transition: all 0.3s ease;
}

/* FAB icon consistency */

.fab-btn i,
.scroll-to-top-btn i {
    font-size: 1.25rem;
    margin: 0;
    transition: all 0.3s ease;
}

.btn:hover .bi {
    transform: translateX(3px) scale(1.1);
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2));
}

/* Special icon animations for different button types */

.btn-primary:hover .bi {
    transform: translateX(3px) scale(1.15) rotate(5deg);
    filter: drop-shadow(0 2px 6px rgba(255, 255, 255, 0.3));
}

.btn-outline-primary:hover .bi { transform: translateX(3px) scale(1.1) rotate(-3deg); }

.btn-danger:hover .bi {
    transform: translateX(3px) scale(1.1) rotate(10deg);
    filter: drop-shadow(0 2px 4px rgba(220, 53, 69, 0.3));
}

/* Modern Action button styling for card actions */

.action-btn,
.btn-action {
    align-items: center;
    border-radius: 0.5rem;
    display: inline-flex;
    gap: 0.375rem;
    justify-content: center;
    overflow: visible;
    position: relative;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.action-btn::before,
.btn-action::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05));
    border-radius: inherit;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: -1;
}

.action-btn:hover,
.btn-action:hover {
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
    transform: translateY(-3px) scale(1.02);
}

.action-btn:hover::before,
.btn-action:hover::before { opacity: 1; }

.action-btn:active,
.btn-action:active {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transform: translateY(-1px) scale(0.98);
    transition: transform 0.1s ease, box-shadow 0.1s ease;
}

/* Split button styling */

.btn-group .btn {
    border-radius: 2rem;
    border-width: 1.5px;
    font-weight: 500;
    padding: 0.4rem 1rem;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.btn-group .btn-primary { box-shadow: 0 4px 6px rgba(var(--bs-primary-rgb), 0.1); }

.btn-group .btn-outline-primary { box-shadow: 0 4px 6px rgba(var(--bs-primary-rgb), 0.08); }

.btn-group .btn:hover { transform: translateY(-2px); }

.btn-group .btn-primary:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.9);
    box-shadow: 0 6px 12px rgba(var(--bs-primary-rgb), 0.2);
}

.btn-group .btn-outline-primary:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    box-shadow: 0 6px 12px rgba(var(--bs-primary-rgb), 0.15);
}

.btn-group .dropdown-toggle-split {
    border-bottom-left-radius: 0;
    border-left-width: 0;
    border-top-left-radius: 0;
    box-shadow: none;
    margin-left: -2px;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.btn-group .btn:first-child {
    border-bottom-right-radius: 0;
    border-top-right-radius: 0;
    z-index: 1;
}

/* Dark theme adjustments */

[data-bs-theme="dark"] .btn-outline-primary:hover { background-color: rgba(var(--bs-primary-rgb), 0.15); }

[data-bs-theme="dark"] .btn-outline-danger:hover { background-color: rgba(var(--bs-danger-rgb), 0.9); }

/* Additional button styles */

/* Image action buttons for style cards */

.image-action-buttons .action-btn {
    width: 36px;
    height: 36px;
    padding: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #333;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.image-action-buttons .action-btn:hover {
    background: rgba(255, 255, 255, 0.95);
    transform: translateY(-3px) scale(1.1);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
    color: #000;
    border-color: rgba(255, 255, 255, 0.5);
}

.image-action-buttons .action-btn:hover::before { opacity: 1; }

.image-action-buttons .action-btn:active {
    transform: translateY(-1px) scale(1.05);
    transition: all 0.1s ease;
}

.image-action-buttons .action-btn i {
    font-size: 1rem;
    line-height: 1;
    margin: 0;
}

/* Dark theme adjustments for image action buttons */

[data-bs-theme="dark"] .image-action-buttons .action-btn {
    background: rgba(0, 0, 0, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #fff;
}

[data-bs-theme="dark"] .image-action-buttons .action-btn:hover {
    background: rgba(0, 0, 0, 0.85);
    color: #fff;
}

.btn-filter-action {
    align-items: center;
    display: flex;
    justify-content: center;
    min-height: 38px;
    min-width: 80px;
    border-radius: 0.25rem;
    transition: all 0.2s ease;
}

.btn-filter-action:hover {
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    transform: translateY(-1px);
}

.btn-filter-action:active {
    box-shadow: none;
    transform: translateY(0);
}

.btn-filter-action:focus { box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25); }

/* Filters area */

#filtersContainer {
    background-color: var(--bs-filter-area-bg);
    border-radius: var(--compact-card-radius);
    display: flex;
    flex-direction: column;
    height: calc(100vh - 120px);
    overflow: hidden;
    padding: 1rem;
    transition: all 0.3s ease;
}

.filters-content {
    flex-grow: 1;
    overflow-y: auto;
    padding-bottom: 0 !important;
    padding-top: 1rem !important;
}

.filters-content::-webkit-scrollbar { width: 6px; }

.filters-content::-webkit-scrollbar-track { background: transparent; }

.filters-content::-webkit-scrollbar-thumb {
    background-color: rgba(var(--bs-primary-rgb), 0.2);
    border-radius: 20px;
}

.filters-content::-webkit-scrollbar-thumb:hover { background-color: rgba(var(--bs-primary-rgb), 0.4); }

/* Dark theme scrollbar */

[data-bs-theme="dark"] .filters-content::-webkit-scrollbar-thumb { background-color: rgba(var(--bs-primary-rgb), 0.3); }

[data-bs-theme="dark"] .filters-content::-webkit-scrollbar-thumb:hover { background-color: rgba(var(--bs-primary-rgb), 0.5); }

/* Firefox scrollbar support */

.filters-content {
    scrollbar-color: rgba(var(--bs-primary-rgb), 0.2) transparent;
    scrollbar-width: thin;
}

[data-bs-theme="dark"] .filters-content { scrollbar-color: rgba(var(--bs-primary-rgb), 0.3) transparent; }

/* Filter actions container */

.filter-actions-container {
    background-color: var(--bs-filter-area-bg);
    border-top: 1px solid var(--bs-border-color);
    box-shadow: 0 -4px 6px -1px rgba(0, 0, 0, 0.1);
    margin-top: auto;
    padding: 0.75rem 1rem;
    width: 100%;
}

/* Footer */

.footer {
    background-color: var(--bs-body-bg);
    border-top: 1px solid var(--bs-border-color);
    font-size: 0.875rem;
    padding: 0.5rem 0;
    transition: background-color 0.3s ease;
}

.footer small {
    color: var(--bs-body-color);
    opacity: 0.75;
}

.footer a {
    color: var(--bs-body-color);
    opacity: 0.75;
    transition: opacity 0.2s ease;
}

.footer a:hover {
    opacity: 1;
    text-decoration: none;
}

/* Stats and badges */

.stats-badge {
    align-items: center;
    background-color: var(--bs-primary-lighter);
    border-radius: 0.75rem;
    color: var(--bs-primary);
    display: inline-flex;
    font-size: 0.75rem;
    font-weight: 500;
    margin-right: 0.5rem;
    padding: 0.25rem 0.6rem;
    transition: all 0.3s ease;
}

[data-bs-theme="dark"] .stats-badge { background-color: rgba(var(--bs-primary-rgb), 0.2); }

.stats-badge .bi { margin-right: 0.25rem; }

/* Text styling */

.text-muted { color: #6c757d !important; }

[data-bs-theme="dark"] .text-muted { color: #adb5bd !important; }

/* Checkbox styling */

.form-check-input { cursor: pointer; }

/* Animation keyframes */

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateX(-20px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes pulse {
    0% { transform: scale(1); }

    50% { transform: scale(1.05); }

    100% { transform: scale(1); }
}

/* Animations */

.fade-in { animation: fadeIn 0.5s ease forwards; }

.slide-in { animation: slideIn 0.3s ease forwards; }

.pulse { animation: pulse 2s infinite; }

/* Spinner Pulse Animation for Loading Indicator */

.spinner-pulse-container {
    align-items: center;
    display: inline-flex;
    justify-content: center;
}

.spinner-pulse {
    animation: spinner-pulse 1.5s infinite ease-in-out;
    background: linear-gradient(135deg, var(--bs-primary) 0%, var(--bs-primary-lighter, rgba(var(--bs-primary-rgb), 0.7)) 50%, var(--bs-primary) 100%);
    background-size: 200% 200%;
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(var(--bs-primary-rgb), 0.3);
    height: 40px;
    position: relative;
    width: 40px;
}

/* Logo variants for the spinner */

.spinner-pulse .spinner-logo {
    height: auto;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: filter 0.3s ease;
    width: 60%;
    z-index: 2;
}

[data-bs-theme="dark"] .spinner-pulse .spinner-logo {
    content: url("../images/kama-logo-light.png");
    filter: drop-shadow(0 1px 3px rgba(0, 0, 0, 0.5));
}

[data-bs-theme="light"] .spinner-pulse .spinner-logo {
    content: url("../images/kama-logo-dark.png");
    filter: drop-shadow(0 1px 2px rgba(255, 255, 255, 0.5));
}

.spinner-pulse::before,
.spinner-pulse::after {
    background: rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    content: "";
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%) scale(0);
}

.spinner-pulse::before {
    animation: spinner-ripple 1.5s infinite ease-out;
    height: 100%;
    width: 100%;
}

.spinner-pulse::after {
    animation: spinner-ripple 1.5s infinite ease-out 0.5s;
    height: 70%;
    width: 70%;
}

@keyframes spinner-pulse {
    0% {
        background-position: 0% 0%;
        transform: scale(0.95);
    }

    50% {
        background-position: 100% 100%;
        transform: scale(1.05);
    }

    100% {
        background-position: 0% 0%;
        transform: scale(0.95);
    }
}

@keyframes spinner-ripple {
    0% {
        opacity: 1;
        transform: translate(-50%, -50%) scale(0);
    }

    100% {
        opacity: 0;
        transform: translate(-50%, -50%) scale(1.7);
    }
}

/* Loading pulse animation for viewport */

.loading-pulse {
    align-items: center;
    animation: loading-pulse 1.5s infinite;
    background-color: var(--bs-primary);
    background-image: linear-gradient(135deg, var(--bs-primary) 0%, var(--bs-primary-lighter, rgba(var(--bs-primary-rgb), 0.7)) 50%, var(--bs-primary) 100%);
    background-size: 200% 200%;
    border-radius: 50%;
    bottom: 85px;
    box-shadow: 0 0 15px rgba(var(--bs-primary-rgb), 0.3);
    display: flex;
    height: 40px;
    justify-content: center;
    overflow: hidden;
    position: fixed;
    right: 20px;
    width: 40px;
    z-index: 1035;
}

/* Logo variants for the loading pulse */

.loading-pulse .pulse-logo {
    height: auto;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: filter 0.3s ease;
    width: 60%;
    z-index: 2;
}

[data-bs-theme="dark"] .loading-pulse .pulse-logo {
    content: url("../images/kama-logo-light.png");
    filter: drop-shadow(0 1px 3px rgba(0, 0, 0, 0.5));
}

[data-bs-theme="light"] .loading-pulse .pulse-logo {
    content: url("../images/kama-logo-dark.png");
    filter: drop-shadow(0 1px 2px rgba(255, 255, 255, 0.5));
}

.pulse-ripple {
    animation: pulse-ripple-inner 1.5s infinite ease-out;
    background-color: rgba(255, 255, 255, 0.25);
    border-radius: 50%;
    height: 70%;
    position: relative;
    width: 70%;
}

@keyframes pulse-ripple-inner {
    0% {
        opacity: 0.3;
        transform: scale(0.5);
    }

    50% {
        opacity: 0.5;
        transform: scale(1.2);
    }

    100% {
        opacity: 0.3;
        transform: scale(0.5);
    }
}

.loading-pulse::before {
    animation: ripple 1.5s infinite ease-out;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    content: "";
    height: 100%;
    position: absolute;
    transform: scale(0);
    width: 100%;
}

.loading-pulse::after {
    animation: ripple 1.5s infinite ease-out 0.5s;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 50%;
    content: "";
    height: 70%;
    position: absolute;
    transform: scale(0);
    width: 70%;
}

@keyframes loading-pulse {
    0% {
        background-position: 0% 0%;
        box-shadow: 0 0 0 0 rgba(var(--bs-primary-rgb), 0.7);
        transform: scale(0.95);
    }

    50% {
        background-position: 100% 100%;
        box-shadow: 0 0 15px 6px rgba(var(--bs-primary-rgb), 0.4);
        transform: scale(1);
    }

    100% {
        background-position: 0% 0%;
        box-shadow: 0 0 0 0 rgba(var(--bs-primary-rgb), 0.7);
        transform: scale(0.95);
    }
}

@keyframes ripple {
    0% {
        opacity: 1;
        transform: scale(0);
    }

    100% {
        opacity: 0;
        transform: scale(1.5);
    }
}

/* Hover effect */

/* .style-card:hover .style-image.image-loaded img { transform: scale(1.05); } */

/* Metal color variants with theme support */

.metal-all {
    background-color: var(--bs-light);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .metal-all { background-color: var(--bs-dark); }

.metal-all.active {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

[data-bs-theme="dark"] .metal-all.active {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: var(--bs-white);
}

/* Gold with theme support */

.metal-gold {
    background-color: rgba(255, 215, 0, 0.1);
    color: #b8860b;
}

[data-bs-theme="dark"] .metal-gold {
    background-color: rgba(255, 215, 0, 0.05);
    color: #ffd700;
}

.metal-gold i { color: #ffd700; }

.metal-gold.active {
    background-color: #ffd700;
    border-color: #b8860b;
    color: #5a4500;
}

[data-bs-theme="dark"] .metal-gold.active {
    background-color: #ffd700;
    border-color: #ffd700;
    color: #5a4500;
}

/* Dual tone (Gold & Silver) with theme support */

.metal-dualtone {
    background: linear-gradient(135deg, rgba(255, 215, 0, 0.15) 0%, rgba(192, 192, 192, 0.15) 100%);
    border: 1px solid rgba(168, 148, 94, 0.2);
    color: #a8945e;
}

[data-bs-theme="dark"] .metal-dualtone {
    background: linear-gradient(135deg, rgba(255, 215, 0, 0.1) 0%, rgba(192, 192, 192, 0.1) 100%);
    border: 1px solid rgba(212, 188, 108, 0.2);
    color: #d4bc6c;
}

.metal-dualtone i {
    -webkit-background-clip: text;
    background: linear-gradient(135deg, #ffd700, #c0c0c0);
    background-clip: text;
    color: transparent;
}

.metal-dualtone.active {
    background: linear-gradient(135deg, #ffd700 0%, #c0c0c0 100%);
    border-color: rgba(168, 148, 94, 0.6);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
    color: #5a4500;
}

[data-bs-theme="dark"] .metal-dualtone.active {
    background: linear-gradient(135deg, #ffd700 0%, #e5e4e2 100%);
    border-color: #d4bc6c;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
    color: #333;
}

.metal-dualtone:hover {
    border-color: rgba(168, 148, 94, 0.4);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

[data-bs-theme="dark"] .metal-dualtone:hover {
    border-color: rgba(212, 188, 108, 0.4);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

/* Platinum with theme support */

.metal-platinum {
    background-color: rgba(229, 228, 226, 0.2);
    color: #777;
}

[data-bs-theme="dark"] .metal-platinum {
    background-color: rgba(229, 228, 226, 0.1);
    color: #e5e4e2;
}

.metal-platinum i { color: #e5e4e2; }

.metal-platinum.active {
    background-color: #e5e4e2;
    border-color: #a9a9a9;
    color: #333;
}

[data-bs-theme="dark"] .metal-platinum.active {
    background-color: #e5e4e2;
    border-color: #e5e4e2;
    color: #333;
}

/* Silver with theme support */

.metal-silver {
    background-color: rgba(192, 192, 192, 0.2);
    color: #808080;
}

[data-bs-theme="dark"] .metal-silver {
    background-color: rgba(192, 192, 192, 0.1);
    color: #c0c0c0;
}

.metal-silver i { color: #c0c0c0; }

.metal-silver.active {
    background-color: #c0c0c0;
    border-color: #a9a9a9;
    color: #333;
}

[data-bs-theme="dark"] .metal-silver.active {
    background-color: #c0c0c0;
    border-color: #c0c0c0;
    color: #333;
}

/* Other metal with theme support */

.metal-other {
    background-color: rgba(255, 255, 255, 0.1);
    color: #777;
}

[data-bs-theme="dark"] .metal-other {
    background-color: rgba(255, 255, 255, 0.05);
    color: #aaa;
}

.metal-other.active {
    background-color: #a9a9a9;
    border-color: #808080;
}

[data-bs-theme="dark"] .metal-other.active {
    background-color: #a9a9a9;
    border-color: #a9a9a9;
    color: #212529;
}

/* Searchable Selects */

.searchable-select { width: 100%; }

/* Select2 Customization to match application theme */

.select2-container--bootstrap-5 { font-size: 0.875rem; }

/* Selection box styling */

.select2-container--bootstrap-5 .select2-selection {
    appearance: none;
    background-color: #fff;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
    background-position: right 0.75rem center;
    background-repeat: no-repeat;
    background-size: 16px 12px;
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    color: #212529;
    font-size: 0.875rem;
    min-height: 38px;
    padding: 0.375rem 0.75rem;
    padding-right: 2.25rem;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection {
    background-color: var(--bs-input-bg);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23adb5bd' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

.select2-container--bootstrap-5 .select2-selection--single {
    align-items: center;
    display: flex;
    height: 38px;
}

.select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered {
    color: inherit;
    line-height: 1.5;
    overflow: hidden;
    padding-left: 0;
    padding-right: 0;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Fix for dark mode text color in select boxes */

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection__rendered { color: var(--bs-body-color); }

/* More specific selectors to ensure text is visible in dark mode */

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered { color: var(--bs-body-color); }

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__rendered { color: var(--bs-body-color); }

/* Also fix placeholder color in dark mode */

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--single .select2-selection__placeholder,
[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__placeholder { color: rgba(255, 255, 255, 0.6); }

/* Hide the default arrow */

.select2-container--bootstrap-5 .select2-selection__arrow { display: none; }

/* Placeholder */

.select2-container--bootstrap-5 .select2-selection__placeholder {
    color: #6c757d;
    opacity: 0.8;
}

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection__placeholder { color: rgba(255, 255, 255, 0.6); }

/* Focus and open states */

.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Dropdown styling */

.select2-container--bootstrap-5 .select2-dropdown {
    background-color: #fff;
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.1);
    font-size: 0.875rem;
    overflow: hidden;
    z-index: 1056;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-search {
    background-color: #fff;
    padding: 0.375rem;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-search .select2-search__field {
    background-color: #fff;
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
    color: #212529;
    font-size: 0.875rem;
    padding: 0.375rem 0.75rem;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-results__options {
    max-height: 15rem;
    overflow-y: auto;
    padding: 0.375rem 0;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-results__option {
    color: #212529;
    padding: 0.375rem 0.75rem;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-results__option--highlighted {
    background-color: #0d6efd;
    color: #fff;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-results__option--selected {
    background-color: #0a58ca;
    color: #fff;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-results__option--disabled { color: #6c757d; }

.select2-container--bootstrap-5 .select2-dropdown .select2-results__message {
    color: #6c757d;
    padding: 0.375rem 0.75rem;
}

/* Dark theme overrides for dropdown */

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-dropdown {
    background-color: #212529;
    border-color: #343a40;
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-dropdown .select2-search { background-color: #212529; }

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-dropdown .select2-search .select2-search__field {
    background-color: #343a40;
    border-color: #495057;
    color: #e9ecef;
}

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-dropdown .select2-results__option { color: #e9ecef; }

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-dropdown .select2-results__message { color: #adb5bd; }

/* Open state styling */

.select2-container--bootstrap-5.select2-container--open .select2-selection {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%234e91ff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 11l6-6 6 6'/%3e%3c/svg%3e");
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Multiple select styling */

.select2-container--bootstrap-5 .select2-selection--multiple {
    min-height: 38px;
    padding: 0.25rem 0.5rem;
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__rendered {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    margin: 0;
    padding: 0;
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__choice {
    align-items: center;
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.2);
    border-radius: 0.25rem;
    color: var(--bs-body-color);
    display: flex;
    font-size: 0.8rem;
    margin: 0;
    padding: 0.125rem 0.25rem 0.125rem 0.5rem;
}

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__choice {
    background-color: rgba(var(--bs-primary-rgb), 0.2);
    border-color: rgba(var(--bs-primary-rgb), 0.3);
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__choice__remove {
    color: var(--bs-body-color);
    cursor: pointer;
    font-size: 1.1em;
    margin-left: 0.25rem;
    opacity: 0.7;
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__choice__remove:hover { opacity: 1; }

.select2-container--bootstrap-5 .select2-selection--multiple .select2-search {
    align-self: center;
    flex: 1;
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-search__field {
    background-color: transparent;
    border: none;
    color: inherit;
    font-size: 0.875rem;
    margin: 0;
    padding: 0.125rem 0;
    width: 100% !important;
}

/* Filter action buttons */

.btn-filter-action {
    border-radius: 0.25rem;
    min-width: 80px;
    transition: all 0.2s ease;
}

.btn-filter-action:hover { transform: translateY(-1px); }

.btn-filter-action:active { transform: translateY(1px); }

.btn-filter-action:focus { box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25); }

/* Form control focus states with theme support */

.form-select:focus,
.form-control:focus {
    border-color: rgba(var(--bs-primary-rgb), 0.5);
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.15);
}

/* Range buttons hover enhancement */

.btn-range:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.08);
    border-color: rgba(var(--bs-primary-rgb), 0.2);
}

.btn-range:focus { box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.15); }

/* Filter section transition effects */

.filter-section { transition: border-color 0.3s ease, padding-bottom 0.3s ease; }

.filter-section:hover { border-bottom-color: rgba(var(--bs-primary-rgb), 0.3); }

/* Section header subtle enhancement */

.section-header {
    align-items: center;
    display: flex;
    gap: 0.5rem;
    transition: all 0.3s ease;
}

.section-header i {
    color: var(--bs-primary);
    margin-right: 0;
    transition: transform 0.3s ease, color 0.3s ease;
}

.filter-section:hover .section-header i { transform: scale(1.1); }

/* Metal buttons enhanced hover */

.metal-btn:hover {
    border-color: rgba(var(--bs-body-color-rgb), 0.3);
    transform: translateY(-1px);
}

[data-bs-theme="dark"] .metal-btn:hover {
    border-color: rgba(255, 255, 255, 0.25);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Filter label hover effect */

.filter-label { transition: color 0.2s ease; }

.filter-group:hover .filter-label { color: var(--bs-primary); }

/* Enhanced Range Slider Styling */

.noUi-target {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    border: none;
    border-radius: 3px;
    box-shadow: none;
    height: 6px;
    margin: 10px 0 15px;
}

.noUi-connect {
    background: var(--bs-primary);
    border-radius: 3px;
    box-shadow: none;
    transition: background-color 0.3s ease;
}

.noUi-horizontal .noUi-handle {
    background-color: #fff;
    border: 2px solid var(--bs-primary);
    border-radius: 50%;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    height: 18px !important;
    right: -9px !important;
    top: -6px;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    width: 18px !important;
}

.noUi-horizontal .noUi-handle:hover {
    box-shadow: 0 0 6px rgba(var(--bs-primary-rgb), 0.4);
    transform: scale(1.1);
}

.noUi-horizontal .noUi-handle:active {
    box-shadow: 0 0 2px rgba(var(--bs-primary-rgb), 0.6);
    transform: scale(0.95);
}

/* Dark theme adjustments for sliders */

[data-bs-theme="dark"] .noUi-target { background-color: rgba(255, 255, 255, 0.1); }

[data-bs-theme="dark"] .noUi-horizontal .noUi-handle {
    background-color: var(--bs-dark);
    border: 2px solid var(--bs-primary);
}

/* Fix for Select2 clear button - hide by default for empty values */

.select2-container--bootstrap-5 .select2-selection--single .select2-selection__clear { display: none; }

/* Only show clear button for inputs with selected values */

.select2-has-value .select2-selection__clear { display: block !important; }

/* Additional improvements for Select2 compatibility with theme */

.select2-container--bootstrap-5 .select2-selection { transition: border-color 0.2s ease, box-shadow 0.2s ease; }

.select2-container--bootstrap-5 .select2-selection:hover {
    border-color: rgba(var(--bs-primary-rgb), 0.4);
    box-shadow: 0 0 0 0.1rem rgba(var(--bs-primary-rgb), 0.1);
}

/* Match Select2 sizing with other form elements in filters */

.filters-content .select2-container--bootstrap-5 .select2-selection {
    background-position: right 0.5rem center;
    background-size: 12px 10px;
    font-size: 0.85rem;
    min-height: 34px;
    padding: 0.35rem 0.65rem;
    padding-right: 2rem;
}

/* Match Collection dropdown with other filter dropdowns */

#collectionName { font-size: 0.85rem; }

/* Authentication styles */

.auth-body {
    align-items: center;
    background-color: var(--bs-body-bg);
    background-image: linear-gradient(to bottom right, rgba(var(--bs-primary-rgb), 0.1), rgba(var(--bs-primary-rgb), 0.05));
    display: flex;
    justify-content: center;
    margin-bottom: 0; /* Override the default body margin */
    min-height: 100vh;
}

.auth-body .card { transition: all 0.3s ease; }

.auth-body .card:hover {
    box-shadow: var(--bs-shadow-medium);
    transform: translateY(-5px);
}

.auth-body .input-group { transition: all 0.2s ease; }

.auth-body .input-group:focus-within {
    box-shadow: 0 0.25rem 0.5rem rgba(var(--bs-primary-rgb), 0.1);
    transform: translateY(-2px);
}

.auth-body .input-group-text {
    background-color: var(--bs-body-bg);
    border-right: none;
    color: var(--bs-primary);
}

.auth-body .form-control { border-left: none; }

.auth-body .form-control:focus { box-shadow: none; }

.auth-body .btn-primary { transition: all 0.3s ease; }

.auth-body .btn-primary:hover {
    box-shadow: 0 0.5rem 1rem rgba(var(--bs-primary-rgb), 0.2);
    transform: translateY(-2px);
}

/* Dark mode specific auth styles */

[data-bs-theme="dark"] .auth-body { background-image: linear-gradient(to bottom right, rgba(var(--bs-primary-rgb), 0.15), rgba(0, 0, 0, 0.5)); }

[data-bs-theme="dark"] .auth-body .input-group-text {
    background-color: var(--bs-input-bg);
    color: var(--bs-primary);
}

/* Access Denied page */

.access-denied-icon {
    color: var(--bs-danger);
    font-size: 5rem;
    margin-bottom: 1.5rem;
}

/* Fix text color when dropdown is focused/open in dark mode */

[data-bs-theme="dark"] .select2-container--bootstrap-5.select2-container--focus .select2-selection__rendered,
[data-bs-theme="dark"] .select2-container--bootstrap-5.select2-container--open .select2-selection__rendered { color: var(--bs-body-color); }

/* Hide the default arrow */

.select2-container--bootstrap-5 .select2-selection__arrow { display: none; }

/* Fix for dark mode select boxes - more direct and higher specificity selectors */

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection { color: white !important; }

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection .select2-selection__rendered { color: white !important; }

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered { color: white !important; }

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__rendered { color: white !important; }

/* Fix placeholder color in dark mode with higher contrast */

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--single .select2-selection__placeholder,
[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__placeholder { color: rgba(255, 255, 255, 0.8) !important; }

/* Fix for dropdown items in dark mode */

[data-bs-theme="dark"] .dropdown-menu,
[data-bs-theme="dark"] #fiscalYearDropdownMenu,
[data-bs-theme="dark"] #monthYearDropdownMenu {
    background-color: var(--bs-dark);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .dropdown-item,
[data-bs-theme="dark"] .fiscal-year-check,
[data-bs-theme="dark"] .month-year-check { color: white !important; }

[data-bs-theme="dark"] .fiscal-year-check label,
[data-bs-theme="dark"] .month-year-check label { color: white !important; }

[data-bs-theme="dark"] #toggleAllFiscalYears,
[data-bs-theme="dark"] #toggleAllMonths {
    border-color: var(--bs-border-color);
    color: white !important;
}

/* Fix for hover states in dark mode */

[data-bs-theme="dark"] .dropdown-item:hover,
[data-bs-theme="dark"] .fiscal-year-check:hover,
[data-bs-theme="dark"] .month-year-check:hover { background-color: rgba(var(--bs-primary-rgb), 0.2); }

/* Add this to your CSS file */

.dropdown-menu {
    position: absolute; /* Ensure absolute positioning */
    z-index: 9999; /* Higher than standard Bootstrap z-index */
}

/* Fix potential overflow issues in parent containers */

.collection-card,
.card-body {
    overflow: visible !important; /* Override any overflow: hidden */
}

/* Theme-compliant modals */

.modal-content {
    background-color: var(--bs-card-bg);
    border-color: var(--bs-border-color);
    box-shadow: var(--bs-shadow-medium);
    color: var(--bs-body-color);
    transition: background-color 0.3s ease, color 0.3s ease;
}

.modal-header { border-bottom-color: var(--bs-border-color); }

.modal-footer { border-top-color: var(--bs-border-color); }

[data-bs-theme="dark"] .modal-header .btn-close { filter: invert(1) grayscale(100%) brightness(200%); }

/* Size Chart Modal Dark Mode Table Styling */

[data-bs-theme="dark"] #sizeChartModal .table {
    color: var(--bs-body-color);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] #sizeChartModal .table thead.table-dark {
    background-color: var(--bs-dark);
    color: white;
}

[data-bs-theme="dark"] #sizeChartModal .table tbody tr { color: var(--bs-body-color); }

[data-bs-theme="dark"] #sizeChartModal .table tbody tr:nth-of-type(odd) { background-color: rgba(255, 255, 255, 0.05); }

[data-bs-theme="dark"] #sizeChartModal .table tbody tr:hover {
    background-color: rgba(255, 255, 255, 0.1);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] #sizeChartModal .table td,
[data-bs-theme="dark"] #sizeChartModal .table th { border-color: var(--bs-border-color); }

[data-bs-theme="dark"] #sizeChartModal .table strong { color: var(--bs-body-color); }

/* Additional dark mode styling for size chart modal content */

[data-bs-theme="dark"] #sizeChartModal .text-muted { color: rgba(255, 255, 255, 0.6) !important; }

[data-bs-theme="dark"] #sizeChartModal h6.text-muted { color: rgba(255, 255, 255, 0.7) !important; }

[data-bs-theme="dark"] #sizeChartModal .alert-info {
    background-color: rgba(var(--bs-info-rgb), 0.1);
    border-color: rgba(var(--bs-info-rgb), 0.2);
    color: var(--bs-body-color);
}

/* Ensure table styling works for all table variants in size chart modal */

[data-bs-theme="dark"] #sizeChartModal .table-sm { font-size: 0.875rem; }

[data-bs-theme="dark"] #sizeChartModal .table-responsive { border-color: var(--bs-border-color); }

/* Fix for any potential Bootstrap table overrides */

[data-bs-theme="dark"] #sizeChartModal .table > :not(caption) > * > * {
    background-color: transparent;
    border-bottom-color: var(--bs-border-color);
}

/* Ensure correct positioning on mobile */

@media (max-width: 767.98px) {
    .bulk-action-bar {
        top: 56px; /* Height of the navbar */
    }
}

/* Dual action buttons for collection/wishlist */

.action-buttons {
    display: flex;
    position: absolute;
    right: 8px;
    top: 8px;
    z-index: 5;
}

.action-buttons .btn {
    align-items: center;
    display: flex;
    height: 32px;
    justify-content: center;
    margin-left: 5px;
    opacity: 0.85;
    padding: 0;
    transition: all 0.2s ease;
    width: 32px;
}

.action-buttons .btn:hover {
    opacity: 1;
    transform: scale(1.1);
}

.action-buttons .btn.active {
    background-color: rgba(var(--bs-primary-rgb), 0.15);
    color: var(--bs-primary);
}

/* Collection grid layout improvements */

.collection-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.collection-item-card {
    border: none;
    border-radius: var(--compact-card-radius);
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
    height: 100%;
    overflow: hidden;
    position: relative;
    transition: all 0.3s ease;
}

.collection-item-card:hover {
    border-color: rgba(var(--bs-primary-rgb), 0.3);
    box-shadow: 0 8px 20px rgba(var(--bs-primary-rgb), 0.15);
    transform: translateY(-5px);
}

.collection-item-card .card-header {
    align-items: center;
    background-color: rgba(var(--bs-primary-rgb), 0.03);
    border-bottom: 1px solid rgba(var(--bs-primary-rgb), 0.1);
    display: flex;
    justify-content: space-between;
    padding: 0.75rem 1rem;
}

.collection-item-card .card-body { padding: 1rem; }

.collection-item-image {
    align-items: center;
    background-color: var(--bs-body-bg);
    border-bottom: 1px solid var(--bs-border-color);
    display: flex;
    height: 220px;
    justify-content: center;
    overflow: hidden;
    position: relative;
}

.collection-item-image img {
    max-height: 100%;
    max-width: 100%;
    object-fit: contain;
    transition: transform 0.3s ease;
}

.collection-item-card:hover .collection-item-image img { transform: scale(1.05); }

.collection-item-card .btn {
    opacity: 0.7;
    transition: all 0.2s ease;
}

.collection-item-card:hover .btn { opacity: 1; }

.collection-item-card .edit-notes-btn:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-primary) !important;
}

.collection-item-card .remove-item-btn:hover {
    background-color: rgba(var(--bs-danger-rgb), 0.1);
    color: var(--bs-danger) !important;
}

.drag-handle {
    border-radius: 5px;
    cursor: grab;
    opacity: 0.5;
    transition: opacity 0.2s ease, background-color 0.2s ease;
}

.drag-handle:hover,
.drag-handle:focus {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    opacity: 1;
    outline: none;
}

.drag-handle:focus-visible { box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.25); }

/* Drag and drop visual states */

.sortable-ghost {
    background-color: var(--bs-primary-bg-subtle);
    opacity: 0.4;
}

.sortable-chosen {
    box-shadow: var(--bs-shadow-medium);
    opacity: 1;
    z-index: 1000;
}

.sortable-drag {
    box-shadow: var(--bs-shadow-medium);
    opacity: 0.9;
    z-index: 1000;
}

.dragging { cursor: grabbing; }

/* Improved item notes */

.item-notes {
    background-color: rgba(var(--bs-primary-rgb), 0.05);
    border-left: 3px solid rgba(var(--bs-primary-rgb), 0.6);
    border-radius: 0.25rem;
    color: var(--bs-body-color);
    font-size: 0.85rem;
    line-height: 1.4;
    margin-top: 0.75rem;
    padding: 10px;
    transition: background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
    word-break: break-word;
}

.item-notes:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.08);
    border-color: rgba(var(--bs-primary-rgb), 0.8);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.1);
}

[data-bs-theme="dark"] .item-notes {
    background-color: rgba(var(--bs-primary-rgb), 0.1) !important;
    border-color: rgba(var(--bs-primary-rgb), 0.5) !important;
    color: var(--bs-body-color);
}

/* Enhanced toast styling */

.toast {
    background-color: var(--bs-body-bg);
    border-color: var(--bs-border-color);
    box-shadow: var(--bs-shadow-medium);
}

.toast-header {
    background-color: rgba(var(--bs-light-rgb), 0.1);
    border-bottom-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .toast-header { background-color: rgba(255, 255, 255, 0.05); }

/* Screen reader announcements */

.visually-hidden {
    border: 0;
    clip: rect(0, 0, 0, 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}

/* Improve export preview section */

.table-preview { font-size: 0.85rem; }

.table-preview th {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .table-preview th {
    background-color: rgba(var(--bs-primary-rgb), 0.2);
    color: var(--bs-body-color);
}

/* Responsive card image sizing */

@media (max-width: 576px) {
    .collection-item-image { height: 180px; }
}

@media (min-width: 577px) and (max-width: 768px) {
    .collection-item-image { height: 160px; }
}

/* Additional Collection Item transition effects */

.collection-item { transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease, opacity 0.3s ease; }

/* Fade in animation for collection items */

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translate3d(0, 20px, 0);
    }

    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

.collection-item {
    animation: fadeInUp 0.5s ease forwards;
    animation-delay: calc(var(--animation-order, 0) * 0.1s);
}

/* Loading indicator styles */

#loadingIndicator {
    padding: 1.5rem 0;
    transition: all 0.3s ease;
    opacity: 0;
    transform: translateY(10px);
}

#loadingIndicator:not(.d-none) {
    opacity: 1;
    transform: translateY(0);
}

#loadingIndicator .spinner-border {
    height: 1.25rem;
    width: 1.25rem;
    border-width: 0.15em;
}

#loadingIndicator p {
    margin-top: 0.75rem;
    margin-bottom: 0;
    font-size: 0.875rem;
    color: var(--bs-secondary);
    font-weight: 500;
}

[data-bs-theme="dark"] #loadingIndicator p { color: var(--bs-gray-400); }

.loading-indicator {
    align-items: center;
    display: inline-flex;
    justify-content: center;
}

.loading-indicator .spinner-border {
    height: 1rem;
    margin-right: 0.5rem;
    width: 1rem;
}

/* Enhanced modal transitions */

.modal.fade .modal-dialog {
    opacity: 0;
    transform: scale(0.9);
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}

.modal.show .modal-dialog {
    opacity: 1;
    transform: scale(1);
}

/* Progress bar animation */

.progress-bar-animated { animation: progress-bar-stripes 1s linear infinite; }

/* Confirmation modal styles */

#confirmRemoveModal .modal-content { overflow: hidden; }

#confirmRemoveModal .modal-header { background-color: rgba(var(--bs-danger-rgb), 0.1); }

[data-bs-theme="dark"] #confirmRemoveModal .modal-header { background-color: rgba(var(--bs-danger-rgb), 0.2); }

/* Add a subtle transition effect for notes */

.item-notes { animation: fadeIn 0.3s ease-in-out; }

/* Content header spacing */

.content-header {
    margin-bottom: 1.5rem;
    position: relative;
    z-index: 1;
}

/* Enhanced sticky header styling for wishlist and cart pages */
.content-header.sticky-top {
    background-color: var(--bs-body-bg);
    border-bottom: 1px solid var(--bs-border-color);
    padding: 1rem 0;
    margin-bottom: 1.5rem;
    transition: box-shadow 0.3s ease, background-color 0.3s ease, border-color 0.3s ease;
    z-index: 100;
}

.content-header.sticky-top.scrolled {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

[data-bs-theme="dark"] .content-header.sticky-top {
    background-color: var(--bs-dark);
    border-bottom-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .content-header.sticky-top.scrolled {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.content-header .catalog-title h5 {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--bs-body-color);
    margin: 0;
}

.content-header .catalog-title h5 i {
    font-size: 1.5rem;
}

.content-header .catalog-title .badge {
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.375rem 0.75rem;
}

@media (max-width: 767.98px) {
    .content-header.sticky-top {
        padding: 0.75rem 0;
    }
    
    .content-header .catalog-title h5 {
        font-size: 1.25rem;
    }
    
    .content-header .catalog-title h5 i {
        font-size: 1.25rem;
    }
}

/* Action buttons consistent styling */

.action-btn {
    align-items: center;
    border-radius: 0.375rem;
    display: inline-flex;
    gap: 0.375rem;
    justify-content: center;
    transition: all 0.2s ease;
}

.action-btn:hover { transform: translateY(-1px); }

/* Consistent action buttons layout */

.actions-container {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

@media (max-width: 767.98px) {
    .actions-container {
        justify-content: center;
        margin-top: 1rem;
    }

    .bulk-action-bar {
        position: fixed;
        top: 0;
    }
}

/* Enhanced styling for the wishlist and export buttons in the navigation header */

.catalog-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.catalog-actions .action-buttons {
    align-items: center;
    display: flex;
    gap: 0.75rem;
}

#viewWishlist, #exportBtn {
    align-items: center;
    border-radius: 50rem;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.12);
    display: inline-flex;
    font-size: 0.875rem;
    font-weight: 500;
    justify-content: center;
    overflow: hidden;
    padding: 0.5rem 1.125rem;
    position: relative;
    transition: all 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

#viewWishlist::after, #exportBtn::after {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0) 100%);
    content: '';
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
}

#viewWishlist:hover, #exportBtn:hover:not(:disabled) {
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.18);
    transform: translateY(-3px);
}

#viewWishlist:active, #exportBtn:active:not(:disabled) {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    transform: translateY(1px);
    transition: all 0.1s ease;
}

/* Add a subtle shine effect on hover */

#viewWishlist:hover::before, #exportBtn:hover:not(:disabled)::before {
    animation: shine 1s forwards;
    background: rgba(255, 255, 255, 0.2);
    content: '';
    height: 200%;
    left: -60%;
    pointer-events: none;
    position: absolute;
    top: -50%;
    transform: rotate(25deg);
    width: 20%;
}

@keyframes shine {
    to { left: 150%; }
}

/* Specific styles for the Wishlist button */

#viewWishlist {
    align-items: center;
    background-color: transparent;
    border: 1.5px solid rgba(var(--bs-danger-rgb), 0.7);
    border-radius: 2rem;
    box-shadow: 0 4px 6px rgba(var(--bs-danger-rgb), 0.1);
    color: var(--bs-danger);
    display: inline-flex;
    font-weight: 500;
    justify-content: center;
    padding: 0.4rem 1rem;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

#viewWishlist:hover {
    background-color: rgba(var(--bs-danger-rgb), 0.08);
    border-color: var(--bs-danger);
    box-shadow: 0 6px 12px rgba(var(--bs-danger-rgb), 0.2);
    transform: translateY(-2px);
}

#viewWishlist:active {
    box-shadow: 0 2px 8px rgba(var(--bs-danger-rgb), 0.15);
    transform: translateY(0);
}

#viewWishlist.btn-danger {
    background-color: var(--bs-danger);
    border-color: var(--bs-danger);
    color: white;
}

#viewWishlist.btn-danger:hover {
    background-color: var(--bs-danger);
    border-color: var(--bs-danger);
    box-shadow: 0 6px 12px rgba(var(--bs-danger-rgb), 0.2);
    transform: translateY(-2px);
}

/* Specific styles for the Export button */

.export-button-group {
    border-radius: 0.25rem;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.12);
    overflow: hidden;
}

#exportSelectedBtn, #exportFilteredBtn {
    background-color: var(--bs-success);
    border-color: var(--bs-success);
    border-radius: 2rem;
    box-shadow: 0 4px 6px rgba(var(--bs-success-rgb), 0.1);
    color: white;
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.5rem 0.875rem;
    position: relative;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

#exportSelectedBtn::after, #exportFilteredBtn::after {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0) 100%);
    content: '';
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
}

#exportSelectedBtn:hover:not(:disabled), #exportFilteredBtn:hover {
    background-color: var(--bs-success);
    box-shadow: 0 6px 12px rgba(var(--bs-success-rgb), 0.2);
    transform: translateY(-2px);
}

#exportSelectedBtn:active:not(:disabled), #exportFilteredBtn:active {
    box-shadow: 0 2px 8px rgba(var(--bs-success-rgb), 0.15);
    transform: translateY(0);
}

#exportSelectedBtn:disabled {
    box-shadow: none;
    cursor: not-allowed;
    opacity: 0.65;
    transform: none;
}

/* Dark mode adjustments */

[data-bs-theme="dark"] #viewWishlist { border-color: rgba(var(--bs-danger-rgb), 0.5); }

[data-bs-theme="dark"] #viewWishlist:hover {
    background-color: rgba(var(--bs-danger-rgb), 0.15);
    border-color: rgba(var(--bs-danger-rgb), 0.8);
}

[data-bs-theme="dark"] #exportBtn:disabled {
    background-color: rgba(var(--bs-success-rgb), 0.5);
    border-color: rgba(var(--bs-success-rgb), 0.3);
}

/* Add prominent icon styling */

#viewWishlist i, #exportBtn i {
    font-size: 1rem;
    margin-right: 0.375rem;
    transition: transform 0.2s ease;
}

#viewWishlist:hover i, #exportBtn:hover:not(:disabled) i { transform: scale(1.2); }

/* Card action buttons styling */

.card-actions {
    align-items: center;
    display: flex;
    gap: 0.25rem;
}

.btn-action {
    align-items: center;
    background: transparent;
    border: none;
    border-radius: 50%;
    color: var(--bs-gray-600);
    display: flex;
    height: 32px;
    justify-content: center;
    margin-left: 0.25rem;
    opacity: 0.85;
    padding: 0;
    transition: all 0.2s ease;
    width: 32px;
}

.btn-action:hover {
    background-color: rgba(var(--bs-gray-200-rgb), 0.4);
    opacity: 1;
    transform: translateY(-1px);
}

.btn-action:active { transform: translateY(0); }

.btn-action.collection-btn:hover { color: var(--bs-primary); }

.btn-action.wishlist-btn:hover,
.btn-action.wishlist-btn.active { color: var(--bs-danger); }

.btn-action.wishlist-btn.active { opacity: 1; }

[data-bs-theme="dark"] .btn-action { color: var(--bs-gray-400); }

[data-bs-theme="dark"] .btn-action:hover { background-color: rgba(255, 255, 255, 0.1); }

[data-bs-theme="dark"] .btn-action.collection-btn:hover { color: var(--bs-primary); }

[data-bs-theme="dark"] .btn-action.wishlist-btn:hover,
[data-bs-theme="dark"] .btn-action.wishlist-btn.active { color: var(--bs-danger); }

.btn-action.collection-btn.active {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-primary);
    opacity: 1;
}

/* Enhanced Folder animation for collection */

.folder-pulse {
    animation: folderPulse 0.8s cubic-bezier(0.18, 0.89, 0.32, 1.28);
    position: relative;
}

.folder-pulse::after {
    animation: folderRipple 0.8s ease-out;
    background: rgba(var(--bs-primary-rgb), 0.2);
    border-radius: 50%;
    content: '';
    height: 100%;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%) scale(0);
    width: 100%;
    z-index: -1;
}

@keyframes folderPulse {
    0% { transform: scale(1); }

    40% {
        filter: drop-shadow(0 0 4px rgba(var(--bs-primary-rgb), 0.7));
        transform: scale(1.5);
    }

    70% { transform: scale(0.9); }

    100% { transform: scale(1); }
}

@keyframes folderRipple {
    0% {
        opacity: 1;
        transform: translate(-50%, -50%) scale(0);
    }

    100% {
        opacity: 0;
        transform: translate(-50%, -50%) scale(2.5);
    }
}

/* Enhanced button hover effects */

.btn-action {
    overflow: visible;
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), background-color 0.3s ease, color 0.3s ease, opacity 0.3s ease;
}

.btn-action:hover {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
    transform: translateY(-3px) scale(1.1);
}

.btn-action:active {
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
    transform: translateY(1px) scale(0.95);
    transition: transform 0.1s ease, box-shadow 0.1s ease;
}

/* Active state enhancements */

.btn-action.wishlist-btn.active {
    animation: activeGlow 2s infinite alternate;
    color: var(--bs-danger);
    text-shadow: 0 0 5px rgba(220, 53, 69, 0.3);
}

.btn-action.collection-btn.active {
    animation: activeGlow 2s infinite alternate;
    color: var(--bs-primary);
    text-shadow: 0 0 5px rgba(var(--bs-primary-rgb), 0.3);
}

@keyframes activeGlow {
    0% { filter: drop-shadow(0 0 1px currentColor); }

    100% { filter: drop-shadow(0 0 3px currentColor); }
}

/* Success overlay animation for collection addition */

.success-overlay {
    align-items: center;
    backdrop-filter: blur(2px);
    background-color: rgba(var(--bs-primary-rgb), 0.2);
    border-radius: 0.375rem;
    display: flex;
    height: 100%;
    justify-content: center;
    left: 0;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    transform: scale(0.9);
    transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    width: 100%;
    z-index: 10;
}

.success-overlay.show {
    opacity: 1;
    transform: scale(1);
}

.success-overlay i {
    animation: successPop 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
    color: var(--bs-success);
    filter: drop-shadow(0 0 10px rgba(var(--bs-success-rgb), 0.7));
    font-size: 3rem;
}

@keyframes successPop {
    0% {
        opacity: 0;
        transform: scale(0.5);
    }

    40% {
        opacity: 1;
        transform: scale(1.3);
    }

    70% { transform: scale(0.9); }

    100% { transform: scale(1); }
}

/* Collection button state transition */

.collection-btn i { transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }

.collection-btn.active i { transform: scale(1.2); }

/* Dropdown loading indicator */

.dropdown-loading-indicator {
    position: absolute;
    right: 30px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 5;
}

.filter-group { position: relative; }

/* Disabled dropdown styling */

select:disabled {
    background-color: rgba(var(--bs-secondary-rgb), 0.1);
    cursor: not-allowed;
    opacity: 0.8;
}

/* Navbar icon button styling */

.navbar .btn.nav-link.rounded-circle {
    align-items: center;
    display: flex;
    height: 36px;
    justify-content: center;
    margin: 0 2px;
    position: relative;
    transition: all 0.2s ease;
    width: 36px;
}

.navbar .btn.nav-link.rounded-circle:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    transform: translateY(-2px);
}

.navbar .btn.nav-link.rounded-circle.active {
    background-color: rgba(var(--bs-primary-rgb), 0.15);
    color: var(--bs-primary);
}

.navbar .btn.nav-link.rounded-circle i { font-size: 1.1rem; }

/* Enhanced toast styling */

.toast-custom {
    backdrop-filter: blur(10px);
    border-radius: 0.5rem;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08) !important;
    margin-bottom: 0.75rem;
    min-width: 300px;
    opacity: 1 !important;
    opacity: 0;
    overflow: hidden;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.3s ease;
}

.toast-custom .toast-body {
    font-size: 0.9rem;
    font-weight: 500;
    padding: 0.8rem 0.8rem 0.8rem 1rem;
}

.toast-enter {
    opacity: 1;
    transform: translateY(0);
}

/* Toast close button styling */

.btn-close-success { filter: invert(24%) sepia(94%) saturate(1957%) hue-rotate(123deg) brightness(97%) contrast(103%); }

.btn-close-primary { filter: invert(40%) sepia(97%) saturate(1117%) hue-rotate(201deg) brightness(96%) contrast(96%); }

.btn-close-warning { filter: invert(65%) sepia(53%) saturate(4792%) hue-rotate(360deg) brightness(102%) contrast(104%); }

.btn-close-error,
.btn-close-danger { filter: invert(14%) sepia(90%) saturate(3299%) hue-rotate(343deg) brightness(80%) contrast(104%); }

/* Stacking multiple toasts */

#toast-container {
    align-items: flex-end;
    display: flex;
    flex-direction: column;
    z-index: 9900; /* Standardized z-index value */
}

/* Dark theme toast adjustments */

[data-bs-theme="dark"] .toast-custom { box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2) !important; }

[data-bs-theme="dark"] .bg-success-subtle { background-color: rgba(25, 135, 84, 0.15) !important; }

[data-bs-theme="dark"] .bg-warning-subtle { background-color: rgba(255, 193, 7, 0.15) !important; }

[data-bs-theme="dark"] .bg-danger-subtle { background-color: rgba(220, 53, 69, 0.15) !important; }

[data-bs-theme="dark"] .bg-primary-subtle { background-color: rgba(13, 110, 253, 0.15) !important; }

/* Animation for toast notifications */

@keyframes toast-in-right {
    from {
        opacity: 0;
        transform: translateX(100%);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes toast-in-left {
    from {
        opacity: 0;
        transform: translateX(-100%);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Filter Indicators Styling */

.filter-indicator {
    align-items: center;
    background: linear-gradient(145deg, var(--bs-primary), #0953c2);
    border: none;
    border-radius: 50rem;
    box-shadow: 0 2px 5px rgba(var(--bs-primary-rgb), 0.3);
    color: #ffffff;
    cursor: default;
    display: inline-flex;
    font-size: 0.85rem;
    margin-left: 0.5rem;
    margin-right: 0.4rem;
    padding: 0.4rem 0.75rem;
    transition: all 0.2s ease;
}

.filter-indicator:hover {
    box-shadow: 0 3px 8px rgba(var(--bs-primary-rgb), 0.4);
    transform: translateY(-2px);
}

.filter-indicator .btn-close {
    align-items: center;
    background-color: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    display: inline-flex;
    filter: brightness(1.8);
    font-size: 0.65rem;
    height: 0.85rem;
    justify-content: center;
    margin-left: 0.45rem;
    opacity: 0.7;
    padding: 0.2rem;
    transition: all 0.25s ease;
    width: 0.85rem;
}

.filter-indicator .btn-close:hover {
    background-color: rgba(255, 255, 255, 0.35);
    filter: brightness(2);
    opacity: 1;
    transform: scale(1.15) rotate(90deg);
}

.filter-indicator .btn-close:active { transform: scale(0.9); }

.filter-indicator i {
    font-size: 0.9rem;
    margin-right: 0.35rem;
    opacity: 0.9;
}

.filter-indicator .fw-semibold {
    letter-spacing: 0.01em;
    margin-right: 0.25rem;
    opacity: 0.85;
}

/* #activeFilters { */

/*     align-items: center; */

/*     display: flex; */

/*     flex-wrap: wrap; */

/*     min-height: 42px; */

/*     padding: 0.25rem 0; */

/*     transition: all 0.3s ease; */

/* } */

#activeFilters .text-muted {
    animation: fadeIn 0.5s ease-in-out;
    background-color: rgba(var(--bs-secondary-rgb), 0.08);
    border-radius: 0.375rem;
    color: var(--bs-body-color);
    font-size: 0.85rem;
    font-style: italic;
    opacity: 0.8;
    padding: 0.4rem 0.75rem;
}

#activeFilters .text-muted i {
    color: var(--bs-body-color);
    opacity: 0.7;
}

[data-bs-theme="dark"] #activeFilters .text-muted {
    background-color: rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.7);
}

[data-bs-theme="dark"] #activeFilters .text-muted i { color: rgba(255, 255, 255, 0.7); }

[data-bs-theme="light"] #activeFilters .text-muted { color: rgba(0, 0, 0, 0.6); }

[data-bs-theme="light"] #activeFilters .text-muted i { color: rgba(0, 0, 0, 0.5); }

[data-bs-theme="dark"] .filter-indicator {
    background: linear-gradient(145deg, var(--bs-primary), #0953c2);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
    color: rgba(255, 255, 255, 0.95);
}

[data-bs-theme="dark"] #activeFilters .text-muted { background-color: rgba(255, 255, 255, 0.05); }

[data-bs-theme="dark"] .filter-indicator .fw-semibold { color: rgba(255, 255, 255, 0.9); }

[data-bs-theme="dark"] .filter-indicator i { color: rgba(255, 255, 255, 0.85); }

/* Light theme specifics */

[data-bs-theme="light"] .filter-indicator { color: #ffffff; }

[data-bs-theme="light"] .filter-indicator .fw-semibold { color: rgba(255, 255, 255, 0.95); }

[data-bs-theme="light"] .filter-indicator i { color: rgba(255, 255, 255, 0.9); }

/* Filter badges entrance animation */

@keyframes badgeIn {
    0% {
        opacity: 0;
        transform: scale(0.8);
    }

    70% { transform: scale(1.05); }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.filter-indicator { animation: badgeIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }

/* Filter group styling enhancements */

.filter-group {
    margin-bottom: 1.2rem;
    position: relative;
}

.filter-group .filter-label {
    color: var(--bs-body-color);
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 0.35rem;
    opacity: 0.75;
    transition: opacity 0.2s ease, color 0.2s ease;
}

.filter-group:hover .filter-label {
    color: var(--bs-primary);
    opacity: 1;
}

/* Section header enhancements */

.section-header {
    align-items: center;
    display: flex;
    gap: 0.5rem;
    transition: all 0.3s ease;
}

.section-header i {
    color: var(--bs-primary);
    margin-right: 0;
    transition: transform 0.3s ease, color 0.3s ease;
}

/* Removed: border-bottom, margin-bottom, padding-bottom, font-size, and hover/theme-specific rules for .section-header */

.filter-section:hover .section-header { border-bottom-color: rgba(var(--bs-primary-rgb), 0.25); }

.filter-section:hover .section-header i {
    color: var(--bs-primary);
    transform: scale(1.15);
}

[data-bs-theme="dark"] .section-header { border-bottom-color: rgba(var(--bs-primary-rgb), 0.15); }

[data-bs-theme="dark"] .filter-section:hover .section-header { border-bottom-color: rgba(var(--bs-primary-rgb), 0.35); }

[data-bs-theme="dark"] .filter-indicator .btn-close {
    background-color: rgba(255, 255, 255, 0.25);
    filter: brightness(2);
}

[data-bs-theme="dark"] .filter-indicator .btn-close:hover {
    background-color: rgba(255, 255, 255, 0.4);
    filter: brightness(2.2);
}

[data-bs-theme="light"] .filter-indicator .btn-close {
    background-color: rgba(255, 255, 255, 0.2);
    filter: brightness(1.8);
}

/* Export Split Button Styles - Additional Specific Styling */

/* Dropdown item icon styling */

.dropdown-item i {
    text-align: center;
    width: 1.2rem;
}

.dropdown-item:hover i { color: inherit; }

/* Excel and PDF icon colors */

.dropdown-item i.bi-file-earmark-excel { color: #1D6F42; }

.dropdown-item i.bi-file-earmark-pdf { color: #F40F02; }

/* Dark theme adjustments */

[data-bs-theme="dark"] .dropdown-item i.bi-file-earmark-excel { color: #2ECC71; }

[data-bs-theme="dark"] .dropdown-item i.bi-file-earmark-pdf { color: #FF6B6B; }

/* Dropdown styling for split buttons */

.btn-group .dropdown-menu {
    animation: fadeIn 0.2s ease-out;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.1);
    border-radius: 0.5rem;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
    min-width: 10rem;
    padding: 0.5rem 0;
    z-index: 1050 !important; /* Ensure dropdowns appear above bulk action bar */
}

.btn-group .dropdown-item {
    align-items: center;
    display: flex;
    font-size: 0.875rem;
    padding: 0.5rem 1rem;
    transition: all 0.2s ease;
}

.btn-group .dropdown-item:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.08);
    transform: translateX(2px);
}

.btn-group .dropdown-item:active {
    background-color: rgba(var(--bs-primary-rgb), 0.15);
    transform: translateX(0);
}

/* Dark theme adjustments for dropdowns */

[data-bs-theme="dark"] .btn-group .dropdown-menu {
    background-color: var(--bs-dark);
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
}

[data-bs-theme="dark"] .btn-group .dropdown-item { color: rgba(255, 255, 255, 0.85); }

[data-bs-theme="dark"] .btn-group .dropdown-item:hover {
    background-color: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 1);
}

[data-bs-theme="dark"] .btn-group .dropdown-divider { border-color: rgba(255, 255, 255, 0.1); }

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.btn-group .dropdown-item {
    align-items: center;
    display: flex;
    font-size: 0.875rem;
    padding: 0.5rem 1rem;
    transition: all 0.2s ease;
}

/* Ensure proper positioning for export button dropdowns */

.catalog-actions .btn-group .dropdown-menu,
.actions-container .btn-group .dropdown-menu {
    margin-top: 0.25rem !important;
    transform: translate3d(0px, 0px, 0px) !important;
}

/* Left-aligned dropdown menus */

.catalog-actions .btn-group .dropdown-menu:not(.dropdown-menu-end),
.actions-container .btn-group .dropdown-menu:not(.dropdown-menu-end) { inset: 100% auto auto 0px !important; }

/* Right-aligned dropdown menus */

.catalog-actions .btn-group .dropdown-menu.dropdown-menu-end,
.actions-container .btn-group .dropdown-menu.dropdown-menu-end { inset: 100% 0px auto auto !important; }

/* Image search icon overlay button */

.btn-image-fullscreen {
    background-color: rgba(0, 0, 0, 0.6);
    border: none;
    border-radius: 50%;
    color: white;
    cursor: pointer;
    height: 36px;
    opacity: 0.8; /* Always visible */
    position: absolute;
    right: 50px;
    bottom: 10px;
    transition: all 0.2s ease-in-out;
    width: 36px;
    z-index: 5;
}

.btn-image-fullscreen i { font-size: 1rem; }

.btn-image-fullscreen:hover {
    background-color: var(--bs-info);
    opacity: 1;
    transform: scale(1.1);
}

[data-bs-theme="dark"] .btn-image-fullscreen { background-color: rgba(255, 255, 255, 0.2); }

[data-bs-theme="dark"] .btn-image-fullscreen:hover { background-color: var(--bs-info); }

/* Personalization icon overlay button */

.btn-personalization {
    background-color: rgba(0, 0, 0, 0.6);
    border: none;
    border-radius: 50%;
    color: white;
    cursor: pointer;
    height: 36px;
    opacity: 0.8; /* Always visible */
    position: absolute;
    right: 90px;
    bottom: 10px;
    transition: all 0.2s ease-in-out;
    width: 36px;
    z-index: 5;
}

.btn-personalization i { font-size: 1rem; }

.btn-personalization:hover {
    background-color: var(--bs-warning);
    opacity: 1;
    transform: scale(1.1);
}

[data-bs-theme="dark"] .btn-personalization { background-color: rgba(255, 255, 255, 0.2); }

[data-bs-theme="dark"] .btn-personalization:hover { background-color: var(--bs-warning); }

/* Similarity Search Modal */

.similarity-modal-overlay {
    background: rgba(0, 0, 0, 0.85);
    bottom: 0;
    display: none;
    left: 0;
    overflow-y: auto;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 1050;
}

.similarity-modal-content {
    background: var(--bs-body-bg);
    border-radius: 8px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
    margin: 2rem auto;
    max-width: 1200px;
    opacity: 0;
    position: relative;
    transform: translateY(-20px);
    transition: all 0.3s ease-out;
    width: 90%;
}

/* Theme-aware close buttons (offcanvas/modal) */

[data-bs-theme="dark"] .btn-close {
    /* Invert default icon to show on dark backgrounds */
    filter: invert(1) grayscale(100%);
    opacity: .85;
}

.offcanvas .btn-close,
.modal .btn-close {
    opacity: .75;
    transition: opacity .15s ease-in-out, transform .15s ease-in-out;
}

.offcanvas .btn-close:hover,
.modal .btn-close:hover {
    opacity: 1;
    transform: scale(1.05);
}

[data-bs-theme="dark"] .offcanvas .btn-close:hover,
[data-bs-theme="dark"] .modal .btn-close:hover { opacity: 1; }

/* Theme-aware accordion glyphs */

.accordion-button::after { transition: filter .15s ease-in-out, opacity .15s ease-in-out, transform .15s ease-in-out; }

[data-bs-theme="dark"] .accordion-button::after {
    /* Ensure chevron remains visible on dark backgrounds */
    filter: invert(1) grayscale(100%);
    opacity: .9;
}

.similarity-modal-content.animate-in {
    opacity: 1;
    transform: translateY(0);
}

.similarity-modal-header {
    align-items: center;
    border-bottom: 1px solid var(--bs-border-color);
    display: flex;
    justify-content: space-between;
    padding: 1rem 1.5rem;
}

.similarity-modal-close {
    background: none;
    border: none;
    color: var(--bs-body-color);
    cursor: pointer;
    font-size: 2rem;
    line-height: 1;
    opacity: 0.7;
    padding: 0.25rem 0.5rem;
    transition: opacity 0.2s;
}

.similarity-modal-close:hover { opacity: 1; }

.similarity-modal-body { padding: 1.5rem; }

.similarity-split-pane {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: 300px 1fr;
}

@media (max-width: 768px) {
    .similarity-split-pane { grid-template-columns: 1fr; }
}

.similarity-reference-pane {
    background: var(--bs-tertiary-bg);
    border-radius: 8px;
    padding: 1rem;
}

.similarity-reference-image-container {
    border-radius: 4px;
    overflow: hidden;
    padding-bottom: 100%;
    position: relative;
}

.similarity-reference-image-container img {
    background: var(--bs-body-bg);
    height: 100%;
    left: 0;
    object-fit: contain;
    position: absolute;
    top: 0;
    width: 100%;
}

.similarity-reference-info {
    margin-top: 1rem;
    text-align: center;
}

.similarity-images-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
}

.similarity-card-wrapper {
    position: relative;
    margin: 0;
    width: 100%;
}

.similarity-score-badge {
    background: rgba(var(--bs-primary-rgb), 0.9);
    border-radius: 4px;
    color: white;
    font-size: 0.875rem;
    font-weight: 600;
    padding: 0.25rem 0.5rem;
    position: absolute;
    right: 0.5rem;
    top: 0.5rem;
    z-index: 1;
}

/* Similarity Search Loader */

/* Similarity loader removed - using shimmer effects instead */

/* Error Container */

.similarity-error-container {
    background-color: var(--bs-warning-bg-subtle);
    border: 1px solid var(--bs-warning-border-subtle);
    border-radius: 4px;
    color: var(--bs-warning-text);
    margin: 1rem;
    padding: 1rem;
}

/* Debug Link */

.debug-link {
    bottom: 5px;
    color: var(--bs-secondary);
    cursor: pointer;
    font-size: 10px;
    position: absolute;
    right: 5px;
    text-decoration: underline;
    z-index: 1;
}

/* --- Styles moved from Views/Dashboard/Styles.cshtml (filter/sidebar, actions, etc.) --- */

.filters-wrapper {
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 32px); /* Reduced for better fit */
    position: sticky;
    top: 16px; /* Slightly smaller offset for more space */
}

.filters-content {
    flex-grow: 1;
    overflow-y: auto;
    padding-top: 1rem !important;
    max-height: calc(100vh - 110px);
    min-height: 0;
}

.filter-actions-wrapper {
    background: var(--bs-body-bg);
    border-top: 1px solid var(--bs-border-color);
    bottom: 0;
    box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.05);
    left: 0;
    margin-top: auto;
    padding: 0.75rem 1rem;
    position: sticky;
    right: 0;
    width: 100%;
    z-index: 1020;
}

[data-bs-theme="dark"] .filter-actions-wrapper {
    background: var(--bs-dark);
    box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.15);
}

.filter-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.btn-filter-action {
    align-items: center;
    display: flex;
    justify-content: center;
    min-height: 38px;
    transition: all 0.2s ease;
}

.btn-filter-action:hover {
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    transform: translateY(-1px);
}

.btn-filter-action:active {
    box-shadow: none;
    transform: translateY(0);
}

.filter-label {
    align-items: center;
    color: var(--bs-body-color);
    display: flex;
    font-size: 0.875rem;
    font-weight: 500;
    justify-content: space-between;
    margin-bottom: 0.5rem;
}

.fiscal-year-check {
    align-items: center;
    display: flex;
    margin-bottom: 0.75rem;
    padding-left: 0.25rem;
}

.fiscal-year-check label {
    cursor: pointer;
    font-size: 0.875rem;
    margin-bottom: 0;
    margin-left: 0.25rem;
}

.filter-group { margin-bottom: 1.25rem; }

.filter-section {
    margin-bottom: 1rem;
    margin-top: 1.5rem;
}

/* --- End of moved styles --- */

/* --- Metal Buttons: Pill Style, Stretched, Flex Layout --- */

.metal-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    width: 100%;
}

.metal-btn {
    align-items: center;
    background: var(--bs-light);
    border: 1.5px solid var(--bs-border-color);
    border-radius: 999px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
    color: var(--bs-body-color);
    display: flex;
    flex: 1 1 0;
    font-weight: 500;
    justify-content: center;
    margin-bottom: 0.25rem;
    max-width: 100%;
    min-width: 110px;
    padding: 0.5rem 1.25rem;
    transition: background 0.2s, color 0.2s, border 0.2s, box-shadow 0.2s;
}

.metal-btn i {
    font-size: 1.1em;
    margin-right: 0.5rem;
}

.metal-btn.active, .metal-btn:focus {
    background: var(--bs-primary-lighter);
    border-color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.10);
    color: var(--bs-primary);
}

.metal-btn:hover {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
    color: #fff;
}

.metal-gold {
    background: #fffbe6;
    border-color: #ffe066;
    color: #bfa100;
}

.metal-gold.active, .metal-gold:focus, .metal-gold:hover {
    background: #ffe066;
    border-color: #ffd700;
    color: #856404;
}

.metal-platinum {
    background: #f0f0f7;
    border-color: #d7ddf0;
    color: #6c757d;
}

.metal-platinum.active, .metal-platinum:focus, .metal-platinum:hover {
    background: #d7ddf0;
    border-color: #b0b6c1;
    color: #212529;
}

.metal-silver {
    background: #f8f9fa;
    border-color: #e0e0e0;
    color: #7a7a7a;
}

.metal-silver.active, .metal-silver:focus, .metal-silver:hover {
    background: #e0e0e0;
    border-color: #b0b6c1;
    color: #212529;
}

.metal-dualtone {
    background: linear-gradient(90deg, #fffbe6 0%, #f0f0f7 100%);
    border-color: #d7ddf0;
    color: #8d6f5c;
}

.metal-dualtone.active, .metal-dualtone:focus, .metal-dualtone:hover {
    background: linear-gradient(90deg, #ffe066 0%, #d7ddf0 100%);
    border-color: #b0b6c1;
    color: #543a29;
}

.metal-other {
    background: #f8f9fa;
    border-color: #dee2e6;
    color: #495057;
}

.metal-other.active, .metal-other:focus, .metal-other:hover {
    background: #e9ecef;
    border-color: #adb5bd;
    color: #212529;
}

[data-bs-theme="dark"] .metal-btn {
    background: #212434;
    border-color: #637682;
    color: #d7ddf0;
}

[data-bs-theme="dark"] .metal-btn.active, [data-bs-theme="dark"] .metal-btn:focus {
    background: #28465a;
    border-color: #ffd700;
    color: #ffd700;
}

[data-bs-theme="dark"] .metal-btn:hover {
    background: #8d6f5c;
    border-color: #ffd700;
    color: #fffbe6;
}

[data-bs-theme="dark"] .metal-gold {
    background: #221a18;
    border-color: #8d6f5c;
    color: #ffd700;
}

[data-bs-theme="dark"] .metal-gold.active, [data-bs-theme="dark"] .metal-gold:focus, [data-bs-theme="dark"] .metal-gold:hover {
    background: #8d6f5c;
    border-color: #ffd700;
    color: #fffbe6;
}

[data-bs-theme="dark"] .metal-platinum {
    background: #212434;
    border-color: #637682;
    color: #d7ddf0;
}

[data-bs-theme="dark"] .metal-platinum.active, [data-bs-theme="dark"] .metal-platinum:focus, [data-bs-theme="dark"] .metal-platinum:hover {
    background: #637682;
    border-color: #d7ddf0;
    color: #fffbe6;
}

[data-bs-theme="dark"] .metal-silver {
    background: #212434;
    border-color: #637682;
    color: #95a7b4;
}

[data-bs-theme="dark"] .metal-silver.active, [data-bs-theme="dark"] .metal-silver:focus, [data-bs-theme="dark"] .metal-silver:hover {
    background: #95a7b4;
    border-color: #d7ddf0;
    color: #212434;
}

[data-bs-theme="dark"] .metal-dualtone {
    background: linear-gradient(90deg, #221a18 0%, #212434 100%);
    border-color: #8d6f5c;
    color: #d7ddf0;
}

[data-bs-theme="dark"] .metal-dualtone.active, [data-bs-theme="dark"] .metal-dualtone:focus, [data-bs-theme="dark"] .metal-dualtone:hover {
    background: linear-gradient(90deg, #8d6f5c 0%, #d7ddf0 100%);
    border-color: #ffd700;
    color: #fffbe6;
}

[data-bs-theme="dark"] .metal-other {
    background: #212434;
    border-color: #637682;
    color: #d7ddf0;
}

[data-bs-theme="dark"] .metal-other.active, [data-bs-theme="dark"] .metal-other:focus, [data-bs-theme="dark"] .metal-other:hover {
    background: #637682;
    border-color: #d7ddf0;
    color: #fffbe6;
}

/* --- Filter Container Height & Scroll --- */

.filter-form-scrollable, .filters-wrapper {
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 40px);
    min-height: 0;
}

.filter-fields, .filters-content {
    max-height: calc(100vh - 110px);
    min-height: 0;
    overflow-y: auto;
    padding-right: 1rem;
}

/* --- Filter Actions: Responsive, Consistent --- */

.filter-actions-wrapper {
    background: var(--bs-body-bg);
    border-top: 1px solid var(--bs-border-color);
    padding: 1rem 1.5rem 0.75rem 1.5rem;
    z-index: 10;
}

.filter-actions {
    display: flex;
    flex-direction: row;
    gap: 0.75rem;
}

@media (max-width: 576px) {
    .filter-actions { flex-direction: column; }
}

.btn-filter-action {
    border-radius: 0.5rem;
    font-weight: 500;
    padding: 0.5rem 0.75rem;
    transition: box-shadow 0.2s, background 0.2s, color 0.2s;
    width: 100%;
}

/* --- Floating Action Buttons Container --- */

.floating-actions-container {
    position: fixed;
    bottom: 30px; /* Increased bottom spacing */
    right: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    z-index: 1049;
    align-items: center;
    padding: 0;
    pointer-events: none; /* Allow clicks to pass through container but not children */
    transition: gap 0.3s ease;
}

/* --- Modern FAB Button Base Styles --- */

.fab-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: none;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    opacity: 1;
    pointer-events: auto;
    transform: scale(1);
    margin: 0;
    position: relative;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    overflow: hidden;
}

.fab-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.1));
    border-radius: inherit;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
}

.fab-btn:hover {
    transform: scale(1.1) translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
}

.fab-btn:hover::before { opacity: 1; }

.fab-btn:active {
    transform: scale(0.95) translateY(0);
    transition: transform 0.1s ease;
}

.fab-btn i {
    font-size: 1.25rem;
    transition: all 0.3s ease;
}

/* --- FAB Button Variants --- */

.fab-collection { background: var(--bs-primary); }

.fab-collection:hover { background: rgba(var(--bs-primary-rgb), 0.8); }

.fab-cart { background: var(--bs-success); }

.fab-cart:hover { background: rgba(var(--bs-success-rgb), 0.8); }

.fab-download { background: var(--bs-info); }

.fab-download:hover { background: rgba(var(--bs-info-rgb), 0.8); }

/* Dark theme adjustments for FABs */

[data-bs-theme="dark"] .fab-btn { box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25); }

[data-bs-theme="dark"] .fab-collection { background: var(--bs-primary); }

[data-bs-theme="dark"] .fab-collection:hover { background: rgba(var(--bs-primary-rgb), 0.8); }

[data-bs-theme="dark"] .fab-cart { background: var(--bs-success); }

[data-bs-theme="dark"] .fab-cart:hover { background: rgba(var(--bs-success-rgb), 0.8); }

[data-bs-theme="dark"] .fab-download { background: var(--bs-info); }

[data-bs-theme="dark"] .fab-download:hover { background: rgba(var(--bs-info-rgb), 0.8); }

/* --- Modern Scroll to Top Button --- */

.scroll-to-top-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--bs-primary), rgba(var(--bs-primary-rgb), 0.9));
    border: none;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 4px 15px rgba(var(--bs-primary-rgb), 0.3);
    opacity: 0;
    pointer-events: none;
    transform: translateY(10px) scale(0.95);
    margin: 0;
    position: relative;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    overflow: hidden;
}

.scroll-to-top-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.1));
    border-radius: inherit;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
}

.scroll-to-top-btn.visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

.scroll-to-top-btn:hover {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.9), var(--bs-primary));
    transform: scale(1.1) translateY(-2px);
    box-shadow: 0 8px 25px rgba(var(--bs-primary-rgb), 0.4);
}

.scroll-to-top-btn:hover::before { opacity: 1; }

.scroll-to-top-btn:active {
    transform: scale(0.95) translateY(0);
    transition: transform 0.1s ease;
}

.scroll-to-top-btn i {
    font-size: 1.25rem;
    transition: all 0.3s ease;
}

/* Dark theme adjustments */

[data-bs-theme="dark"] .scroll-to-top-btn {
    background: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

[data-bs-theme="dark"] .scroll-to-top-btn:hover { background: rgba(var(--bs-primary-rgb), 0.8); }

/* Responsive design for mobile devices */

@media (max-width: 576px) {
    .floating-actions-container {
        bottom: 25px;
        right: 15px;
        gap: 10px;
    }

    .fab-btn,
    .scroll-to-top-btn {
        width: 36px;
        height: 36px;
    }

    .fab-btn i,
    .scroll-to-top-btn i { font-size: 1.1rem; }
}

/* Ensure proper positioning when only scroll-to-top button is present */

.floating-actions-container:has(.scroll-to-top-btn:only-child) { gap: 0; }

/* When scroll-to-top button is hidden, reduce gap for seamless transition */

.floating-actions-container:has(.scroll-to-top-btn:not(.visible)) { gap: 8px; }

/* Smooth transition when scroll-to-top button appears/disappears */

.floating-actions-container .scroll-to-top-btn { transition: all 0.3s ease, opacity 0.3s ease, transform 0.3s ease; }

/* Removed obsolete/conflicting overrides previously forcing top on filter containers */

/* --- Compact Filter Modal & Form --- */

.compact-modal .modal-dialog { max-width: 480px; }

.compact-modal-content {
    border-radius: 0.6rem !important;
    padding: 0.5rem 0.5rem 0.5rem 0.5rem !important;
}

.compact-modal .modal-header,
.compact-modal .modal-body { padding: 0.75rem 1rem !important; }

.compact-filter-form .filter-fields {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
}

.compact-filter-form .mb-4 { margin-bottom: 0.75rem !important; }

.compact-filter-form .mb-3 { margin-bottom: 0.5rem !important; }

.compact-filter-form .mb-2 { margin-bottom: 0.35rem !important; }

.compact-filter-form .section-header { font-size: 1rem; }

.compact-filter-form label.filter-label { font-size: 0.95rem; }

.compact-filter-form .form-select,
.compact-filter-form .select2-selection {
    font-size: 0.95rem;
    min-height: 32px;
}

.compact-filter-form .btn-filter-action {
    font-size: 0.97rem;
    padding-bottom: 0.3rem !important;
    padding-top: 0.3rem !important;
}

.compact-filter-form .metal-buttons .btn {
    font-size: 0.95rem;
    padding: 0.25rem 0.75rem;
}

.compact-filter-form .filter-actions { gap: 0.5rem !important; }

@media (max-width: 600px) {
    .compact-modal .modal-dialog { max-width: 98vw; }

    .compact-modal .modal-header, .compact-modal .modal-body { padding: 0.5rem 0.5rem !important; }
}

[data-bs-theme="dark"] .compact-modal-content {
    background-color: var(--bs-dark);
    color: var(--bs-body-color);
}

/* Mega Menu Container */

.mega-menu-container {
    position: relative;
    z-index: 1000;
}

.mega-menu-container .mega-menu {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    margin-top: 0;
}

/* Ensure navbar has higher z-index than mega-menu */

.navbar {
    position: relative;
    z-index: 1001;
}

/* Fix dropdown menu z-index */

.dropdown-menu { z-index: 1002; }

/* Filter form scrollable area */

.filter-fields-scrollable {
    max-height: calc(100vh - 170px);
    min-height: 0;
    overflow-y: auto;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

/* Root filter form container */

.filter-form-root {
    height: 100%;
    min-height: 0;
}

/* Similarity Search Modal - Revamped to match ProductDetailModal */

.similarity-search-modal.modal {
    z-index: 1055; /* Lower than product-detail-modal (1060) */
}

.similarity-search-modal .modal-dialog {
    max-width: 100%;
}

.similarity-search-modal .modal-content {
    border: none;
    border-radius: 0;
    height: 100vh;
    position: relative;
}

.similarity-search-modal .modal-header {
    padding: 0.75rem 1.5rem;
    border-bottom: 1px solid var(--bs-border-color);
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .similarity-search-modal .modal-header .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

.similarity-search-modal .modal-body {
    overflow-y: auto;
    scroll-behavior: smooth;
    scroll-padding-top: 0;
}

/* Reference Section */
.similarity-search-modal .similarity-reference-section {
    height: 100%;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    border-right: 1px solid var(--bs-border-color);
    background-color: var(--bs-body-bg);
}

.similarity-reference-container {
    display: flex;
    flex-direction: column;
    height: 100%;
    align-items: center;
    justify-content: center;
}

.similarity-reference-image-wrapper {
    position: relative;
    width: 100%;
    height: 70%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background-color: var(--bs-body-bg);
    margin-bottom: 1rem;
}

/* Pinterest-style region selection: container for image + overlay */
.similarity-region-select-container {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 auto;
    min-height: 0;
}

.similarity-region-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    cursor: crosshair;
    z-index: 2;
}

.similarity-region-selection {
    position: absolute;
    border: 2px solid var(--bs-primary);
    background: rgba(var(--bs-primary-rgb), 0.18);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25), inset 0 0 0 1px rgba(255, 255, 255, 0.15);
    pointer-events: auto;
    z-index: 3;
    display: none;
    border-radius: 8px;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding: 6px;
    box-sizing: border-box;
}

.similarity-region-selection:not(.similarity-region-selection--valid) .similarity-region-search-btn {
    display: none;
}

.similarity-region-selection .similarity-region-search-btn {
    background: var(--bs-primary);
    color: var(--bs-white);
    border: none;
    border-radius: 6px;
    padding: 6px 12px;
    font-size: 0.8rem;
    font-weight: 500;
    white-space: nowrap;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.similarity-region-selection .similarity-region-search-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.25);
    color: var(--bs-white);
    background: var(--bs-primary);
    border-color: transparent;
}

.similarity-region-selection .similarity-region-search-btn:active {
    transform: translateY(0);
}

.similarity-region-toolbar {
    flex-shrink: 0;
    padding: 0.5rem 0;
    width: 100%;
}

.similarity-region-hint {
    margin-bottom: 0.25rem;
}

[data-bs-theme="dark"] .similarity-region-selection {
    background: rgba(var(--bs-primary-rgb), 0.25);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.4), inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.similarity-reference-image {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 8px;
    display: block;
    position: relative;
    z-index: 1;
}

.similarity-reference-info {
    text-align: center;
    width: 100%;
    padding: 0.5rem;
}

.similarity-reference-style-no {
    color: var(--bs-body-color);
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.similarity-category-scope-toggle-wrapper {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.similarity-category-scope-toggle {
    display: inline-flex;
}

.similarity-category-scope-toggle .btn {
    font-size: 0.8rem;
}

.similarity-category-scope-toggle .btn.active {
    background-color: var(--bs-primary);
    color: var(--bs-white);
    border-color: var(--bs-primary);
}

.similarity-category-scope-toggle .btn.active:hover {
    background-color: var(--bs-primary);
    color: var(--bs-white);
    border-color: var(--bs-primary);
    filter: brightness(1.05);
}

/* Results Section */
.similarity-search-modal .similarity-results-section {
    height: 100%;
    padding: 1.5rem;
    overflow-y: auto;
}

.similarity-results-container {
    height: 100%;
}

.similarity-images-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    width: 100%;
    padding: 0;
    margin: 0;
}

.similarity-image-card {
    background-color: var(--bs-body-bg);
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    cursor: pointer;
    overflow: hidden;
    position: relative;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.similarity-image-card:hover,
.similarity-image-card:focus {
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.15);
    outline: none;
    transform: translateY(-5px);
}

.similarity-image-wrapper {
    overflow: hidden;
    padding-top: 100%; /* 1:1 aspect ratio */
    position: relative;
}

.similarity-image-wrapper img {
    height: 100%;
    left: 0;
    object-fit: cover;
    position: absolute;
    top: 0;
    transition: transform 0.3s ease;
    width: 100%;
}

.similarity-image-card:hover .similarity-image-wrapper img { transform: scale(1.05); }

.similarity-hover-overlay {
    align-items: center;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    height: 100%;
    justify-content: center;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: opacity 0.3s ease;
    width: 100%;
}

.similarity-image-card:hover .similarity-hover-overlay,
.similarity-image-card:focus .similarity-hover-overlay { opacity: 1; }

.similarity-actions {
    transform: translateY(20px);
    transition: transform 0.3s ease;
}

.similarity-image-card:hover .similarity-actions,
.similarity-image-card:focus .similarity-actions { transform: translateY(0); }

.similarity-image-info {
    align-items: center;
    display: flex;
    justify-content: space-between;
    padding: 0.75rem;
}

.similarity-style-no { font-weight: 500; }

.similarity-score {
    color: var(--bs-gray-600);
    font-size: 0.8rem;
}

/* Similarity loader removed - using shimmer effects instead */

[data-bs-theme="dark"] .similarity-search-modal .similarity-reference-section {
    background-color: var(--bs-body-bg);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .similarity-reference-image-wrapper {
    background-color: var(--bs-body-bg);
}

[data-bs-theme="dark"] .similarity-reference-style-no {
    color: var(--bs-body-color);
}

/* Responsive adjustments */

@media (max-width: 991.98px) {
    .similarity-search-modal .similarity-reference-section {
        border-right: none;
        border-bottom: 1px solid var(--bs-border-color);
        height: auto;
        max-height: 50vh;
    }

    .similarity-reference-image-wrapper {
        height: auto;
        min-height: 200px;
        max-height: 300px;
    }

    .similarity-reference-image {
        display: block;
        margin: 0 auto;
    }

    .similarity-region-toolbar {
        padding: 0.5rem 0.25rem;
    }

    .similarity-region-actions .btn {
        font-size: 0.8rem;
    }

    .similarity-search-modal .similarity-results-section {
        height: auto;
    }

    .similarity-images-grid {
        gap: 0.875rem;
        grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    }
}

@media (max-width: 767.98px) {
    .similarity-images-grid {
        gap: 0.875rem;
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    }
}

@media (max-width: 576px) {
    .similarity-images-grid {
        gap: 0.75rem;
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    }
}

/* Similarity search styling */

/* .similarity-score-badge { */

/*     position: absolute; */

/*     bottom: 10px; */

/*     right: 10px; */

/*     background-color: rgba(var(--bs-primary-rgb), 0.85); */

/*     color: #fff; */

/*     font-size: 0.75rem; */

/*     font-weight: 600; */

/*     padding: 0.25rem 0.5rem; */

/*     border-radius: 0.25rem; */

/*     box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); */

/*     z-index: 5; */

/* } */

[data-bs-theme="dark"] .similarity-score-badge {
    background-color: rgba(var(--bs-primary-rgb), 0.9);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.4);
}

/* Adjust card grid in similarity modal */

.similarity-results-pane .col-xl-3,
.similarity-results-pane .col-lg-4,
.similarity-results-pane .col-md-6 {
    flex: 0 0 100%;
    max-width: 100%;
    padding: 0.5rem;
    width: 100%;
}

/* Image height control in similarity modal */

.similarity-results-pane .style-image { height: 200px; }

.similarity-results-pane .style-image img {
    max-height: 200px;
    object-fit: contain;
}

/* Style card wrapper in similarity modal */

.similarity-card-wrapper {
    width: 100%;
    margin: 0;
    padding: 0;
}

/* Hide checkboxes in similarity modal */

.similarity-modal-overlay .selection-control { display: none; }

/* Ensure style-card in similarity modal has proper spacing */
.similarity-images-grid .similarity-card-wrapper .style-card {
    margin: 0;
    padding: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.similarity-images-grid .similarity-card-wrapper .style-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
    transform: translateY(-2px);
}

.similarity-images-grid .similarity-card-wrapper .style-header {
    padding: 0.75rem;
    border-bottom: 1px solid var(--bs-border-color);
}

.similarity-images-grid .similarity-card-wrapper .style-image {
    margin: 0;
    padding: 0;
    flex-shrink: 0;
}

.similarity-images-grid .similarity-card-wrapper .style-specs {
    padding: 0.75rem;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

/* Ensure consistent tooltip styling across the application */

.tooltip {
    --bs-tooltip-max-width: 200px;
    --bs-tooltip-padding-x: 0.5rem;
    --bs-tooltip-padding-y: 0.25rem;
    --bs-tooltip-font-size: 0.75rem;
    --bs-tooltip-color: var(--bs-body-bg);
    --bs-tooltip-bg: var(--bs-body-color);
    --bs-tooltip-border-radius: 0.25rem;
    --bs-tooltip-opacity: 0.9;
    z-index: 1090;
}

/* Tooltip styling for dark mode */

[data-bs-theme="dark"] .tooltip {
    --bs-tooltip-color: var(--bs-dark);
    --bs-tooltip-bg: var(--bs-light);
}

/* Tooltip metal type styling */

.tooltip-metal-gold { color: #ffd700; }

.tooltip-metal-platinum { color: #e5e4e2; }

.tooltip-metal-silver { color: #c0c0c0; }

[data-bs-theme="dark"] .tooltip-metal-gold,
[data-bs-theme="dark"] .tooltip-metal-platinum,
[data-bs-theme="dark"] .tooltip-metal-silver { text-shadow: 0 0 2px rgba(0, 0, 0, 0.5); }

/* Disable card selection in similarity modal */

.similarity-modal-overlay .style-card {
    cursor: default;
    pointer-events: auto;
}

.similarity-modal-overlay .style-card:hover {
    box-shadow: var(--bs-shadow-sm);
    transform: none;
}

/* But keep buttons clickable */

.similarity-modal-overlay .card-actions .btn-action {
    cursor: pointer;
    pointer-events: auto;
}

/* Adjust card grid in similarity modal */

/* Image Search Button */

.btn-image-search {
    align-items: center;
    background: rgba(var(--bs-primary-rgb), 0.9);
    border: none;
    border-radius: 50%;
    bottom: 10px; /* Ensure consistent bottom-right placement */
    color: white;
    cursor: pointer;
    display: flex;
    height: 2rem;
    justify-content: center;
    opacity: 1;
    position: absolute;
    right: 10px;
    transition: opacity 0.2s ease-in-out;
    width: 2rem;
    z-index: 2;
}

.btn-image-search:hover { background: var(--bs-primary); }

.btn-image-search i { font-size: 1rem; }

/* Cart Item Styles */

.cart-item-card {
    align-items: stretch;
    background: var(--bs-card-bg);
    border-radius: 0.75rem;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    margin-bottom: 16px;
    overflow: hidden;
    padding: 0;
    border: 1px solid var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .cart-item-card {
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}

/* Cart Item Image Column */

.cart-item-image-col {
    align-items: center;
    background: var(--bs-card-bg);
    border: none;
    border-radius: 0.3rem;
    box-shadow: none;
    display: flex;
    justify-content: center;
    margin: 0;
    max-width: 200px;
    max-height: 200px;
    margin: 16px 0 0 16px;
    overflow: hidden;
    box-sizing: border-box; /* Ensure padding is respected */
}

/* Cart Item Image */

.cart-item-image {
    background: none;
    border: none;
    border-radius: 0;
    box-shadow: none;
    display: block;
    height: 100%;
    margin: 0;
    object-fit: cover;
    padding: 0;
    width: 100%;
    box-sizing: border-box; /* Ensure image respects parent padding */
}

/* Cart Item Content Column */

.cart-item-content-col {
    display: flex;
    flex: 1 1 0%;
    flex-direction: column;
    justify-content: space-between;
    padding: 16px 20px;
    color: var(--bs-body-color);
    background: var(--bs-card-bg); /* Ensure theme consistency */
}

/* Cart Item Style */

.cart-item-style {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
    color: var(--bs-body-color);
}

/* Cart Item Attributes */

.cart-item-attributes {
    color: var(--bs-secondary);
    font-size: 0.97rem;
    margin-bottom: 0.5rem;
}

/* Pipe separators removed; chips provide spacing */

.cart-item-attributes span:not(:last-child)::after { content: none; }

/* Cart Note Display */

.cart-note-display {
    color: var(--bs-secondary);
    margin-bottom: 0.5rem;
}

/* Cart Controls Row */

.cart-controls-row {
    align-items: center;
    display: flex;
    flex-direction: row;
    gap: 0.75rem;
    justify-content: flex-start;
    margin-top: auto;
}

.cart-controls-row .quantity-control,
.cart-controls-row .cart-action-btn { margin: 0; }

/* Cart Quantity Row */

.cart-quantity-row {
    align-items: center;
    display: flex;
    margin-left: 0;
    margin-top: 0.5rem;
}

/* Cart Item Responsive Styles */

@media (max-width: 768px) {
    .cart-item-card {
        align-items: stretch;
        flex-direction: column;
    }

    .cart-item-image-col {
        height: 150px;
        justify-content: center;
        max-width: 100%;
        min-width: 100%;
        border-radius: 0.75rem 0.75rem 0 0;
        background: var(--bs-card-bg);
    }

    .cart-item-image {
        height: 150px;
        width: 100%;
        object-fit: cover;
    }

    .cart-item-content-col { padding: 16px; }

    .cart-quantity-row { margin-left: 0; }

    .cart-note-container {
        margin-left: 0;
        width: 100%;
    }
}

@media (max-width: 576px) {
    .cart-controls-row {
        flex-wrap: wrap;
        gap: 0.5rem;
    }
}

/* Cart Item Dark Theme Styles */

[data-bs-theme="dark"] .cart-item-card,
.cart-item-card[data-bs-theme="dark"] {
    background-color: var(--bs-card-bg);
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .cart-item-card .cart-item-attributes,
.cart-item-card[data-bs-theme="dark"] .cart-item-attributes { 
    color: var(--bs-secondary); 
}

[data-bs-theme="dark"] .cart-item-card .cart-item-style {
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .cart-item-card .cart-note-display {
    color: var(--bs-secondary);
}

[data-bs-theme="dark"] .cart-item-card .cart-engraving-display {
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .cart-item-card .cart-engraving-display .text-primary {
    color: var(--bs-primary) !important;
}

/* Cart Note Zone */

.cart-note-zone {
    min-height: 32px;
    transition: opacity 0.2s;
}

.cart-note-edit-zone {
    animation: fadeInNote 0.2s;
    display: none;
}

@keyframes fadeInNote {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.cart-note-input.form-control {
    border-radius: 8px;
    font-size: 14px;
    min-height: 42px;
    padding: 10px 14px;
    resize: none;
    transition: box-shadow 0.2s;
    background: var(--bs-input-bg);
    color: var(--bs-body-color);
    border: 1px solid var(--bs-border-color);
}

.cart-note-input.form-control:focus { box-shadow: 0 0 0 2px var(--bs-primary, #2563eb); }

.note-char-counter {
    font-size: 12px;
    opacity: 0.7;
}

.save-note-btn[disabled] {
    opacity: 0.7;
    pointer-events: none;
}

.cancel-note-btn {
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .cancel-note-btn {
    color: var(--bs-body-color);
}

.cancel-note-btn:hover {
    color: var(--bs-primary);
    text-decoration: none;
}

.note-feedback {
    font-size: 13px;
    min-height: 18px;
}

.cart-note-zone .cart-note-btn {
    font-size: 1rem;
    padding: 0 0.5rem;
    color: var(--bs-primary);
}

/* Cart Engraving Zone */
.cart-engraving-zone {
    min-height: 32px;
    transition: opacity 0.2s;
}

.cart-engraving-display {
    color: var(--bs-body-color);
}

.cart-engraving-display .text-primary {
    color: var(--bs-primary) !important;
}

.cart-engraving-btn {
    color: var(--bs-primary);
}

.cart-engraving-btn:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-primary);
}

[data-bs-theme="dark"] .cart-engraving-btn:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.2);
}

.cart-engraving-btn .text-muted {
    color: var(--bs-secondary) !important;
}

[data-bs-theme="dark"] .cart-engraving-btn .text-muted {
    color: var(--bs-secondary) !important;
}

/* Cart Quantity Control */

.quantity-control {
    position: relative;
    align-items: center;
    display: inline-flex;
    gap: 6px;
}

.quantity-btn {
    align-items: center;
    background-color: var(--bs-input-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    font-size: 16px;
    height: 32px;
    justify-content: center;
    padding: 0;
    width: 32px;
    color: var(--bs-body-color);
}

.quantity-btn:hover { 
    background-color: var(--bs-primary-lighter, rgba(var(--bs-primary-rgb), 0.1)); 
    color: var(--bs-primary);
}

[data-bs-theme="dark"] .quantity-btn:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.2);
}

.quantity-input {
    border: 1px solid var(--bs-border-color);
    border-radius: 8px;
    font-size: 14px;
    height: 32px;
    padding: 6px 0;
    text-align: center;
    width: 36px;
    background: var(--bs-input-bg);
    color: var(--bs-body-color);
}

/* Hide number input spinners for cleaner UI */

.quantity-input::-webkit-outer-spin-button,
.quantity-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.quantity-input[type=number] { -moz-appearance: textfield; }

.qty-input-spinner-overlay {
    align-items: center;
    background: rgba(255, 255, 255, 0.7);
    border-radius: 8px;
    display: flex;
    height: 32px;
    justify-content: center;
    left: 50%;
    pointer-events: none;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 36px;
    z-index: 2;
}

[data-bs-theme="dark"] .qty-input-spinner-overlay {
    background: rgba(0, 0, 0, 0.7);
}

/* Cart Action Buttons */

.cart-action-btn {
    align-items: center;
    background: none;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    font-size: 18px;
    justify-content: center;
    padding: 6px;
    color: var(--bs-body-color);
    transition: background 0.2s, color 0.2s;
}

.cart-action-btn:hover {
    background-color: rgba(var(--bs-body-color-rgb), 0.1);
}

[data-bs-theme="dark"] .cart-action-btn:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

.cart-note-btn { color: var(--bs-primary); }

.cart-note-btn.active {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-primary);
}

.cart-wishlist-btn { color: var(--bs-danger); }

.cart-wishlist-btn.active {
    background-color: rgba(var(--bs-danger-rgb), 0.1);
    color: var(--bs-danger);
}

.cart-delete-btn {
    color: var(--bs-danger);
    transition: background 0.2s, color 0.2s;
}

.cart-delete-btn:hover {
    background-color: rgba(var(--bs-danger-rgb), 0.1);
    color: var(--bs-danger);
}

.cart-update-btn {
    background-color: rgba(var(--bs-success-rgb), 0.1);
    border-radius: 50%;
    color: var(--bs-success);
    transition: all 0.2s ease;
}

.cart-update-btn:hover {
    background-color: rgba(var(--bs-success-rgb), 0.2);
    transform: scale(1.05);
}

/* Cart Summary Card Styles */

.cart-summary-card {
    align-self: flex-start;
    background: var(--bs-card-bg);
    border-radius: 1.25rem;
    box-shadow: var(--bs-panel-shadow);
    flex-grow: 0;
    flex-shrink: 0;
    height: auto;
    margin-bottom: 2rem;
    max-width: 100%;
    min-width: 260px;
    padding: 2rem 1.5rem;
    transition: box-shadow 0.2s;
}

.cart-summary-card .fs-5 {
    color: var(--bs-primary);
    font-size: 1.5rem !important;
}

.cart-summary-card .fs-6 {
    color: var(--bs-success);
    font-size: 1.15rem !important;
}

.cart-summary-card .text-secondary {
    font-weight: 500;
    opacity: 0.85;
    color: var(--bs-secondary);
}

[data-bs-theme="dark"] .cart-summary-card .text-secondary {
    color: var(--bs-secondary);
    opacity: 0.9;
}

[data-bs-theme="dark"] .cart-summary-card .text-warning {
    color: var(--bs-warning) !important;
}

[data-bs-theme="dark"] .cart-summary-card .text-muted {
    color: var(--bs-secondary) !important;
}

.cart-summary-card .btn-primary {
    border-radius: 0.75rem;
    box-shadow: 0 2px 8px rgba(13, 110, 253, 0.08);
    font-size: 1.1rem;
    padding: 0.75rem 0;
}

.cart-summary-card .btn-primary:active { 
    box-shadow: 0 1px 4px rgba(13, 110, 253, 0.12); 
}

[data-bs-theme="dark"] .cart-summary-card .btn-primary {
    box-shadow: 0 2px 8px rgba(13, 110, 253, 0.2);
}

[data-bs-theme="dark"] .cart-summary-card .btn-primary:active {
    box-shadow: 0 1px 4px rgba(13, 110, 253, 0.3);
}

[data-bs-theme="dark"] .cart-summary-card .border-top {
    border-top-color: var(--bs-border-color) !important;
}

@media (max-width: 991.98px) {
    .cart-summary-card {
        margin-top: 2rem;
        min-width: unset;
        padding: 1.25rem 1rem;
        position: static !important;
    }
}

@media (max-width: 767.98px) {
    .cart-summary-card {
        margin-top: 1.5rem;
        padding: 1rem 0.75rem;
    }
}

/* Theme Image Styles */

.theme-img-polished { filter: brightness(1.05) contrast(1.05); }

[data-bs-theme="dark"] .theme-img-polished,
.cart-item-card[data-bs-theme="dark"] .theme-img-polished { filter: brightness(1.1) contrast(1.1); }

/* Cart Note Zone */

.cart-note-zone {
    min-height: 32px;
    transition: opacity 0.2s;
}

.cart-note-container {
    margin-left: 0;
    margin-top: 0.5rem;
    width: 100%;
}

.cart-note-edit-zone {
    animation: fadeInNote 0.2s;
    display: none;
}

@keyframes fadeInNote {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

/* Cart Summary Highlight Effect */

.highlight-change { animation: highlight-pulse 1s ease-in-out; }

@keyframes highlight-pulse {
    0% { color: var(--bs-primary); }

    50% { color: var(--bs-success); }

    100% { color: var(--bs-primary); }
}

/* Cart Title Styles */

.cart-page-title {
    align-items: center;
    background: var(--bs-body-bg);
    border-bottom: 1px solid var(--bs-border-color);
    display: flex;
    font-size: 1.75rem;
    font-weight: 700;
    justify-content: space-between;
    left: 0;
    margin: 0;
    padding: 1.25rem 0 1rem;
    position: fixed;
    right: 0;
    top: 0;
    transition: box-shadow 0.3s ease, background-color 0.3s;
    width: 100%;
    z-index: 1;
    color: var(--bs-body-color);
}

.cart-page-title.scrolled { 
    box-shadow: 0 4px 6px -2px rgba(0, 0, 0, 0.05); 
}

[data-bs-theme="dark"] .cart-page-title.scrolled {
    box-shadow: 0 4px 6px -2px rgba(0, 0, 0, 0.3);
}

[data-bs-theme="dark"] .cart-page-title {
    background: var(--bs-dark);
    border-bottom-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

.cart-page-title .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.cart-page-title h2 {
    color: var(--bs-primary);
    font-size: 1.75rem;
    font-weight: 700;
    margin: 0;
}

@media (max-width: 767.98px) {
    .cart-page-title { padding: 1rem 0 0.75rem; }

    .cart-page-title h2 { font-size: 1.5rem; }
}

/* Email Modal Styles */

#sendCartEmailModal .modal-content { border-radius: 0.75rem; }

#sendCartEmailModal .form-floating > .form-control { padding-left: 1rem; }

#sendCartEmailModal .form-floating > label { padding-left: 1rem; }

#sendCartEmailModal .email-attachments-section {
    background-color: rgba(0, 0, 0, 0.02);
    border-radius: 0.5rem;
    padding: 1rem;
}

#sendCartEmailModal .form-check-label { font-size: 0.95rem; }

[data-bs-theme="dark"] #sendCartEmailModal .email-attachments-section { background-color: rgba(255, 255, 255, 0.05); }

/* Mail Progress Modal Styles */

#mailProgressModal .modal-content { border-radius: 0.75rem; }

#mailProgressModal .progress {
    border-radius: 0.5rem;
    overflow: hidden;
}

/* Email Tags Input Styles */

.email-tags-input-container {
    background-color: var(--bs-body-bg);
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    min-height: 58px;
    padding: 0.5rem;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    width: 100%;
}

.email-tags-input-container.focused {
    border-color: #86b7fe;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
    outline: 0;
}

.email-tags-input-container.is-invalid { border-color: #dc3545; }

.email-tags-input-container.is-invalid.focused { box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25); }

.email-tag {
    align-items: center;
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.2);
    border-radius: 0.25rem;
    color: var(--bs-primary);
    display: inline-flex;
    font-size: 0.875rem;
    margin: 0.125rem;
    padding: 0.25rem 0.5rem;
}

.email-tag.invalid {
    background-color: rgba(var(--bs-danger-rgb), 0.1);
    border-color: rgba(var(--bs-danger-rgb), 0.2);
    color: var(--bs-danger);
}

.email-tag .remove-tag {
    align-items: center;
    background: transparent;
    border: none;
    color: currentColor;
    cursor: pointer;
    display: inline-flex;
    font-size: 0.875rem;
    height: 16px;
    justify-content: center;
    margin-left: 0.25rem;
    opacity: 0.7;
    padding: 0;
    width: 16px;
}

.email-tag .remove-tag:hover { opacity: 1; }

.email-input {
    background: transparent;
    border: none;
    flex: 1;
    font-size: 0.875rem;
    min-width: 100px;
    outline: none;
    padding: 0.25rem;
}

.email-tags-label {
    color: rgba(var(--bs-body-color-rgb), 0.65);
    font-size: 0.875rem;
    left: 0.75rem;
    pointer-events: none;
    position: absolute;
    top: 0;
    transform: translateY(-50%) scale(0.85);
    background-color: var(--bs-body-bg);
    padding: 0 0.25rem;
}

.email-tags-wrapper {
    position: relative;
    margin-bottom: 1rem;
}

[data-bs-theme="dark"] .email-tags-input-container {
    background-color: var(--bs-dark);
    border-color: #495057;
}

[data-bs-theme="dark"] .email-tags-label {
    background-color: var(--bs-dark);
    color: rgba(255, 255, 255, 0.65);
}

[data-bs-theme="dark"] .email-tag { background-color: rgba(var(--bs-primary-rgb), 0.2); }

[data-bs-theme="dark"] .email-tag.invalid { background-color: rgba(var(--bs-danger-rgb), 0.2); }

/* Swatch bar styling for style cards */

.swatch-bar {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0.5rem;
    background: none !important;
    border-radius: 0;
    min-height: 32px;
    position: static;
}

/* Size swatch styling */

.size-swatch-container {
    position: relative;
    overflow: hidden;
    border-radius: 4px;
    min-height: 32px;
    padding: 0 30px; /* Add padding to prevent overlap with navigation buttons */
}

/* Diamond quality swatch styling (mirrors size swatches) */

.diamond-quality-swatch-container {
    position: relative;
    overflow: hidden;
    border-radius: 4px;
    min-height: 32px;
    padding: 0 30px; /* Space for nav buttons */
}

.diamond-quality-swatch-container[data-swatch-count="1"],
.diamond-quality-swatch-container[data-swatch-count="2"],
.diamond-quality-swatch-container[data-swatch-count="3"],
.diamond-quality-swatch-container[data-swatch-count="4"] { padding: 0; }

.diamond-quality-swatch-bar {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    gap: 0.25rem;
    background: none !important;
    border-radius: 0;
    min-height: 32px;
    position: static;
    flex-wrap: nowrap;
    transition: transform 0.3s ease;
    width: max-content;
}

.diamond-quality-swatch-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    border: none;
    border-radius: 50%;
    background: rgba(var(--bs-primary-rgb), 0.9);
    color: white;
    display: none;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    z-index: 10;
    font-size: 0.75rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    opacity: 0;
    visibility: hidden;
}

.diamond-quality-swatch-nav.show {
    display: flex;
    opacity: 1;
    visibility: visible;
}

.diamond-quality-swatch-nav:hover {
    background: var(--bs-primary);
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
}

.diamond-quality-swatch-nav:active { transform: translateY(-50%) scale(0.95); }

.diamond-quality-swatch-nav-prev { left: 4px; }

.diamond-quality-swatch-nav-next { right: 4px; }

.diamond-quality-swatch-nav:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: translateY(-50%);
}

.diamond-quality-swatch-nav:disabled:hover {
    background: rgba(var(--bs-primary-rgb), 0.9);
    transform: translateY(-50%);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .diamond-quality-swatch-bar { background: transparent !important; }

[data-bs-theme="dark"] .diamond-quality-swatch-nav {
    background: rgba(var(--bs-primary-rgb), 0.8);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
}

[data-bs-theme="dark"] .diamond-quality-swatch-nav:hover {
    background: var(--bs-primary);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.5);
}

@media (max-width: 576px) {
    .diamond-quality-swatch-container { }

    .diamond-quality-swatch-container[data-swatch-count="1"],
    .diamond-quality-swatch-container[data-swatch-count="2"],
    .diamond-quality-swatch-container[data-swatch-count="3"],
    .diamond-quality-swatch-container[data-swatch-count="4"] { padding: 0; }

    .diamond-quality-swatch-nav {
        width: 20px;
        height: 20px;
        font-size: 0.65rem;
    }

    .diamond-quality-swatch-nav-prev { left: 2px; }

    .diamond-quality-swatch-nav-next { right: 2px; }
}

@media (min-width: 577px) and (max-width: 768px) {
    .diamond-quality-swatch-container { padding: 0 28px; }

    .diamond-quality-swatch-container[data-swatch-count="1"],
    .diamond-quality-swatch-container[data-swatch-count="2"],
    .diamond-quality-swatch-container[data-swatch-count="3"],
    .diamond-quality-swatch-container[data-swatch-count="4"] { padding: 0; }

    .diamond-quality-swatch-nav {
        width: 22px;
        height: 22px;
        font-size: 0.7rem;
    }
}

/* Remove padding when swatch count is below pagination threshold (5) */

.size-swatch-container[data-swatch-count="1"],
.size-swatch-container[data-swatch-count="2"],
.size-swatch-container[data-swatch-count="3"],
.size-swatch-container[data-swatch-count="4"] {
    padding: 0; /* No padding needed when navigation buttons are not shown */
}

.size-swatch-bar {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    gap: 0.25rem;
    background: none !important;
    border-radius: 0;
    min-height: 32px;
    position: static;
    flex-wrap: nowrap;
    transition: transform 0.3s ease;
    width: max-content;
}

.size-swatch-btn {
    min-width: 2.5em;
    height: 2.1em;
    border-radius: 4px;
    border: 2px solid var(--bs-border-color, #ccc);
    background: var(--bs-body-bg);
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    padding: 0px;
    outline: none;
    position: relative;
    font-size: 0.75rem;
    font-weight: 500;
}

.size-swatch-btn:hover {
    border-color: var(--bs-primary);
    box-shadow: 0 2px 6px rgba(var(--bs-primary-rgb), 0.2);
    transform: translateY(-1px);
}

.size-swatch-btn.selected {
    border-color: var(--bs-primary);
    background-color: var(--bs-primary);
    color: white;
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3);
}

.size-chart-btn {
    font-size: 0.75rem;
    color: var(--bs-primary);
    text-decoration: none;
    transition: all 0.2s ease;
    cursor: pointer;
    white-space: nowrap;
    margin-top: 0.5rem;
    display: block;
}

.size-chart-btn:hover {
    color: var(--bs-primary);
    text-decoration: underline;
}

/* Dark mode styles for size swatches */

[data-bs-theme="dark"] .size-swatch-btn {
    background: var(--bs-dark);
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .size-swatch-btn:hover {
    border-color: var(--bs-primary);
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .size-swatch-btn.selected {
    border-color: var(--bs-primary);
    background-color: var(--bs-primary);
    color: white;
}

[data-bs-theme="dark"] .size-chart-btn { color: var(--bs-primary); }

[data-bs-theme="dark"] .size-chart-btn:hover {
    color: var(--bs-primary);
    text-decoration: underline;
}

/* Size swatch pagination navigation */

.size-swatch-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    border: none;
    border-radius: 50%;
    background: rgba(var(--bs-primary-rgb), 0.9);
    color: white;
    display: none; /* Hidden by default, shown by JavaScript when needed */
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    z-index: 10;
    font-size: 0.75rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    opacity: 0;
    visibility: hidden;
}

.size-swatch-nav.show {
    display: flex;
    opacity: 1;
    visibility: visible;
}

.size-swatch-nav:hover {
    background: var(--bs-primary);
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
}

.size-swatch-nav:active { transform: translateY(-50%) scale(0.95); }

.size-swatch-nav-prev { left: 4px; }

.size-swatch-nav-next { right: 4px; }

.size-swatch-nav:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: translateY(-50%);
}

.size-swatch-nav:disabled:hover {
    background: rgba(var(--bs-primary-rgb), 0.9);
    transform: translateY(-50%);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Dark mode style for size swatch bar */

[data-bs-theme="dark"] .size-swatch-bar { background: transparent !important; }

/* Dark mode styles for pagination navigation */

[data-bs-theme="dark"] .size-swatch-nav {
    background: rgba(var(--bs-primary-rgb), 0.8);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
}

[data-bs-theme="dark"] .size-swatch-nav:hover {
    background: var(--bs-primary);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.5);
}

/* Responsive adjustments for size swatch pagination */

@media (max-width: 576px) {
    .size-swatch-container {
        padding: 0 25px; /* Reduce padding on mobile */
    }

    /* Remove padding when swatch count is below pagination threshold (5) on mobile */
    .size-swatch-container[data-swatch-count="1"],
    .size-swatch-container[data-swatch-count="2"],
    .size-swatch-container[data-swatch-count="3"],
    .size-swatch-container[data-swatch-count="4"] {
        padding: 0; /* No padding needed when navigation buttons are not shown */
    }

    .size-swatch-nav {
        width: 20px;
        height: 20px;
        font-size: 0.65rem;
    }

    .size-swatch-nav-prev { left: 2px; }

    .size-swatch-nav-next { right: 2px; }
}

@media (min-width: 577px) and (max-width: 768px) {
    .size-swatch-container {
        padding: 0 28px; /* Slightly reduce padding on tablets */
    }

    /* Remove padding when swatch count is below pagination threshold (5) on tablets */
    .size-swatch-container[data-swatch-count="1"],
    .size-swatch-container[data-swatch-count="2"],
    .size-swatch-container[data-swatch-count="3"],
    .size-swatch-container[data-swatch-count="4"] {
        padding: 0; /* No padding needed when navigation buttons are not shown */
    }

    .size-swatch-nav {
        width: 22px;
        height: 22px;
        font-size: 0.7rem;
    }
}

.swatch-bar .swatch-btn {
    width: 2.1em;
    height: 2.1em;
    min-width: 2.1em;
    min-height: 2.1em;
    border-radius: 4px;
    border: 2px solid var(--bs-border-color, #ccc);
    background: #eee;
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.10), 0 0.5px 1.5px rgba(255, 255, 255, 0.10) inset;
    padding: 0;
    outline: none;
    position: relative;
    overflow: hidden;
}

/* Realistic metal gradients */

.swatch-btn[aria-label*="Yellow"], .swatch-btn[aria-label*="Gold"] {
    background: linear-gradient(135deg, #fffbe6 0%, #ffe066 40%, #ffd700 70%, #fffbe6 100%);
    box-shadow: 0 0 8px 1px #ffe06699, 0 1px 8px #fffbe6 inset;
}

.swatch-btn[aria-label*="White"] {
    background: linear-gradient(135deg, #f8f8f8 0%, #e6e6e6 40%, #d7ddf0 70%, #ffffff 100%);
    box-shadow: 0 0 8px 1px #d7ddf099, 0 1px 8px #ffffff inset;
}

.swatch-btn[aria-label*="Rose"] {
    background: linear-gradient(135deg, #fff0f0 0%, #e6b7a9 40%, #c97e6a 70%, #fff0f0 100%);
    box-shadow: 0 0 8px 1px #e6b7a999, 0 1px 8px #fff0f0 inset;
}

.swatch-btn[aria-label*="Platinum"] {
    background: linear-gradient(135deg, #e5e4e2 0%, #bfc1c2 40%, #f8f8f8 100%);
    box-shadow: 0 0 8px 1px #e5e4e299, 0 1px 8px #f8f8f8 inset;
}

.swatch-btn[aria-label*="Silver"] {
    background: linear-gradient(135deg, #f8f8f8 0%, #c0c0c0 40%, #e5e4e2 100%);
    box-shadow: 0 0 8px 1px #c0c0c099, 0 1px 8px #f8f8f8 inset;
}

/* Swatch hover/focus */

.swatch-bar .swatch-btn:hover, .swatch-bar .swatch-btn:focus {
    border-color: var(--bs-primary, #0d6efd);
    box-shadow: 0 0 0 2px var(--bs-primary-lighter, #b3b3b3), 0 1px 8px #fffbe6 inset;
    filter: brightness(1.08) drop-shadow(0 0 2px #ffd70055);
    outline: none;
}

.swatch-bar .swatch-btn.selected {
    border-color: var(--bs-primary, #333);
    box-shadow: 0 0 0 2px var(--bs-primary-lighter, #b3b3b3), 0 1px 8px #fffbe6 inset;
    filter: brightness(1.12) drop-shadow(0 0 2px #ffd70099);
}

/* Dark mode swatches - same as light mode (explicit values to override Bootstrap vars) */
/* Exclude multi-color swatches from single-tone rules */
[data-bs-theme="dark"] .swatch-bar .swatch-btn:not(.multi-color) {
    background: #eee !important;
    border-color: #ccc !important;
}

[data-bs-theme="dark"] .swatch-btn:not(.multi-color)[aria-label*="Yellow"], 
[data-bs-theme="dark"] .swatch-btn:not(.multi-color)[aria-label*="Gold"] {
    background: linear-gradient(135deg, #fffbe6 0%, #ffe066 40%, #ffd700 70%, #fffbe6 100%) !important;
    box-shadow: 0 0 8px 1px #ffe06699, 0 1px 8px #fffbe6 inset !important;
}

[data-bs-theme="dark"] .swatch-btn:not(.multi-color)[aria-label*="White"] {
    background: linear-gradient(135deg, #f8f8f8 0%, #e6e6e6 40%, #d7ddf0 70%, #ffffff 100%) !important;
    box-shadow: 0 0 8px 1px #d7ddf099, 0 1px 8px #ffffff inset !important;
}

[data-bs-theme="dark"] .swatch-btn:not(.multi-color)[aria-label*="Rose"] {
    background: linear-gradient(135deg, #fff0f0 0%, #e6b7a9 40%, #c97e6a 70%, #fff0f0 100%) !important;
    box-shadow: 0 0 8px 1px #e6b7a999, 0 1px 8px #fff0f0 inset !important;
}

[data-bs-theme="dark"] .swatch-btn:not(.multi-color)[aria-label*="Platinum"] {
    background: linear-gradient(135deg, #e5e4e2 0%, #bfc1c2 40%, #f8f8f8 100%) !important;
    box-shadow: 0 0 8px 1px #e5e4e299, 0 1px 8px #f8f8f8 inset !important;
}

[data-bs-theme="dark"] .swatch-btn:not(.multi-color)[aria-label*="Silver"] {
    background: linear-gradient(135deg, #f8f8f8 0%, #c0c0c0 40%, #e5e4e2 100%) !important;
    box-shadow: 0 0 8px 1px #c0c0c099, 0 1px 8px #f8f8f8 inset !important;
}

[data-bs-theme="dark"] .swatch-bar .swatch-btn:hover, 
[data-bs-theme="dark"] .swatch-bar .swatch-btn:focus {
    border-color: #0d6efd !important;
    box-shadow: 0 0 0 2px #b3b3b3, 0 1px 8px #fffbe6 inset !important;
    filter: brightness(1.08) drop-shadow(0 0 2px #ffd70055) !important;
}

[data-bs-theme="dark"] .swatch-bar .swatch-btn.selected {
    border-color: #333 !important;
    box-shadow: 0 0 0 2px #b3b3b3, 0 1px 8px #fffbe6 inset !important;
    filter: brightness(1.12) drop-shadow(0 0 2px #ffd70099) !important;
}

/* Expand button for style card color swatches */
.swatch-bar .style-card-expand-btn {
    min-width: 60px;
    min-height: 26px;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.7rem;
    font-weight: 500;
    border: 1px solid var(--bs-border-color, #ccc);
    background: var(--bs-secondary-bg, #f8f9fa);
    color: var(--bs-body-color, #333);
    transition: all 0.2s;
    cursor: pointer;
    white-space: nowrap;
    margin-left: 4px;
}

.swatch-bar .style-card-expand-btn:hover,
.swatch-bar .style-card-expand-btn:focus {
    border-color: var(--bs-primary, #0d6efd);
    background: var(--bs-primary-bg-subtle, #e7f1ff);
    color: var(--bs-primary, #0d6efd);
    outline: none;
    transform: scale(1.05);
}

/* Dark mode expand button - same as light mode */
[data-bs-theme="dark"] .swatch-bar .style-card-expand-btn {
    background: #f8f9fa !important;
    border-color: #ccc !important;
    color: #333 !important;
}

[data-bs-theme="dark"] .swatch-bar .style-card-expand-btn:hover,
[data-bs-theme="dark"] .swatch-bar .style-card-expand-btn:focus {
    border-color: #0d6efd !important;
    background: #e7f1ff !important;
    color: #0d6efd !important;
}

/* Hide swatches that should not be visible initially */
.swatch-bar .swatch-btn.style-card-swatch-hidden {
    display: none !important;
}

/* Style card color swatches: same look/feel as product detail modal, smaller size, initials only */
.style-card-color-swatch-bar.swatch-bar {
    gap: 6px;
}

.style-card-color-swatch-bar .swatch-btn {
    width: auto;
    min-width: 44px;
    min-height: 26px;
    height: 26px;
    padding: 4px 8px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 9.1px;
    font-weight: 600;
}

.style-card-color-swatch-bar .swatch-btn .swatch-color-name {
    font-size: 9.1px;
    font-weight: 600;
    color: var(--bs-body-color, #333);
    text-align: center;
    white-space: nowrap;
    line-height: 1.2;
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.8);
    pointer-events: none;
}

[data-bs-theme="dark"] .style-card-color-swatch-bar .swatch-btn .swatch-color-name {
    color: #333 !important;
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.8) !important;
}

/* Dark mode swatches use same hover/selected styles as light mode - handled by general rules above */

/* =========================
   N8N CHAT THEME INTEGRATION
   ========================= */

/* Ensure n8n chat respects theme changes */

.n8n-chat-container { transition: all 0.3s ease; }

/* Light theme specific overrides */

[data-bs-theme="light"] .n8n-chat-container {
    --n8n-shadow-color: rgba(0, 0, 0, 0.1);
    --n8n-border-subtle: rgba(0, 0, 0, 0.05);
}

/* Dark theme specific overrides */

[data-bs-theme="dark"] .n8n-chat-container {
    --n8n-shadow-color: rgba(0, 0, 0, 0.3);
    --n8n-border-subtle: rgba(255, 255, 255, 0.05);
}

/* Enhanced image loading states */

.n8n-image-loading {
    opacity: 0.6;
    filter: blur(1px);
    transition: all 0.3s ease;
}

.n8n-image-loaded {
    opacity: 1;
    filter: none;
}

.n8n-image-error {
    opacity: 0.5;
    filter: grayscale(100%);
}

.n8n-image-hover {
    transform: scale(1.02);
    box-shadow: var(--bs-shadow-medium) !important;
}

/* Ensure chat doesn't interfere with other modals */

.n8n-chat-container { z-index: 1050; }

/* Responsive adjustments for mobile */

@media (max-width: 576px) {
    .n8n-chat-container {
        bottom: 10px !important;
        right: 10px !important;
        width: calc(100vw - 20px) !important;
        height: calc(100vh - 100px) !important;
    }

    .n8n-chat-container.minimized {
        width: 50px !important;
        height: 50px !important;
        right: 10px !important;
    }
}

/* =========================
   REDESIGNED STYLE CARD LAYOUT
   ========================= */

/* Global smooth scrolling */

html, body { scroll-behavior: smooth; }

/* Smoother horizontal scroll for swatch containers */

.swatch-scrollable,
.metal-purity-swatch-bar,
.diamond-quality-swatch-bar {
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch; /* momentum on iOS */
}

/* Swatches section - positioned below image */

.style-swatches-section {
    background-color: rgba(var(--bs-light-rgb), 0.3);
    border-top: 1px solid var(--bs-border-color);
    border-bottom: 1px solid rgba(var(--bs-border-color), 0.5);
}

/* Swatch scrollable container */

.swatch-scrollable {
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
    scrollbar-color: rgba(var(--bs-primary-rgb), 0.3) transparent;
}

.swatch-scrollable::-webkit-scrollbar { height: 4px; }

.swatch-scrollable::-webkit-scrollbar-track { background: transparent; }

.swatch-scrollable::-webkit-scrollbar-thumb {
    background-color: rgba(var(--bs-primary-rgb), 0.3);
    border-radius: 2px;
}

.swatch-scrollable::-webkit-scrollbar-thumb:hover { background-color: rgba(var(--bs-primary-rgb), 0.5); }

[data-bs-theme="dark"] .swatch-scrollable { scrollbar-color: rgba(var(--bs-primary-rgb), 0.4) transparent; }

[data-bs-theme="dark"] .swatch-scrollable::-webkit-scrollbar-thumb { background-color: rgba(var(--bs-primary-rgb), 0.4); }

[data-bs-theme="dark"] .swatch-scrollable::-webkit-scrollbar-thumb:hover { background-color: rgba(var(--bs-primary-rgb), 0.6); }

[data-bs-theme="dark"] .style-swatches-section {
    background-color: rgba(255, 255, 255, 0.02);
    border-top-color: rgba(255, 255, 255, 0.1);
    border-bottom-color: rgba(255, 255, 255, 0.1);
}

/* Swatch groups */

.swatch-group {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    /* Ensure consistent alignment */
    align-items: center;
    justify-content: flex-start;
    /* Ensure consistent width and alignment */
    width: 100%;
}

.swatch-group:last-child { margin-bottom: 0; }

.swatch-label {
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--bs-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    /* Fixed width to ensure consistent alignment */
    width: 55px;
    min-width: 55px;
    flex-shrink: 0;
    /* Ensure consistent alignment */
    display: flex;
    align-items: center;
    justify-content: flex-start;
    /* Ensure text is left-aligned within the fixed width */
    text-align: left;
    padding-left: 0;
    padding-right: 0;
    margin-right: 0.5rem; /* Add spacing between label and swatch bar */
}

[data-bs-theme="dark"] .swatch-label { color: rgba(255, 255, 255, 0.7); }

/* Enhanced swatch bar styling */

.swatch-bar {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.2rem;
    padding: 0.2rem;
    border-radius: 0.375rem;
    background-color: rgba(var(--bs-primary-rgb), 0.05);
    flex: 1;
    min-height: 35px;
    /* Ensure consistent alignment */
    align-items: center;
    justify-content: flex-start;
}

[data-bs-theme="dark"] .swatch-bar {
    background-color: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.1);
}

/* Enhanced color swatch buttons */

.swatch-bar .swatch-btn {
    width: 28px;
    height: 28px;
    border-radius: 4px;
    border: 2px solid var(--bs-border-color);
    background-color: var(--bs-card-bg);
    transition: all 0.2s ease;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.swatch-bar .swatch-btn:hover,
.swatch-bar .swatch-btn:focus {
    transform: scale(1.1);
    border-color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3);
}

.swatch-bar .swatch-btn.selected {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.3);
}

/* Style card color swatches: override for pill size/weight (must follow .swatch-bar .swatch-btn) */
.style-card-color-swatch-bar .swatch-btn {
    font-weight: 600;
    font-size: 9.1px;
    height: 26px;
}

/* Metal purity swatches */

.metal-purity-swatch-bar {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.2rem;
    padding: 0.2rem;
    border-radius: 0.375rem;
    /* background-color: rgba(var(--bs-secondary-rgb), 0.05); */
    /* border: 1px solid rgba(var(--bs-secondary-rgb), 0.1); */
    flex: 1;
    min-height: 35px;
    /* Ensure consistent alignment */
    align-items: center;
    justify-content: flex-start;
}

[data-bs-theme="dark"] .metal-purity-swatch-bar {
    background-color: rgba(255, 255, 255, 0.03);
    border-color: rgba(255, 255, 255, 0.08);
}

.metal-purity-swatch-bar .purity-swatch-btn {
    min-width: 44px;
    height: 26px;
    padding: 0.2rem 0.4rem;
    font-size: 0.65rem;
    font-weight: 600;
    border-radius: 0.25rem;
    border: 1px solid var(--bs-border-color);
    background-color: var(--bs-card-bg);
    color: var(--bs-body-color);
    transition: all 0.2s ease;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    white-space: nowrap;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    flex-shrink: 0;
}

.metal-purity-swatch-bar .purity-swatch-btn:hover,
.metal-purity-swatch-bar .purity-swatch-btn:focus {
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15);
    border-color: var(--bs-primary);
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-primary);
}

.metal-purity-swatch-bar .purity-swatch-btn.selected {
    background-color: var(--selected-metal-color, var(--bs-primary));
    border-color: var(--selected-metal-color, var(--bs-primary));
    color: var(--selected-metal-text-color, #000);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.metal-purity-swatch-bar .purity-swatch-btn.selected:hover {
    background-color: var(--selected-metal-color, var(--bs-primary));
    border-color: var(--selected-metal-color, var(--bs-primary));
    color: var(--selected-metal-text-color, #000);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

[data-bs-theme="dark"] .metal-purity-swatch-bar .purity-swatch-btn {
    background-color: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.9);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .metal-purity-swatch-bar .purity-swatch-btn:hover,
[data-bs-theme="dark"] .metal-purity-swatch-bar .purity-swatch-btn:focus {
    background-color: rgba(var(--bs-primary-rgb), 0.2);
    border-color: var(--bs-primary);
    color: var(--bs-primary);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}

[data-bs-theme="dark"] .metal-purity-swatch-bar .purity-swatch-btn.selected {
    background-color: var(--selected-metal-color, var(--bs-primary));
    border-color: var(--selected-metal-color, var(--bs-primary));
    color: var(--selected-metal-text-color, #fff);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}

[data-bs-theme="dark"] .metal-purity-swatch-bar .purity-swatch-btn.selected:hover {
    background-color: var(--selected-metal-color, var(--bs-primary));
    border-color: var(--selected-metal-color, var(--bs-primary));
    color: var(--selected-metal-text-color, #fff);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

/* Diamond Quality Swatch Styles */

.diamond-quality-swatch-bar {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.2rem;
    padding: 0.2rem;
    border-radius: 0.375rem;
    /* background-color: rgba(var(--bs-secondary-rgb), 0.05); */
    /* border: 1px solid rgba(var(--bs-secondary-rgb), 0.1); */
    flex: 1;
    min-height: 35px;
    /* Ensure consistent alignment */
    align-items: center;
    justify-content: flex-start;
}

[data-bs-theme="dark"] .diamond-quality-swatch-bar {
    background-color: rgba(255, 255, 255, 0.03);
    border-color: rgba(255, 255, 255, 0.08);
}

.diamond-quality-swatch-bar .quality-swatch-btn {
    min-width: 44px;
    height: 26px;
    padding: 0.2rem 0.4rem;
    font-size: 0.65rem;
    font-weight: 600;
    border-radius: 0.25rem;
    border: 1px solid var(--bs-border-color);
    background-color: var(--bs-card-bg);
    color: var(--bs-body-color);
    transition: all 0.2s ease;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    white-space: nowrap;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    flex-shrink: 0;
}

.diamond-quality-swatch-bar .quality-swatch-btn:hover,
.diamond-quality-swatch-bar .quality-swatch-btn:focus {
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15);
    border-color: var(--bs-primary);
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-primary);
}

.diamond-quality-swatch-bar .quality-swatch-btn.selected {
    background-color: white;
    border-color: var(--bs-primary);
    color: var(--bs-primary);
    box-shadow: 0 2px 6px rgba(var(--bs-primary-rgb), 0.4);
}

.diamond-quality-swatch-bar .quality-swatch-btn.selected:hover {
    background-color: white;
    border-color: var(--bs-primary);
    color: var(--bs-primary);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.5);
}

[data-bs-theme="dark"] .diamond-quality-swatch-bar .quality-swatch-btn {
    background-color: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.9);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .diamond-quality-swatch-bar .quality-swatch-btn:hover,
[data-bs-theme="dark"] .diamond-quality-swatch-bar .quality-swatch-btn:focus {
    background-color: rgba(var(--bs-primary-rgb), 0.2);
    border-color: var(--bs-primary);
    color: var(--bs-primary);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}

[data-bs-theme="dark"] .diamond-quality-swatch-bar .quality-swatch-btn.selected {
    background-color: white;
    border-color: var(--bs-primary);
    color: var(--bs-primary);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}

[data-bs-theme="dark"] .diamond-quality-swatch-bar .quality-swatch-btn.selected:hover {
    background-color: white;
    border-color: var(--bs-primary);
    color: var(--bs-primary);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

/* Enhanced spec badges row */

.spec-badges-row {
    gap: 0.4rem;
    margin-bottom: 0.75rem;
}

.spec-badge {
    min-width: 60px;
    padding: 0.35rem 0.6rem;
    font-size: 0.7rem;
    font-weight: 600;
    border-radius: 0.375rem;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.2);
    background-color: rgba(var(--bs-primary-rgb), 0.08);
    color: var(--bs-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: all 0.2s ease;
}

.spec-badge:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

/* Enhanced style details */

.style-details {
    /* margin-top: 0.75rem; */
    /* padding-top: 0.75rem; */
    border-top: 1px solid rgba(var(--bs-border-color), 0.5);
    /* margin-bottom: 0.75rem; */
}

.style-category {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--bs-body-color);
}

.style-metal {
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--bs-secondary);
}

/* Responsive adjustments */

@media (max-width: 576px) {
    .style-swatches-section { padding: 0.5rem !important; }

    .swatch-group {
        gap: 0.4rem !important;
        flex-direction: column;
        align-items: flex-start !important;
    }

    .swatch-label {
        font-size: 0.6rem;
        width: 50px !important;
        min-width: 50px !important;
        margin-bottom: 0.2rem;
        /* Ensure consistent alignment on mobile */
        align-items: flex-start !important;
        justify-content: flex-start !important;
        text-align: left !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .swatch-bar,
    .metal-purity-swatch-bar,
    .diamond-quality-swatch-bar {
        min-height: 32px;
        width: 100%;
        /* Ensure consistent alignment on mobile */
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 0.2rem !important;
        padding: 0.2rem !important;
    }

    .metal-purity-swatch-bar .purity-swatch-btn {
        min-width: 40px;
        height: 24px;
        font-size: 0.6rem;
        padding: 0px;
    }

    .diamond-quality-swatch-bar .quality-swatch-btn {
        min-width: 40px;
        height: 24px;
        font-size: 0.6rem;
        padding: 0.15rem 0.35rem;
    }

    .spec-badge {
        min-width: 55px;
        padding: 0.25rem 0.4rem;
        font-size: 0.65rem;
    }

    .style-code { font-size: 0.7rem; }

    .style-category { font-size: 0.7rem; }

    .style-metal { font-size: 0.65rem; }

    .style-pricing .final-price { font-size: 1rem; }
}

@media (min-width: 577px) and (max-width: 768px) {
    .metal-purity-swatch-bar .purity-swatch-btn {
        min-width: 42px;
        height: 25px;
        font-size: 0.63rem;
    }

    .diamond-quality-swatch-bar .quality-swatch-btn {
        min-width: 42px;
        height: 25px;
        font-size: 0.63rem;
    }

    .swatch-bar .swatch-btn {
        width: 26px;
        height: 26px;
    }

    .spec-badge {
        min-width: 58px;
        padding: 0.3rem 0.45rem;
        font-size: 0.68rem;
    }
}

/* Pricing section styling */

.style-pricing {
    background-color: rgba(var(--bs-light-rgb), 0.5);
    border-radius: 0.375rem;
    padding: 0.5rem;
    transition: opacity 0.3s ease;
}

.style-pricing .final-price {
    font-size: 1.1rem;
    color: var(--bs-primary);
    font-weight: 600;
}

.style-pricing .pricing-details { font-size: 0.8rem; }

.style-pricing .base-price { color: var(--bs-secondary); }

.style-pricing .markup-info {
    color: var(--bs-secondary);
    font-size: 0.75rem;
}

/* Pricing loading state */

.style-card.pricing-loading .style-pricing {
    opacity: 0.6;
    pointer-events: none;
}

.style-card.pricing-loading .style-pricing::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid var(--bs-primary);
    border-top: 2px solid transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }

    100% { transform: rotate(360deg); }
}

[data-bs-theme="dark"] .style-pricing { background-color: rgba(var(--bs-dark-rgb), 0.3); }

[data-bs-theme="dark"] .style-pricing .final-price { color: var(--bs-primary); }

/* Additional compact optimizations */

.style-card {
    /* Ensure consistent spacing */
    display: flex;
    flex-direction: column;
}

.style-image {
    /* Slightly reduce image height for more compact cards */
    height: 200px;
}

/* Ensure swatches don't wrap and scroll properly */

.swatch-bar,
.metal-purity-swatch-bar,
.diamond-quality-swatch-bar {
    /* Prevent wrapping and enable horizontal scroll */
    flex-wrap: nowrap !important;
    overflow-x: auto;
    overflow-y: hidden;
}

/* Optimize action buttons for compact layout */

.card-actions .btn-action {
    padding: 0.25rem;
    font-size: 0.9rem;
}

/* Ensure proper spacing in compact layout */


.style-specs {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

/* =========================
   STYLE CARD SPACING STANDARDIZATION
   ========================= */

/* Normalize spacing using compact variables, scoped to style card elements */


.style-swatches-section {
    /* Ensure consistent swatch container padding */
    /* padding: var(--compact-spacing-sm) !important; */
}

.style-specs {
    /* Consistent specs container padding */
    padding: var(--compact-spacing-sm) !important;
}

.spec-badges-row {
    /* Consistent spacing between badges and bottom gap */
    gap: var(--compact-spacing-sm);
    margin-bottom: var(--compact-spacing-sm) !important;
}

.spec-badge {
    /* Use standardized padding and width */
    padding: var(--compact-badge-padding) !important;
    min-width: var(--compact-spec-badge-min-width) !important;
}

.swatch-bar,
.metal-purity-swatch-bar,
.diamond-quality-swatch-bar {
    /* Harmonize inner spacing and gaps */
    gap: var(--compact-spacing-xs) !important;
    padding: var(--compact-spacing-xs) 0 !important;
}

/* Make diamond quality swatches multiline and remove horizontal scrolling */

.diamond-quality-swatch-bar {
    flex-wrap: wrap !important;
    overflow-x: visible !important;
    -webkit-overflow-scrolling: auto !important;
}

/* Align diamond CTS text with the Quality label in the same row */

/* Use a shared swatch chip height variable for vertical centering */

:root { --swatch-chip-height: 26px; }

.swatch-group .swatch-label,
.swatch-group .diamond-cts {
    align-self: flex-start;
    line-height: 0.65rem;
    margin-top: calc((var(--swatch-chip-height) - 0.65rem) / 2);
}

.swatch-group .diamond-cts {
    margin-left: 0.5rem;
    white-space: nowrap;
}

@media (max-width: 576px) {
    :root { --swatch-chip-height: 24px; }
}

/* Ensure pricing section maintains consistent structure during dynamic updates */

.style-pricing {
    /* Maintain consistent structure */
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 3rem;
}

.style-pricing .pricing-info {
    /* Ensure consistent alignment */
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
}

/* Ensure spec badges maintain consistent spacing during updates */

.spec-badge {
    /* Prevent layout shifts during content updates */
    min-height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Ensure swatch selection states are consistent */

.swatch-btn.selected,
.purity-swatch-btn.selected,
.quality-swatch-btn.selected {
    /* Maintain consistent selected state appearance */
    transform: scale(1.05);
    z-index: 2;
}

/* Ensure consistent swatch bar alignment and spacing */

.swatch-bar,
.metal-purity-swatch-bar,
.diamond-quality-swatch-bar {
    /* Consistent spacing between swatches */
    gap: 0.2rem !important;
    /* Consistent padding */
    padding: 0.2rem !important;
    /* Ensure items are centered vertically */
    align-items: center !important;
    /* Ensure consistent flex behavior */
    flex: 1;
    min-height: 35px;
    /* Ensure consistent starting position */
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Ensure consistent button spacing within swatch bars */

.swatch-bar .swatch-btn,
.metal-purity-swatch-bar .purity-swatch-btn,
.diamond-quality-swatch-bar .quality-swatch-btn {
    /* Remove any margin classes that might interfere */
    margin: 0 !important;
    /* Ensure consistent flex behavior */
    flex-shrink: 0;
}

/* Ensure swatch labels are consistently aligned */

.swatch-label {
    /* Consistent alignment */
    align-items: center !important;
    justify-content: flex-start !important;
    /* Consistent sizing */
    width: 55px !important;
    min-width: 55px !important;
    flex-shrink: 0 !important;
    /* Ensure text is left-aligned */
    text-align: left !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Dual tone weights display */

.dual-tone-weights {
    font-size: 0.85em;
    line-height: 1.2;
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .dual-tone-weights { color: var(--bs-body-color); }

/* Separate metal badges for dual tone jewelry */

.gold-badge {
    background-color: rgba(255, 193, 7, 0.1);
    border-color: rgba(255, 193, 7, 0.3);
}

.platinum-badge {
    background-color: rgba(13, 202, 240, 0.1);
    border-color: rgba(13, 202, 240, 0.3);
}

.silver-badge {
    background-color: rgba(108, 117, 125, 0.1);
    border-color: rgba(108, 117, 125, 0.3);
}

[data-bs-theme="dark"] .gold-badge {
    background-color: rgba(255, 193, 7, 0.2);
    border-color: rgba(255, 193, 7, 0.4);
}

[data-bs-theme="dark"] .platinum-badge {
    background-color: rgba(13, 202, 240, 0.2);
    border-color: rgba(13, 202, 240, 0.4);
}

[data-bs-theme="dark"] .silver-badge {
    background-color: rgba(108, 117, 125, 0.2);
    border-color: rgba(108, 117, 125, 0.4);
}

/* =========================
   MULTI-COLOR SWATCH STYLES
   ========================= */

/* Multi-color swatch base styles */

.swatch-btn.multi-color {
    position: relative;
    overflow: hidden;
}

/* Split style for 2-color combinations (e.g., White Rose, Yellow White) */

.swatch-btn.multi-color[data-multi-color-type="split"] { background: conic-gradient(from 0deg, var(--color-2) 0deg 180deg, var(--color-1) 180deg 360deg); }

/* Gradient style for 3-color combinations (e.g., Yellow White Rose) */

.swatch-btn.multi-color[data-multi-color-type="gradient"] { background: conic-gradient(from 0deg, var(--color-2) 0deg 120deg, var(--color-3) 120deg 240deg, var(--color-1) 240deg 360deg); }

/* Color variables for multi-color swatches - using ordered colors for correct sequence */

.swatch-btn.multi-color[data-ordered-colors="White-Rose"] {
    --color-1: #f8f8f8; /* White first */
    --color-2: #e6b7a9; /* Rose second */
}

.swatch-btn.multi-color[data-ordered-colors="Rose-White"] {
    --color-1: #e6b7a9; /* Rose first */
    --color-2: #f8f8f8; /* White second */
}

.swatch-btn.multi-color[data-ordered-colors="Yellow-White"] {
    --color-1: #ffd700; /* Yellow first */
    --color-2: #f8f8f8; /* White second */
}

.swatch-btn.multi-color[data-ordered-colors="White-Yellow"] {
    --color-1: #f8f8f8; /* White first */
    --color-2: #ffd700; /* Yellow second */
}

.swatch-btn.multi-color[data-ordered-colors="Yellow-White-Rose"] {
    --color-1: #ffd700; /* Yellow first */
    --color-2: #f8f8f8; /* White second */
    --color-3: #e6b7a9; /* Rose third */
}

.swatch-btn.multi-color[data-ordered-colors="Yellow-Rose"] {
    --color-1: #ffd700; /* Yellow first */
    --color-2: #e6b7a9; /* Rose second */
}

.swatch-btn.multi-color[data-ordered-colors="Rose-Yellow"] {
    --color-1: #e6b7a9; /* Rose first */
    --color-2: #ffd700; /* Yellow second */
}

/* Additional 3-color combinations */
.swatch-btn.multi-color[data-ordered-colors="Yellow-Rose-White"] {
    --color-1: #ffd700; /* Yellow first */
    --color-2: #e6b7a9; /* Rose second */
    --color-3: #f8f8f8; /* White third */
}

.swatch-btn.multi-color[data-ordered-colors="White-Rose-Yellow"] {
    --color-1: #f8f8f8; /* White first */
    --color-2: #e6b7a9; /* Rose second */
    --color-3: #ffd700; /* Yellow third */
}

.swatch-btn.multi-color[data-ordered-colors="White-Yellow-Rose"] {
    --color-1: #f8f8f8; /* White first */
    --color-2: #ffd700; /* Yellow second */
    --color-3: #e6b7a9; /* Rose third */
}

.swatch-btn.multi-color[data-ordered-colors="Rose-White-Yellow"] {
    --color-1: #e6b7a9; /* Rose first */
    --color-2: #f8f8f8; /* White second */
    --color-3: #ffd700; /* Yellow third */
}

.swatch-btn.multi-color[data-ordered-colors="Rose-Yellow-White"] {
    --color-1: #e6b7a9; /* Rose first */
    --color-2: #ffd700; /* Yellow second */
    --color-3: #f8f8f8; /* White third */
}

/* Additional light mode color combinations for better coverage */

.swatch-btn.multi-color[data-ordered-colors="White-Gold"] {
    --color-1: #f8f8f8; /* White first */
    --color-2: #ffd700; /* Gold second */
}

.swatch-btn.multi-color[data-ordered-colors="Gold-White"] {
    --color-1: #ffd700; /* Gold first */
    --color-2: #f8f8f8; /* White second */
}

.swatch-btn.multi-color[data-ordered-colors="Rose-Gold"] {
    --color-1: #e6b7a9; /* Rose first */
    --color-2: #ffd700; /* Gold second */
}

.swatch-btn.multi-color[data-ordered-colors="Gold-Rose"] {
    --color-1: #ffd700; /* Gold first */
    --color-2: #e6b7a9; /* Rose second */
}

/* Dark theme multi-color swatches - same as light mode */
[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="White-Rose"] {
    --color-1: #f8f8f8; /* White first - same as light mode */
    --color-2: #e6b7a9; /* Rose second - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Rose-White"] {
    --color-1: #e6b7a9; /* Rose first - same as light mode */
    --color-2: #f8f8f8; /* White second - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Yellow-White"] {
    --color-1: #ffd700; /* Yellow first - same as light mode */
    --color-2: #f8f8f8; /* White second - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="White-Yellow"] {
    --color-1: #f8f8f8; /* White first - same as light mode */
    --color-2: #ffd700; /* Yellow second - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Yellow-White-Rose"] {
    --color-1: #ffd700; /* Yellow first - same as light mode */
    --color-2: #f8f8f8; /* White second - same as light mode */
    --color-3: #e6b7a9; /* Rose third - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Yellow-Rose"] {
    --color-1: #ffd700; /* Yellow first - same as light mode */
    --color-2: #e6b7a9; /* Rose second - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Rose-Yellow"] {
    --color-1: #e6b7a9; /* Rose first - same as light mode */
    --color-2: #ffd700; /* Yellow second - same as light mode */
}

/* Additional dark mode 3-color combinations - same as light mode */
[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Yellow-Rose-White"] {
    --color-1: #ffd700; /* Yellow first - same as light mode */
    --color-2: #e6b7a9; /* Rose second - same as light mode */
    --color-3: #f8f8f8; /* White third - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="White-Rose-Yellow"] {
    --color-1: #f8f8f8; /* White first - same as light mode */
    --color-2: #e6b7a9; /* Rose second - same as light mode */
    --color-3: #ffd700; /* Yellow third - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="White-Yellow-Rose"] {
    --color-1: #f8f8f8; /* White first - same as light mode */
    --color-2: #ffd700; /* Yellow second - same as light mode */
    --color-3: #e6b7a9; /* Rose third - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Rose-White-Yellow"] {
    --color-1: #e6b7a9; /* Rose first - same as light mode */
    --color-2: #f8f8f8; /* White second - same as light mode */
    --color-3: #ffd700; /* Yellow third - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Rose-Yellow-White"] {
    --color-1: #e6b7a9; /* Rose first - same as light mode */
    --color-2: #ffd700; /* Yellow second - same as light mode */
    --color-3: #f8f8f8; /* White third - same as light mode */
}

/* Additional dark mode color combinations - same as light mode */
[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="White-Gold"] {
    --color-1: #f8f8f8; /* White first - same as light mode */
    --color-2: #ffd700; /* Gold second - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Gold-White"] {
    --color-1: #ffd700; /* Gold first - same as light mode */
    --color-2: #f8f8f8; /* White second - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Rose-Gold"] {
    --color-1: #e6b7a9; /* Rose first - same as light mode */
    --color-2: #ffd700; /* Gold second - same as light mode */
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-ordered-colors="Gold-Rose"] {
    --color-1: #ffd700; /* Gold first - same as light mode */
    --color-2: #e6b7a9; /* Rose second - same as light mode */
}

/* Ensure conic-gradient backgrounds render correctly in dark mode - must override single-tone rules */
[data-bs-theme="dark"] .swatch-btn.multi-color[data-multi-color-type="split"] {
    background: conic-gradient(from 0deg, var(--color-2) 0deg 180deg, var(--color-1) 180deg 360deg) !important;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.10), 0 0.5px 1.5px rgba(255, 255, 255, 0.10) inset !important;
}

[data-bs-theme="dark"] .swatch-btn.multi-color[data-multi-color-type="gradient"] {
    background: conic-gradient(from 0deg, var(--color-2) 0deg 120deg, var(--color-3) 120deg 240deg, var(--color-1) 240deg 360deg) !important;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.10), 0 0.5px 1.5px rgba(255, 255, 255, 0.10) inset !important;
}

/* Dark mode hover/selected effects for multi-color swatches - same as light mode */
[data-bs-theme="dark"] .swatch-btn.multi-color:hover,
[data-bs-theme="dark"] .swatch-btn.multi-color:focus {
    transform: scale(1.1);
    border-color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3);
    filter: brightness(1.05);
}

[data-bs-theme="dark"] .swatch-btn.multi-color.selected {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.3);
    filter: brightness(1.1);
}

/* Enhanced hover and focus effects for multi-color swatches */

.swatch-btn.multi-color:hover,
.swatch-btn.multi-color:focus {
    transform: scale(1.1);
    border-color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3);
    filter: brightness(1.05);
}

.swatch-btn.multi-color.selected {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.3);
    filter: brightness(1.1);
}

/* Loading state for pricing updates */

.style-card.pricing-loading .style-pricing {
    opacity: 0.7;
    pointer-events: none;
}

.style-card.pricing-loading .style-pricing::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 16px;
    height: 16px;
    margin: -8px 0 0 -8px;
    border: 2px solid var(--bs-primary);
    border-top: 2px solid transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

/* Metal type name styling */

.metal-type {
    font-size: 1em;
    font-weight: 500;
    opacity: 0.8;
    color: var(--bs-body-color);
}

.metal-weight { font-weight: 600; }

/* Compact styling for specs overlay */

.specs-badge .metal-type {
    font-size: 0.7em;
    margin-left: 2px;
}

/* Ensure proper spacing in dual tone badges */

.metal-grams-badge .metal-weight { margin-right: 2px; }

/* =========================
   CART PRICING STYLES
   ========================= */

.cart-item-pricing {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.05), rgba(var(--bs-success-rgb), 0.05));
    border-radius: 8px;
    padding: 12px;
    margin: 8px 0;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.1);
    transition: all 0.3s ease;
}

.cart-item-pricing:hover {
    border-color: rgba(var(--bs-primary-rgb), 0.2);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.1);
}

.cart-item-pricing .text-primary {
    color: var(--bs-primary) !important;
    font-weight: 600;
}

.cart-item-pricing .text-success {
    color: var(--bs-success) !important;
    font-weight: 700;
}

[data-bs-theme="dark"] .cart-item-pricing .text-primary {
    color: var(--bs-primary) !important;
}

[data-bs-theme="dark"] .cart-item-pricing .text-success {
    color: var(--bs-success) !important;
}

[data-bs-theme="dark"] .cart-item-pricing .text-muted {
    color: var(--bs-secondary) !important;
}

[data-bs-theme="dark"] .cart-item-pricing {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.1), rgba(var(--bs-success-rgb), 0.1));
    border-color: rgba(var(--bs-primary-rgb), 0.2);
}

[data-bs-theme="dark"] .cart-item-pricing:hover {
    border-color: rgba(var(--bs-primary-rgb), 0.3);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.2);
}

/* Price update highlight effect */

.highlight-change { animation: priceUpdate 1s ease-in-out; }

@keyframes priceUpdate {
    0% {
        background-color: rgba(var(--bs-success-rgb), 0.2);
        transform: scale(1);
    }

    50% {
        background-color: rgba(var(--bs-success-rgb), 0.4);
        transform: scale(1.05);
    }

    100% {
        background-color: transparent;
        transform: scale(1);
    }
}

/* Quantity input spinner overlay */

.qty-input-spinner-overlay {
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    z-index: 10;
}

.quantity-control { position: relative; }

.cart-summary-pricing {
    background: linear-gradient(135deg, rgba(var(--bs-success-rgb), 0.05), rgba(var(--bs-primary-rgb), 0.05));
    border-radius: 12px;
    padding: 16px;
    margin: 16px 0;
    border: 1px solid rgba(var(--bs-success-rgb), 0.1);
}

.cart-summary-pricing .total-price {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--bs-success);
}

.cart-summary-pricing .subtotal-price {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--bs-primary);
}

[data-bs-theme="dark"] .cart-summary-pricing {
    background: linear-gradient(135deg, rgba(var(--bs-success-rgb), 0.1), rgba(var(--bs-primary-rgb), 0.1));
    border-color: rgba(var(--bs-success-rgb), 0.2);
}

.pricing-unavailable {
    background: rgba(var(--bs-warning-rgb), 0.1);
    border: 1px solid rgba(var(--bs-warning-rgb), 0.2);
    border-radius: 6px;
    padding: 8px 12px;
    color: var(--bs-warning);
    font-size: 0.875rem;
}

[data-bs-theme="dark"] .pricing-unavailable {
    background: rgba(var(--bs-warning-rgb), 0.15);
    border-color: rgba(var(--bs-warning-rgb), 0.3);
}

.cart-item-pricing .unit-price-label,
.cart-item-pricing .total-price-label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--bs-secondary);
}

[data-bs-theme="dark"] .cart-item-pricing .unit-price-label,
[data-bs-theme="dark"] .cart-item-pricing .total-price-label { color: var(--bs-gray-400); }

/* Animation for pricing updates */

@keyframes priceUpdate {
    0% { transform: scale(1); }

    50% { transform: scale(1.05); }

    100% { transform: scale(1); }
}

.cart-item-pricing.updated { animation: priceUpdate 0.3s ease-in-out; }

/* Responsive pricing display */

@media (max-width: 576px) {
    .cart-item-pricing {
        padding: 8px;
        margin: 6px 0;
    }

    .cart-item-pricing .text-success { font-size: 0.9rem; }

    .cart-summary-pricing {
        padding: 12px;
        margin: 12px 0;
    }

    .cart-summary-pricing .total-price { font-size: 1.25rem; }
}

/* Dark theme adjustments for FABs */

[data-bs-theme="dark"] .fab-btn { box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25); }

[data-bs-theme="dark"] .fab-collection { background: var(--bs-primary); }

[data-bs-theme="dark"] .fab-collection:hover { background: rgba(var(--bs-primary-rgb), 0.8); }

[data-bs-theme="dark"] .fab-cart { background: var(--bs-success); }

[data-bs-theme="dark"] .fab-cart:hover { background: rgba(var(--bs-success-rgb), 0.8); }

[data-bs-theme="dark"] .fab-download { background: var(--bs-info); }

[data-bs-theme="dark"] .fab-download:hover { background: rgba(var(--bs-info-rgb), 0.8); }

/* Export Format Modal Styling */

#exportFormatModal .modal-dialog { max-width: 480px; }

#exportFormatModal .modal-content {
    border-radius: 12px;
    border: none;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

#exportFormatModal .modal-header {
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    padding: 1.5rem 1.5rem 1rem;
}

#exportFormatModal .modal-title {
    font-weight: 600;
    color: var(--bs-dark);
}

#exportFormatModal .modal-body { padding: 1.5rem; }

#exportFormatModal .modal-footer {
    border-top: 1px solid rgba(0, 0, 0, 0.1);
    padding: 1rem 1.5rem 1.5rem;
}

#exportFormatModal .modal-body .btn {
    border-width: 2px;
    padding: 1.25rem;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
    background: white;
    border-radius: 10px;
    font-weight: 500;
}

#exportFormatModal .modal-body .btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

/* Excel Button Styling */

#exportFormatModal .btn-outline-success {
    border-color: #198754;
    color: #198754;
}

#exportFormatModal .btn-outline-success:hover {
    background: #198754;
    border-color: #198754;
    color: white;
}

#exportFormatModal .btn-outline-success:hover .bi-file-earmark-excel { color: white !important; }

#exportFormatModal .btn-outline-success .bi-file-earmark-excel {
    color: #198754;
    transition: color 0.3s ease;
}

/* PDF Button Styling */

#exportFormatModal .btn-outline-danger {
    border-color: #dc3545;
    color: #dc3545;
}

#exportFormatModal .btn-outline-danger:hover {
    background: #dc3545;
    border-color: #dc3545;
    color: white;
}

#exportFormatModal .btn-outline-danger:hover .bi-file-earmark-pdf { color: white !important; }

#exportFormatModal .btn-outline-danger .bi-file-earmark-pdf {
    color: #dc3545;
    transition: color 0.3s ease;
}

/* Dark theme adjustments */

[data-bs-theme="dark"] #exportFormatModal .modal-content {
    background: var(--bs-dark);
    border: 1px solid var(--bs-border-color);
}

[data-bs-theme="dark"] #exportFormatModal .modal-header { border-bottom: 1px solid var(--bs-border-color); }

[data-bs-theme="dark"] #exportFormatModal .modal-footer { border-top: 1px solid var(--bs-border-color); }

[data-bs-theme="dark"] #exportFormatModal .modal-title { color: var(--bs-light); }

[data-bs-theme="dark"] #exportFormatModal .modal-body .btn {
    background: var(--bs-dark);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] #exportFormatModal .btn-outline-success {
    border-color: #20c997;
    color: #20c997;
}

[data-bs-theme="dark"] #exportFormatModal .btn-outline-success:hover {
    background: #20c997;
    border-color: #20c997;
    color: var(--bs-dark);
}

[data-bs-theme="dark"] #exportFormatModal .btn-outline-success .bi-file-earmark-excel { color: #20c997; }

[data-bs-theme="dark"] #exportFormatModal .btn-outline-success:hover .bi-file-earmark-excel { color: var(--bs-dark) !important; }

[data-bs-theme="dark"] #exportFormatModal .btn-outline-danger {
    border-color: #fd7e14;
    color: #fd7e14;
}

[data-bs-theme="dark"] #exportFormatModal .btn-outline-danger:hover {
    background: #fd7e14;
    border-color: #fd7e14;
    color: var(--bs-dark);
}

[data-bs-theme="dark"] #exportFormatModal .btn-outline-danger .bi-file-earmark-pdf { color: #fd7e14; }

[data-bs-theme="dark"] #exportFormatModal .btn-outline-danger:hover .bi-file-earmark-pdf { color: var(--bs-dark) !important; }



/* Image loading states */

.style-image img.loading { opacity: 0; }

.style-image.image-loaded img { opacity: 1; }

/* Optimized image loading spinner */

.image-loading-spinner {
    background-color: rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
    left: 50%;
    opacity: 1;
    padding: 1rem;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 0.3s ease;
    z-index: 5;
}

[data-bs-theme="dark"] .image-loading-spinner { background-color: rgba(33, 37, 41, 0.8); }

.image-loaded .image-loading-spinner {
    opacity: 0;
    pointer-events: none;
}

/* Image styling with optimized transitions */

.style-image img {
    height: 100%;
    object-fit: contain;
    opacity: 0; /* Start with hidden image */
    padding: 0.5rem;
    transition: all 0.3s ease;
    width: 100%;
}

/* Lazy loading optimizations */

.style-image img.lazy-image {
    opacity: 0;
    transform: scale(0.95);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.style-image img.lazy-image.loaded {
    opacity: 1;
    transform: scale(1);
}

/* Optimized loading spinner for lazy loading */

.image-loading-spinner {
    background-color: rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
    left: 50%;
    opacity: 1;
    padding: 1rem;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 0.3s ease;
    z-index: 5;
    display: none; /* Hidden by default for lazy loading */
}

[data-bs-theme="dark"] .image-loading-spinner { background-color: rgba(33, 37, 41, 0.8); }

.image-loaded .image-loading-spinner {
    opacity: 0;
    pointer-events: none;
}

/* Memory optimization: Hide images that are far out of view */

.style-image img[data-observed="true"] { will-change: opacity, transform; }

/* Smooth loading animation */

@keyframes imageFadeIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.style-image img.loaded { animation: imageFadeIn 0.4s ease-out; }

/* =========================
   MOBILE ACCESSIBILITY & TOUCH IMPROVEMENTS
   ========================= */

/* Mobile tap targets - ensure minimum 44px touch targets */

@media (max-width: 991.98px) {
    /* Icon consistency fixes for mobile */
    .navbar .btn.nav-link.rounded-circle i,
    .theme-toggle-btn .theme-icon {
        font-size: 1.125rem; /* Slightly smaller for mobile */
    }

    .btn-action i,
    .action-btn i {
        font-size: 0.9rem; /* Smaller for mobile action buttons */
    }

    .fab-btn i,
    .scroll-to-top-btn i {
        font-size: 1.125rem; /* Consistent with nav icons */
    }

    /* Style card checkboxes and buttons */
    .style-checkbox {
        min-height: 44px;
        min-width: 44px;
        padding: 12px;
        border-radius: 0.5rem;
        border: 2px solid var(--bs-border-color);
        transition: all 0.15s ease;
    }

    .style-checkbox:checked {
        background-color: var(--bs-primary);
        border-color: var(--bs-primary);
    }

    .btn-action {
        min-height: 44px;
        min-width: 44px;
        padding: 12px;
        border-radius: 0.5rem;
        transition: all 0.15s ease;
    }

    .btn-action:hover {
        transform: scale(1.05);
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    }

    /* Mobile offcanvas improvements - scoped to mobileNavOffcanvas only */
    #mobileNavOffcanvas .offcanvas-body .nav-link {
        min-height: 44px;
        padding: 12px 16px;
        display: flex;
        align-items: center;
    }

    /* Mobile action buttons in offcanvas - scoped to mobileNavOffcanvas only */
    #mobileNavOffcanvas .offcanvas-body .btn {
        min-height: 44px;
        padding: 12px 16px;
    }

    /* Better spacing for mobile cards */
    .col-6 .style-card {
        margin-bottom: 1.5rem;
        border-radius: 0.75rem;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
        transition: all 0.2s ease;
    }

    .col-6 .style-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    }

    /* Improve card grid spacing */
    .row.g-3 {
        --bs-gutter-x: 1rem;
        --bs-gutter-y: 1.5rem;
    }

    /* Improve mobile filter buttons */
    .filter-remove-btn {
        min-height: 32px;
        min-width: 32px;
    }

    /* Mobile filter section improvements */
    .filter-action-bar {
        padding: 1rem;
        border-radius: 0.75rem;
        margin-bottom: 1rem;
        background: var(--bs-body-bg);
        border: 1px solid var(--bs-border-color);
    }

    /* Mobile button spacing improvements */
    .btn {
        padding: 0.5rem 0.75rem;
        font-size: 0.875rem;
        border-radius: 0.5rem;
    }

    .btn-sm {
        padding: 0.375rem 0.5rem;
        font-size: 0.8125rem;
    }

    /* Mobile form controls */
    .form-control,
    .form-select {
        padding: 0.5rem 0.75rem;
        font-size: 0.875rem;
        border-radius: 0.5rem;
    }

    /* Mobile swatch improvements */
    .swatch-bar,
    .metal-purity-swatch-bar,
    .diamond-quality-swatch-bar {
        gap: 0.375rem;
        padding: 0.5rem 0;
    }

    .swatch-btn,
    .purity-swatch-btn,
    .quality-swatch-btn {
        min-width: 40px;
        min-height: 40px;
        font-size: 0.75rem;
    }
}

/* Tablet specific improvements */

@media (min-width: 576px) and (max-width: 991.98px) {
    /* Tablet icon sizing */
    .navbar .btn.nav-link.rounded-circle i,
    .theme-toggle-btn .theme-icon { font-size: 1.2rem; }

    .btn-action i,
    .action-btn i { font-size: 0.95rem; }

    .fab-btn i,
    .scroll-to-top-btn i { font-size: 1.2rem; }

    /* Tablet button improvements */
    .btn {
        padding: 0.5rem 1rem;
        font-size: 0.875rem;
    }

    /* Tablet card improvements */
    .col-md-6 .style-card { margin-bottom: 1.25rem; }

    /* Tablet form improvements */
    .form-control,
    .form-select { padding: 0.5rem 0.75rem; }

    /* Tablet swatch improvements */
    .swatch-btn,
    .purity-swatch-btn,
    .quality-swatch-btn {
        min-width: 42px;
        min-height: 42px;
        font-size: 0.8rem;
    }

    .filter-action-bar .form-select {
        border-radius: 0.5rem;
        border: 1px solid var(--bs-border-color);
        font-size: 0.9rem;
    }

    .filter-action-bar .form-select:focus {
        border-color: var(--bs-primary);
        box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
    }

    /* Mobile filter dropdowns spacing */
    .filter-action-bar .d-flex {
        gap: 0.75rem;
        flex-wrap: wrap;
    }

    .filter-action-bar .filter-item {
        min-width: 120px;
        flex: 1;
    }
}

/* Responsive spacing utilities */

.mt-lg-7 { margin-top: 5rem !important; }

@media (min-width: 992px) {
    .mt-lg-7 { margin-top: 6rem !important; }
}

/* Mobile offcanvas specific styles */

#mobileNavOffcanvas .offcanvas-body {
    padding: 1.5rem 1rem;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto; /* Allow shrinking and growing */
    overflow-y: auto;
    overflow-x: hidden;
    /* Ensure no horizontal scroll */
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    /* Prevent scroll anchoring issues */
    overflow-anchor: none;
    /* Ensure proper scrolling on all devices */
    -webkit-overflow-scrolling: touch;
    /* Handle safe area insets */
    padding-bottom: max(1.5rem, env(safe-area-inset-bottom));
}

/* Mobile offcanvas theme support - isolated from filter drawer */

#mobileNavOffcanvas {
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
    /* Ensure mobileNavOffcanvas doesn't inherit filter drawer styles */
    position: fixed !important;
    z-index: 1055 !important;
}

/* Mobile offcanvas specific isolation */

#mobileNavOffcanvas .offcanvas-header {
    /* Mobile offcanvas header specific styling */
    background-color: var(--bs-body-bg) !important;
    border-bottom-color: var(--bs-border-color) !important;
    flex-shrink: 0 !important;
}

#mobileNavOffcanvas .offcanvas-body {
    /* Mobile offcanvas body specific styling - isolated from filter-drawer-body */
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
    /* Override any filter-drawer-body styles that might leak */
    padding: 1.5rem 1rem !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    flex: 1 1 auto !important;
    overflow-anchor: none !important;
    -webkit-overflow-scrolling: touch !important;
    padding-bottom: max(1.5rem, env(safe-area-inset-bottom)) !important;
}

#mobileNavOffcanvas .offcanvas-footer {
    /* Mobile offcanvas footer specific styling - isolated from filter-drawer-footer */
    background-color: var(--bs-body-bg) !important;
    border-top-color: var(--bs-border-color) !important;
    flex-shrink: 0 !important;
    margin-top: auto !important;
    padding: 1rem !important;
}

/* Theme-compatible scrollbars */

/* Light theme scrollbars */

[data-bs-theme="light"] ::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

[data-bs-theme="light"] ::-webkit-scrollbar-track {
    background: var(--bs-body-bg);
    border-radius: 4px;
}

[data-bs-theme="light"] ::-webkit-scrollbar-thumb {
    background: var(--bs-secondary);
    border-radius: 4px;
    border: 1px solid var(--bs-body-bg);
}

[data-bs-theme="light"] ::-webkit-scrollbar-thumb:hover { background: var(--bs-secondary-color); }

[data-bs-theme="light"] ::-webkit-scrollbar-corner { background: var(--bs-body-bg); }

/* Dark theme scrollbars */

[data-bs-theme="dark"] ::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

[data-bs-theme="dark"] ::-webkit-scrollbar-track {
    background: var(--bs-body-bg);
    border-radius: 4px;
}

[data-bs-theme="dark"] ::-webkit-scrollbar-thumb {
    background: var(--bs-secondary);
    border-radius: 4px;
    border: 1px solid var(--bs-body-bg);
}

[data-bs-theme="dark"] ::-webkit-scrollbar-thumb:hover { background: var(--bs-secondary-color); }

[data-bs-theme="dark"] ::-webkit-scrollbar-corner { background: var(--bs-body-bg); }

/* Firefox scrollbars */

[data-bs-theme="light"] {
    scrollbar-width: thin;
    scrollbar-color: var(--bs-secondary) var(--bs-body-bg);
}

[data-bs-theme="dark"] {
    scrollbar-width: thin;
    scrollbar-color: var(--bs-secondary) var(--bs-body-bg);
}

/* Duplicate styles removed - consolidated above */

/* Offcanvas headers and text */

#mobileNavOffcanvas h6 { color: var(--bs-body-color) !important; }

#mobileNavOffcanvas .text-muted { color: var(--bs-secondary-color) !important; }

/* Accordion theme support */

#mobileNavOffcanvas .accordion {
    --bs-accordion-bg: var(--bs-body-bg);
    --bs-accordion-color: var(--bs-body-color);
    --bs-accordion-border-color: var(--bs-border-color);
}

#mobileNavOffcanvas .accordion-item {
    background-color: var(--bs-body-bg) !important;
    border-color: var(--bs-border-color) !important;
}

#mobileNavOffcanvas .accordion-button {
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}

#mobileNavOffcanvas .accordion-button:not(.collapsed) {
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}

#mobileNavOffcanvas .accordion-button:focus {
    border-color: var(--bs-primary) !important;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25) !important;
}

#mobileNavOffcanvas .accordion-body {
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
}

/* Offcanvas specific scrollbar styling */

#mobileNavOffcanvas ::-webkit-scrollbar { width: 6px; }

#mobileNavOffcanvas ::-webkit-scrollbar-track {
    background: var(--bs-body-bg);
    border-radius: 3px;
}

#mobileNavOffcanvas ::-webkit-scrollbar-thumb {
    background: var(--bs-secondary);
    border-radius: 3px;
    border: 1px solid var(--bs-body-bg);
}

#mobileNavOffcanvas ::-webkit-scrollbar-thumb:hover { background: var(--bs-secondary-color); }

/* Accordion scrollbar styling */

#mobileNavOffcanvas .accordion ::-webkit-scrollbar { width: 4px; }

#mobileNavOffcanvas .accordion ::-webkit-scrollbar-track { background: transparent; }

#mobileNavOffcanvas .accordion ::-webkit-scrollbar-thumb {
    background: var(--bs-secondary);
    border-radius: 2px;
}

#mobileNavOffcanvas .accordion ::-webkit-scrollbar-thumb:hover { background: var(--bs-secondary-color); }

/* Nav links theme support */

#mobileNavOffcanvas .nav-link { color: var(--bs-body-color) !important; }

#mobileNavOffcanvas .nav-link:hover {
    color: var(--bs-primary) !important;
    background-color: rgba(var(--bs-primary-rgb), 0.1) !important;
}

#mobileNavOffcanvas .nav-link.active {
    color: var(--bs-primary) !important;
    background-color: rgba(var(--bs-primary-rgb), 0.1) !important;
}

/* Mobile offcanvas quick actions specific styling */

#mobileNavOffcanvas .action-buttons-group {
    /* Override any existing styles for mobile offcanvas */
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    -moz-box-sizing: border-box !important; /* Firefox */
    -webkit-box-sizing: border-box !important; /* Safari */
    padding: 0.5rem 0.25rem !important;
    margin: 0 !important;
    justify-content: space-evenly !important; /* Equal spacing between buttons */
    overflow-x: hidden !important; /* Prevent overflow in Firefox */
    border-top-color: var(--bs-border-color) !important;
}

#mobileNavOffcanvas .action-buttons-group .btn {
    /* Ensure buttons fit within container with equal spacing */
    min-width: 30px !important;
    min-height: 30px !important;
    padding: 0.2rem !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
    -moz-flex-shrink: 0 !important; /* Firefox */
    -webkit-flex-shrink: 0 !important; /* Safari */
    /* Firefox mobile specific fixes */
    -moz-box-sizing: border-box !important;
    -webkit-box-sizing: border-box !important;
}

/* Very small screens - even more compact */

@media (max-width: 400px) {
    #mobileNavOffcanvas .action-buttons-group {
        padding: 0.25rem 0.125rem !important;
        justify-content: space-evenly !important; /* Equal spacing on small screens too */
    }

    #mobileNavOffcanvas .action-buttons-group .btn {
        min-width: 28px !important;
        min-height: 28px !important;
        padding: 0.15rem !important;
    }
}

/* Duplicate offcanvas-footer styles removed - consolidated above */

/* Ensure offcanvas has proper height structure with cross-browser viewport support */

#mobileNavOffcanvas {
    display: flex;
    flex-direction: column;
    /* Subtract the main navbar height so the panel fully fits (see GP thread) */
    height: 100vh; /* Fallback */
    height: 100dvh; /* Modern */
    min-height: 100vh;
    min-height: 100dvh;
    max-height: 100vh;
    max-height: 100dvh;
}

/* Duplicate offcanvas-header styles removed - consolidated above */

#mobileNavOffcanvas .nav-link {
    border-radius: 0.5rem;
    margin-bottom: 0.5rem;
    padding: 0.75rem 1rem;
    font-weight: 500;
    transition: all 0.15s ease;
    border: 1px solid transparent;
}

#mobileNavOffcanvas .nav-link:hover,
#mobileNavOffcanvas .nav-link:focus {
    background-color: var(--bs-primary-bg-subtle);
    border-color: var(--bs-primary-border-subtle);
    transform: translateX(4px);
}

#mobileNavOffcanvas .nav-link.active {
    background-color: var(--bs-primary);
    color: var(--bs-white);
    border-color: var(--bs-primary);
}

/* Mobile action buttons styling */

#mobileNavOffcanvas .action-buttons-group { margin-bottom: 0; }

#mobileNavOffcanvas .action-buttons-group .btn {
    border-radius: 0.5rem;
    font-weight: 500;
    padding: 0.5rem;
    transition: all 0.15s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

#mobileNavOffcanvas .action-buttons-group .btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Fix icon movement in offcanvas - prevent global button icon hover effects */

#mobileNavOffcanvas .btn:hover .bi,
#mobileNavOffcanvas .btn:hover i {
    transform: none !important;
    filter: none !important;
}

/* Ensure offcanvas icons stay centered */

#mobileNavOffcanvas .btn .bi,
#mobileNavOffcanvas .btn i {
    margin: 0 !important;
    transition: none !important;
}

/* Logout button styling */

#mobileNavOffcanvas #mobileNavLogout .btn {
    border-radius: 0.5rem;
    font-weight: 500;
    padding: 0.75rem 1rem;
    transition: all 0.15s ease;
}

#mobileNavOffcanvas #mobileNavLogout .btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Fix logout button icon movement */

#mobileNavOffcanvas #mobileNavLogout .btn:hover .bi,
#mobileNavOffcanvas #mobileNavLogout .btn:hover i {
    transform: none !important;
    filter: none !important;
}

#mobileNavOffcanvas #mobileNavLogout .btn .bi,
#mobileNavOffcanvas #mobileNavLogout .btn i {
    margin-right: 0.5rem !important;
    transition: none !important;
}

/* Categories section styling */

#mobileNavCategories {
    flex: 1;
    /* overflow-y: auto; */
}

#mobileNavCategories .navbar-nav { gap: 0.25rem; }

#mobileNavCategories .nav-item {
    border-bottom: 1px solid var(--bs-border-color-translucent);
    padding-bottom: 0.5rem;
    margin-bottom: 0.5rem;
}

#mobileNavCategories .nav-item:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

/* Dark theme adjustments for mobile */

[data-bs-theme="dark"] #mobileNavOffcanvas .nav-link:hover,
[data-bs-theme="dark"] #mobileNavOffcanvas .nav-link:focus {
    background-color: rgba(141, 111, 92, 0.13);
    color: #8d6f5c;
    border-color: rgba(141, 111, 92, 0.3);
}

[data-bs-theme="dark"] #mobileNavOffcanvas .nav-link.active {
    background-color: #8d6f5c;
    color: #d7ddf0;
    border-color: #8d6f5c;
}

[data-bs-theme="dark"] #mobileNavOffcanvas .offcanvas-footer {
    background: #212434;
    border-top-color: #343a40;
}

[data-bs-theme="dark"] #mobileNavOffcanvas .action-buttons-group { border-bottom-color: #343a40; }

[data-bs-theme="dark"] #mobileNavCategories .nav-item { border-bottom-color: #343a40; }

[data-bs-theme="dark"] .filter-action-bar {
    background: #212434;
    border-color: #343a40;
}

[data-bs-theme="dark"] .filter-action-bar .form-select {
    background-color: #212434;
    border-color: #343a40;
    color: #d7ddf0;
}

[data-bs-theme="dark"] .filter-action-bar .form-select:focus {
    background-color: #212434;
    border-color: #8d6f5c;
    color: #d7ddf0;
}

[data-bs-theme="dark"] .col-6 .style-card {
    background-color: #212434;
    border: 1px solid #343a40;
}

[data-bs-theme="dark"] .col-6 .style-card:hover { box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3); }

/* =========================
   MOBILE OFFCANVAS POLISH
   ========================= */

/* Logout button text visibility */

#mobileNavOffcanvas #mobileNavLogout .btn span { display: inline !important; }

/* Accordion styling for mobile offcanvas */

#mobileNavOffcanvas .accordion {
    --bs-accordion-border-color: var(--bs-border-color);
    --bs-accordion-bg: transparent;
    /* Prevent horizontal scroll */
    overflow-x: hidden;
    width: 100%;
    max-width: 100%;
}

#mobileNavOffcanvas .accordion-item {
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    margin-bottom: 0.5rem;
    /* Prevent horizontal scroll */
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

#mobileNavOffcanvas .accordion-button {
    background-color: transparent;
    border: none;
    padding: 0.75rem 1rem;
    font-weight: 500;
    color: var(--bs-body-color);
    border-radius: 0.5rem;
    /* Prevent horizontal scroll */
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#mobileNavOffcanvas .accordion-button:not(.collapsed) {
    background-color: var(--bs-primary-bg-subtle);
    color: var(--bs-primary);
    box-shadow: none;
}

#mobileNavOffcanvas .accordion-button:focus { box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25); }

/* Chevron removed - no longer needed */

#mobileNavOffcanvas .accordion-body {
    padding: 0.75rem 1rem 1rem;
    /* Prevent horizontal scroll */
    overflow-x: hidden;
    width: 100%;
    max-width: 100%;
    word-wrap: break-word;
    word-break: break-word;
}

#mobileNavOffcanvas .accordion-body .nav-link {
    padding: 0.5rem 0;
    border-radius: 0.375rem;
    transition: background-color 0.15s ease;
}

#mobileNavOffcanvas .accordion-body .nav-link:hover { background-color: var(--bs-tertiary-bg); }

/* Subcategory links styling */

#mobileNavOffcanvas .accordion-body .nav-link {
    transition: all 0.15s ease;
    border-radius: 0.375rem;
    padding: 0.5rem 0.75rem !important;
    margin-bottom: 0.25rem;
}

#mobileNavOffcanvas .accordion-body .nav-link:hover {
    background-color: var(--bs-primary-bg-subtle);
    color: var(--bs-primary) !important;
    transform: translateX(4px);
}

/* Group headers styling */

#mobileNavOffcanvas .accordion-body h6 {
    border-bottom: 1px solid var(--bs-border-color);
    padding-bottom: 0.5rem;
    margin-bottom: 0.75rem;
}

/* Dark theme adjustments for accordion */

[data-bs-theme="dark"] #mobileNavOffcanvas .accordion-button:not(.collapsed) {
    background-color: rgba(141, 111, 92, 0.13);
    color: #8d6f5c;
}

[data-bs-theme="dark"] #mobileNavOffcanvas .accordion-body .nav-link:hover { background-color: rgba(141, 111, 92, 0.1); }

/* FAB hiding when offcanvas is open */

.offcanvas.show ~ * .filters-fab,
.offcanvas.show ~ * .btn-fab,
.offcanvas.show ~ * [class*="fab"],
.offcanvas.show ~ * .floating-action-button { display: none !important; }

/* Duplicate offcanvas-footer sticky styles removed - consolidated above */

/* Tighten spacing for small screens */

@media (max-width: 575.98px) {
    #mobileNavOffcanvas .offcanvas-body { padding: 1rem 0.75rem; }

    #mobileNavOffcanvas .offcanvas-footer { padding: 0.75rem; }

    #mobileNavOffcanvas .accordion-button {
        padding: 0.625rem 0.75rem;
        font-size: 0.9rem;
    }

    #mobileNavOffcanvas .accordion-body { padding: 0.5rem 0.75rem 0.75rem; }
}

/* ===== Desktop Toast (glassmorphism) ===== */

.toast.toast-glass {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    overflow: hidden;
    backdrop-filter: saturate(180%) blur(12px);
    -webkit-backdrop-filter: saturate(180%) blur(12px);
    background: rgba(33, 37, 41, 0.35);
    color: rgba(255, 255, 255, 0.95);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

[data-bs-theme="light"] .toast.toast-glass {
    background: rgba(255, 255, 255, 0.6);
    color: #212529;
    border-color: rgba(0, 0, 0, 0.06);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
}

.toast.toast-glass .toast-header {
    background: transparent !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: inherit;
}

[data-bs-theme="light"] .toast.toast-glass .toast-header { border-bottom: 1px solid rgba(0, 0, 0, 0.08); }

.toast.toast-glass .toast-body { color: inherit; }

/* type accent ring on left edge */

.toast.toast-glass.toast--success { box-shadow: inset 4px 0 0 0 rgba(25, 135, 84, 0.9), 0 12px 30px rgba(0, 0, 0, 0.18); }

.toast.toast-glass.toast--error { box-shadow: inset 4px 0 0 0 rgba(220, 53, 69, 0.9), 0 12px 30px rgba(0, 0, 0, 0.18); }

.toast.toast-glass.toast--warning { box-shadow: inset 4px 0 0 0 rgba(255, 193, 7, 0.9), 0 12px 30px rgba(0, 0, 0, 0.18); }

.toast.toast-glass.toast--info { box-shadow: inset 4px 0 0 0 rgba(13, 110, 253, 0.9), 0 12px 30px rgba(0, 0, 0, 0.18); }

/* header/icon/close button colors */

.toast.toast-glass .toast-header i { filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.15)); }

.toast.toast-glass.toast--success .toast-header i { color: #28a745; }

.toast.toast-glass.toast--error .toast-header i { color: #dc3545; }

.toast.toast-glass.toast--warning .toast-header i { color: #ffc107; }

.toast.toast-glass.toast--info .toast-header i { color: #0d6efd; }

.toast.toast-glass .btn-close {
    filter: invert(1) grayscale(100%);
    opacity: .8;
}

[data-bs-theme="light"] .toast.toast-glass .btn-close { filter: none; }

/* ===== Mobile Toast (glassmorphism) ===== */

@media (max-width: 575.98px) {
    .mobile-toast-container {
        bottom: 16px;
        left: 50%;
        right: auto;
        width: calc(100% - 32px);
        max-width: 460px;
        padding: 0 8px;
        pointer-events: none; /* allow clicks only on toast */
    }

    .mobile-toast {
        position: relative;
        margin: 0 auto;
        border-radius: 14px;
        backdrop-filter: saturate(180%) blur(14px);
        -webkit-backdrop-filter: saturate(180%) blur(14px);
        background: rgba(33, 37, 41, 0.38);
        color: #fff;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
        transform: translateY(16px);
        opacity: 0;
        transition: transform 200ms ease, opacity 200ms ease;
        pointer-events: auto; /* allow interactions */
    }

    [data-bs-theme="light"] .mobile-toast {
        background: rgba(255, 255, 255, 0.45);
        color: #212529;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
    }

    .mobile-toast.show {
        transform: translateY(0);
        opacity: 1;
    }

    .mobile-toast.hide {
        transform: translateY(16px);
        opacity: 0;
    }

    .mobile-toast-content {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 12px 14px;
    }

    .mobile-toast-icon {
        font-size: 1.1rem;
        flex: 0 0 auto;
        filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.2));
    }

    /* type colors */
    .mobile-toast-success { color: #2ecc71; }

    .mobile-toast-error { color: #e74c3c; }

    .mobile-toast-warning { color: #f1c40f; }

    .mobile-toast-info { color: #3498db; }

    .mobile-toast-text {
        flex: 1 1 auto;
        font-size: 0.95rem;
        line-height: 1.35;
        word-wrap: break-word;
        word-break: break-word;
    }

    .mobile-toast-close {
        appearance: none;
        border: none;
        background: transparent;
        color: inherit;
        font-size: 1.25rem;
        line-height: 1;
        opacity: 0.85;
        padding: 4px 6px;
        border-radius: 8px;
    }

    .mobile-toast-close:active { transform: scale(0.96); }
}