/**
 * ENNU Retail Shop - Luxury Gold/Navy Theme v1.0
 *
 * Matching the proven luxury kiosk design from ennu-public-booking
 *
 * @package ENNU\RetailShop
 * @version 1.0.0
 */

/* ==========================================================================
   Fixed Header Offset - Account for theme/unified header
   ========================================================================== */
#ennu-retail-shop {
    padding-top: 0; /* Wrapper handles header offset */
}


body.admin-bar #ennu-retail-shop {
    padding-top: 0; /* Theme handles admin bar */
}

/* Override unified header content padding - wrapper handles it now */
.ennu-rs-main.ennu-unified-header-content {
    padding-top: 0 !important;
}

/* ==========================================================================
   Peptides Division Overrides - JS handles all header offset via .ennu-rs-wrapper
   ========================================================================== */
.ennu-rs[data-division="peptides"] .ennu-rs-wrapper {
    padding-top: 0 !important; /* JS will set this dynamically */
}

.ennu-rs[data-division="peptides"] .ennu-rs-main,
.ennu-rs[data-division="peptides"] .ennu-rs-main.ennu-unified-header-content {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

@media (max-width: 768px) {
    #ennu-retail-shop {
        clear: both; /* Clear floated header */
        padding-top: 0;
    }

    body.admin-bar #ennu-retail-shop {
        padding-top: 0;
    }
}

/* ==========================================================================
   Hide Theme Sidebars - Retail Shop Should Be Full Width
   ========================================================================== */
/* Hide all possible theme/WooCommerce sidebars when retail shop is present */
.ennu-rs ~ #sidebar,
.ennu-rs ~ .sidebar,
.ennu-rs ~ #secondary,
.ennu-rs ~ .secondary,
body:has(.ennu-rs) #sidebar,
body:has(.ennu-rs) .sidebar,
body:has(.ennu-rs) #secondary,
body:has(.ennu-rs) .secondary,
body:has(.ennu-rs) #primary-sidebar,
body:has(.ennu-rs) #secondary-sidebar,
body:has(.ennu-rs) .widget-area,
body:has(.ennu-rs) .woocommerce-sidebar,
body:has(.ennu-rs) aside.sidebar,
body:has(.ennu-rs) aside#secondary,
body:has(.ennu-rs) .sidebar-primary,
body:has(.ennu-rs) .sidebar-secondary,
.ennu-rs #sidebar,
.ennu-rs .sidebar,
.ennu-rs #secondary,
.ennu-rs .secondary,
.ennu-rs #primary-sidebar,
.ennu-rs #secondary-sidebar,
.ennu-rs .widget-area,
.ennu-rs .woocommerce-sidebar,
.ennu-rs aside.sidebar:not(.ennu-rs-sidebar),
.ennu-rs aside#secondary,
.ennu-rs .sidebar-primary,
.ennu-rs .sidebar-secondary,
body.page #sidebar,
body.page .sidebar,
body.page #secondary,
body.page .secondary {
    display: none !important;
}

/* Force full width for content areas containing retail shop */
body:has(.ennu-rs) #primary,
body:has(.ennu-rs) .content-area,
body:has(.ennu-rs) #main,
body:has(.ennu-rs) .site-main,
.ennu-rs #primary,
.ennu-rs .content-area,
.ennu-rs #main,
.ennu-rs .site-main,
body.page #primary,
body.page .content-area {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    float: none !important;
}

/* Ensure retail shop container takes full width */
.ennu-rs {
    width: 100% !important;
    max-width: 100% !important;
}

/* Override theme row/container constraints */
body:has(.ennu-rs) .row,
body:has(.ennu-rs) .container-fluid,
.ennu-rs .row,
.ennu-rs .container-fluid {
    max-width: 100% !important;
}

/* ==========================================================================
   CSS Variables - Luxury Gold/Navy Theme
   ========================================================================== */
:root {
    /* Primary Brand - Luxury Gold */
    --ennu-rs-gold: #C9A962;
    --ennu-rs-gold-light: #E5D4A1;
    --ennu-rs-gold-dark: #A68B4B;
    --ennu-rs-gold-gradient: linear-gradient(135deg, #C9A962 0%, #E5D4A1 50%, #C9A962 100%);

    /* Secondary - Deep Navy */
    --ennu-rs-navy: #1A2744;
    --ennu-rs-navy-light: #2D3E5F;
    --ennu-rs-navy-dark: #0F1829;

    /* Neutrals - Warm Cream */
    --ennu-rs-cream: #FAF8F5;
    --ennu-rs-white: #FFFFFF;
    --ennu-rs-charcoal: #2C3E50;
    --ennu-rs-slate: #5D6D7E;

    /* Semantic */
    --ennu-rs-success: #2E7D5A;
    --ennu-rs-success-light: #E8F5EE;
    --ennu-rs-error: #B8505A;
    --ennu-rs-error-light: #FDEDEF;
    --ennu-rs-warning: #C9962F;
    --ennu-rs-warning-light: #FEF7E8;
    --ennu-rs-info: #4A7BA7;
    --ennu-rs-info-light: #EBF4FA;

    /* Text */
    --ennu-rs-text: var(--ennu-rs-navy);
    --ennu-rs-text-secondary: var(--ennu-rs-charcoal);
    --ennu-rs-text-muted: var(--ennu-rs-slate);
    --ennu-rs-text-placeholder: #A0AEC0;

    /* Borders */
    --ennu-rs-border: rgba(201, 169, 98, 0.2);
    --ennu-rs-border-strong: rgba(201, 169, 98, 0.4);

    /* Layout */
    --ennu-rs-radius-sm: 10px;
    --ennu-rs-radius: 12px;
    --ennu-rs-radius-lg: 16px;
    --ennu-rs-radius-xl: 20px;
    --ennu-rs-radius-full: 9999px;

    /* Shadows - Elegant */
    --ennu-rs-shadow-subtle: 0 1px 3px rgba(26, 39, 68, 0.04);
    --ennu-rs-shadow-card: 0 4px 16px rgba(26, 39, 68, 0.06);
    --ennu-rs-shadow-elevated: 0 8px 32px rgba(26, 39, 68, 0.10);
    --ennu-rs-shadow-gold: 0 4px 20px rgba(201, 169, 98, 0.25);
    --ennu-rs-shadow-gold-hover: 0 8px 32px rgba(201, 169, 98, 0.4);
    --ennu-rs-shadow-focus: 0 0 0 4px rgba(201, 169, 98, 0.15);

    /* Animation */
    --ennu-rs-ease: cubic-bezier(0.4, 0, 0.2, 1);
    --ennu-rs-ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ennu-rs-duration: 150ms;
    --ennu-rs-duration-smooth: 300ms;

    /* Typography - Josefin Sans */
    --ennu-rs-font-body: 'Josefin Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --ennu-rs-font-display: 'Josefin Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* ==========================================================================
   Accessibility
   ========================================================================== */
.ennu-rs-live-region {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}


/* ==========================================================================
   Base Container - Luxury Kiosk Style
   ========================================================================== */
.ennu-rs {
    font-family: var(--ennu-rs-font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--ennu-rs-text);
    background: linear-gradient(180deg, var(--ennu-rs-cream) 0%, var(--ennu-rs-white) 100%);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: relative;
    z-index: 1; /* Below unified header (z-index: 1000) */
}

.ennu-rs *,
.ennu-rs *::before,
.ennu-rs *::after {
    box-sizing: border-box;
}

/* ==========================================================================
   Layout - Main Wrapper with Cart Sidebar
   ========================================================================== */
.ennu-rs-wrapper {
    display: flex;
    flex-direction: column;
    gap: 0;
    max-width: none; /* Full width */
    margin: 0;
    padding: 0;
    padding-top: 0; /* JS handles this based on header position */
}

/* When page is scrolled and header is shrunk */
.ennu-rs-wrapper.is-scrolled-offset {
    padding-top: 0;
}

@media (max-width: 1024px) {
    .ennu-rs-wrapper {
        flex-direction: column;
        padding: 0;
        padding-top: 0;
        gap: 0;
    }
}

@media (max-width: 768px) {
    .ennu-rs-wrapper {
        padding: 0;
        /* padding-top now handled by .ennu-rs-below-header */
    }
    
    .ennu-rs-header {
        padding: 12px 16px;
    }
    
    .ennu-rs-logo {
        margin-bottom: 8px;
    }
    
    .ennu-rs-logo-img {
        max-height: 28px;
    }
    
    /* Proper spacing for fixed header on mobile - wrapper handles it now */
    .ennu-rs-main.ennu-unified-header-content {
        padding-top: 0 !important;
    }
    
    /* Mobile wrapper spacing - padding-top now handled by .ennu-rs-below-header */
    
    /* Remove top padding from main content on mobile */
    .ennu-rs-main.ennu-unified-header-content {
        padding-top: 0 !important;
        margin-top: 0 !important;
    }
    
    /* Remove horizontal padding from container for flush layout on mobile */
    .ennu-rs-container {
        padding: 12px 0;
    }
    
    /* Horizontal scrollable filter on mobile */
    .ennu-rs-category-filter {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none; /* Firefox */
        -ms-overflow-style: none; /* IE/Edge */
        gap: 8px;
        margin: 0 -16px 16px -16px;
        padding: 8px 16px;
        justify-content: flex-start;
        scroll-snap-type: x proximity;
        scroll-padding: 16px;
    }

    .ennu-rs-category-filter::after {
        content: '';
        flex-shrink: 0;
        width: 8px; /* Extra space at end for last button padding */
    }

    .ennu-rs-category-filter::-webkit-scrollbar {
        display: none; /* Chrome/Safari */
    }

    .ennu-rs-category-btn {
        flex-shrink: 0;
        padding: 10px 16px;
        font-size: 0.8125rem;
        gap: 6px;
        border-width: 1.5px;
        border-radius: 20px;
        white-space: nowrap;
        scroll-snap-align: start;
    }

    .ennu-rs-category-btn a {
        color: inherit;
        text-decoration: none;
    }
}

/* Desktop sidebar overlay (slide-in panel when header cart is clicked) */
.ennu-rs-sidebar-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 100005; /* Just below sidebar (100006) */
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    pointer-events: none;
}
.ennu-rs-sidebar-overlay.open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

@media (max-width: 1024px) {
    .ennu-rs-sidebar-overlay {
        display: none !important;
    }
}

/* Cart Sidebar */
.ennu-rs-sidebar {
    width: 340px;
    flex-shrink: 0;
    /* JS handles sticky behavior - see setupStickySidebar() */
    position: relative;
    z-index: 0; /* Allow header dropdowns to appear above */
}

.ennu-rs-sidebar-inner {
    background: var(--ennu-rs-white);
    border-radius: 0;
    box-shadow: none;
    border: none;
    overflow: visible;
    max-height: none;
    display: flex;
    flex-direction: column;
    margin-top: 0; /* Don't overlap header */
    /* When JS applies max-height in fixed mode, this flex layout ensures
       cart items scroll while checkout button stays at bottom */
}

/* Desktop: Fixed cart panel - positioned below header */
@media (min-width: 1025px) {
    .ennu-rs-sidebar-inner {
        position: fixed;
        top: 100px; /* Account for header height */
        right: 0;
        bottom: 0;
        width: 340px;
        max-height: calc(100vh - 100px);
        overflow: hidden;
        z-index: 999; /* Below unified header (z-index: 1000) */
    }
}

.ennu-rs-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 24px;
    background: var(--ennu-rs-navy);
    color: #FFFFFF;
    position: relative;
    flex-shrink: 0; /* Never shrink - always visible */
}

.ennu-rs-sidebar-header::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--ennu-rs-gold-gradient);
}

.ennu-rs-sidebar-header h3 {
    margin: 0;
    font-family: var(--ennu-rs-font-display);
    font-size: 1.125rem;
    font-weight: 600;
    color: #FFFFFF;
}

.ennu-rs-cart-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 28px;
    padding: 0 8px;
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);
    border-radius: var(--ennu-rs-radius-full);
    font-size: 0.875rem;
    font-weight: 700;
}

.ennu-rs-sidebar-close {
    display: none;
    align-items: center;
    justify-content: center;
    padding: 4px;
    margin: 0 0 0 8px;
    background: transparent;
    border: none;
    border-radius: var(--ennu-rs-radius);
    color: #fff;
    cursor: pointer;
    transition: background 0.2s ease;
}
.ennu-rs-sidebar-close:hover {
    background: rgba(255, 255, 255, 0.15);
}
.ennu-rs-sidebar-close svg {
    stroke: var(--ennu-rs-gold);
}

.ennu-rs-sidebar-toggle {
    display: none;
    transition: transform 0.3s ease;
}

.ennu-rs-sidebar-toggle svg {
    stroke: var(--ennu-rs-gold);
}

@media (max-width: 768px) {
    .ennu-rs-sidebar-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        margin-left: auto;
    }
}

/* Cart Items */
.ennu-rs-cart-items {
    padding: 20px 24px;
    flex: 1;
    overflow-y: auto;
    min-height: 0; /* Allow flex shrinking for scroll */
    max-height: calc(100vh - 380px); /* Allow scrolling while keeping checkout button visible */
}

.ennu-rs-cart-item {
    display: flex;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid var(--ennu-rs-border);
}

.ennu-rs-cart-item:last-child {
    border-bottom: none;
}

.ennu-rs-cart-item-image {
    width: 64px;
    height: 64px;
    border-radius: var(--ennu-rs-radius);
    overflow: hidden;
    background: var(--ennu-rs-cream);
    flex-shrink: 0;
}

.ennu-rs-cart-item-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ennu-rs-cart-item-details {
    flex: 1;
    min-width: 0;
}

.ennu-rs-cart-item-name {
    font-size: 0.9375rem;
    font-weight: 600;
    color: #1A2744 !important; /* Navy - force override theme styles */
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ennu-rs-cart-item-price {
    font-size: 0.875rem;
    color: #A68B4B !important; /* Gold dark - force override */
    font-weight: 600;
}

/* Ensure sidebar text colors are correct */
.ennu-rs-sidebar-inner,
.ennu-rs-sidebar-inner * {
    color: #1A2744; /* Default to navy */
}

.ennu-rs-sidebar-header,
.ennu-rs-sidebar-header * {
    color: #FFFFFF !important;
}

.ennu-rs-cart-item-member-price {
    font-size: 0.75rem;
    color: var(--ennu-rs-success);
}

.ennu-rs-cart-item-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 8px;
}

.ennu-rs-qty-btn {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ennu-rs-cream);
    border: none;
    border-radius: var(--ennu-rs-radius-sm);
    font-size: 1rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    cursor: pointer;
    transition: all var(--ennu-rs-duration);
}

.ennu-rs-qty-btn:hover {
    background: var(--ennu-rs-gold);
    border-color: var(--ennu-rs-gold);
    color: var(--ennu-rs-white);
}

.ennu-rs-cart-item-qty {
    font-size: 0.9375rem;
    font-weight: 600;
    min-width: 24px;
    text-align: center;
}

/* Editable quantity input */
.ennu-rs-cart-item-qty-input {
    font-size: 0.9375rem;
    font-weight: 600;
    width: 50px;
    min-width: 50px;
    text-align: center;
    border: 1px solid var(--ennu-rs-border);
    border-radius: var(--ennu-rs-radius);
    padding: 4px 8px;
    background: var(--ennu-rs-white);
    color: var(--ennu-rs-text);
    transition: all var(--ennu-rs-duration);
    -moz-appearance: textfield; /* Firefox */
}

.ennu-rs-cart-item-qty-input::-webkit-outer-spin-button,
.ennu-rs-cart-item-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.ennu-rs-cart-item-qty-input:focus {
    outline: none;
    border-color: var(--ennu-rs-gold);
    box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.1);
}

.ennu-rs-cart-item-qty-input:hover {
    border-color: var(--ennu-rs-gold);
}

.ennu-rs-cart-item-remove {
    margin-left: auto;
    background: rgba(220, 53, 69, 0.1);
    border: 1px solid rgba(220, 53, 69, 0.2);
    border-radius: var(--ennu-rs-radius);
    color: var(--ennu-rs-error);
    cursor: pointer;
    padding: 6px;
    opacity: 0.8;
    transition: all var(--ennu-rs-duration);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ennu-rs-cart-item-remove:hover {
    opacity: 1;
    background: var(--ennu-rs-error);
    border-color: var(--ennu-rs-error);
    color: var(--ennu-rs-white);
}

.ennu-rs-cart-item-remove svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Cart Empty State */
.ennu-rs-cart-empty {
    padding: 40px 24px;
    text-align: center;
    color: var(--ennu-rs-text-muted);
}

.ennu-rs-cart-empty-icon {
    font-size: 3rem;
    margin-bottom: 16px;
    opacity: 0.5;
}

/* Cart Totals */
.ennu-rs-cart-totals {
    padding: 20px 24px;
    background: var(--ennu-rs-cream);
    border-top: 1px solid var(--ennu-rs-border);
}

.ennu-rs-cart-row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    font-size: 0.9375rem;
}

.ennu-rs-cart-row--discount {
    color: var(--ennu-rs-success);
}

.ennu-rs-cart-row--total {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--ennu-rs-navy);
    padding-top: 12px;
    margin-top: 8px;
    border-top: 2px dashed var(--ennu-rs-border);
}

.ennu-rs-cart-row--total span:last-child {
    color: var(--ennu-rs-gold-dark);
}

/* Checkout Button in Sidebar */
.ennu-rs-checkout-btn-container {
    padding: 16px 24px 24px;
    flex-shrink: 0; /* Never shrink - always visible even when sidebar is constrained */
    background: var(--ennu-rs-white);
    position: sticky;
    bottom: 0;
    border-top: 1px solid var(--ennu-rs-border);
    box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.05);
}

/* Ensure checkout button is always visible on desktop */
@media (min-width: 1025px) {
    .ennu-rs-sidebar-inner {
        display: flex;
        flex-direction: column;
    }

    .ennu-rs-cart-items {
        max-height: calc(100vh - 420px); /* More space for checkout button */
    }

    .ennu-rs-cart-totals {
        flex-shrink: 0;
    }
}

/* Main Content */
.ennu-rs-main {
    flex: 1;
    min-width: 0;
}

.ennu-rs-container {
    background: var(--ennu-rs-white);
    border-radius: 0;
    box-shadow: none;
    overflow: hidden;
    border: none;
}

/* Wrapper for all content below the unified header */
.ennu-rs-below-header {
    display: block;
    position: relative;
    /* No top padding - removed per user request */
    padding-top: 0;
}

/* Scrolled header is shorter */
.ennu-unified-header.is-scrolled ~ .ennu-unified-header-content .ennu-rs-below-header,
.ennu-rs-below-header.is-header-scrolled {
    padding-top: 0;
}

/* Tablet breakpoint */
@media (max-width: 1024px) {
    .ennu-rs-below-header {
        padding-top: 0;
    }
}

/* Mobile breakpoint - header is compact (no title/subtitle) */
@media (max-width: 768px) {
    .ennu-rs-below-header {
        padding-top: 0;
    }

    .ennu-rs-below-header.is-header-scrolled {
        padding-top: 0;
    }
}

/* Small mobile */
@media (max-width: 480px) {
    .ennu-rs-below-header {
        padding-top: 0;
    }
}

/* ==========================================================================
   Header - Luxury Kiosk Style with Logo
   ========================================================================== */
.ennu-rs-header {
    padding: 32px 0;
    text-align: center;
    border-bottom: 1px solid var(--ennu-rs-border);
    background: linear-gradient(180deg, var(--ennu-rs-cream) 0%, var(--ennu-rs-white) 100%);
    position: relative;
}

.ennu-rs-header::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 120px;
    height: 4px;
    background: var(--ennu-rs-gold-gradient);
    border-radius: 2px;
}

.ennu-rs-logo {
    margin-bottom: 20px;
}

.ennu-rs-logo-img {
    max-width: 180px;
    max-height: 60px;
    width: auto;
    height: auto;
}

.ennu-rs-title {
    font-family: var(--ennu-rs-font-display);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: 600;
    color: var(--ennu-rs-navy);
    margin: 0 0 12px;
    letter-spacing: 0.02em;
}

.ennu-rs-subtitle {
    font-size: 1.125rem;
    color: var(--ennu-rs-slate);
    margin: 0;
}

/* ==========================================================================
   Progress Bar - Gold Theme
   ========================================================================== */
.ennu-rs-progress {
    padding: 24px 0;
    background: var(--ennu-rs-cream);
    border-bottom: 1px solid var(--ennu-rs-border);
}

.ennu-rs-progress-bar {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 20px;
}

.ennu-rs-progress-track {
    flex: 1;
    height: 6px;
    background: rgba(201, 169, 98, 0.2);
    border-radius: var(--ennu-rs-radius-full);
    overflow: hidden;
}

.ennu-rs-progress-fill {
    height: 100%;
    background: var(--ennu-rs-gold-gradient);
    border-radius: var(--ennu-rs-radius-full);
    transition: width 0.5s var(--ennu-rs-ease);
    box-shadow: 0 0 8px rgba(201, 169, 98, 0.4);
}

.ennu-rs-progress-text {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--ennu-rs-gold-dark);
    white-space: nowrap;
}

/* Step Indicators */
.ennu-rs-step-indicators {
    display: flex;
    justify-content: center;
    gap: 0;
}

.ennu-rs-step-indicator {
    display: flex;
    align-items: center;
    position: relative;
}

.ennu-rs-step-indicator:not(:last-child)::after {
    content: '';
    width: 56px;
    height: 2px;
    background: rgba(201, 169, 98, 0.2);
    transition: background var(--ennu-rs-duration-smooth);
}

.ennu-rs-step-indicator.completed:not(:last-child)::after {
    background: var(--ennu-rs-gold);
}

.ennu-rs-step-number {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ennu-rs-white);
    border: 3px solid rgba(201, 169, 98, 0.3);
    border-radius: 50%;
    position: relative;
    flex-shrink: 0;
    font-weight: 600;
    font-size: 0.9375rem;
    color: var(--ennu-rs-slate);
    transition: all var(--ennu-rs-duration-smooth);
    position: relative;
    z-index: 1;
}

.ennu-rs-step-indicator.active .ennu-rs-step-number {
    background: var(--ennu-rs-gold);
    border-color: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);
    box-shadow: var(--ennu-rs-shadow-gold);
}

.ennu-rs-step-indicator.completed .ennu-rs-step-number {
    background: var(--ennu-rs-success);
    border-color: var(--ennu-rs-success);
    color: var(--ennu-rs-white);
}

.ennu-rs-step-indicator.completed .ennu-rs-step-number span {
    display: none;
}

.ennu-rs-step-indicator.completed .ennu-rs-step-number::after {
    content: '';
    width: 12px;
    height: 6px;
    border-left: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(-45deg);
    margin-top: -2px;
}

.ennu-rs-step-label {
    position: absolute;
    top: calc(100% + 10px);
    /* Center under the 40px step-number circle, not the full indicator width */
    left: 20px; /* Half of step-number width (40px / 2) */
    transform: translateX(-50%);
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--ennu-rs-slate);
    white-space: nowrap;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.ennu-rs-step-indicator.active .ennu-rs-step-label {
    color: var(--ennu-rs-gold-dark);
    font-weight: 600;
}

@media (max-width: 600px) {
    .ennu-rs-step-label {
        font-size: 0.5rem;
        letter-spacing: 0.01em;
        top: calc(100% + 6px);
    }
    
    .ennu-rs-step-indicators {
        padding-bottom: 20px; /* Make room for labels */
        gap: 4px; /* Add spacing between indicators */
    }
    
    .ennu-rs-step-indicator:not(:last-child)::after {
        width: 24px; /* Wider connector for more spacing */
        margin: 0 2px;
    }
    
    .ennu-rs-step-number {
        width: 26px;
        height: 26px;
        font-size: 0.625rem;
    }
    
    .ennu-rs-step-label {
        left: 13px; /* Half of smaller step-number width (26px / 2) */
    }
    
    /* Keep horizontal scroll on small mobile, slightly smaller buttons */
    .ennu-rs-category-filter {
        gap: 6px;
        margin-bottom: 12px;
    }

    .ennu-rs-category-btn {
        padding: 8px 14px;
        font-size: 0.75rem;
    }
}

/* ==========================================================================
   Steps Container - Slide Transitions
   ========================================================================== */
.ennu-rs-steps {
    position: relative;
    min-height: 450px;
    overflow: hidden;
}

.ennu-rs-step {
    display: none;
    padding: 40px 0;
    animation: stepSlideIn 0.5s var(--ennu-rs-ease) forwards;
}

.ennu-rs-step.active {
    display: block;
}

@keyframes stepSlideIn {
    from {
        opacity: 0;
        transform: translateX(60px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes stepSlideInReverse {
    from {
        opacity: 0;
        transform: translateX(-60px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.ennu-rs-step-header {
    text-align: center;
    margin-bottom: 36px;
}

.ennu-rs-step-title {
    font-family: var(--ennu-rs-font-display);
    font-size: clamp(1.5rem, 3vw, 1.75rem);
    font-weight: 600;
    color: var(--ennu-rs-navy);
    margin: 0 0 12px;
}

.ennu-rs-step-description {
    font-size: 1.0625rem;
    color: var(--ennu-rs-slate);
    margin: 0;
}

@media (max-width: 600px) {
    .ennu-rs-step {
        padding: 28px 20px;
    }
    
    .ennu-rs-step-title {
        font-size: 1.375rem;
    }
}

/* ==========================================================================
   Category Filter - Gold Pills
   ========================================================================== */
.ennu-rs-category-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 24px;
    justify-content: center;
}

.ennu-rs-category-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 22px;
    background: var(--ennu-rs-white);
    border: 2px solid rgba(201, 169, 98, 0.3);
    border-radius: var(--ennu-rs-radius-full);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--ennu-rs-text-secondary);
    cursor: pointer;
    transition: all var(--ennu-rs-duration-smooth);
    font-family: inherit;
}

.ennu-rs-category-btn:hover {
    border-color: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);  /* Changed from gold-dark for better contrast */
    background: rgba(201, 169, 98, 0.15);  /* Increased opacity for visibility */
}

.ennu-rs-category-btn.active {
    background: var(--ennu-rs-navy);
    border-color: var(--ennu-rs-navy);
    color: #FFFFFF !important; /* Ensure white text for high contrast */
    font-weight: 600;
    text-shadow: 0 0 1px rgba(255,255,255,0.3);
}

.ennu-rs-category-btn:focus {
    outline: 2px solid var(--ennu-rs-gold);
    outline-offset: 2px;
}

.ennu-rs-category-btn:focus-visible {
    outline: 2px solid var(--ennu-rs-gold);
    outline-offset: 2px;
}

/* Search & Tools Row */
.ennu-rs-tools-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}

.ennu-rs-search-box {
    flex: 1;
    min-width: 200px;
    position: relative;
}

.ennu-rs-search-icon {
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--ennu-rs-gold-dark);
    pointer-events: none;
}

.ennu-rs-search-input {
    width: 100%;
    padding: 16px 20px 16px 52px;
    font-size: 1rem;
    font-family: inherit;
    color: var(--ennu-rs-text);
    background: var(--ennu-rs-cream);
    border: 2px solid var(--ennu-rs-border);
    border-radius: 0;
    transition: all var(--ennu-rs-duration-smooth);
    outline: none;
}

.ennu-rs-search-input:focus {
    border-color: var(--ennu-rs-gold);
    background: var(--ennu-rs-white);
    box-shadow: var(--ennu-rs-shadow-focus);
}

.ennu-rs-search-input::placeholder {
    color: var(--ennu-rs-text-placeholder);
}

/* ==========================================================================
   Product Card Grid
   ========================================================================== */
.ennu-rs-card-grid {
    display: grid;
    gap: 20px;
}

.ennu-rs-card-grid--products {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

/* Product Card */
.ennu-rs-product-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--ennu-rs-white);
    border: 2px solid var(--ennu-rs-border);
    border-left: 5px solid var(--ennu-rs-gold);
    border-radius: 0;
    overflow: hidden;
    transition: all var(--ennu-rs-duration-smooth);
}

.ennu-rs-product-card:hover {
    border-color: var(--ennu-rs-gold);
    box-shadow: var(--ennu-rs-shadow-gold);
    transform: translateY(-4px);
}

.ennu-rs-product-image {
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.15) 0%, var(--ennu-rs-cream) 100%);
}

.ennu-rs-product-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    transition: transform 0.4s var(--ennu-rs-ease);
}

.ennu-rs-product-card:hover .ennu-rs-product-image img {
    transform: scale(1.08);
}

.ennu-rs-product-content {
    padding: 16px 18px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.ennu-rs-product-category {
    display: inline-block;
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--ennu-rs-gold-dark);
    background: rgba(201, 169, 98, 0.15);
    padding: 3px 8px;
    border-radius: var(--ennu-rs-radius-full);
    margin-bottom: 8px;
    align-self: flex-start;
}

.ennu-rs-product-title-row {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 6px;
    flex-wrap: wrap;
}

.ennu-rs-product-name {
    font-family: var(--ennu-rs-font-display);
    font-size: 1rem;
    font-weight: 600;
    color: #1A1A1A;
    margin: 0;
    line-height: 1.3;
}

.ennu-rs-api-inline {
    font-size: 0.7rem;
    font-weight: 400;
    color: #5D6D7E;
    background: #F0F3F7;
    padding: 3px 8px;
    border-radius: 10px;
    white-space: nowrap;
    display: inline-block;
}

.ennu-rs-api-inline strong {
    font-weight: 600;
    margin-right: 2px;
}

.ennu-rs-dose-inline {
    font-size: 0.7rem;
    font-weight: 400;
    color: #A68B4B;
    background: #FFF8E7;
    padding: 3px 8px;
    border-radius: 10px;
    white-space: nowrap;
    display: inline-block;
}

.ennu-rs-dose-inline strong {
    font-weight: 600;
    margin-right: 2px;
}

.ennu-rs-product-description-wrapper {
    margin-bottom: 12px;
    flex: 1;
}

.ennu-rs-product-description {
    font-size: 0.8125rem;
    color: #444444;
    line-height: 1.5;
    margin-bottom: 8px;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ennu-rs-learn-more-link {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--ennu-rs-gold);
    background: transparent;
    border: 1px solid var(--ennu-rs-gold);
    padding: 4px 10px;
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.2s ease;
    cursor: pointer;
}

.ennu-rs-learn-more-link:hover {
    background: var(--ennu-rs-gold);
    color: #FFFFFF;
    text-decoration: none;
}

/* API and Dose Specs */
.ennu-rs-product-specs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    margin-bottom: 10px;
    padding: 8px 0;
    border-bottom: 1px dashed var(--ennu-rs-border);
}

.ennu-rs-spec {
    font-size: 0.75rem;
    color: var(--ennu-rs-navy);
    background: rgba(201, 169, 98, 0.1);
    padding: 4px 10px;
    border-radius: var(--ennu-rs-radius);
}

.ennu-rs-spec strong {
    color: var(--ennu-rs-gold-dark);
    font-weight: 600;
    margin-right: 4px;
}

/* =========================================
   Bundle/Stack Product Cards
   ========================================= */

.ennu-rs-product-card--bundle {
    border: 2px solid var(--ennu-rs-gold);
    position: relative;
}

.ennu-rs-bundle-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 4px 10px;
    border-radius: 4px;
    z-index: 10;
}

/* Bundle Image Carousel */
.ennu-rs-product-carousel {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--ennu-rs-cream);
    border-radius: var(--ennu-rs-radius) var(--ennu-rs-radius) 0 0;
}

.ennu-rs-carousel-track {
    position: relative;
    width: 100%;
    height: 100%;
}

.ennu-rs-carousel-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ennu-rs-carousel-slide.active {
    opacity: 1;
}

.ennu-rs-carousel-slide img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    object-position: center;
}

.ennu-rs-carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
    opacity: 0;
    transition: opacity 0.2s ease, background 0.2s ease;
}

.ennu-rs-product-carousel:hover .ennu-rs-carousel-btn {
    opacity: 1;
}

.ennu-rs-carousel-btn:hover {
    background: var(--ennu-rs-gold);
}

.ennu-rs-carousel-btn--prev {
    left: 8px;
}

.ennu-rs-carousel-btn--next {
    right: 8px;
}

.ennu-rs-carousel-dots {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 6px;
    z-index: 5;
}

.ennu-rs-carousel-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.5);
    border: 1px solid var(--ennu-rs-navy);
    cursor: pointer;
    padding: 0;
    transition: background 0.2s ease;
}

.ennu-rs-carousel-dot.active,
.ennu-rs-carousel-dot:hover {
    background: var(--ennu-rs-gold);
}

/* Bundled Items List */
.ennu-rs-bundled-items {
    margin: 10px 0;
    padding: 12px;
    background: rgba(201, 169, 98, 0.08);
    border-radius: var(--ennu-rs-radius);
}

.ennu-rs-bundled-items-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.ennu-rs-bundled-items-label {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--ennu-rs-gold-dark);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.ennu-rs-bundled-learn-more {
    font-size: 0.6rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    background: rgba(201, 169, 98, 0.2);
    border: 1px solid var(--ennu-rs-gold);
    border-radius: 10px;
    padding: 2px 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.ennu-rs-bundled-learn-more:hover {
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);
}

.ennu-rs-bundled-items-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.ennu-rs-bundled-item {
    padding-bottom: 10px;
    border-bottom: 1px dashed rgba(201, 169, 98, 0.3);
}

.ennu-rs-bundled-item:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

.ennu-rs-bundled-item-title-row {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-bottom: 4px;
    flex-wrap: wrap;
}

.ennu-rs-bundled-item-name {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
}

.ennu-rs-bundled-api-inline {
    font-size: 0.7rem;
    font-weight: 400;
    color: #5D6D7E;
    background: #F0F3F7;
    padding: 3px 8px;
    border-radius: 10px;
    white-space: nowrap;
    display: inline-block;
}

.ennu-rs-bundled-api-inline strong {
    font-weight: 600;
    margin-right: 2px;
}

.ennu-rs-bundled-dose-inline {
    font-size: 0.7rem;
    font-weight: 400;
    color: #A68B4B;
    background: #FFF8E7;
    padding: 3px 8px;
    border-radius: 10px;
    white-space: nowrap;
    display: inline-block;
}

.ennu-rs-bundled-dose-inline strong {
    font-weight: 600;
    margin-right: 2px;
}

.ennu-rs-bundled-item-specs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 4px;
}

.ennu-rs-bundled-item-specs .ennu-rs-spec {
    font-size: 0.65rem;
    padding: 2px 6px;
}

/* Description hidden by default */
.ennu-rs-bundled-item-desc {
    font-size: 0.75rem;
    color: var(--ennu-rs-text-muted);
    line-height: 1.4;
    margin: 4px 0 0 0;
    display: none;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, margin 0.3s ease;
}

/* Show descriptions when expanded */
.ennu-rs-bundled-items.expanded .ennu-rs-bundled-item-desc {
    display: block;
    max-height: 200px;
}

/* Optional bundled items */
.ennu-rs-bundled-item.is-optional {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.ennu-rs-bundled-item.is-optional .ennu-rs-bundled-item-name {
    flex: 1;
    margin-bottom: 0;
}

/* Toggle switch for optional items */
.ennu-rs-bundled-item-toggle {
    position: relative;
    width: 36px;
    height: 20px;
    flex-shrink: 0;
    cursor: pointer;
}

.ennu-rs-bundled-item-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}

.ennu-rs-toggle-slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background-color: #ccc;
    border-radius: 20px;
    transition: background-color 0.3s ease;
}

.ennu-rs-toggle-slider::before {
    content: "";
    position: absolute;
    height: 16px;
    width: 16px;
    left: 2px;
    bottom: 2px;
    background-color: white;
    border-radius: 50%;
    transition: transform 0.3s ease;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

.ennu-rs-bundled-item-toggle input:checked + .ennu-rs-toggle-slider {
    background-color: var(--ennu-rs-gold);
}

.ennu-rs-bundled-item-toggle input:checked + .ennu-rs-toggle-slider::before {
    transform: translateX(16px);
}

.ennu-rs-bundled-item-toggle input:focus + .ennu-rs-toggle-slider {
    box-shadow: 0 0 0 2px rgba(201, 169, 98, 0.3);
}

/* Deselected state */
.ennu-rs-bundled-item.is-deselected .ennu-rs-bundled-item-name {
    opacity: 0.5;
    text-decoration: line-through;
}

.ennu-rs-bundled-item.is-deselected .ennu-rs-bundled-item-optional-badge,
.ennu-rs-bundled-item.is-deselected .ennu-rs-bundled-item-price {
    opacity: 0.5;
}

/* Exclusive group (radio select) */
.ennu-rs-exclusive-group {
    border: 2px solid var(--ennu-rs-gold);
    border-radius: 8px;
    padding: 8px;
    margin-bottom: 8px;
    background: rgba(201, 169, 98, 0.04);
}

.ennu-rs-exclusive-group-label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--ennu-rs-gold);
    margin-bottom: 6px;
    padding-left: 4px;
}

.ennu-rs-bundled-item.is-exclusive {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 6px 4px;
    border-radius: 6px;
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.ennu-rs-bundled-item.is-exclusive:hover {
    background: rgba(201, 169, 98, 0.08);
}

.ennu-rs-bundled-item.is-exclusive.is-deselected {
    opacity: 0.55;
}

.ennu-rs-bundled-item.is-exclusive.is-deselected .ennu-rs-bundled-item-name {
    text-decoration: none;
    opacity: 1;
}

/* Content wrapper for exclusive group items (title + variation selector) */
.ennu-rs-bundled-item-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0;
    min-width: 0; /* Allow content to shrink */
}

/* Radio button for exclusive groups */
.ennu-rs-bundled-item-radio {
    position: relative;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    margin-top: 2px; /* Align with text baseline */
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ennu-rs-bundled-item-radio input[type="radio"] {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}

.ennu-rs-radio-indicator {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid #ccc;
    background: #fff;
    transition: all 0.2s ease;
    position: relative;
}

.ennu-rs-bundled-item-radio input[type="radio"]:checked + .ennu-rs-radio-indicator {
    border-color: var(--ennu-rs-gold);
    background: #fff;
}

.ennu-rs-bundled-item-radio input[type="radio"]:checked + .ennu-rs-radio-indicator::after {
    content: "";
    position: absolute;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--ennu-rs-gold);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.ennu-rs-bundled-item-radio input[type="radio"]:focus + .ennu-rs-radio-indicator {
    box-shadow: 0 0 0 2px rgba(201, 169, 98, 0.3);
}

/* Variation Selector for Bundled Items (including exclusive groups) */
.ennu-rs-bundled-variation-selector {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: 8px;
    padding: 8px 10px;
    background: rgba(255, 255, 255, 0.5);
    border: 1px solid rgba(201, 169, 98, 0.3);
    border-radius: 6px;
    width: 100%;
}

.ennu-rs-bundled-variation-label {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 2px;
}

.ennu-rs-bundled-variation-select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 100%;
    padding: 8px 32px 8px 12px;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--ennu-rs-navy);
    background-color: white;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23C9A962' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 12px;
    border: 2px solid var(--ennu-rs-gold);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.ennu-rs-bundled-variation-select:hover {
    border-color: var(--ennu-rs-gold-dark);
    box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.1);
}

.ennu-rs-bundled-variation-select:focus {
    outline: none;
    border-color: var(--ennu-rs-gold-dark);
    box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.2);
}

.ennu-rs-bundled-variation-select:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background-color: #f5f5f5;
}

.ennu-rs-bundled-variation-select option {
    padding: 8px;
    font-size: 0.85rem;
}

/* For exclusive group items, make selector full width within the content wrapper */
.ennu-rs-bundled-item.is-exclusive .ennu-rs-bundled-variation-selector {
    width: 100%;
    margin-left: 0;
}

/* Optional badge */
.ennu-rs-bundled-item-optional-badge {
    font-size: 0.55rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 2px 6px;
    background: rgba(201, 169, 98, 0.15);
    color: var(--ennu-rs-gold-dark);
    border-radius: 4px;
}

/* Optional item price */
.ennu-rs-bundled-item-price {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--ennu-rs-gold);
    margin-left: auto;
}

/* ==========================================================================
   Cart Bundled Items (Sidebar & Step 2)
   Compact toggle styling for bundle items in cart context
   ========================================================================== */

.ennu-rs-cart-bundled-items {
    margin-top: 8px;
    padding: 8px;
    background: rgba(201, 169, 98, 0.06);
    border-radius: 6px;
    font-size: 0.75rem;
}

.ennu-rs-cart-bundled-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 3px 0;
    border-bottom: 1px dashed rgba(201, 169, 98, 0.2);
}

.ennu-rs-cart-bundled-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.ennu-rs-cart-bundled-name {
    font-size: 0.7rem;
    color: var(--ennu-rs-text);
}

.ennu-rs-cart-bundled-item.is-deselected .ennu-rs-cart-bundled-name {
    opacity: 0.5;
    text-decoration: line-through;
}

/* Compact toggle for cart context */
.ennu-rs-cart-bundled-toggle,
.ennu-rs-summary-bundled-toggle {
    position: relative;
    width: 28px;
    height: 14px;
    flex-shrink: 0;
    cursor: pointer;
}

.ennu-rs-cart-bundled-toggle input,
.ennu-rs-summary-bundled-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}

.ennu-rs-toggle-slider-sm {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background-color: #ccc;
    border-radius: 14px;
    transition: background-color 0.3s ease;
}

.ennu-rs-toggle-slider-sm::before {
    content: "";
    position: absolute;
    height: 10px;
    width: 10px;
    left: 2px;
    bottom: 2px;
    background-color: white;
    border-radius: 50%;
    transition: transform 0.3s ease;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.ennu-rs-cart-bundled-toggle input:checked + .ennu-rs-toggle-slider-sm,
.ennu-rs-summary-bundled-toggle input:checked + .ennu-rs-toggle-slider-sm {
    background-color: var(--ennu-rs-gold);
}

.ennu-rs-cart-bundled-toggle input:checked + .ennu-rs-toggle-slider-sm::before,
.ennu-rs-summary-bundled-toggle input:checked + .ennu-rs-toggle-slider-sm::before {
    transform: translateX(14px);
}

/* Step 2 Summary bundled items styling */
.ennu-rs-summary-bundled-list {
    list-style: none;
    margin: 6px 0 0 0;
    padding: 0;
}

.ennu-rs-summary-bundled-list li {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 0;
    font-size: 0.75rem;
    color: var(--ennu-rs-text-muted);
}

.ennu-rs-summary-bundled-list li.is-optional {
    color: var(--ennu-rs-text);
}

.ennu-rs-summary-bundled-list li.is-deselected .ennu-rs-summary-bundled-name {
    opacity: 0.5;
    text-decoration: line-through;
}

.ennu-rs-summary-bundled-name {
    flex: 1;
}

.ennu-rs-optional-tag {
    font-size: 0.6rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    padding: 1px 4px;
    background: rgba(201, 169, 98, 0.12);
    color: var(--ennu-rs-gold-dark);
    border-radius: 3px;
}

.ennu-rs-product-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 1px solid var(--ennu-rs-border);
    margin-top: auto;
}

.ennu-rs-product-price {
    font-family: var(--ennu-rs-font-display);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--ennu-rs-gold-dark);
}

.ennu-rs-product-member-price {
    display: flex;
    flex-direction: column;
}

.ennu-rs-product-member-price .original {
    font-size: 0.875rem;
    color: var(--ennu-rs-text-muted);
    text-decoration: line-through;
}

.ennu-rs-product-member-price .member {
    font-size: 0.75rem;
    color: var(--ennu-rs-success);
    font-weight: 600;
}

/* Discounted price display (when coupon is applied) */
.ennu-rs-product-discounted-price {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
}

.ennu-rs-price-original {
    font-size: 0.9rem;
    color: var(--ennu-rs-text-muted);
    text-decoration: line-through;
    font-weight: 400;
}

.ennu-rs-price-discounted {
    font-family: var(--ennu-rs-font-display);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--ennu-rs-gold-dark);
}

.ennu-rs-discount-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 6px;
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 600;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.ennu-rs-product-size {
    font-size: 0.75rem;
    color: var(--ennu-rs-text-muted);
}

/* Variation Selector */
.ennu-rs-variation-selector {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 12px;
    padding: 12px;
    background: var(--ennu-rs-bg-card);
    border: 1px solid var(--ennu-rs-border);
    border-radius: var(--ennu-rs-radius-sm);
}

.ennu-rs-variation-label {
    font-family: var(--ennu-rs-font-display);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ennu-rs-text-primary);
    margin: 0;
}

.ennu-rs-variation-select {
    width: 100%;
    padding: 10px 12px;
    background: var(--ennu-rs-white);
    border: 1px solid var(--ennu-rs-border);
    border-radius: var(--ennu-rs-radius-sm);
    font-family: inherit;
    font-size: 0.9375rem;
    color: var(--ennu-rs-text-primary);
    cursor: pointer;
    transition: all 0.2s ease;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234a5568' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

.ennu-rs-variation-select:hover {
    border-color: var(--ennu-rs-gold-dark);
}

.ennu-rs-variation-select:focus {
    outline: none;
    border-color: var(--ennu-rs-gold-dark);
    box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.1);
}

.ennu-rs-variation-select option:disabled {
    color: var(--ennu-rs-text-muted);
}

/* Product Actions Container (Quantity + Add to Cart) */
.ennu-rs-product-actions {
    display: flex;
    gap: 12px;
    margin-top: 12px;
    align-items: center;
}

/* Quantity Selector on Product Cards */
.ennu-rs-qty-selector {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--ennu-rs-white);
    border: 2px solid var(--ennu-rs-gold);
    border-radius: var(--ennu-rs-radius);
    overflow: hidden;
    flex-shrink: 0;
}

.ennu-rs-qty-selector .ennu-rs-qty-btn {
    width: 40px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(201, 169, 98, 0.1);
    border: none;
    cursor: pointer;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    transition: background var(--ennu-rs-duration), color var(--ennu-rs-duration);
}

.ennu-rs-qty-selector .ennu-rs-qty-btn:hover {
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-white);
}

.ennu-rs-qty-selector .ennu-rs-qty-btn:active {
    transform: scale(0.95);
}

.ennu-rs-qty-selector .ennu-rs-qty-input {
    width: 50px;
    min-width: 50px;
    height: 44px;
    text-align: center;
    border: none;
    border-left: 1px solid var(--ennu-rs-border);
    border-right: 1px solid var(--ennu-rs-border);
    background: var(--ennu-rs-white);
    color: var(--ennu-rs-navy);
    font-size: 0.9375rem;
    font-weight: 600;
    padding: 0 4px;
}

.ennu-rs-qty-selector .ennu-rs-qty-input::-webkit-outer-spin-button,
.ennu-rs-qty-selector .ennu-rs-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.ennu-rs-qty-selector .ennu-rs-qty-input:focus {
    outline: none;
    background: rgba(201, 169, 98, 0.05);
}

/* Add to Cart Button */
.ennu-rs-product-actions .ennu-rs-add-to-cart {
    margin-top: 0;
    flex: 1;
}

.ennu-rs-add-to-cart {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 14px 20px;
    margin-top: 12px;
    background: var(--ennu-rs-gold-gradient);
    border: none;
    border-radius: var(--ennu-rs-radius);
    font-family: inherit;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    cursor: pointer;
    transition: all var(--ennu-rs-duration-smooth);
    box-shadow: var(--ennu-rs-shadow-gold);
}

.ennu-rs-add-to-cart:hover {
    transform: translateY(-2px);
    box-shadow: var(--ennu-rs-shadow-gold-hover);
}

.ennu-rs-add-to-cart.added {
    background: var(--ennu-rs-success);
    color: var(--ennu-rs-white);
}

.ennu-rs-add-to-cart:disabled {
    background: var(--ennu-rs-text-placeholder);
    box-shadow: none;
    cursor: not-allowed;
    transform: none;
}

/* Out of Stock Badge */
.ennu-rs-out-of-stock {
    position: absolute;
    top: 12px;
    right: 12px;
    padding: 6px 12px;
    background: var(--ennu-rs-error);
    color: var(--ennu-rs-white);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: var(--ennu-rs-radius-full);
}

/* ==========================================================================
   Fulfillment Selection Cards
   ========================================================================== */
.ennu-rs-fulfillment-options {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
    margin-bottom: 32px;
}

.ennu-rs-fulfillment-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0;
    background: var(--ennu-rs-white);
    border: 3px solid var(--ennu-rs-border);
    border-radius: 0;
    cursor: pointer;
    transition: all var(--ennu-rs-duration-smooth);
    text-align: center;
}

.ennu-rs-fulfillment-card:hover {
    border-color: var(--ennu-rs-gold);
    box-shadow: var(--ennu-rs-shadow-gold);
}

.ennu-rs-fulfillment-card.selected {
    border-color: var(--ennu-rs-gold);
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.1) 0%, rgba(201, 169, 98, 0.05) 100%);
    box-shadow: var(--ennu-rs-shadow-gold);
}

.ennu-rs-fulfillment-card.selected::after {
    content: '';
    position: absolute;
    top: 16px;
    right: 16px;
    width: 28px;
    height: 28px;
    background: var(--ennu-rs-gold);
    border-radius: 50%;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231A2744' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 14px;
}

.ennu-rs-fulfillment-card input[type="radio"] {
    position: absolute;
    opacity: 0;
}

.ennu-rs-fulfillment-icon {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ennu-rs-cream);
    border-radius: 50%;
    margin-bottom: 16px;
}

.ennu-rs-fulfillment-icon svg {
    width: 32px;
    height: 32px;
    stroke: var(--ennu-rs-gold-dark);
}

.ennu-rs-fulfillment-title {
    font-family: var(--ennu-rs-font-display);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    margin-bottom: 8px;
}

.ennu-rs-fulfillment-subtitle {
    font-size: 0.9375rem;
    color: var(--ennu-rs-slate);
}

/* Pickup Location Selection */
.ennu-rs-pickup-locations {
    display: none;
    margin-top: 24px;
}

.ennu-rs-pickup-locations.visible {
    display: block;
}

.ennu-rs-location-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: var(--ennu-rs-cream);
    border: 2px solid var(--ennu-rs-border);
    border-left: 5px solid var(--ennu-rs-gold);
    border-radius: 0;
    margin-bottom: 12px;
    cursor: pointer;
    transition: all var(--ennu-rs-duration-smooth);
}

.ennu-rs-location-card:hover {
    border-color: var(--ennu-rs-gold);
}

.ennu-rs-location-card.selected {
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.1) 0%, rgba(201, 169, 98, 0.05) 100%);
    border-color: var(--ennu-rs-gold);
}

.ennu-rs-location-card input[type="radio"] {
    width: 20px;
    height: 20px;
    accent-color: var(--ennu-rs-gold);
}

.ennu-rs-location-info {
    flex: 1;
}

.ennu-rs-location-name {
    font-weight: 600;
    color: var(--ennu-rs-navy);
    margin-bottom: 4px;
}

.ennu-rs-location-address {
    font-size: 0.875rem;
    color: var(--ennu-rs-slate);
}

/* Shipping Form */
.ennu-rs-shipping-form {
    display: none;
    margin-top: 24px;
}

.ennu-rs-shipping-form.visible {
    display: block;
}

/* Section Cards (for combined step) */
.ennu-rs-section-card {
    background: var(--ennu-rs-white);
    border-radius: 0;
    padding: 24px;
    border: none;
}

.ennu-rs-section-title {
    font-family: var(--ennu-rs-font-display);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--ennu-rs-border);
}

/* Address Note (for peptides billing = shipping) */
.ennu-rs-address-note {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 18px;
    margin: 0 0 24px;
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.1) 0%, rgba(201, 169, 98, 0.05) 100%);
    border-left: 3px solid var(--ennu-rs-gold);
    border-radius: var(--ennu-rs-radius-md);
    font-size: 0.875rem;
    color: var(--ennu-rs-navy);
    line-height: 1.5;
}

.ennu-rs-address-note svg {
    flex-shrink: 0;
    color: var(--ennu-rs-gold);
    margin-top: 2px;
}

.ennu-rs-address-note-text {
    flex: 1;
}

.ennu-rs-address-note-text strong {
    display: block;
    margin-bottom: 4px;
    font-weight: 600;
    color: var(--ennu-rs-navy);
}

/* Warning variant - more prominent */
.ennu-rs-address-note--warning {
    background: linear-gradient(135deg, #FFF8E1 0%, #FFF3CD 100%);
    border-left: 4px solid #F59E0B;
    border: 1px solid rgba(245, 158, 11, 0.3);
    border-left-width: 4px;
}

.ennu-rs-address-note--warning svg {
    color: #D97706;
}

/* Info variant - informational, less alarming */
.ennu-rs-address-note--info {
    background: linear-gradient(135deg, #E8F4FD 0%, #DBEAFE 100%);
    border: 1px solid rgba(59, 130, 246, 0.3);
    border-left-width: 4px;
    border-left-color: var(--ennu-rs-gold);
}

.ennu-rs-address-note--info svg {
    color: var(--ennu-rs-gold-dark);
}

/* Section Description */
.ennu-rs-section-description {
    font-size: 0.9rem;
    color: var(--ennu-rs-text-muted);
    margin: -12px 0 20px;
    line-height: 1.5;
}

/* Field Hint */
.ennu-rs-field-hint {
    display: block;
    font-size: 0.8rem;
    color: var(--ennu-rs-text-muted);
    margin-top: 4px;
}

/* Logged In Banner */
.ennu-rs-logged-in-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    background: linear-gradient(135deg, rgba(34, 139, 34, 0.1) 0%, rgba(34, 139, 34, 0.05) 100%);
    border-left: 4px solid #228B22;
    border-radius: var(--ennu-rs-radius-md);
    color: var(--ennu-rs-navy);
    font-size: 1rem;
}

.ennu-rs-logged-in-banner svg {
    color: #228B22;
    flex-shrink: 0;
}

.ennu-rs-logged-in-banner strong {
    color: var(--ennu-rs-gold);
}

/* Inline Login Notice */
.ennu-rs-inline-login-notice {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 16px;
    margin-bottom: 20px;
    background: linear-gradient(135deg, rgba(66, 153, 225, 0.1) 0%, rgba(66, 153, 225, 0.05) 100%);
    border-left: 3px solid #4299E1;
    border-radius: var(--ennu-rs-radius-md);
    font-size: 0.9rem;
    color: var(--ennu-rs-navy);
    line-height: 1.5;
}

.ennu-rs-inline-login-notice svg {
    color: #4299E1;
    flex-shrink: 0;
    margin-top: 2px;
}

/* Inline Login Actions */
.ennu-rs-inline-login-actions {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-top: 16px;
}

.ennu-rs-inline-login-actions .ennu-rs-btn {
    min-width: 120px;
}

.ennu-rs-link {
    color: var(--ennu-rs-gold);
    font-size: 0.9rem;
    text-decoration: none;
    transition: color 0.2s ease;
}

.ennu-rs-link:hover {
    color: var(--ennu-rs-navy);
    text-decoration: underline;
}

/* ==========================================================================
   Login Options (Social + Magic Link + Password)
   ========================================================================== */

.ennu-rs-login-options-wrapper {
    padding: 0;
}

.ennu-rs-login-options-header {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 16px;
    margin-bottom: 16px;
    background: linear-gradient(135deg, rgba(66, 153, 225, 0.1) 0%, rgba(66, 153, 225, 0.05) 100%);
    border: 1px solid rgba(66, 153, 225, 0.2);
    border-radius: var(--ennu-rs-radius);
    font-size: 0.9rem;
    color: var(--ennu-rs-navy);
    line-height: 1.5;
    animation: slideInFade 0.3s var(--ennu-rs-ease) forwards;
}

.ennu-rs-login-options-header svg {
    color: #4299E1;
    flex-shrink: 0;
    margin-top: 2px;
}

.ennu-rs-login-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Social Button Base */
.ennu-rs-social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 12px 20px;
    border: 1px solid var(--ennu-rs-border-strong);
    border-radius: var(--ennu-rs-radius);
    background: var(--ennu-rs-white);
    font-family: var(--ennu-rs-font-body);
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--ennu-rs-navy);
    cursor: pointer;
    transition: all 0.2s var(--ennu-rs-ease);
}

.ennu-rs-social-btn:hover {
    border-color: var(--ennu-rs-gold);
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.05) 0%, rgba(201, 169, 98, 0.02) 100%);
    box-shadow: var(--ennu-rs-shadow-card);
}

.ennu-rs-social-btn:active {
    transform: scale(0.99);
}

.ennu-rs-social-btn svg {
    flex-shrink: 0;
}

/* Microsoft Button */
.ennu-rs-social-btn--microsoft:hover {
    border-color: #00A4EF;
    background: rgba(0, 164, 239, 0.05);
}

/* Google Button */
.ennu-rs-social-btn--google:hover {
    border-color: #4285F4;
    background: rgba(66, 133, 244, 0.05);
}

/* Magic Link Button */
.ennu-rs-social-btn--magic {
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.1) 0%, rgba(201, 169, 98, 0.05) 100%);
    border-color: rgba(201, 169, 98, 0.3);
}

.ennu-rs-social-btn--magic:hover {
    border-color: var(--ennu-rs-gold);
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.15) 0%, rgba(201, 169, 98, 0.08) 100%);
}

.ennu-rs-social-btn--magic svg {
    color: var(--ennu-rs-gold);
}

/* Password Button */
.ennu-rs-social-btn--password {
    background: transparent;
    border-style: dashed;
}

.ennu-rs-social-btn--password:hover {
    background: rgba(26, 39, 68, 0.03);
    border-color: var(--ennu-rs-navy-light);
}

.ennu-rs-social-btn--password svg {
    color: var(--ennu-rs-slate);
}

/* Login Divider */
.ennu-rs-login-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 8px 0;
    color: var(--ennu-rs-text-muted);
    font-size: 0.85rem;
}

.ennu-rs-login-divider::before,
.ennu-rs-login-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--ennu-rs-border);
}

/* Password Login Form */
#rs-password-login-form {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--ennu-rs-border);
    animation: slideInFade 0.25s var(--ennu-rs-ease) forwards;
}

.ennu-rs-password-login-actions {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-top: 16px;
}

.ennu-rs-password-login-actions .ennu-rs-btn {
    min-width: 120px;
}

/* Create Instead Link */
.ennu-rs-create-instead {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--ennu-rs-border);
    text-align: center;
}

/* Animation */
@keyframes slideInFade {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Single Shipping Rate (auto-selected) */
.ennu-rs-shipping-rate-single {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.1) 0%, rgba(201, 169, 98, 0.05) 100%);
    border: 2px solid var(--ennu-rs-gold);
    border-left: 5px solid var(--ennu-rs-gold);
    border-radius: 0;
}

.ennu-rs-shipping-rate-info {
    display: flex;
    align-items: center;
    gap: 16px;
}

.ennu-rs-shipping-rate-label {
    font-weight: 600;
    color: var(--ennu-rs-navy);
}

.ennu-rs-shipping-rate-cost {
    font-weight: 700;
    color: var(--ennu-rs-gold-dark);
}

.ennu-rs-shipping-rate-check {
    width: 24px;
    height: 24px;
    color: var(--ennu-rs-success);
}

/* Hide calculate button when rates auto-show */
#rs-calculate-shipping {
    display: none;
}

/* Aesthetic division shipping rate styling */
[data-division="aesthetic"] .ennu-rs-shipping-rate-single {
    background: linear-gradient(135deg, rgba(55, 65, 81, 0.1) 0%, rgba(55, 65, 81, 0.05) 100%);
    border-color: var(--ennu-rs-gold);
}

[data-division="aesthetic"] .ennu-rs-shipping-rate-cost {
    color: var(--ennu-rs-gold-dark);
}

/* ==========================================================================
   Form Styles
   ========================================================================== */
.ennu-rs-form {
    max-width: 600px;
    margin: 0 auto;
}

.ennu-rs-form-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-bottom: 20px;
}

@media (max-width: 560px) {
    .ennu-rs-form-row {
        grid-template-columns: 1fr;
    }
}

.ennu-rs-form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ennu-rs-form-group.full-width {
    grid-column: 1 / -1;
}

.ennu-rs-label {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
}

.ennu-rs-required {
    color: var(--ennu-rs-gold-dark);
}

.ennu-rs-input,
.ennu-rs-select {
    width: 100%;
    padding: 18px 20px;
    font-size: 1.0625rem;
    font-family: inherit;
    color: var(--ennu-rs-text);
    background: var(--ennu-rs-cream);
    border: 3px solid var(--ennu-rs-border);
    border-radius: 0;
    transition: all var(--ennu-rs-duration-smooth);
    outline: none;
}

.ennu-rs-input:hover:not(:focus),
.ennu-rs-select:hover:not(:focus) {
    border-color: var(--ennu-rs-border-strong);
}

.ennu-rs-input:focus,
.ennu-rs-select:focus {
    border-color: var(--ennu-rs-gold);
    background: var(--ennu-rs-white);
    box-shadow: var(--ennu-rs-shadow-focus);
}

.ennu-rs-input::placeholder {
    color: var(--ennu-rs-text-placeholder);
}

.ennu-rs-input[aria-invalid="true"] {
    border-color: var(--ennu-rs-error);
    background: var(--ennu-rs-error-light);
}

.ennu-rs-field-error {
    font-size: 0.875rem;
    color: var(--ennu-rs-error);
    display: none;
}

.ennu-rs-form-group.has-error .ennu-rs-field-error {
    display: block;
}

/* ==========================================================================
   Summary Card - Navy Header with Gold Accent
   ========================================================================== */
.ennu-rs-summary-card {
    background: var(--ennu-rs-cream);
    border-radius: 0;
    border: 2px solid var(--ennu-rs-border);
    overflow: hidden;
    margin-bottom: 28px;
}

.ennu-rs-summary-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    background: var(--ennu-rs-navy);
    color: var(--ennu-rs-white);
    position: relative;
}

.ennu-rs-summary-header::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--ennu-rs-gold-gradient);
}

.ennu-rs-summary-header h3 {
    margin: 0;
    font-family: var(--ennu-rs-font-display);
    font-size: 1.125rem;
    font-weight: 600;
    color: #FFFFFF;
}

.ennu-rs-summary-items {
    padding: 20px 24px;
}

.ennu-rs-summary-item {
    display: flex;
    justify-content: space-between;
    padding: 12px 0;
    border-bottom: 1px solid var(--ennu-rs-border);
}

.ennu-rs-summary-item:last-child {
    border-bottom: none;
}

.ennu-rs-summary-label {
    color: var(--ennu-rs-slate);
}

.ennu-rs-summary-value {
    font-weight: 600;
    color: var(--ennu-rs-navy);
}

.ennu-rs-summary-pricing {
    padding: 20px 24px;
    border-top: 1px solid var(--ennu-rs-border);
    background: var(--ennu-rs-white);
}

.ennu-rs-summary-row {
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
    font-size: 0.9375rem;
}

.ennu-rs-summary-row--discount {
    color: var(--ennu-rs-success);
}

.ennu-rs-summary-row--total {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--ennu-rs-navy);
    padding-top: 16px;
    margin-top: 8px;
    border-top: 2px dashed var(--ennu-rs-border);
}

.ennu-rs-summary-row--total span:last-child {
    color: var(--ennu-rs-gold-dark);
}

/* ==========================================================================
   Membership Upsell Section
   ========================================================================== */
.ennu-rs-membership-section {
    margin-bottom: 28px;
}

.ennu-rs-membership-existing {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    background: var(--ennu-rs-success-light);
    border-radius: 0;
    border: 2px solid var(--ennu-rs-success);
}

.ennu-rs-membership-existing-icon svg {
    stroke: var(--ennu-rs-success);
}

.ennu-rs-membership-status {
    font-weight: 600;
    color: var(--ennu-rs-success);
    display: block;
}

.ennu-rs-membership-discount {
    font-size: 0.875rem;
    color: var(--ennu-rs-text-secondary);
}

.ennu-rs-membership-addon {
    background: var(--ennu-rs-cream);
    border: 2px solid var(--ennu-rs-border);
    border-radius: 0;
    overflow: hidden;
}

.ennu-rs-membership-addon-header {
    padding: 12px 24px;
    background: linear-gradient(135deg, var(--ennu-rs-gold) 0%, var(--ennu-rs-gold-light) 100%);
}

.ennu-rs-membership-badge {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #ffffff;
}

.ennu-rs-membership-addon-content {
    padding: 24px;
}

.ennu-rs-membership-main {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
}

.ennu-rs-membership-title {
    font-family: var(--ennu-rs-font-display);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    margin: 0 0 8px;
}

.ennu-rs-membership-savings {
    font-size: 0.9375rem;
    color: var(--ennu-rs-success);
    font-weight: 500;
}

.ennu-rs-membership-action {
    display: flex;
    align-items: center;
    gap: 16px;
}

.ennu-rs-membership-price {
    font-family: var(--ennu-rs-font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ennu-rs-navy);
}

.ennu-rs-membership-period {
    font-size: 0.875rem;
    font-weight: 400;
    color: var(--ennu-rs-text-secondary);
}

/* Toggle Switch */
.ennu-rs-toggle {
    position: relative;
    display: inline-block;
    cursor: pointer;
}

.ennu-rs-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}

.ennu-rs-toggle-track {
    display: block;
    width: 56px;
    height: 30px;
    background: var(--ennu-rs-border);
    border-radius: var(--ennu-rs-radius-full);
    position: relative;
    transition: background 0.25s ease;
}

.ennu-rs-toggle-thumb {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 24px;
    height: 24px;
    background: var(--ennu-rs-white);
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
    transition: transform 0.25s ease;
}

.ennu-rs-toggle input:checked + .ennu-rs-toggle-track {
    background: var(--ennu-rs-gold);
}

.ennu-rs-toggle input:checked + .ennu-rs-toggle-track .ennu-rs-toggle-thumb {
    transform: translateX(26px);
}

.ennu-rs-toggle input:focus + .ennu-rs-toggle-track {
    box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.3);
}

/* Benefits List */
.ennu-rs-benefits-list {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
}

.ennu-rs-benefits-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 8px 0;
    font-size: 0.9375rem;
    color: var(--ennu-rs-text-secondary);
}

.ennu-rs-benefits-list svg {
    flex-shrink: 0;
    color: var(--ennu-rs-success);
    margin-top: 2px;
}

/* ==========================================================================
   GiftUp Gift Card Section (Collapsible)
   ========================================================================== */
.ennu-rs-giftup-wrapper {
    margin-bottom: 24px;
    border: none;
    border-radius: 0;
    overflow: hidden;
    background: var(--ennu-rs-white);
}

.ennu-rs-giftup-toggle {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 20px;
    background: var(--ennu-rs-cream);
    cursor: pointer;
    user-select: none;
    transition: background 0.2s ease;
}

.ennu-rs-giftup-toggle:hover {
    background: #f5f0e6;
}

.ennu-rs-giftup-toggle:focus {
    outline: 2px solid var(--ennu-rs-gold);
    outline-offset: -2px;
}

.ennu-rs-giftup-icon {
    font-size: 1.25rem;
}

.ennu-rs-giftup-toggle-text {
    font-weight: 500;
    color: var(--ennu-rs-navy);
}

.ennu-rs-giftup-badge {
    margin-left: auto;
    padding: 4px 12px;
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);
    border-radius: 12px;
    font-size: 0.85rem;
    font-weight: 600;
}

.ennu-rs-giftup-arrow {
    margin-left: 8px;
    font-size: 0.75rem;
    color: var(--ennu-rs-text-secondary);
    transition: transform 0.2s ease;
}

.ennu-rs-giftup-wrapper.expanded .ennu-rs-giftup-arrow {
    transform: rotate(90deg);
}

.ennu-rs-giftup-panel {
    padding: 20px;
    border-top: 1px solid var(--ennu-rs-border);
    background: var(--ennu-rs-white);
}

/* Code Entry Section */
.ennu-rs-giftup-code-section {
    margin-bottom: 16px;
}

.ennu-rs-giftup-label {
    display: block;
    margin-bottom: 8px;
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--ennu-rs-text-secondary);
}

.ennu-rs-giftup-code-row {
    display: flex;
    gap: 10px;
}

.ennu-rs-giftup-code-row input {
    flex: 1;
}

.ennu-rs-giftup-code-row button {
    flex-shrink: 0;
    min-width: 80px;
}

.ennu-rs-giftup-message {
    margin-top: 8px;
    font-size: 0.875rem;
    min-height: 20px;
}

.ennu-rs-giftup-message .ennu-rs-success {
    color: #059669;
}

.ennu-rs-giftup-message .ennu-rs-error {
    color: #dc2626;
}

.ennu-rs-giftup-message .ennu-rs-warning {
    color: #d97706;
}

/* Balance Panel */
.ennu-rs-giftup-balance-panel {
    padding-top: 16px;
    border-top: 1px dashed var(--ennu-rs-border);
}

.ennu-rs-giftup-balance-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    padding: 12px 16px;
    background: linear-gradient(135deg, #fef9e7 0%, #fdf3d1 100%);
    border-radius: var(--ennu-rs-radius);
}

.ennu-rs-giftup-balance-info span {
    color: var(--ennu-rs-text-secondary);
}

.ennu-rs-giftup-balance-info strong {
    font-size: 1.25rem;
    color: var(--ennu-rs-gold-dark);
}

/* Amount Selector */
.ennu-rs-giftup-amount-section {
    margin-top: 16px;
}

.ennu-rs-giftup-amount-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 8px;
}

.ennu-rs-giftup-slider {
    flex: 1;
    height: 6px;
    -webkit-appearance: none;
    appearance: none;
    background: var(--ennu-rs-border);
    border-radius: 3px;
    outline: none;
}

.ennu-rs-giftup-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    background: var(--ennu-rs-gold);
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid var(--ennu-rs-white);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
    transition: transform 0.15s ease;
}

.ennu-rs-giftup-slider::-webkit-slider-thumb:hover {
    transform: scale(1.1);
}

.ennu-rs-giftup-slider::-moz-range-thumb {
    width: 20px;
    height: 20px;
    background: var(--ennu-rs-gold);
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid var(--ennu-rs-white);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.ennu-rs-giftup-amount-input-wrapper {
    display: flex;
    align-items: center;
    gap: 4px;
}

.ennu-rs-giftup-currency {
    color: var(--ennu-rs-text-secondary);
    font-weight: 500;
}

.ennu-rs-giftup-amount-input {
    width: 70px !important;
    text-align: right;
    padding: 8px 10px !important;
}

/* Applied Row */
.ennu-rs-giftup-applied-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px dashed var(--ennu-rs-border);
}

.ennu-rs-giftup-applied-info {
    display: flex;
    align-items: center;
    gap: 8px;
}

.ennu-rs-giftup-applied-icon {
    color: #059669;
    font-weight: bold;
}

.ennu-rs-giftup-applied-info strong {
    color: #059669;
    font-size: 1.1rem;
}

/* Text/Link Button Styles */
.ennu-rs-btn--text {
    background: transparent;
    border: none;
    color: var(--ennu-rs-gold-dark);
    padding: 6px 12px;
    font-weight: 500;
    cursor: pointer;
    transition: color 0.2s ease;
}

.ennu-rs-btn--text:hover {
    color: var(--ennu-rs-gold);
    text-decoration: underline;
}

.ennu-rs-btn--danger {
    color: #dc2626;
}

.ennu-rs-btn--danger:hover {
    color: #b91c1c;
}

/* Mobile Responsive */
@media (max-width: 600px) {
    .ennu-rs-giftup-toggle {
        padding: 14px 16px;
    }
    
    .ennu-rs-giftup-panel {
        padding: 16px;
    }
    
    .ennu-rs-giftup-amount-row {
        flex-wrap: wrap;
    }
    
    .ennu-rs-giftup-slider {
        width: 100%;
        order: 1;
        margin-bottom: 8px;
    }
    
    .ennu-rs-giftup-amount-input-wrapper {
        order: 2;
    }
    
    .ennu-rs-giftup-amount-row button {
        order: 3;
        margin-left: auto;
    }
}

/* Legacy GiftUp Section (backward compatibility) */
.ennu-rs-giftup-section {
    margin-bottom: 28px;
    padding: 20px 24px;
    background: var(--ennu-rs-cream);
    border: 2px solid var(--ennu-rs-border);
    border-radius: 0;
}

.ennu-rs-giftup-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.ennu-rs-giftup-title {
    font-weight: 600;
    color: var(--ennu-rs-navy);
}

.ennu-rs-giftup-balance {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--ennu-rs-gold-dark);
}

.ennu-rs-giftup-apply {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ennu-rs-giftup-apply-label {
    color: var(--ennu-rs-text-secondary);
}

/* ==========================================================================
   Payment Section
   ========================================================================== */
.ennu-rs-payment {
    margin-bottom: 28px;
}

.ennu-rs-payment-title {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--ennu-rs-font-display);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    margin: 0 0 20px;
}

.ennu-rs-card-element {
    padding: 20px;
    background: var(--ennu-rs-white);
    border: 3px solid var(--ennu-rs-border);
    border-radius: 0;
    transition: all var(--ennu-rs-duration-smooth);
}

.ennu-rs-card-element:focus-within {
    border-color: var(--ennu-rs-gold);
    box-shadow: var(--ennu-rs-shadow-focus);
}

.ennu-rs-card-errors {
    font-size: 0.9375rem;
    color: var(--ennu-rs-error);
    margin-top: 10px;
    display: none;
}

.ennu-rs-card-errors.visible {
    display: block;
}

/* Authorize.Net Accept.js Fields */
.ennu-rs-authnet-fields {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.ennu-rs-authnet-fields .ennu-rs-form-group {
    margin-bottom: 0;
}

.ennu-rs-authnet-fields .ennu-rs-form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: var(--ennu-rs-text-primary);
    font-size: 0.9375rem;
}

.ennu-rs-authnet-fields .ennu-rs-input {
    width: 100%;
    padding: 16px 20px;
    font-size: 1rem;
    font-family: inherit;
    background: var(--ennu-rs-white);
    border: 2px solid var(--ennu-rs-border);
    border-radius: var(--ennu-rs-radius);
    transition: all var(--ennu-rs-duration-fast);
}

.ennu-rs-authnet-fields .ennu-rs-input:focus {
    outline: none;
    border-color: var(--ennu-rs-gold);
    box-shadow: var(--ennu-rs-shadow-focus);
}

.ennu-rs-authnet-fields .ennu-rs-input::placeholder {
    color: var(--ennu-rs-text-tertiary);
}

.ennu-rs-card-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.ennu-rs-form-group--half {
    flex: 1;
}

.ennu-rs-secure-notice {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
    padding: 16px 20px;
    background: var(--ennu-rs-success-light);
    border-radius: var(--ennu-rs-radius);
    font-size: 0.875rem;
    color: var(--ennu-rs-success);
}

/* ==========================================================================
   Navigation - Luxury Gold Buttons
   ========================================================================== */
.ennu-rs-navigation {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px 0;
    border-top: 1px solid var(--ennu-rs-border);
    background: var(--ennu-rs-cream);
}

.ennu-rs-nav-spacer {
    flex: 1;
}

/* Primary Button - Gold Gradient */
.ennu-rs-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 18px 36px;
    min-height: 56px;
    font-size: 1.0625rem;
    font-weight: 600;
    font-family: inherit;
    color: var(--ennu-rs-navy);
    background: var(--ennu-rs-gold-gradient);
    border: none;
    border-radius: 0;
    cursor: pointer;
    transition: all var(--ennu-rs-duration-smooth);
    text-decoration: none;
    line-height: 1.2;
    position: relative;
    overflow: hidden;
    box-shadow: var(--ennu-rs-shadow-gold);
}

.ennu-rs-btn:hover:not(:disabled) {
    transform: translateY(-4px) scale(1.02);
    box-shadow: var(--ennu-rs-shadow-gold-hover);
}

.ennu-rs-btn:focus {
    outline: none;
    box-shadow: var(--ennu-rs-shadow-gold), var(--ennu-rs-shadow-focus);
}

.ennu-rs-btn:disabled {
    background: var(--ennu-rs-text-placeholder);
    box-shadow: none;
    cursor: not-allowed;
    transform: none;
    opacity: 0.6;
    pointer-events: none;
}

/* Secondary/Ghost Button */
.ennu-rs-btn--secondary,
.ennu-rs-btn--ghost {
    background: var(--ennu-rs-white);
    border: 2px solid var(--ennu-rs-navy);
    color: var(--ennu-rs-navy);
    box-shadow: none;
}

.ennu-rs-btn--secondary:hover:not(:disabled),
.ennu-rs-btn--ghost:hover:not(:disabled) {
    background: var(--ennu-rs-navy);
    color: var(--ennu-rs-white);
    transform: none;
    box-shadow: none;
}

/* Submit Button - Full Width */
.ennu-rs-btn--submit {
    width: 100%;
    padding: 22px 40px;
    min-height: 64px;
    font-size: 1.25rem;
    border-radius: 0;
}

/* Loading State */
.ennu-rs-btn.loading {
    pointer-events: none;
    opacity: 0.7;
    cursor: wait;
}

.ennu-rs-btn .btn-loading {
    display: none;
}

.ennu-rs-btn.loading .btn-text {
    display: none;
}

.ennu-rs-btn.loading .btn-loading {
    display: flex;
    align-items: center;
    gap: 12px;
}

.ennu-rs-spinner {
    width: 22px;
    height: 22px;
    border: 3px solid rgba(26, 39, 68, 0.2);
    border-top-color: var(--ennu-rs-navy);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ==========================================================================
   Success Screen - Animated Checkmark + Confetti
   ========================================================================== */
.ennu-rs-success {
    text-align: center;
    padding: 56px 48px;
    position: relative;
}

.ennu-rs-success-animation {
    margin-bottom: 32px;
    position: relative;
}

.ennu-rs-success-circle {
    width: 120px;
    height: 120px;
    margin: 0 auto;
    position: relative;
}

.ennu-rs-success-check {
    width: 100%;
    height: 100%;
}

.ennu-rs-success-circle-bg {
    stroke: var(--ennu-rs-success);
    stroke-width: 3;
    fill: var(--ennu-rs-success);
    animation: successPop 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

.ennu-rs-success-check-path {
    stroke: var(--ennu-rs-white);
    stroke-width: 4;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 50;
    stroke-dashoffset: 50;
    animation: checkDraw 0.4s 0.4s ease-out forwards;
}

@keyframes successPop {
    0% { transform: scale(0); opacity: 0; }
    50% { transform: scale(1.1); }
    100% { transform: scale(1); opacity: 1; }
}

@keyframes checkDraw {
    to { stroke-dashoffset: 0; }
}

.ennu-rs-success-glow {
    position: absolute;
    inset: -30px;
    border-radius: 50%;
    background: radial-gradient(circle at center, rgba(46, 125, 90, 0.3) 0%, transparent 70%);
    animation: glowPulse 2s ease-in-out infinite;
    pointer-events: none;
}

@keyframes glowPulse {
    0%, 100% { transform: scale(1); opacity: 0.5; }
    50% { transform: scale(1.2); opacity: 0.8; }
}

.ennu-rs-success-title {
    font-family: var(--ennu-rs-font-display);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: 600;
    color: var(--ennu-rs-navy);
    margin: 0 0 16px;
}

.ennu-rs-success-message {
    font-size: 1.125rem;
    color: var(--ennu-rs-slate);
    margin-bottom: 40px;
    max-width: 450px;
    margin-left: auto;
    margin-right: auto;
}

.ennu-rs-success-details {
    background: var(--ennu-rs-cream);
    border-radius: 0;
    padding: 24px 28px;
    margin-bottom: 40px;
    max-width: 450px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
    border-left: 5px solid var(--ennu-rs-gold);
}

.ennu-rs-success-details .detail-row {
    display: flex;
    justify-content: space-between;
    padding: 12px 0;
    font-size: 1rem;
    border-bottom: 1px solid var(--ennu-rs-border);
}

.ennu-rs-success-details .detail-row:last-child {
    border-bottom: none;
}

.ennu-rs-success-details .detail-label {
    color: var(--ennu-rs-slate);
}

.ennu-rs-success-details .detail-value {
    font-weight: 600;
    color: var(--ennu-rs-navy);
}

.ennu-rs-success-actions {
    display: flex;
    gap: 20px;
    justify-content: center;
    flex-wrap: wrap;
}

/* Confetti Container */
.ennu-rs-confetti-container {
    position: fixed;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    z-index: 100;
}

.ennu-rs-confetti {
    position: absolute;
    width: 12px;
    height: 12px;
    opacity: 0;
}

.ennu-rs-confetti.animate {
    animation: confettiFall 3s ease-out forwards;
}

@keyframes confettiFall {
    0% { opacity: 1; transform: translateY(-100vh) rotate(0deg); }
    100% { opacity: 0; transform: translateY(100vh) rotate(720deg); }
}

/* ==========================================================================
   Loading & Empty States
   ========================================================================== */
.ennu-rs-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 56px;
    gap: 20px;
}

.ennu-rs-loading-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--ennu-rs-cream);
    border-top-color: var(--ennu-rs-gold);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

.ennu-rs-loading-text {
    font-size: 1rem;
    color: var(--ennu-rs-slate);
    animation: fadeInOut 2s ease-in-out infinite;
}

@keyframes fadeInOut {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 1; }
}

.ennu-rs-empty-state {
    padding: 56px 24px;
    text-align: center;
}

.ennu-rs-empty-state p {
    color: var(--ennu-rs-slate);
    margin-bottom: 20px;
}

/* ==========================================================================
   Messages & Toasts
   ========================================================================== */
.ennu-rs-message {
    padding: 18px 24px;
    border-radius: 0;
    margin-bottom: 24px;
    font-size: 1rem;
    display: flex;
    align-items: center;
    gap: 14px;
}

.ennu-rs-message--error {
    background: var(--ennu-rs-error-light);
    border: 1px solid var(--ennu-rs-error);
    color: var(--ennu-rs-error);
}

.ennu-rs-message--success {
    background: var(--ennu-rs-success-light);
    border: 1px solid var(--ennu-rs-success);
    color: var(--ennu-rs-success);
}

.ennu-rs-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    padding: 16px 24px;
    background: var(--ennu-rs-navy);
    color: var(--ennu-rs-white);
    border-radius: 0;
    box-shadow: none;
    z-index: 1000;
    transform: translateY(100px);
    opacity: 0;
    transition: all 0.3s var(--ennu-rs-ease-out);
}

.ennu-rs-toast.visible {
    transform: translateY(0);
    opacity: 1;
}

.ennu-rs-toast--success {
    background: var(--ennu-rs-success);
}

.ennu-rs-toast--error {
    background: var(--ennu-rs-error);
}

/* ==========================================================================
   Coupon Section
   ========================================================================== */
.ennu-rs-coupon-section {
    margin-bottom: 20px;
}

.ennu-rs-coupon-row {
    display: flex;
    gap: 12px;
}

.ennu-rs-coupon-input {
    flex: 1;
    padding: 14px 16px;
    font-size: 0.9375rem;
    font-family: inherit;
    color: var(--ennu-rs-text);
    background: var(--ennu-rs-white);
    border: 2px solid var(--ennu-rs-border);
    border-radius: var(--ennu-rs-radius);
    outline: none;
    transition: border-color var(--ennu-rs-duration);
}

.ennu-rs-coupon-input:focus {
    border-color: var(--ennu-rs-gold);
}

.ennu-rs-coupon-btn {
    padding: 14px 24px;
    background: var(--ennu-rs-navy);
    color: var(--ennu-rs-white);
    border: none;
    border-radius: var(--ennu-rs-radius);
    font-family: inherit;
    font-size: 0.9375rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--ennu-rs-duration);
}

.ennu-rs-coupon-btn:hover {
    background: var(--ennu-rs-navy-light);
}

.ennu-rs-coupon-applied {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: var(--ennu-rs-success-light);
    border-radius: var(--ennu-rs-radius);
    color: var(--ennu-rs-success);
    font-weight: 500;
}

.ennu-rs-coupon-remove {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--ennu-rs-error);
    cursor: pointer;
    font-size: 1.25rem;
}

/* Coupon section margins */
.ennu-rs-coupon-section {
    padding: 0 24px 20px;
}

/* ==========================================================================
   Editable Cart Summary (Step 2)
   ========================================================================== */
.ennu-rs-summary-item--editable {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 16px 0;
}

.ennu-rs-summary-item-info {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}

.ennu-rs-summary-item-name {
    font-weight: 500;
    color: var(--ennu-rs-navy);
    flex: 1;
    line-height: 1.4;
}

.ennu-rs-summary-item-price {
    font-weight: 600;
    color: var(--ennu-rs-navy);
    white-space: nowrap;
}

.ennu-rs-summary-item-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.ennu-rs-qty-control {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--ennu-rs-white);
    border: 2px solid var(--ennu-rs-border);
    border-radius: var(--ennu-rs-radius);
    overflow: hidden;
}

.ennu-rs-qty-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ennu-rs-cream);
    border: none;
    cursor: pointer;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    transition: background var(--ennu-rs-duration), color var(--ennu-rs-duration);
}

.ennu-rs-qty-btn:hover {
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);
}

.ennu-rs-qty-btn:active {
    transform: scale(0.95);
}

.ennu-rs-qty-value {
    min-width: 40px;
    text-align: center;
    font-weight: 600;
    font-size: 0.9375rem;
    color: var(--ennu-rs-navy);
}

.ennu-rs-remove-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(220, 53, 69, 0.1);
    border: 2px solid rgba(220, 53, 69, 0.3);
    border-radius: var(--ennu-rs-radius);
    cursor: pointer;
    color: #dc3545;
    transition: all var(--ennu-rs-duration);
}

.ennu-rs-remove-btn:hover {
    background: var(--ennu-rs-error);
    border-color: var(--ennu-rs-error);
    color: var(--ennu-rs-white);
}

.ennu-rs-remove-btn svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    flex-shrink: 0;
}

.ennu-rs-auto-badge {
    display: inline-block;
    padding: 2px 8px;
    background: var(--ennu-rs-info-light, #e3f2fd);
    color: var(--ennu-rs-info, #2196f3);
    font-size: 0.6875rem;
    font-weight: 600;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    margin-left: 8px;
    vertical-align: middle;
}

/* Required badge - red styling for needles/water */
.ennu-rs-auto-badge--required {
    background: #fee2e2;
    color: #dc2626;
}

/* Stack/Bundle badge for cart summary */
.ennu-rs-stack-badge {
    display: inline-block;
    padding: 2px 8px;
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-dark);
    font-size: 0.6875rem;
    font-weight: 700;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    margin-right: 8px;
    vertical-align: middle;
}

.ennu-rs-stack-badge--small {
    font-size: 0.625rem;
    padding: 1px 6px;
}

/* Bundle item in cart summary */
.ennu-rs-summary-item--bundle {
    background: rgba(212, 175, 55, 0.08);
    border-radius: 8px;
    padding: 12px !important;
    margin-bottom: 8px;
}

/* Bundled items list in Step 2 summary */
.ennu-rs-summary-bundled {
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.ennu-rs-summary-bundled-label {
    display: block;
    font-size: 0.75rem;
    color: #8B7355;
    font-weight: 600;
    margin-bottom: 6px;
}

.ennu-rs-summary-bundled-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px 12px;
}

.ennu-rs-summary-bundled-list li {
    font-size: 0.75rem;
    color: var(--ennu-rs-text-muted, #666);
    position: relative;
    padding-left: 12px;
}

.ennu-rs-summary-bundled-list li::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--ennu-rs-gold);
}

/* Bundled items list in payment step order summary */
.ennu-rs-order-bundled {
    padding: 6px 0 6px 16px;
    margin-bottom: 4px;
}

.ennu-rs-order-bundled-label {
    display: block;
    font-size: 0.6875rem;
    color: #8B7355;
    font-weight: 600;
    margin-bottom: 4px;
}

.ennu-rs-order-bundled-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ennu-rs-order-bundled-list li {
    font-size: 0.6875rem;
    color: var(--ennu-rs-text-muted, #666);
    padding: 1px 0 1px 10px;
    position: relative;
}

.ennu-rs-order-bundled-list li::before {
    content: '–';
    position: absolute;
    left: 0;
    color: var(--ennu-rs-gold);
}

/* Summary header - ensure white text */
.ennu-rs-summary-header h3 {
    color: #FFFFFF !important;
}

/* ==========================================================================
   Responsive - Mobile Optimized
   ========================================================================== */

/* Desktop: Sidebar as slide-in cart panel
   Hidden off-screen by default, slides in when .open is added */
@media (min-width: 1025px) {
    .ennu-rs-sidebar {
        position: fixed !important;
        top: 0;
        right: 0;
        bottom: 0;
        width: 340px;
        max-width: 100vw;
        z-index: 100006;
        transform: translateX(100%); /* Hidden off-screen to the right */
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: -4px 0 24px rgba(0, 0, 0, 0.15);
    }

    /* When opened - slide in from right */
    .ennu-rs-sidebar.open {
        transform: translateX(0); /* Slide into view */
    }

    /* Theme overlay (ennu-sidebar-overlay) must sit behind the open sidebar */
    #ennu-sidebar-overlay {
        z-index: 100004 !important;
    }

    .ennu-rs-sidebar .ennu-rs-sidebar-close {
        display: flex;
    }

    .ennu-rs-sidebar .ennu-rs-sidebar-toggle {
        display: none;
    }

    /* Smooth transitions for sidebar inner element */
    .ennu-rs-sidebar-inner {
        transition: top 0.15s ease-out, bottom 0.15s ease-out;
    }
}

@media (max-width: 1024px) {
    /* HIDE cart sidebar on tablet/mobile - use mobile cart footer instead */
    .ennu-rs-sidebar,
    .ennu-rs-sidebar.open,
    #rs-sidebar,
    #rs-sidebar.open {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
        pointer-events: none !important;
    }

    .ennu-rs-sidebar-inner {
        max-height: none; /* No height limit when not sticky */
    }

    /* Also hide sidebar overlay on mobile */
    .ennu-rs-sidebar-overlay,
    #rs-sidebar-overlay {
        display: none !important;
    }
}

@media (max-width: 768px) {
    .ennu-rs-wrapper {
        padding: 0;
        /* padding-top now handled by .ennu-rs-below-header */
        gap: 0;
        flex-direction: column;
    }
    
    /* HIDE cart sidebar on mobile - use inline cart summary instead */
    .ennu-rs-sidebar {
        display: none !important;
    }
    
    .ennu-rs-main {
        padding-bottom: 100px; /* Space for fixed navigation */
        width: 100%;
    }
    
    .ennu-rs-container {
        border-radius: 0;
        border-left: none;
        border-right: none;
        box-shadow: none;
    }
    
    .ennu-rs-header {
        padding: 16px;
        text-align: center;
    }
    
    .ennu-rs-header h1 {
        font-size: 1.25rem;
    }
    
    .ennu-rs-header p {
        font-size: 0.875rem;
    }
    
    .ennu-rs-progress {
        padding: 12px 0 8px 0;
    }
    
    .ennu-rs-step-content {
        padding: 0;
    }
    
    /* Fixed bottom navigation - ensure it's above all other elements including chat widgets */
    .ennu-rs-navigation {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: var(--ennu-rs-white);
        padding: 12px 16px;
        padding-bottom: max(16px, env(safe-area-inset-bottom));
        border-top: 1px solid var(--ennu-rs-border);
        box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.1);
        z-index: 99999; /* Below mobile menu (100000+) but above other content */
        display: flex;
        gap: 12px;
        pointer-events: auto;
    }
    
    .ennu-rs-navigation .ennu-rs-btn {
        pointer-events: auto;
        cursor: pointer;
        position: relative;
        z-index: 1;
    }
    
    /* Hide navigation when mobile cart footer is shown (step 1) */
    .ennu-rs-navigation.hidden-mobile {
        display: none !important;
    }
    
    .ennu-rs-navigation .ennu-rs-btn {
        flex: 1;
        padding: 14px 20px;
        font-size: 1rem;
        min-height: 48px; /* Minimum touch target size (WCAG) */
        /* Ensure touch targets are responsive */
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1);
        touch-action: manipulation;
        /* Prevent accidental text selection */
        -webkit-user-select: none;
        user-select: none;
    }
    
    /* Ensure navigation container doesn't have hidden overflow that clips buttons */
    .ennu-rs-navigation {
        overflow: visible !important;
    }
    
    /* Add padding at bottom of content to prevent overlap with fixed navigation/cart footer */
    .ennu-rs-main {
        padding-bottom: 120px; /* Account for navigation bar + safe area */
    }
    
    /* Extra bottom padding on step content to ensure buttons are visible */
    .ennu-rs-step {
        padding-bottom: 24px;
    }
    
    /* Hide spacer on mobile */
    .ennu-rs-nav-spacer {
        display: none;
    }
    
    /* Product cards - single column on small screens */
    .ennu-rs-card-grid--products {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    
    .ennu-rs-product-card {
        padding: 0;
        flex-direction: column;
    }
    
    /* Mobile: Full HD images, no cropping */
    .ennu-rs-product-image {
        aspect-ratio: 1 / 1;
        width: 100%;
        max-height: 300px;
        background: var(--ennu-rs-cream);
    }
    
    .ennu-rs-product-image img {
        object-fit: contain;
        object-position: center;
    }
    
    .ennu-rs-product-content {
        padding: 16px;
    }
    
    /* More description text on mobile */
    .ennu-rs-product-description {
        -webkit-line-clamp: 4;
    }
    
    /* Specs on mobile - keep on same row */
    .ennu-rs-product-specs {
        flex-direction: row;
        gap: 8px;
    }
    
    .ennu-rs-spec {
        font-size: 0.7rem;
        padding: 3px 8px;
    }
    
    /* Cart summary section (inline, not floating) */
    #rs-cart-summary {
        margin: 16px 0;
        border-radius: 12px;
    }
    
    .ennu-rs-summary-header {
        padding: 16px;
        font-size: 1rem;
    }
    
    .ennu-rs-summary-items {
        padding: 0 16px 16px;
    }
    
    .ennu-rs-summary-item {
        padding: 12px 0;
        font-size: 0.9375rem;
    }
    
    /* Fulfillment options */
    .ennu-rs-fulfillment-options {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    .ennu-rs-fulfillment-card {
        padding: 20px 16px;
    }
    
    /* Shipping form */
    #rs-shipping-address-form {
        padding: 16px;
    }
    
    .ennu-rs-form-group {
        margin-bottom: 16px;
    }
    
    .ennu-rs-input {
        padding: 14px 16px;
        font-size: 16px; /* Prevent iOS zoom */
    }
    
    /* Customer info form */
    #rs-customer-form {
        padding: 16px;
    }
    
    /* Payment section */
    #rs-payment-section {
        padding: 16px;
    }
    
    .ennu-rs-membership-offer {
        padding: 16px;
        margin-bottom: 16px;
    }
    
    /* Totals displayed inline */
    .ennu-rs-order-totals {
        background: var(--ennu-rs-cream);
        border-radius: 12px;
        padding: 16px;
        margin: 16px 0;
    }
    
    .ennu-rs-totals-row {
        padding: 8px 0;
        font-size: 0.9375rem;
    }
    
    .ennu-rs-totals-row--total {
        font-size: 1.125rem;
        padding-top: 12px;
        margin-top: 8px;
        border-top: 2px solid var(--ennu-rs-border);
    }
}

@media (max-width: 480px) {
    .ennu-rs-header h1 {
        font-size: 1.125rem;
    }
    
    .ennu-rs-step-indicator {
        gap: 4px;
    }
    
    .ennu-rs-step-number {
        width: 32px;
        height: 32px;
        font-size: 0.75rem;
    }
    
    .ennu-rs-step-label {
        font-size: 0.625rem;
        left: 16px;
    }
    
    .ennu-rs-navigation .ennu-rs-btn {
        padding: 12px 16px;
        font-size: 0.9375rem;
    }
    
    /* Editable cart summary - smaller controls */
    .ennu-rs-qty-btn {
        width: 32px;
        height: 32px;
    }
    
    .ennu-rs-qty-value {
        min-width: 32px;
    }
    
    .ennu-rs-remove-btn {
        width: 32px;
        height: 32px;
    }
    
    /* Coupon section mobile */
    .ennu-rs-coupon-section {
        padding: 0 16px 16px;
    }

    .ennu-rs-coupon-row {
        flex-direction: column;
        align-items: stretch; /* Make button full width */
    }

    .ennu-rs-coupon-btn {
        width: 100%; /* Full width button on mobile for easier tapping */
    }
    
    .ennu-rs-coupon-btn {
        width: 100%;
    }
    
    /* Push all chat widgets up on mobile to avoid overlapping navigation */
    /* Navigation bar is ~100px tall on mobile, add extra margin for safety */
    #intercom-container,
    .intercom-lightweight-app,
    .intercom-launcher,
    .intercom-launcher-frame,
    .intercom-messenger-frame,
    .intercom-namespace,
    .intercom-app,
    .intercom-launcher-button,
    iframe[name="intercom-launcher-frame"],
    iframe[name="intercom-messenger-frame"],
    div[class*="intercom"],
    /* Drift */
    #drift-frame-controller,
    #drift-frame-chat,
    /* Crisp */
    .crisp-client,
    /* Zendesk */
    iframe#launcher,
    /* LiveChat */
    #chat-widget-container,
    /* Tidio */
    #tidio-chat,
    /* Freshdesk */
    #freshworks-widget,
    /* HubSpot */
    #hubspot-messages-iframe-container {
        bottom: 120px !important; /* Increased from 100px for more clearance */
        transform: translateY(0) !important; /* Override any transform that might reset position */
    }
    
    /* Ensure Intercom is pushed up even when launcher is at a fixed position */
    .intercom-lightweight-app-launcher,
    .intercom-launcher-badge-frame {
        bottom: 120px !important;
    }
}

/* ==========================================================================
   Mobile Cart Footer
   ========================================================================== */
.ennu-rs-mobile-cart-footer {
    display: none;
}

@media (max-width: 1024px) {
    /* Toast positioning above mobile footer */
    .ennu-rs-toast {
        bottom: 100px; /* Position above mobile cart footer */
        right: 16px;
        left: 16px;
        text-align: center;
    }
    
    /* Mobile Cart Footer Bar - shown only on step 1 (JS controls visibility) */
    .ennu-rs-mobile-cart-footer {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: var(--ennu-rs-navy);
        padding: 12px 16px;
        padding-bottom: max(12px, env(safe-area-inset-bottom));
        z-index: 10000; /* Above navigation */
        box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.15);
        align-items: center;
        justify-content: space-between;
        gap: 12px;
    }
    
    .ennu-rs-mobile-cart-info {
        display: flex;
        align-items: center;
        gap: 8px;
        cursor: pointer;
    }
    
    .ennu-rs-mobile-cart-toggle {
        display: flex;
        align-items: center;
        gap: 8px;
        color: var(--ennu-rs-white);
        background: transparent;
        border: none;
        cursor: pointer;
        font-size: 1rem;
        font-weight: 600;
        padding: 8px 0;
    }
    
    .ennu-rs-mobile-cart-toggle svg {
        width: 24px;
        height: 24px;
    }
    
    .ennu-rs-mobile-cart-count {
        background: var(--ennu-rs-gold);
        color: var(--ennu-rs-navy);
        font-size: 0.75rem;
        font-weight: 700;
        width: 22px;
        height: 22px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .ennu-rs-mobile-cart-total {
        color: var(--ennu-rs-gold);
        font-size: 1.125rem;
        font-weight: 700;
    }
    
    .ennu-rs-mobile-cart-btn {
        background: var(--ennu-rs-gold-gradient);
        color: var(--ennu-rs-navy);
        border: none;
        border-radius: 0;
        padding: 14px 24px;
        font-size: 1rem;
        font-weight: 600;
        cursor: pointer;
        transition: all 0.2s ease;
        box-shadow: var(--ennu-rs-shadow-gold);
        flex: 1;
    }
    
    .ennu-rs-mobile-cart-btn:disabled {
        background: var(--ennu-rs-text-placeholder);
        box-shadow: none;
        cursor: not-allowed;
    }
    
    /* Mobile Cart Panel (slides up) */
    .ennu-rs-mobile-cart-panel {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: var(--ennu-rs-white);
        border-radius: 20px 20px 0 0;
        box-shadow: 0 -8px 40px rgba(0, 0, 0, 0.2);
        z-index: 1001;
        transform: translateY(100%);
        transition: transform 0.3s var(--ennu-rs-ease-out);
        max-height: 70vh;
        overflow: hidden;
        display: flex;
        flex-direction: column;
    }
    
    .ennu-rs-mobile-cart-panel.open {
        transform: translateY(0);
    }
    
    .ennu-rs-mobile-cart-panel-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 16px 20px;
        border-bottom: 1px solid var(--ennu-rs-border);
        background: var(--ennu-rs-navy);
        color: var(--ennu-rs-white);
    }
    
    .ennu-rs-mobile-cart-panel-header h3 {
        margin: 0;
        font-size: 1.125rem;
        color: var(--ennu-rs-white);
    }
    
    .ennu-rs-mobile-cart-panel-close {
        background: transparent;
        border: none;
        color: var(--ennu-rs-white);
        cursor: pointer;
        padding: 8px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .ennu-rs-mobile-cart-panel-close svg {
        width: 24px;
        height: 24px;
    }
    
    .ennu-rs-mobile-cart-panel-items {
        flex: 1;
        overflow-y: auto;
        padding: 16px;
    }
    
    .ennu-rs-mobile-cart-panel-footer {
        padding: 16px 20px;
        border-top: 1px solid var(--ennu-rs-border);
        background: var(--ennu-rs-cream);
    }
    
    .ennu-rs-mobile-cart-panel-totals {
        display: flex;
        flex-direction: column;
        gap: 6px;
        margin-bottom: 12px;
        font-size: 1rem;
    }
    
    .ennu-rs-mobile-subtotal-row,
    .ennu-rs-mobile-discount-row,
    .ennu-rs-mobile-total-row {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    
    .ennu-rs-mobile-discount-row {
        color: var(--ennu-rs-success);
        font-size: 0.9rem;
    }
    
    .ennu-rs-mobile-discount-row span:last-child {
        font-weight: 600;
    }
    
    .ennu-rs-mobile-total-row {
        padding-top: 8px;
        border-top: 1px solid var(--ennu-rs-border);
        font-size: 1.125rem;
        font-weight: 600;
    }
    
    .ennu-rs-mobile-cart-panel-totals .total-amount {
        color: var(--ennu-rs-gold-dark);
    }
    
    .ennu-rs-mobile-cart-panel-checkout {
        width: 100%;
        background: var(--ennu-rs-navy);
        color: var(--ennu-rs-white);
        border: none;
        border-radius: var(--ennu-rs-radius-md);
        padding: 14px 20px;
        font-size: 1rem;
        font-weight: 600;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
    }
    
    /* Cart panel overlay */
    .ennu-rs-mobile-cart-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 1000;
        opacity: 0;
        visibility: hidden;
        pointer-events: none; /* Prevent blocking clicks when hidden */
        transition: all 0.3s ease;
    }
    
    .ennu-rs-mobile-cart-overlay.open {
        pointer-events: auto; /* Allow clicks only when open */
    }
    
    .ennu-rs-mobile-cart-overlay.open {
        opacity: 1;
        visibility: visible;
    }
    
    /* Add padding at bottom of main content to prevent overlap with footer */
    #ennu-retail-shop {
        padding-bottom: 80px;
    }
    
    /* Hide desktop sidebar on mobile */
    .ennu-rs-sidebar {
        display: none;
    }
}

/* ==========================================================================
   Hero Banner (Peptides Division)
   ========================================================================== */
.ennu-rs-hero {
    padding: 32px 0;
    background: linear-gradient(135deg, var(--ennu-rs-navy) 0%, #2a3f5f 100%);
    border-radius: 0;
    margin: 0;
    text-align: center;
}

.ennu-rs-hero-content {
    max-width: 600px;
    margin: 0 auto;
}

.ennu-rs-hero-title {
    font-family: var(--ennu-rs-font-display);
    font-size: 1.75rem;
    font-weight: 700;
    color: #FFFFFF !important;
    margin: 0 0 8px;
}

.ennu-rs-hero-subtitle {
    font-size: 1rem;
    color: var(--ennu-rs-gold);
    margin: 0;
    font-weight: 400;
}

@media (max-width: 768px) {
    .ennu-rs-hero {
        padding: 24px 16px;
        margin: 0;
    }
    
    .ennu-rs-hero-title {
        font-size: 1.5rem;
    }
    
    .ennu-rs-hero-subtitle {
        font-size: 0.875rem;
    }
}

/* ==========================================================================
   Flush Edge-to-Edge Layout (Peptides/Full Width Mode)
   ========================================================================== */

/* Hero - flush to edges */
.ennu-rs[data-division="peptides"] .ennu-rs-hero {
    margin-left: 0;
    margin-right: 0;
    border-radius: 0;
}

/* Progress bar - flush to edges */
.ennu-rs[data-division="peptides"] .ennu-rs-progress {
    margin-left: 0;
    margin-right: 0;
}

/* Header - flush to edges */
.ennu-peptides-header {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    border-radius: 0;
}

@media (max-width: 768px) {
    .ennu-rs[data-division="peptides"] .ennu-rs-hero {
        margin-left: 0;
        margin-right: 0;
        border-radius: 0;
    }
    
    .ennu-rs[data-division="peptides"] .ennu-rs-progress {
        margin-left: 0;
        margin-right: 0;
    }
}

/* ==========================================================================
   Affiliate Banner
   ========================================================================== */
.ennu-rs-affiliate-banner {
    padding: 16px 24px;
    background: linear-gradient(135deg, var(--ennu-rs-gold-light) 0%, var(--ennu-rs-gold) 100%);
    border-radius: 0;
    margin: 0 0 24px;
}

.ennu-rs-affiliate-banner__content {
    display: flex;
    align-items: center;
    gap: 12px;
}

.ennu-rs-affiliate-banner__icon {
    font-size: 1.5rem;
}

.ennu-rs-affiliate-banner__text strong {
    display: block;
    color: var(--ennu-rs-navy);
    font-size: 1rem;
}

.ennu-rs-affiliate-banner__text span {
    color: var(--ennu-rs-charcoal);
    font-size: 0.875rem;
}

@media (max-width: 768px) {
    .ennu-rs-affiliate-banner {
        margin: 0 0 16px;
    }
}

/* ==========================================================================
   Dark Mode Support
   ========================================================================== */
@media (prefers-color-scheme: dark) {
    .ennu-rs.ennu-rs--auto-theme,
    .ennu-rs.ennu-rs--dark {
        --ennu-rs-cream: #1a1f2e;
        --ennu-rs-white: #0d1117;
        --ennu-rs-charcoal: #c9d1d9;
        --ennu-rs-slate: #8b949e;
        --ennu-rs-text: #e6edf3;
        --ennu-rs-text-secondary: #c9d1d9;
        --ennu-rs-text-muted: #8b949e;
        --ennu-rs-text-placeholder: #6e7681;
        --ennu-rs-border: rgba(201, 169, 98, 0.15);
        --ennu-rs-border-strong: rgba(201, 169, 98, 0.3);
        --ennu-rs-shadow-card: 0 4px 16px rgba(0, 0, 0, 0.3);
        --ennu-rs-shadow-elevated: 0 8px 32px rgba(0, 0, 0, 0.4);
        --ennu-rs-success-light: rgba(46, 125, 90, 0.15);
        --ennu-rs-error-light: rgba(184, 80, 90, 0.15);
        --ennu-rs-warning-light: rgba(201, 150, 47, 0.15);
        --ennu-rs-info-light: rgba(74, 123, 167, 0.15);
    }

    .ennu-rs.ennu-rs--auto-theme,
    .ennu-rs.ennu-rs--dark {
        background: linear-gradient(180deg, #0d1117 0%, #161b22 100%);
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-container,
    .ennu-rs.ennu-rs--dark .ennu-rs-container,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-sidebar-inner,
    .ennu-rs.ennu-rs--dark .ennu-rs-sidebar-inner {
        background: #161b22;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-header,
    .ennu-rs.ennu-rs--dark .ennu-rs-header {
        background: linear-gradient(180deg, #1a1f2e 0%, #161b22 100%);
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-product-card,
    .ennu-rs.ennu-rs--dark .ennu-rs-product-card,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-fulfillment-card,
    .ennu-rs.ennu-rs--dark .ennu-rs-fulfillment-card,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-location-card,
    .ennu-rs.ennu-rs--dark .ennu-rs-location-card {
        background: #21262d;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-product-name,
    .ennu-rs.ennu-rs--dark .ennu-rs-product-name {
        color: #e6edf3;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-product-description,
    .ennu-rs.ennu-rs--dark .ennu-rs-product-description {
        color: #8b949e;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-input,
    .ennu-rs.ennu-rs--dark .ennu-rs-input,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-select,
    .ennu-rs.ennu-rs--dark .ennu-rs-select,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-coupon-input,
    .ennu-rs.ennu-rs--dark .ennu-rs-coupon-input,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-search-input,
    .ennu-rs.ennu-rs--dark .ennu-rs-search-input {
        background: #21262d;
        color: #e6edf3;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-input:focus,
    .ennu-rs.ennu-rs--dark .ennu-rs-input:focus,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-select:focus,
    .ennu-rs.ennu-rs--dark .ennu-rs-select:focus {
        background: #0d1117;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-category-btn,
    .ennu-rs.ennu-rs--dark .ennu-rs-category-btn {
        background: #21262d;
        color: #c9d1d9;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-category-btn.active,
    .ennu-rs.ennu-rs--dark .ennu-rs-category-btn.active {
        background: var(--ennu-rs-gold);
        color: var(--ennu-rs-navy);
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-summary-card,
    .ennu-rs.ennu-rs--dark .ennu-rs-summary-card,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-membership-addon,
    .ennu-rs.ennu-rs--dark .ennu-rs-membership-addon,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-giftup-section,
    .ennu-rs.ennu-rs--dark .ennu-rs-giftup-section {
        background: #21262d;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-summary-pricing,
    .ennu-rs.ennu-rs--dark .ennu-rs-summary-pricing {
        background: #161b22;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-cart-totals,
    .ennu-rs.ennu-rs--dark .ennu-rs-cart-totals,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-progress,
    .ennu-rs.ennu-rs--dark .ennu-rs-progress,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-navigation,
    .ennu-rs.ennu-rs--dark .ennu-rs-navigation {
        background: #1a1f2e;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-card-element,
    .ennu-rs.ennu-rs--dark .ennu-rs-card-element {
        background: #21262d;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-success-details,
    .ennu-rs.ennu-rs--dark .ennu-rs-success-details {
        background: #21262d;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-btn--secondary,
    .ennu-rs.ennu-rs--dark .ennu-rs-btn--secondary,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-btn--ghost,
    .ennu-rs.ennu-rs--dark .ennu-rs-btn--ghost {
        background: #21262d;
        border-color: #30363d;
        color: #e6edf3;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-btn--secondary:hover,
    .ennu-rs.ennu-rs--dark .ennu-rs-btn--secondary:hover,
    .ennu-rs.ennu-rs--auto-theme .ennu-rs-btn--ghost:hover,
    .ennu-rs.ennu-rs--dark .ennu-rs-btn--ghost:hover {
        background: #30363d;
    }

    .ennu-rs.ennu-rs--auto-theme .ennu-rs-qty-btn,
    .ennu-rs.ennu-rs--dark .ennu-rs-qty-btn {
        background: #30363d;
        color: #e6edf3;
    }
}

/* Manual dark mode toggle class */
.ennu-rs.ennu-rs--dark {
    --ennu-rs-cream: #1a1f2e;
    --ennu-rs-white: #0d1117;
    --ennu-rs-charcoal: #c9d1d9;
    --ennu-rs-slate: #8b949e;
    --ennu-rs-text: #e6edf3;
    --ennu-rs-text-secondary: #c9d1d9;
    --ennu-rs-text-muted: #8b949e;
}

/* ==========================================================================
   Reduced Motion - Accessibility
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
    .ennu-rs *,
    .ennu-rs *::before,
    .ennu-rs *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }

    .ennu-rs-progress-fill {
        transition: none;
    }

    .ennu-rs-product-card:hover {
        transform: none;
    }

    .ennu-rs-product-card:hover .ennu-rs-product-image img {
        transform: none;
    }

    .ennu-rs-btn:hover:not(:disabled) {
        transform: none;
    }

    .ennu-rs-add-to-cart:hover {
        transform: none;
    }

    .ennu-rs-step {
        animation: none;
    }

    .ennu-rs-confetti {
        display: none;
    }

    .ennu-rs-success-circle-bg,
    .ennu-rs-success-check-path,
    .ennu-rs-success-glow {
        animation: none;
    }

    .ennu-rs-success-circle-bg {
        opacity: 1;
        transform: scale(1);
    }

    .ennu-rs-success-check-path {
        stroke-dashoffset: 0;
    }
}

/* ==========================================================================
   RTL (Right-to-Left) Support
   ========================================================================== */
[dir="rtl"] .ennu-rs,
.ennu-rs[dir="rtl"] {
    direction: rtl;
    text-align: right;
}

[dir="rtl"] .ennu-rs-wrapper,
.ennu-rs[dir="rtl"] .ennu-rs-wrapper {
    flex-direction: row-reverse;
}

[dir="rtl"] .ennu-rs-product-card,
.ennu-rs[dir="rtl"] .ennu-rs-product-card {
    border-left: 2px solid var(--ennu-rs-border);
    border-right: 5px solid var(--ennu-rs-gold);
}

[dir="rtl"] .ennu-rs-location-card,
.ennu-rs[dir="rtl"] .ennu-rs-location-card {
    border-left: 2px solid var(--ennu-rs-border);
    border-right: 5px solid var(--ennu-rs-gold);
}

[dir="rtl"] .ennu-rs-success-details,
.ennu-rs[dir="rtl"] .ennu-rs-success-details {
    border-left: none;
    border-right: 5px solid var(--ennu-rs-gold);
}

[dir="rtl"] .ennu-rs-cart-item-remove,
.ennu-rs[dir="rtl"] .ennu-rs-cart-item-remove {
    margin-left: 0;
    margin-right: auto;
}

[dir="rtl"] .ennu-rs-coupon-remove,
.ennu-rs[dir="rtl"] .ennu-rs-coupon-remove {
    margin-left: 0;
    margin-right: auto;
}

[dir="rtl"] .ennu-rs-search-icon,
.ennu-rs[dir="rtl"] .ennu-rs-search-icon {
    left: auto;
    right: 20px;
}

[dir="rtl"] .ennu-rs-search-input,
.ennu-rs[dir="rtl"] .ennu-rs-search-input {
    padding-left: 20px;
    padding-right: 52px;
}

[dir="rtl"] .ennu-rs-fulfillment-card.selected::after,
.ennu-rs[dir="rtl"] .ennu-rs-fulfillment-card.selected::after {
    left: 16px;
    right: auto;
}

[dir="rtl"] .ennu-rs-step-indicator:not(:last-child)::after,
.ennu-rs[dir="rtl"] .ennu-rs-step-indicator:not(:last-child)::after {
    transform: scaleX(-1);
}

[dir="rtl"] .ennu-rs-navigation,
.ennu-rs[dir="rtl"] .ennu-rs-navigation {
    flex-direction: row-reverse;
}

/* RTL animations */
@keyframes stepSlideInRTL {
    from {
        opacity: 0;
        transform: translateX(-60px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes stepSlideInReverseRTL {
    from {
        opacity: 0;
        transform: translateX(60px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

[dir="rtl"] .ennu-rs-step,
.ennu-rs[dir="rtl"] .ennu-rs-step {
    animation-name: stepSlideInRTL;
}

/* ==========================================================================
   High Contrast Mode Support
   ========================================================================== */
@media (prefers-contrast: high) {
    .ennu-rs {
        --ennu-rs-border: rgba(0, 0, 0, 0.5);
        --ennu-rs-border-strong: rgba(0, 0, 0, 0.8);
    }

    .ennu-rs-product-card,
    .ennu-rs-fulfillment-card,
    .ennu-rs-location-card,
    .ennu-rs-summary-card,
    .ennu-rs-input,
    .ennu-rs-select,
    .ennu-rs-btn {
        border-width: 3px;
    }

    .ennu-rs-btn:focus,
    .ennu-rs-input:focus,
    .ennu-rs-select:focus {
        outline: 4px solid #000;
        outline-offset: 2px;
    }

    .ennu-rs-progress-fill {
        background: #000;
    }

    .ennu-rs-step-indicator.active .ennu-rs-step-number {
        background: #000;
        color: #fff;
    }
}

/* ==========================================================================
   Print Styles
   ========================================================================== */
@media print {
    .ennu-rs-sidebar,
    .ennu-rs-navigation,
    .ennu-rs-progress,
    .ennu-rs-category-filter,
    .ennu-rs-tools-row,
    .ennu-rs-add-to-cart,
    .ennu-rs-btn,
    .ennu-rs-toast,
    .ennu-rs-confetti-container {
        display: none !important;
    }

    .ennu-rs {
        background: #fff !important;
    }

    .ennu-rs-container {
        box-shadow: none;
        border: 1px solid #ccc;
    }

    .ennu-rs-product-card {
        page-break-inside: avoid;
    }

    .ennu-rs-success-details {
        border: 2px solid #000;
    }
}


/* ==========================================================================
   Screen Reader Only (Utility)
   ========================================================================== */
.ennu-rs .sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* ==========================================================================
   Offline Banner
   ========================================================================== */
.ennu-rs-offline-banner {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    padding: 12px 20px;
    background: var(--ennu-rs-warning);
    color: var(--ennu-rs-navy);
    text-align: center;
    font-weight: 600;
    z-index: 9999;
    animation: slideDown 0.3s ease-out;
}

.ennu-rs-offline-banner.visible {
    display: block;
}

@keyframes slideDown {
    from {
        transform: translateY(-100%);
    }
    to {
        transform: translateY(0);
    }
}

/* ==========================================================================
   Division Mode: Hide Images in Aesthetic/Medical Modes
   ========================================================================== */

/* Hide product images in aesthetic and medical division modes */
.ennu-rs[data-division="aesthetic"] .ennu-rs-product-image,
.ennu-rs[data-division="medical"] .ennu-rs-product-image {
    display: none !important;
}

/* Hide cart item images in aesthetic and medical division modes */
.ennu-rs[data-division="aesthetic"] .ennu-rs-cart-item-image,
.ennu-rs[data-division="medical"] .ennu-rs-cart-item-image {
    display: none !important;
}

/* Adjust product card layout when images are hidden */
.ennu-rs[data-division="aesthetic"] .ennu-rs-product-card,
.ennu-rs[data-division="medical"] .ennu-rs-product-card {
    min-height: auto;
}

/* Adjust cart item layout when images are hidden */
.ennu-rs[data-division="aesthetic"] .ennu-rs-cart-item,
.ennu-rs[data-division="medical"] .ennu-rs-cart-item {
    gap: 0;
}

/* ==========================================================================
   Member Savings Badge
   ========================================================================== */
.ennu-rs-member-savings {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--ennu-rs-success);
    background: var(--ennu-rs-success-light);
    padding: 4px 8px;
    border-radius: var(--ennu-rs-radius-full);
    margin-top: 4px;
}

/* ==========================================================================
   Toast Variants
   ========================================================================== */
.ennu-rs-toast--warning {
    background: var(--ennu-rs-warning);
    color: var(--ennu-rs-navy);
}

.ennu-rs-toast--info {
    background: var(--ennu-rs-info);
}

/* ==========================================================================
   Loading Text Enhancement
   ========================================================================== */
.ennu-rs-loading-text,
.ennu-rs-no-rates,
.ennu-rs-error-text {
    font-size: 0.9375rem;
    color: var(--ennu-rs-slate);
    padding: 16px 0;
    text-align: center;
}

.ennu-rs-error-text {
    color: var(--ennu-rs-error);
}

/* ==========================================================================
   Membership Summary Item Variant
   ========================================================================== */
.ennu-rs-summary-item--membership {
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.1) 0%, rgba(201, 169, 98, 0.05) 100%);
    margin: 8px -24px;
    padding: 12px 24px;
    border-bottom: none;
}

/* ==========================================================================
   Form Group Focus State
   ========================================================================== */
.ennu-rs-form-group.focused .ennu-rs-card-element {
    border-color: var(--ennu-rs-gold);
    box-shadow: var(--ennu-rs-shadow-focus);
}

/* ==========================================================================
   Skeleton Loading (Future Enhancement)
   ========================================================================== */
.ennu-rs-skeleton {
    background: linear-gradient(
        90deg,
        var(--ennu-rs-cream) 25%,
        rgba(201, 169, 98, 0.1) 50%,
        var(--ennu-rs-cream) 75%
    );
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.5s infinite;
    border-radius: var(--ennu-rs-radius);
}

@keyframes skeleton-shimmer {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

.ennu-rs-skeleton--text {
    height: 1em;
    margin-bottom: 0.5em;
}

.ennu-rs-skeleton--image {
    height: 180px;
}

.ennu-rs-skeleton--button {
    height: 48px;
}

/* ==========================================================================
   Aesthetic Division Color Overrides
   Replaces gold accents with charcoal grey for aesthetics division
   ========================================================================== */

[data-division="aesthetic"].ennu-rs,
.ennu-rs[data-division="aesthetic"] {
    /* Primary Accent - Black (replaces gold) */
    --ennu-rs-gold: #111111;
    --ennu-rs-gold-light: #333333;
    --ennu-rs-gold-dark: #000000;
    --ennu-rs-gold-gradient: linear-gradient(135deg, #1a1a1a 0%, #333333 50%, #111111 100%);
    
    /* Borders adjusted */
    --ennu-rs-border: rgba(0, 0, 0, 0.15);
    --ennu-rs-border-strong: rgba(0, 0, 0, 0.3);
    
    /* Shadows adjusted */
    --ennu-rs-shadow-gold: 0 4px 20px rgba(0, 0, 0, 0.15);
    --ennu-rs-shadow-gold-hover: 0 8px 32px rgba(0, 0, 0, 0.25);
    --ennu-rs-shadow-focus: 0 0 0 4px rgba(0, 0, 0, 0.1);
}

/* Aesthetic division - specific element overrides */
.ennu-rs[data-division="aesthetic"] .ennu-rs-step-indicator.active .ennu-rs-step-number,
.ennu-rs[data-division="aesthetic"] .ennu-rs-step-indicator.completed .ennu-rs-step-number {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
    color: #ffffff;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-step-indicator .ennu-rs-step-number {
    border-color: rgba(0, 0, 0, 0.2);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-btn--primary {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
    color: #ffffff;
    border: none;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-btn--primary:hover {
    background: linear-gradient(135deg, #000000 0%, #1a1a1a 100%);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-sidebar-header {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
    color: #ffffff;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-sidebar-header h3,
.ennu-rs[data-division="aesthetic"] .ennu-rs-sidebar-header .ennu-rs-cart-count {
    color: #ffffff;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-sidebar-header::after {
    background: linear-gradient(135deg, #333333 0%, #1a1a1a 100%);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-product-card:hover {
    border-color: var(--ennu-rs-gold);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-category-btn {
    border-color: rgba(0, 0, 0, 0.2);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-category-btn.active {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
    color: #ffffff;
    border-color: transparent;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-progress-fill {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-fulfillment-option.selected {
    border-color: #111111;
    background: rgba(0, 0, 0, 0.03);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-shipping-option.selected {
    border-color: #111111;
    background: rgba(0, 0, 0, 0.03);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-coupon-applied svg {
    color: #111111;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-summary-item--membership {
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.08) 0%, rgba(0, 0, 0, 0.03) 100%);
}

/* Add to Cart buttons */
.ennu-rs[data-division="aesthetic"] .ennu-rs-add-to-cart {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
    color: #ffffff;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-add-to-cart:hover {
    background: linear-gradient(135deg, #000000 0%, #1a1a1a 100%);
}

/* Navigation buttons (Continue, Previous, etc.) */
.ennu-rs[data-division="aesthetic"] .ennu-rs-btn {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
    color: #ffffff;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-btn:hover {
    background: linear-gradient(135deg, #000000 0%, #1a1a1a 100%);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-btn--secondary {
    background: transparent;
    color: #1a1a1a;
    border: 2px solid rgba(0, 0, 0, 0.2);
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-btn--secondary:hover {
    background: rgba(0, 0, 0, 0.05);
    border-color: #1a1a1a;
}

/* Cart summary header */
.ennu-rs[data-division="aesthetic"] .ennu-rs-summary-header {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
    color: #ffffff;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-summary-header h3 {
    color: #ffffff;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-summary-header::after {
    background: linear-gradient(135deg, #333333 0%, #1a1a1a 100%);
}

/* Sidebar checkout button */
.ennu-rs[data-division="aesthetic"] .ennu-rs-checkout-btn {
    background: linear-gradient(135deg, #1a1a1a 0%, #333333 100%);
    color: #ffffff;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-checkout-btn:hover {
    background: linear-gradient(135deg, #000000 0%, #1a1a1a 100%);
}

/* ==========================================================================
   Collapsible Tools Row (Search & Coupon)
   ========================================================================== */
.ennu-rs-collapsible-tools {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
}

.ennu-rs-collapsible-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: var(--ennu-rs-white);
    border: 2px solid var(--ennu-rs-border);
    border-radius: var(--ennu-rs-radius-full);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--ennu-rs-text);
    cursor: pointer;
    transition: all 0.2s ease;
}

.ennu-rs-collapsible-toggle:hover {
    border-color: var(--ennu-rs-gold);
    background: rgba(201, 169, 98, 0.05);
}

.ennu-rs-collapsible-toggle[aria-expanded="true"] {
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);
    border-color: var(--ennu-rs-gold);
}

.ennu-rs-collapsible-toggle[aria-expanded="true"] svg {
    stroke: var(--ennu-rs-navy);
}

.ennu-rs-collapsible-arrow {
    margin-left: auto;
    transition: transform 0.2s ease;
}

.ennu-rs-collapsible-toggle[aria-expanded="true"] .ennu-rs-collapsible-arrow {
    transform: rotate(180deg);
}

.ennu-rs-collapsible-panels {
    margin-bottom: 16px;
}

.ennu-rs-collapsible-panel {
    padding: 12px 0;
    animation: slideDown 0.2s ease;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ennu-rs-coupon-row--step1 {
    display: flex;
    gap: 8px;
}

.ennu-rs-coupon-row--step1 .ennu-rs-coupon-input {
    flex: 1;
}

/* ==========================================================================
   Mobile Progress Bar Visibility (hide when cart empty)
   ========================================================================== */
@media (max-width: 1024px) {
    /* Hide progress bar on mobile by default */
    .ennu-rs-progress {
        display: none;
    }
    
    /* Show progress bar when cart has items (class added by JS) */
    .ennu-rs.has-cart-items .ennu-rs-progress {
        display: block;
    }
    
    /* When progress bar is hidden, add top margin to category filter for header clearance */
    .ennu-rs:not(.has-cart-items) .ennu-rs-category-filter {
        margin-top: 8px;
    }
}

@media (max-width: 768px) {
    /* Remove container horizontal padding on mobile for flush layout */
    .ennu-rs-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
        overflow: visible;
    }
    
    /* Make progress bar full width flush on mobile */
    .ennu-rs-progress {
        padding: 12px 0 8px 0 !important;
        margin: 0;
        width: 100%;
    }

    /* Full width step indicators - spread edge to edge */
    .ennu-rs-step-indicators {
        justify-content: space-between !important;
        padding: 0 8px 16px 8px !important;
        width: 100%;
    }
    
    /* Adjust connector lines for full width */
    .ennu-rs-step-indicator:not(:last-child)::after {
        flex: 1;
        width: auto;
        min-width: 8px;
    }
    
    /* Add padding back to content sections that need it */
    .ennu-rs-category-filter,
    .ennu-rs-collapsible-tools,
    .ennu-rs-collapsible-panels,
    .ennu-rs-products-grid,
    .ennu-rs-step-content {
        padding-left: 12px;
        padding-right: 12px;
    }
}

/* Aesthetic division collapsible overrides */
.ennu-rs[data-division="aesthetic"] .ennu-rs-collapsible-toggle[aria-expanded="true"] {
    background: #1a1a1a;
    color: #ffffff;
    border-color: #1a1a1a;
}

.ennu-rs[data-division="aesthetic"] .ennu-rs-collapsible-toggle[aria-expanded="true"] svg {
    stroke: #ffffff;
}

/* ==========================================================================
   Inline Tools Row (Search & Coupon) - New Design
   ========================================================================== */
.ennu-rs-inline-tools {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 32px;
    margin-bottom: 28px;
    padding: 0 8px;
}

/* Desktop: Extra spacing between inline tools and product grid */
@media (min-width: 769px) {
    .ennu-rs-inline-tools {
        margin-bottom: 32px;
        padding: 0 8px;
    }
}

.ennu-rs-inline-tool {
    display: flex;
    align-items: center;
}

.ennu-rs-inline-tool--search {
    justify-content: flex-start;
}

.ennu-rs-inline-tool--coupon {
    justify-content: flex-end;
}

.ennu-rs-inline-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--ennu-rs-cream);
    border: 2px solid var(--ennu-rs-gold);
    border-radius: var(--ennu-rs-radius-full);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.ennu-rs-inline-toggle:hover {
    background: var(--ennu-rs-gold);
    color: var(--ennu-rs-navy);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(201, 169, 98, 0.3);
}

.ennu-rs-inline-toggle:hover svg {
    stroke: var(--ennu-rs-navy);
}

.ennu-rs-inline-toggle svg {
    stroke: var(--ennu-rs-gold-dark);
    width: 16px;
    height: 16px;
}

.ennu-rs-inline-field {
    display: flex;
    align-items: center;
    gap: 6px;
    animation: fadeIn 0.15s ease;
}

/* Force hidden state when jQuery .hide() is applied */
.ennu-rs-inline-toggle[style*="display: none"],
.ennu-rs-inline-field[style*="display: none"] {
    display: none !important;
}

@keyframes fadeIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}

.ennu-rs-inline-input {
    padding: 8px 12px;
    font-size: 0.8125rem;
    border: 1px solid var(--ennu-rs-gold);
    border-radius: var(--ennu-rs-radius-full);
    outline: none;
    min-width: 120px;
    transition: all 0.2s ease;
}

.ennu-rs-inline-input:focus {
    border-color: var(--ennu-rs-gold-dark);
}

.ennu-rs-inline-tool--search .ennu-rs-inline-input {
    min-width: 140px;
}

.ennu-rs-inline-tool--coupon .ennu-rs-inline-input {
    min-width: 80px;
}

.ennu-rs-inline-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    padding: 0;
    background: var(--ennu-rs-cream);
    border: none;
    border-radius: 50%;
    font-size: 1.1rem;
    color: var(--ennu-rs-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

.ennu-rs-inline-close:hover {
    background: var(--ennu-rs-border);
    color: var(--ennu-rs-text);
}

.ennu-rs-inline-apply {
    padding: 8px 12px;
    background: var(--ennu-rs-gold);
    border: none;
    border-radius: var(--ennu-rs-radius-full);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--ennu-rs-navy);
    cursor: pointer;
    transition: all 0.2s ease;
}

.ennu-rs-inline-apply:hover {
    background: var(--ennu-rs-gold-dark);
}

.ennu-rs-inline-applied {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: var(--ennu-rs-radius-full);
    font-size: 0.75rem;
    color: #16a34a;
}

.ennu-rs-inline-applied svg {
    stroke: #16a34a;
}

.ennu-rs-inline-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    padding: 0;
    margin-left: 4px;
    background: transparent;
    border: none;
    font-size: 1rem;
    color: #dc2626;
    cursor: pointer;
    opacity: 0.7;
    transition: opacity 0.2s ease;
}

.ennu-rs-inline-remove:hover {
    opacity: 1;
}

/* Mobile adjustments for inline tools */
@media (max-width: 768px) {
    .ennu-rs-inline-tools {
        flex-wrap: wrap;
        padding: 0 12px;
        margin-bottom: 16px;
        gap: 8px;
        position: relative;
        z-index: 5;
    }
    
    .ennu-rs-inline-tool {
        flex-shrink: 0;
    }
    
    /* When search or coupon field is expanded, take full width on mobile */
    .ennu-rs-inline-tool--search.active,
    .ennu-rs-inline-tool--coupon.active {
        flex: 1 1 100%;
        order: -1;
        margin-bottom: 8px;
        position: relative;
        z-index: 10;
    }

    /* Ensure the field doesn't overlap when active */
    .ennu-rs-inline-tool--search.active .ennu-rs-inline-field,
    .ennu-rs-inline-tool--coupon.active .ennu-rs-inline-field {
        position: relative;
        width: 100%;
        margin-top: 0;
    }
    
    /* Hide the other tool's toggle button when one is active */
    .ennu-rs-inline-tool--search.active ~ .ennu-rs-inline-tool--coupon .ennu-rs-inline-toggle,
    .ennu-rs-inline-tools:has(.ennu-rs-inline-tool--coupon.active) .ennu-rs-inline-tool--search .ennu-rs-inline-toggle {
        display: none;
    }
    
    /* Show only the toggle for the inactive tool when the other is active */
    .ennu-rs-inline-tool--search.active ~ .ennu-rs-inline-tool--coupon,
    .ennu-rs-inline-tools:has(.ennu-rs-inline-tool--coupon.active) .ennu-rs-inline-tool--search {
        flex: 0 0 auto;
        order: 0;
    }
    
    .ennu-rs-inline-toggle {
        padding: 6px 10px;
        font-size: 0.75rem;
    }
    
    .ennu-rs-inline-toggle svg {
        width: 14px;
        height: 14px;
    }
    
    .ennu-rs-inline-input {
        padding: 6px 10px;
        font-size: 0.75rem;
        min-width: 80px;
        flex: 1;
    }
    
    .ennu-rs-inline-tool--search .ennu-rs-inline-input {
        min-width: 100px;
    }
    
    .ennu-rs-inline-tool--coupon .ennu-rs-inline-input {
        min-width: 60px;
    }
    
    .ennu-rs-inline-field {
        flex: 1;
    }
    
    .ennu-rs-inline-close {
        width: 24px;
        height: 24px;
        font-size: 1rem;
    }
    
    .ennu-rs-inline-apply {
        padding: 6px 10px;
        font-size: 0.7rem;
    }
    
    .ennu-rs-inline-applied {
        padding: 5px 10px;
        font-size: 0.7rem;
    }
}

/* ==========================================================================
   Confirmation Modal
   ========================================================================== */
.ennu-rs-modal {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: none; /* Hidden by default - shown via JS */
    align-items: center;
    justify-content: center;
    padding: 20px;
    pointer-events: none;
}

.ennu-rs-modal.open,
.ennu-rs-modal.visible,
.ennu-rs-modal[style*="display: flex"] {
    display: flex;
    pointer-events: auto;
}

.ennu-rs-modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    z-index: 0;
}

.ennu-rs-modal-content {
    position: relative;
    z-index: 1;
    background: var(--ennu-rs-white);
    border-radius: 16px;
    padding: 32px;
    max-width: 440px;
    width: 100%;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    animation: modalSlideIn 0.25s ease-out;
}

@keyframes modalSlideIn {
    from {
        opacity: 0;
        transform: translateY(-20px) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.ennu-rs-modal-content h3 {
    font-family: var(--ennu-rs-font-display);
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--ennu-rs-navy);
    margin: 0 0 16px 0;
}

.ennu-rs-modal-content p {
    font-size: 1rem;
    line-height: 1.6;
    color: var(--ennu-rs-slate);
    margin: 0 0 24px 0;
}

.ennu-rs-modal-actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

.ennu-rs-modal-actions .ennu-rs-btn {
    min-width: 120px;
}

@media (max-width: 480px) {
    .ennu-rs-modal-content {
        padding: 24px;
    }
    
    .ennu-rs-modal-actions {
        flex-direction: column-reverse;
    }
    
    .ennu-rs-modal-actions .ennu-rs-btn {
        width: 100%;
    }
}

/* ==========================================================================
   Free Shipping Banner
   ========================================================================== */
.ennu-rs-free-shipping-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 12px 20px;
    background: linear-gradient(135deg, var(--ennu-rs-success) 0%, #2f855a 100%);
    color: #ffffff;
    font-size: 0.95rem;
    font-weight: 600;
    border-radius: 8px;
    margin: 0;
}

.ennu-rs-free-shipping-banner svg {
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .ennu-rs-free-shipping-banner {
        margin: 0;
        padding: 10px 16px;
        font-size: 0.875rem;
        border-radius: 0;
    }
}

/* Free Shipping Note in Shipping Section */
.ennu-rs-shipping-free-note {
    margin: 12px 0 0 0;
    padding: 10px 16px;
    background: rgba(72, 187, 120, 0.1);
    border: 1px solid var(--ennu-rs-success);
    border-radius: 8px;
    color: var(--ennu-rs-success);
    font-size: 0.875rem;
    font-weight: 500;
    text-align: center;
}

.ennu-rs-shipping-free .ennu-rs-free-label {
    color: var(--ennu-rs-success) !important;
    font-weight: 700;
}

/* Account Created Notice - matches public booking style */
.ennu-rs-account-created-notice {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px;
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.1) 0%, rgba(5, 150, 105, 0.05) 100%);
    border: 1px solid rgba(16, 185, 129, 0.3);
    border-radius: 12px;
    margin-bottom: 20px;
    animation: ennu-rs-notice-slide-in 0.3s ease-out;
}

@keyframes ennu-rs-notice-slide-in {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ennu-rs-account-notice-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(16, 185, 129, 0.15);
    border-radius: 50%;
}

.ennu-rs-account-notice-icon svg {
    width: 24px;
    height: 24px;
    stroke: #10b981;
}

.ennu-rs-account-notice-content {
    flex: 1;
}

.ennu-rs-account-notice-content strong {
    display: block;
    color: #065f46;
    font-size: 15px;
    margin-bottom: 4px;
}

.ennu-rs-account-notice-content p {
    margin: 0;
    color: #047857;
    font-size: 14px;
    line-height: 1.5;
}

.ennu-rs-account-notice-close {
    flex-shrink: 0;
    background: none;
    border: none;
    font-size: 20px;
    color: #6b7280;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    opacity: 0.6;
    transition: opacity 0.2s;
}

.ennu-rs-account-notice-close:hover {
    opacity: 1;
}

/* Button spinner for loading state */
.ennu-rs-btn-spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: ennu-rs-spin 0.8s linear infinite;
    vertical-align: middle;
    margin-right: 8px;
}

@keyframes ennu-rs-spin {
    to { transform: rotate(360deg); }
}

/* Dark mode / peptides theme adjustments */
.ennu-peptides-body .ennu-rs-account-created-notice {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.15) 0%, rgba(5, 150, 105, 0.08) 100%);
    border-color: rgba(16, 185, 129, 0.4);
}

.ennu-peptides-body .ennu-rs-account-notice-content strong {
    color: #34d399;
}

.ennu-peptides-body .ennu-rs-account-notice-content p {
    color: #6ee7b7;
}

.ennu-peptides-body .ennu-rs-account-notice-close {
    color: #9ca3af;
}

/* ==========================================================================
   Form Error States
   ========================================================================== */
.ennu-rs-input--error {
    border-color: #dc2626 !important;
    box-shadow: 0 0 0 2px rgba(220, 38, 38, 0.2) !important;
}

.ennu-rs-form-error {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px;
    color: #dc2626;
    font-size: 0.875rem;
    font-weight: 500;
    margin-top: 12px;
}

.ennu-rs-form-error svg {
    flex-shrink: 0;
    stroke: #dc2626;
}

/* ==========================================================================
   QA Fixes - February 2026
   ========================================================================== */

/* Fix: 10px horizontal spacing between buttons and fields */
.ennu-rs-form-row {
    gap: 10px;
}

.ennu-rs-inline-field {
    gap: 10px;
}

/* Fix: 10px vertical spacing for coupon button/field */
.ennu-rs-coupon-section {
    margin-top: 10px;
}

.ennu-rs-coupon-row {
    gap: 10px;
}

/* Fix: Select box sizing consistency with input boxes */
.ennu-rs-select,
select.ennu-rs-input {
    height: 48px;
    min-height: 48px;
    padding: 12px 16px;
    font-size: 1rem;
}

/* Fix: Place Order button vertical spacing */
.ennu-rs-btn--submit {
    margin-top: 20px;
    margin-bottom: 20px;
}

/* Fix: Mobile search bar overlap - ensure proper spacing */
@media (max-width: 768px) {
    .ennu-rs-inline-field {
        width: 100%;
        flex-wrap: nowrap;
        gap: 8px !important; /* Reduce gap on mobile */
    }

    /* Search field (2 elements: input + close) */
    .ennu-rs-inline-tool--search .ennu-rs-inline-input {
        flex: 1;
        min-width: 0;
        max-width: calc(100% - 40px); /* Input takes remaining space minus close button */
    }

    /* Coupon field (3 elements: input + apply + close) */
    .ennu-rs-inline-tool--coupon .ennu-rs-inline-input {
        flex: 1;
        min-width: 0;
        max-width: calc(100% - 110px); /* Input takes remaining space minus apply + close buttons */
    }

    .ennu-rs-inline-apply {
        flex-shrink: 0;
        white-space: nowrap;
        min-width: 60px; /* Ensure apply button has minimum width */
    }

    .ennu-rs-inline-close {
        flex-shrink: 0;
        min-width: 28px; /* Ensure close button has fixed width */
    }

    /* Fix: Mobile cart panel z-index - ensure proper stacking */
    .ennu-rs-mobile-cart-panel {
        z-index: 100005; /* Above footer (10000), below sidebar (100006) */
    }

    .ennu-rs-mobile-cart-overlay {
        z-index: 100004; /* Just below panel */
    }

    .ennu-rs-mobile-cart-footer {
        z-index: 100003; /* Below overlay when cart panel is open */
    }

    /* Fix: Keep Shopping button stacking on mobile */
    .ennu-rs-step[data-step="2"] .ennu-rs-navigation {
        flex-direction: column-reverse;
    }

    .ennu-rs-step[data-step="2"] .ennu-rs-navigation .ennu-rs-btn {
        width: 100%;
    }

    /* Fix: Agreements section equal padding */
    .ennu-rs-consent-section,
    .ennu-rs-agreement-section {
        padding-left: 16px;
        padding-right: 16px;
    }

    /* Fix: Apply button centering for coupon on cart review */
    .ennu-rs-coupon-row--step1 {
        justify-content: center;
    }

    .ennu-rs-coupon-row--step1 .ennu-rs-inline-apply {
        text-align: center;
    }

    /* Fix: Carousel navigation visible on mobile (no hover on touch devices) */
    .ennu-rs-carousel-btn {
        opacity: 1;
        background: rgba(255, 255, 255, 0.95);
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    }
}

/* Fix: Desktop sidebar checkout button always visible */
@media (min-width: 1025px) {
    .ennu-rs-sidebar-inner {
        display: flex;
        flex-direction: column;
    }

    .ennu-rs-cart-items {
        max-height: calc(100vh - 420px);
    }

    .ennu-rs-cart-totals {
        flex-shrink: 0;
    }
}

/* ==========================================================================
   QA Fixes Round 2 - February 2026
   ========================================================================== */

/* Fix #10: Place Order button - visual feedback when disabled */
.ennu-rs-btn--submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    position: relative;
}

.ennu-rs-btn--submit:disabled::after {
    content: '';
    position: absolute;
    inset: 0;
    cursor: not-allowed;
}

/* Fix #15: Sidecart above chat widgets when open on mobile */
@media (max-width: 1024px) {
    .ennu-rs-sidebar.is-open {
        z-index: 2147483646 !important; /* Just below max z-index navigation */
    }

    /* Overlay also needs high z-index */
    .ennu-rs-sidebar.is-open ~ #ennu-sidebar-overlay,
    body.ennu-rs-sidebar-open #ennu-sidebar-overlay {
        z-index: 2147483645 !important;
    }

    /* Hide chat widgets when sidebar is open */
    body.ennu-rs-sidebar-open #intercom-container,
    body.ennu-rs-sidebar-open .intercom-lightweight-app,
    body.ennu-rs-sidebar-open .intercom-launcher,
    body.ennu-rs-sidebar-open .crisp-client,
    body.ennu-rs-sidebar-open #drift-frame-controller,
    body.ennu-rs-sidebar-open #hubspot-messages-iframe-container {
        display: none !important;
    }
}

/* Fix #16: Cart proceed/checkout button clickable on mobile */
@media (max-width: 1024px) {
    .ennu-rs-mobile-cart-footer,
    .ennu-rs-checkout-btn-container {
        pointer-events: auto !important;
        touch-action: manipulation;
    }

    .ennu-rs-mobile-cart-footer .ennu-rs-btn,
    .ennu-rs-checkout-btn-container .ennu-rs-btn {
        pointer-events: auto !important;
        touch-action: manipulation;
        -webkit-tap-highlight-color: transparent;
    }
}

/* Fix #18: Steps 2-5 max-width for readability on desktop */
.ennu-rs-step[data-step="2"] > .ennu-rs-summary-card,
.ennu-rs-step[data-step="3"] > .ennu-rs-section-card,
.ennu-rs-step[data-step="4"] > .ennu-rs-section-card,
.ennu-rs-step[data-step="5"] > .ennu-rs-section-card,
.ennu-rs-step[data-step="2"] .ennu-rs-summary-card,
.ennu-rs-step[data-step="3"] .ennu-rs-section-card,
.ennu-rs-step[data-step="4"] .ennu-rs-section-card,
.ennu-rs-step[data-step="5"] .ennu-rs-section-card {
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
}

/* Step containers themselves need max-width on larger screens */
.ennu-rs-step[data-step="2"],
.ennu-rs-step[data-step="3"],
.ennu-rs-step[data-step="4"],
.ennu-rs-step[data-step="5"] {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
}

.ennu-rs-form-section {
    max-width: 600px;
}

@media (max-width: 768px) {
    .ennu-rs-step[data-step="2"],
    .ennu-rs-step[data-step="3"],
    .ennu-rs-step[data-step="4"],
    .ennu-rs-step[data-step="5"] {
        max-width: 100%;
        padding-left: 15px;
        padding-right: 15px;
    }

    .ennu-rs-step[data-step="2"] > .ennu-rs-summary-card,
    .ennu-rs-step[data-step="3"] > .ennu-rs-section-card,
    .ennu-rs-step[data-step="4"] > .ennu-rs-section-card,
    .ennu-rs-step[data-step="5"] > .ennu-rs-section-card,
    .ennu-rs-step[data-step="2"] .ennu-rs-summary-card,
    .ennu-rs-step[data-step="3"] .ennu-rs-section-card,
    .ennu-rs-step[data-step="4"] .ennu-rs-section-card,
    .ennu-rs-step[data-step="5"] .ennu-rs-section-card {
        max-width: 100%;
    }

    .ennu-rs-form-section {
        max-width: 100%;
    }
}

/* ==========================================================================
   Content Pages - FAQ, About Us, Contact
   ========================================================================== */

/* Page content container */
body.page .entry-content,
body.page .page-content,
body.page article {
    max-width: 1200px;
    margin: 0;
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Page titles */
body.page .entry-title,
body.page .page-title,
body.page h1.entry-title {
    font-size: 42px;
    font-weight: 600;
    color: var(--ennu-rs-navy, #1A2744);
    margin-bottom: 30px;
    text-align: center;
    letter-spacing: -0.5px;
}

/* Section headings */
body.page .entry-content h2,
body.page .page-content h2 {
    font-size: 32px;
    font-weight: 600;
    color: var(--ennu-rs-navy, #1A2744);
    margin-top: 50px;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 2px solid var(--ennu-rs-gold, #C9A962);
}

body.page .entry-content h3,
body.page .page-content h3 {
    font-size: 24px;
    font-weight: 600;
    color: var(--ennu-rs-navy, #1A2744);
    margin-top: 35px;
    margin-bottom: 15px;
}

body.page .entry-content h4,
body.page .page-content h4 {
    font-size: 20px;
    font-weight: 600;
    color: var(--ennu-rs-charcoal, #2C3E50);
    margin-top: 25px;
    margin-bottom: 12px;
}

/* Paragraphs and text */
body.page .entry-content p,
body.page .page-content p {
    font-size: 16px;
    line-height: 1.7;
    color: var(--ennu-rs-charcoal, #2C3E50);
    margin-bottom: 18px;
}

/* Lists */
body.page .entry-content ul,
body.page .page-content ul,
body.page .entry-content ol,
body.page .page-content ol {
    margin: 20px 0 25px 30px;
    color: var(--ennu-rs-charcoal, #2C3E50);
}

body.page .entry-content li,
body.page .page-content li {
    margin-bottom: 10px;
    line-height: 1.6;
}

/* Links */
body.page .entry-content a:not(.button):not(.btn),
body.page .page-content a:not(.button):not(.btn) {
    color: var(--ennu-rs-gold, #C9A962);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: all 0.2s ease;
}

body.page .entry-content a:not(.button):not(.btn):hover,
body.page .page-content a:not(.button):not(.btn):hover {
    color: var(--ennu-rs-gold-dark, #A68B4B);
    border-bottom-color: var(--ennu-rs-gold, #C9A962);
}

/* FAQ Accordion Styling */
.faq-item,
.accordion-item,
body.page .entry-content .faq-item,
body.page .page-content .faq-item {
    background: white;
    border: 1px solid var(--ennu-rs-border, rgba(201, 169, 98, 0.2));
    border-radius: var(--ennu-rs-radius, 12px);
    margin-bottom: 15px;
    overflow: hidden;
    box-shadow: var(--ennu-rs-shadow-subtle, 0 1px 3px rgba(26, 39, 68, 0.04));
    transition: all 0.3s ease;
}

.faq-item:hover,
.accordion-item:hover {
    box-shadow: var(--ennu-rs-shadow-card, 0 4px 16px rgba(26, 39, 68, 0.06));
}

.faq-question,
.accordion-header,
.faq-item .question {
    padding: 20px 25px;
    font-size: 18px;
    font-weight: 600;
    color: var(--ennu-rs-navy, #1A2744);
    cursor: pointer;
    user-select: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.2s ease;
    background: var(--ennu-rs-cream, #FAF8F5);
}

.faq-question:hover,
.accordion-header:hover {
    background: var(--ennu-rs-white, #FFFFFF);
}

.faq-question::after,
.accordion-header::after {
    content: '+';
    font-size: 28px;
    color: var(--ennu-rs-gold, #C9A962);
    transition: transform 0.3s ease;
    font-weight: 300;
    line-height: 1;
}

.faq-item.active .faq-question::after,
.accordion-item.active .accordion-header::after,
.faq-question.active::after {
    transform: rotate(45deg);
}

.faq-answer,
.accordion-content,
.faq-item .answer {
    padding: 0 25px;
    max-height: 0;
    overflow: hidden;
    transition: all 0.3s ease;
}

.faq-item.active .faq-answer,
.accordion-item.active .accordion-content,
.faq-answer.active {
    padding: 20px 25px;
    max-height: 1000px;
}

.faq-answer p,
.accordion-content p {
    margin: 0 0 15px 0;
    color: var(--ennu-rs-charcoal, #2C3E50);
    line-height: 1.7;
}

.faq-answer p:last-child,
.accordion-content p:last-child {
    margin-bottom: 0;
}

/* Contact Form Styling */
body.page .wpcf7,
body.page .contact-form,
body.page .entry-content form:not(.ennu-rs-form),
body.page .page-content form:not(.ennu-rs-form) {
    max-width: 700px;
    margin: 40px auto;
    background: white;
    padding: 40px;
    border-radius: var(--ennu-rs-radius-lg, 16px);
    box-shadow: var(--ennu-rs-shadow-card, 0 4px 16px rgba(26, 39, 68, 0.06));
}

body.page form label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--ennu-rs-navy, #1A2744);
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

body.page form input[type="text"],
body.page form input[type="email"],
body.page form input[type="tel"],
body.page form input[type="url"],
body.page form textarea,
body.page form select {
    width: 100%;
    padding: 14px 18px;
    font-size: 16px;
    color: var(--ennu-rs-navy, #1A2744);
    background: var(--ennu-rs-cream, #FAF8F5);
    border: 1px solid var(--ennu-rs-border, rgba(201, 169, 98, 0.2));
    border-radius: var(--ennu-rs-radius, 12px);
    margin-bottom: 20px;
    transition: all 0.2s ease;
    font-family: inherit;
}

body.page form input:focus,
body.page form textarea:focus,
body.page form select:focus {
    outline: none;
    border-color: var(--ennu-rs-gold, #C9A962);
    background: white;
    box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.1);
}

body.page form textarea {
    min-height: 150px;
    resize: vertical;
}

body.page form button[type="submit"],
body.page form input[type="submit"],
body.page .contact-form .submit-btn {
    background: linear-gradient(135deg, var(--ennu-rs-gold, #C9A962) 0%, var(--ennu-rs-gold-light, #E5D4A1) 100%);
    color: var(--ennu-rs-navy, #1A2744);
    font-size: 16px;
    font-weight: 600;
    padding: 16px 40px;
    border: none;
    border-radius: var(--ennu-rs-radius-full, 9999px);
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: var(--ennu-rs-shadow-gold, 0 4px 20px rgba(201, 169, 98, 0.25));
    text-transform: uppercase;
    letter-spacing: 1px;
}

body.page form button[type="submit"]:hover,
body.page form input[type="submit"]:hover {
    transform: translateY(-2px);
    box-shadow: var(--ennu-rs-shadow-gold-hover, 0 8px 32px rgba(201, 169, 98, 0.4));
}

/* Contact Info Cards */
.contact-info-card,
body.page .contact-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 25px;
    margin: 40px 0;
}

.contact-info-item {
    background: white;
    padding: 30px;
    border-radius: var(--ennu-rs-radius, 12px);
    border: 1px solid var(--ennu-rs-border, rgba(201, 169, 98, 0.2));
    text-align: center;
    transition: all 0.3s ease;
}

.contact-info-item:hover {
    transform: translateY(-5px);
    box-shadow: var(--ennu-rs-shadow-card, 0 4px 16px rgba(26, 39, 68, 0.06));
}

.contact-info-item h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--ennu-rs-navy, #1A2744);
    margin-bottom: 12px;
}

.contact-info-item p {
    font-size: 16px;
    color: var(--ennu-rs-charcoal, #2C3E50);
    margin: 0;
}

/* About Us - Team Grid */
.team-grid,
body.page .team-members {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 30px;
    margin: 40px 0;
}

.team-member {
    text-align: center;
    padding: 25px;
    background: white;
    border-radius: var(--ennu-rs-radius-lg, 16px);
    border: 1px solid var(--ennu-rs-border, rgba(201, 169, 98, 0.2));
    transition: all 0.3s ease;
}

.team-member:hover {
    transform: translateY(-5px);
    box-shadow: var(--ennu-rs-shadow-card, 0 4px 16px rgba(26, 39, 68, 0.06));
}

.team-member img {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 20px;
    border: 3px solid var(--ennu-rs-gold, #C9A962);
}

.team-member h3 {
    font-size: 20px;
    font-weight: 600;
    color: var(--ennu-rs-navy, #1A2744);
    margin-bottom: 8px;
}

.team-member .role {
    font-size: 14px;
    color: var(--ennu-rs-gold, #C9A962);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 12px;
}

.team-member p {
    font-size: 15px;
    color: var(--ennu-rs-charcoal, #2C3E50);
    line-height: 1.6;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    body.page .entry-content,
    body.page .page-content {
        margin: 40px auto 40px;
        padding: 0 20px;
    }

    body.page .entry-title,
    body.page .page-title {
        font-size: 32px;
    }

    body.page .entry-content h2,
    body.page .page-content h2 {
        font-size: 26px;
    }

    body.page .wpcf7,
    body.page .contact-form {
        padding: 30px 20px;
    }

    .contact-info-card,
    body.page .contact-info {
        grid-template-columns: 1fr;
    }

    .team-grid,
    body.page .team-members {
        grid-template-columns: 1fr;
    }
}
