@import url('https://fonts.cdnfonts.com/css/futura-pt');

:root {
    /* Brand Colors - Exact Compliance */
    --agame-primary: #161616;
    --agame-secondary: #0BB3EB;
    --agame-gray: #919191;
    --agame-white: #ffffff;
    --agame-accent: #e91e63;
    --agame-light-gray: #f5f5f5;
    --agame-medium-gray: #e0e0e0;
    --agame-dark-gray: #919191;
    --agame-border: #e0e0e0;
    --agame-success: #4caf50;
    --agame-warning: #ff9800;
    --agame-danger: #f44336;
    --agame-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    --agame-shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.15);
    --agame-radius: 0px;
    --agame-radius-lg: 8px;
    --agame-main-btn: #0BB3EB;
    --agame-close-btn: #161616;
    --agame-next-btn: #161616;
    
    /* Typography - Futura PT Family */
    --agame-font-family: 'Futura PT', 'Avenir Next', 'Avenir', 'Century Gothic', 'Trebuchet MS', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    --agame-font-size-xs: 12px;
    --agame-font-size-sm: 14px;
    --agame-font-size-base: 13px;
    --agame-font-size-lg: 18px;
    --agame-font-size-xl: 20px;
    --agame-font-size-2xl: 24px;
    --agame-font-size-3xl: 30px;
    --agame-font-size-4xl: 40px;
    --agame-font-size-5xl: 48px;
    --agame-font-size-6xl: 60px;
    
    /* Futura PT Font Weights - Brand Compliant */
    --agame-font-weight-book: 300;      /* Book for subtitles */
    --agame-font-weight-medium: 500;
    --agame-font-weight-demi: 600;
    --agame-font-weight-bold: 700;      /* Bold for buttons */
    --agame-font-weight-heavy: 900;     /* Heavy for main titles */
    
    /* Brand Heading Sizes */
    --agame-h1-size: 60px;
    --agame-h1-line-height: 72px;
    --agame-h1-letter-spacing: 16px;
    --agame-h2-size: 48px;
    --agame-h2-line-height: 61px;
    --agame-h2-letter-spacing: 16px;
    --agame-h3-size: 40px;
    --agame-h3-line-height: 58px;
    --agame-h3-letter-spacing: 16px;
    --agame-h4-size: 30px;
    --agame-h4-line-height: 44px;
    --agame-h4-letter-spacing: 16px;
    --agame-h5-size: 24px;
    --agame-h5-line-height: 38px;
    --agame-h5-letter-spacing: 16px;
    --agame-h6-size: 18px;
    --agame-h6-line-height: 29px;
    --agame-h6-letter-spacing: 16px;
}

/* Brand Compliant Heading Styles */
.agame-configurator h1,
.agame-modal h1 {
    font-size: var(--agame-h1-size);
    font-weight: var(--agame-font-weight-heavy);
    line-height: var(--agame-h1-line-height);
    letter-spacing: var(--agame-h1-letter-spacing);
    color: var(--agame-primary);
    margin: 0 0 20px 0;
}

.agame-configurator h2,
.agame-modal h2 {
    font-size: var(--agame-h2-size);
    font-weight: var(--agame-font-weight-heavy);
    line-height: var(--agame-h2-line-height);
    letter-spacing: var(--agame-h2-letter-spacing);
    color: var(--agame-primary);
    margin: 0 0 16px 0;
}

.agame-configurator h3,
.agame-modal h3 {
    font-size: var(--agame-h3-size);
    font-weight: var(--agame-font-weight-heavy);
    line-height: var(--agame-h3-line-height);
    letter-spacing: var(--agame-h3-letter-spacing);
    color: var(--agame-primary);
    margin: 0 0 14px 0;
}

.agame-configurator h4,
.agame-modal h4 {
    font-size: var(--agame-h4-size);
    font-weight: var(--agame-font-weight-heavy);
    line-height: var(--agame-h4-line-height);
    letter-spacing: var(--agame-h4-letter-spacing);
    color: var(--agame-primary);
    margin: 0 0 12px 0;
}

.agame-configurator h5,
.agame-modal h5 {
    font-size: var(--agame-h5-size);
    font-weight: var(--agame-font-weight-heavy);
    line-height: var(--agame-h5-line-height);
    letter-spacing: var(--agame-h5-letter-spacing);
    color: var(--agame-primary);
    margin: 0 0 10px 0;
}

.agame-configurator h6,
.agame-modal h6 {
    font-size: var(--agame-h6-size);
    font-weight: var(--agame-font-weight-heavy);
    line-height: var(--agame-h6-line-height);
    letter-spacing: var(--agame-h6-letter-spacing);
    color: var(--agame-primary);
    margin: 0 0 8px 0;
}

/* Subtitle styles using Book weight */
.agame-subtitle,
.agame-configurator .subtitle,
.agame-modal .subtitle {
    font-weight: var(--agame-font-weight-book);
    color: var(--agame-gray);
}

.agame-modal *,
.agame-configurator-layout *,
.agame-configurator,
.agame-configurator * {
    font-family: 'Futura PT', 'Avenir Next', 'Avenir', 'Century Gothic', 'Trebuchet MS', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
    font-feature-settings: 'kern' 1, 'liga' 1;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Step Title Checkmark Icon */
.agame-step-header h3 .checkmark-icon {
    width: 20px;
    height: 20px;
    background: var(--agame-secondary);
    border-radius: 0%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 12px;
    color: white;
    font-weight: var(--agame-font-weight-bold);
    margin-top: -2px; /* Align with text baseline */
}

/* Configurator Button */
.XXagame-configurator-btn {
    background: linear-gradient(135deg, #0BB3EB, #0891a8);
    color: var(--agame-white);
    border: none;
    padding: 15px 30px;
    border-radius: 0px;
    font-size: 16px;
    font-weight: var(--agame-font-weight-demi);
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 1px;
    box-shadow: var(--agame-shadow);
    margin: 20px 0;
}

.agame-configurator-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(10, 197, 226, 0.3);
}

.agame-configurator-btn:active {
    transform: translateY(0);
}

/* Modal Overlay */
.agame-modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    background: rgba(0, 0, 0, 0.8) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 999999 !important;
    backdrop-filter: blur(5px);
    padding: 0 !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
}

.agame-modal-overlay.active {
    display: flex !important;
}

/* Modal Container - Full Width */
.agame-modal {
    background: white !important;
    border-radius: 0 !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
    width: 100vw !important;
    max-width: none !important;
    min-width: 320px !important;
    height: 95vh !important;
    max-height: none !important;
    display: flex !important;
    flex-direction: column !important;
    opacity: 1 !important;
    position: fixed !important;
    top: 2.5vh !important;
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    animation: none !important;
    overflow: visible !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    z-index: 999999 !important;
}

.agame-configurator-inline {
    display: flex !important;
    flex-direction: row !important;
    width: 100vw !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    position: relative !important;
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
}

.agame-configurator-inline .agame-configurator-layout {
    display: flex !important;
    flex-direction: row !important;
    width: 100% !important;
}

.agame-configurator-inline .agame-configurator-content {
    flex: 1 !important;
    max-width: 35% !important;
    padding-right: 20px !important;
}

.agame-configurator-inline .agame-preview-panel {
    flex: 0 0 65% !important;
    max-width: 65% !important;
    position: sticky !important;
    height: fit-content !important;
}

.agame-configurator-inline .agame-config-panel {
    flex: 0 0 35% !important;
    max-width: 35% !important;
}

/* Responsive override for inline configurator at 1200px breakpoint */
@media (max-width: 1200px) {
    .agame-configurator-inline,
    .agame-configurator-inline.agame-configurator-inline {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        flex-direction: column !important;
        border-radius: 0 !important;
        background: transparent !important;
    }
    
    .agame-configurator-inline .agame-configurator-layout,
    .agame-configurator-inline.agame-configurator-inline .agame-configurator-layout {
        flex-direction: column !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    
    .agame-configurator-inline .agame-configurator-content,
    .agame-configurator-inline.agame-configurator-inline .agame-configurator-content {
        flex: 1 !important;
        max-width: 100% !important;
        width: 100% !important;
        padding: 0 !important;
        padding-right: 0 !important;
        margin: 0 !important;
        order: 2 !important;
    }
    
    .agame-configurator-inline .agame-preview-panel,
    .agame-configurator-inline.agame-configurator-inline .agame-preview-panel {
        flex: 0 0 auto !important;
        max-width: 100% !important;
        min-width: 100% !important;
        width: 100% !important;
        order: 1 !important;
        margin: 0 !important;
        padding: 0 !important;
        box-sizing: border-box !important;
        background: #f8f9fa !important;
        position: static !important;
        height: auto !important;
    }
    
    .agame-configurator-inline .agame-config-panel,
    .agame-configurator-inline.agame-configurator-inline .agame-config-panel {
        flex: 1 1 auto !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 100% !important;
        order: 2 !important;
        padding: 0 !important;
        margin: 0 !important;
        box-sizing: border-box !important;
        background: #ffffff !important;
    }
    
    .agame-configurator-inline .agame-config-panel .netball-kit-title {
        position: static;
        top: auto;
        margin: -20px -32px 20px -32px;
        padding: 12px 32px;
        border-radius: 0;
    }
    
    .agame-configurator-inline #template-navigation .agame-btn {
        flex: 1;
        min-width: 0;
        max-width: none;
        padding: 12px 24px;
        font-size: 14px;
        font-weight: 600;
    }

}

/* Animations */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes slideInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pulse {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
}

/* Loading States */
.agame-loading {
    position: relative;
    overflow: visible;
}

.agame-loading::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(10, 197, 226, 0.3), transparent);
    animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
    0% { left: -100%; }
    100% { left: 100%; }
}

/* Responsive Design - 1200px Breakpoint Layout Change */
@media (max-width: 1200px) {
    /* Navigation buttons at 1200px breakpoint - wider buttons */
    .agame-step-navigation .agame-btn {
        flex: 1 !important;
        min-width: 0 !important;
        max-width: none !important;
        padding: 12px 24px !important;
        font-size: 14px !important;
        font-weight: 600 !important;
    }
    
    /* Template navigation (first step) - single button takes half width, aligned right */
    #template-navigation.agame-step-navigation {
        justify-content: flex-end !important;
    }
    
    #template-navigation .agame-btn {
        flex: 0 0 auto !important;
        width: 26% !important;
        min-width: 0 !important;
        max-width: 50% !important;
        padding: 12px 24px !important;
        font-size: 14px !important;
        font-weight: 600 !important;
    }
    
    /* Modal container adjustments for full viewport usage */
    .agame-modal {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        left: 0 !important;
        right: 0 !important;
    }
    
    /* Override inline configurator container to use full viewport */
    .agame-configurator-inline,
    .agame-configurator-inline.agame-configurator-inline {
        width: 100vw !important;
        max-width: none !important;
        padding: 0 !important;
        margin: 0 !important;
        flex-direction: column !important;
        border-radius: 0 !important;
        background: transparent !important;
        position: relative !important;
        left: 50% !important;
        right: 50% !important;
        margin-left: -50vw !important;
        margin-right: -50vw !important;
    }
    
    /* Change main layout from row to column and use full viewport width */
    .agame-configurator-layout,
    .agame-configurator-layout.inline-layout,
    .agame-configurator-inline .agame-configurator-layout,
    .agame-configurator-inline.agame-configurator-inline .agame-configurator-layout {
        flex-direction: column !important;
        gap: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        box-sizing: border-box !important;
        position: relative !important;
    }
    
    /* Override inline-layout styles for full viewport usage */
    .agame-configurator-layout.inline-layout {
        width: 100% !important;
        height: auto !important;
        padding: 0 !important;
        background: transparent !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        overflow-x: hidden !important;
    }
    
    /* Override ALL preview panel rules with maximum specificity */
    .agame-preview-panel,
    .agame-modal .agame-preview-panel,
    .agame-configurator-inline .agame-preview-panel,
    .agame-configurator-inline.agame-configurator-inline .agame-preview-panel {
        flex: 0 0 auto !important;
        max-width: 100% !important;
        min-width: 100% !important;
        width: 100% !important;
        order: 1 !important;
        margin: 0 !important;
        padding-bottom: 15px !important;
        box-sizing: border-box !important;
        background: #f8f9fa !important;
        position: static !important;
        height: auto !important;
    }
    
    /* Override ALL config panel rules with maximum specificity */
    .agame-config-panel,
    .agame-modal .agame-config-panel,
    .agame-configurator-inline .agame-config-panel,
    .agame-configurator-inline.agame-configurator-inline .agame-config-panel {
        flex: 1 1 auto !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 100% !important;
        order: 2 !important;
        padding: 20px !important;
        margin: 0 !important;
        box-sizing: border-box !important;
        background: #ffffff !important;
        overflow-y: visible !important;
        overflow-x: hidden !important;
        height: auto !important;
    }
    
    /* Override configurator content rules with maximum specificity */
    .agame-configurator-content,
    .agame-configurator-inline .agame-configurator-content,
    .agame-configurator-inline.agame-configurator-inline .agame-configurator-content {
        flex: 1 !important;
        max-width: 100% !important;
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        padding-right: 0 !important;
    }
    
    /* Steps panel also takes full viewport width if present */
    .agame-steps-panel,
    .agame-modal .agame-steps-panel {
        flex: 0 0 auto !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 100% !important;
        order: 3 !important;
        padding: 20px !important;
        box-sizing: border-box !important;
        margin: 0 !important;
    }
    
    /* Adjust preview content for full viewport usage */
    .agame-preview-content {
        min-height: 300px !important;
        padding: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        margin: 0 auto !important;
    }
    
    /* Ensure modal layout works properly on smaller screens */
    .agame-modal {
        height: auto !important;
        max-height: 100vh !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
    }
    
    /* Make sure step content uses full available width */
    .agame-step-content {
        width: 100% !important;
        max-width: 100% !important;
        padding: 20px 20px 20px 20px !important;
        box-sizing: border-box !important;
    }
}

@media (max-width: 768px) {
    .agame-config-panel {
        padding: 16px;
    }
    
    .agame-progress-step {
        padding: 12px 16px;
        min-height: 50px;
    }
    
    .agame-progress-step .step-number {
        width: 28px;
        height: 28px;
        font-size: 12px;
        margin-right: 12px;
    }
    
    .agame-progress-step .step-title {
        font-size: 14px;
    }
    
    .agame-progress-step .step-description {
        font-size: 12px;
    }
    
    .preview-controls-overlay {
        bottom: -50px !important;
    }

    .agame-preview-dual .preview-controls-overlay {
        bottom: 125px !important;
    }
}

.agame-template-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
    
    .agame-btn {
        padding: 10px 20px;
        min-height: 40px;
        font-size: 12px;
    }

/* Netball Modal Specific Styles */
.netball-modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    background: rgba(0, 0, 0, 0.8) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 999999 !important;
    backdrop-filter: blur(5px);
    padding: 20px !important;
    box-sizing: border-box !important;
}

.netball-modal {
    background: white !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
    width: 98vw !important;
    max-width: none !important;
    height: 98vh !important;
    max-height: none !important;
    display: flex !important;
    flex-direction: column !important;
    opacity: 1 !important;
    position: relative !important;
    transform: none !important;
    animation: none !important;
    overflow: visible !important;
    margin: 0 auto !important;
}

/* Configurator Layout - Viper10 Inspired Two-Column Design (Consolidated) */
.agame-configurator-layout {
    display: flex !important;
    gap: 0px;
    height: 100%;
    min-height: 700px !important;
    background: transparent;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
    position: relative !important;
    left: 0 !important;
    right: 0 !important;
    box-sizing: border-box !important;
}

/* Configuration Panel - Right Side (Consolidated) */
.agame-config-panel {
    flex: 0 0 45%;
    width: 38% !important;
    min-width: 320px !important;
    max-width: 380px !important;
    margin-right: 0 !important;
    padding: 32px 20px 32px 25px;
    background: var(--agame-white);
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    max-height: 100%;
    height: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    position: relative;
    box-sizing: border-box !important;
}

/* Preview Header - Minimal and Clean */
.XXagame-preview-header {
    padding: 24px 20px 20px;
    background: var(--agame-white);
    border-bottom: 1px solid var(--agame-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.XXagame-preview-header h3 {
    margin: 0;
    font-size: var(--agame-font-size-lg);
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.XXagame-preview-controls {
    display: flex;
    gap: 8px;
}

.XXagame-preview-btn {
    width: 40px;
    height: 40px;
    border: 1px solid var(--agame-border);
    background: var(--agame-white);
    border-radius: var(--agame-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    color: var(--agame-dark-gray);
}

.XXagame-preview-btn:hover {
    background: var(--agame-main-btn);
    border-color: var(--agame-main-btn);
    color: var(--agame-white);
    transform: translateY(-1px);
    box-shadow: var(--agame-shadow);
}


/* Preview Content - Central Product Display - Now transparent, gradient comes from parent */
.agame-preview-content {
    flex: 1;
    padding: 40px 20px 60px 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    position: relative;
    overflow: visible;
    min-height: 400px;
    border-radius: 2px;
    border: 1px groove var(--agame-border);
    border-right: none;
    border-bottom: none;
    margin-bottom: 10px;
}

/* Preview controls overlay - Always transparent to let parent gradient show through */
.preview-controls-overlay {
    position: absolute;
    bottom: -144px;
    left: 0;
    right: 0;
    transform: none;
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    z-index: 3 !important;
    background: transparent !important;
    padding: 15px 8px;
    border-radius: 0 0 2px 2px;
    border: 1px groove var(--agame-border);
    border-top: none;
    border-right: none;
    border-bottom: none;
    width: 100%;
    box-sizing: border-box;
}

/* Dual view specific positioning - move controls down as per requirements */
.agame-preview-dual .preview-controls-overlay {
    bottom: -140px !important;
    background: transparent !important;
}

/* Dual view specific panel padding */
.agame-preview-panel:has(.agame-preview-dual) {
    padding-bottom: 55px !important;
}

#agame-garment-preview {
    overflow: visible !important;
}

#agame-garment-preview {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 468px;
    overflow: visible;
    position: relative;
}


/* Default shadow for large screens (fullscreen) - above 1201px */
@media (min-width: 1201px) {
    /* Change parent container background to match preview gradient with maximum specificity */
    .agame-preview-panel,
    .agame-modal .agame-preview-panel,
    .agame-configurator-inline .agame-preview-panel,
    .agame-configurator-inline.agame-configurator-inline .agame-preview-panel {
        overflow: visible !important;
        background: linear-gradient(to bottom, #d9dde2 0%, #d4d8dc 25%, #eaeff5 50%, #f0f3f7 75%, #f5f7fa 100%) !important;
    }
    
    /* PSEUDO-ELEMENTO SHADOW DESHABILITADO - USAMOS SOLO .agame-single-shadow */
    .xagame-preview-content::before {
        display: none !important;
        content: none !important;
    }
    
    /* Remove the ::after pseudo-element that was causing separation lines */
    .agame-preview-content::after {
        display: none !important;
        content: none !important;
    }
    
    /* Adjust panel padding for fullscreen to prevent extra space */
    .agame-preview-panel,
    .agame-modal .agame-preview-panel,
    .agame-configurator-inline .agame-preview-panel,
    .agame-configurator-inline.agame-configurator-inline .agame-preview-panel {
        padding-bottom: 160px !important;
    }
}

/* Responsive adjustment for shadow and controls positioning at 1200px and below */
@media (max-width: 1200px) {
    /* Change parent container background to match preview gradient with maximum specificity */
    .agame-preview-panel,
    .agame-modal .agame-preview-panel,
    .agame-configurator-inline .agame-preview-panel,
    .agame-configurator-inline.agame-configurator-inline .agame-preview-panel {
        background: linear-gradient(to bottom, #d9dde2 0%, #d4d8dc 25%, #eaeff5 50%, #f0f3f7 75%, #f5f7fa 100%) !important;
        padding-bottom: 160px !important;
    }
    
    /* Move controls down by 40px for screens under 1200px */
    .preview-controls-overlay {
        bottom: -164px !important;
    }
    
    .agame-preview-dual .preview-controls-overlay {
        bottom: -160px !important;
    }

    /* Move single shadow up 20px to prevent button overlap */
    .agame-single-shadow {
        bottom: -140px !important;
    }
}

/* Remove old garment shadow */
#agame-garment-preview::after {
    display: none;
}

/* Clean garment display without problematic drop-shadow */
#agame-garment-preview img,
#agame-garment-preview canvas,
#agame-garment-preview svg {
    position: relative;
    z-index: 2 !important;
}

.agame-preview-placeholder {
    text-align: center;
    color: var(--agame-gray-500);
}

.agame-placeholder-icon {
    margin-bottom: 16px;
    opacity: 0.5;
}

.agame-preview-placeholder h4 {
    margin: 0 0 8px;
    font-size: 16px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-gray-700);
}

.agame-preview-placeholder p {
    margin: 0;
    font-size: 14px;
    color: var(--agame-gray-500);
}

.agame-preview-footer {
    display: none;
}

.agame-design-info {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.agame-info-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
}

.agame-info-label {
    color: var(--agame-gray-600);
    font-weight: var(--agame-font-weight-medium);
}

.agame-info-value {
    color: var(--agame-gray-900);
    font-weight: var(--agame-font-weight-demi);
}

/* Configuration Panel - Professional Layout */
.agame-config-panel h2 {
    font-size: var(--agame-font-size-xl);
    font-weight: var(--agame-font-weight-heavy);
    color: var(--agame-primary);
    margin: 0 0 8px 0;
    text-transform: uppercase;
    letter-spacing: 1.2px;
}

.agame-config-panel .subtitle {
    font-size: var(--agame-font-size-base);
    color: var(--agame-dark-gray);
    margin: 0 0 32px 0;
    font-weight: var(--agame-font-weight-book);
}

/* Configuration Steps */
.agame-config-step {
    display: block;
    margin-top: -2px;
    margin-bottom: 16px;
    border: none;
    border-radius: 0;
    background: var(--agame-white);
    transition: all 0.3s ease;
    animation: slideInRight 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.agame-config-step.active {
    border: none;
}

.agame-config-step.compressed {
    margin-bottom: 8px;
}

.agame-config-step.compressed .agame-step-header {
    padding: 12px 20px;
    background: white;
    border-radius: 0;
    cursor: pointer;
    transition: all 0.3s ease;
}

.agame-config-step.compressed .agame-step-header:hover {
    background: #0BB3EB;
}

.agame-config-step.compressed .step-header-content {
    margin-bottom: 0px;
    padding-bottom: 0px;
}

.agame-config-step.compressed .step-header-content .step-title {
    margin-bottom: 0px;
}

.agame-config-step.compressed .checkmark-icon {
    margin-top: -2px;
}

.agame-config-step.compressed .agame-step-header h3 .checkmark-icon {
    margin-top: -2px;
}

/* Default step alignment fixes */
.agame-config-step .step-header-content {
    margin-bottom: 0px;
    padding-bottom: 0px;
}

.agame-config-step .step-header-content .step-title {
    margin-bottom: 0px;
}

.agame-config-step .checkmark-icon {
    margin-top: -2px;
}

.agame-config-step .agame-step-header h3 .checkmark-icon {
    margin-top: -2px;
}

.agame-step-header {
    margin-bottom: 0;
    padding: 20px 20px 0px 20px;
    margin-left: -20px;
    margin-top: -15px;
    background: white;
    border-radius: 0;
    transition: all 0.3s ease;
    border-bottom: 1px solid #d7dfe4;
}

.agame-config-step.active .agame-step-header {
    margin-bottom: 4px; /* Reduced from 24px to minimize gray space */
    background: white;
    border-radius: 0;
    border-bottom: none;
}

.agame-step-header h3 {
    margin: 0;
    font-size: var(--agame-font-size-lg);
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
    text-transform: uppercase;
    letter-spacing: 1.2px;
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
    line-height: 1.2;
}

.agame-config-step.active .agame-step-header h3 {
    margin-bottom: 16px;
    padding-bottom: 12px;
}

/* Override for step-header-content in active steps */
.agame-config-step.active .step-header-content {
    margin-bottom: 0px;
    padding-bottom: 0px;
}

.agame-config-step.active .step-header-content .step-title {
    margin-bottom: 0px;
}

.agame-config-step.active .checkmark-icon {
    margin-top: -12px;
}

/* Blue bar under active steps removed as requested */

.agame-step-header p {
    margin: 0;
    color: var(--agame-dark-gray);
    line-height: 1.6;
    font-size: var(--agame-font-size-base);
    opacity: 0.8;
}

.agame-config-step.active .agame-step-header p {
    margin-bottom: 24px;
    opacity: 1;
}

.agame-step-content {
    display: none;
    padding: 20px 0 20px 20px;
    position: relative;
    margin-left: -20px;
    margin-right: 20px;
    border-bottom: 1px solid #d7dfe4;
    box-sizing: border-box;
    overflow: visible;
    opacity: 0;
    transform: translateY(-10px);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

#step-quote .agame-step-content {
    border-bottom: 1px solid #d7dfe4;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.agame-step-content.active {
    display: block;
    opacity: 1;
    transform: translateY(0);
    margin-top: 1px;
    padding-top: 1px;
}

/* Sport Grid Options */
.agame-sport-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-top: 20px;
}

.agame-sport-option {
    border: 2px solid var(--agame-border);
    border-radius: 12px;
    padding: 24px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    background: white;
    position: relative;
    overflow: hidden;
}

.agame-sport-option:hover {
    border-color: var(--agame-primary);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    transform: translateY(-2px);
}

.agame-sport-option.selected {
    border-color: var(--agame-primary);
    background: var(--agame-primary-light);
}

.agame-sport-option .sport-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 16px;
    background: var(--agame-gray-100);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--agame-primary);
}

.agame-sport-option h4 {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-gray-900);
}

.agame-sport-option p {
    margin: 0;
    font-size: 14px;
    color: var(--agame-gray-600);
    line-height: 1.4;
}

@keyframes agame-modal-appear {
    from {
        opacity: 0;
        transform: scale(0.9) translateY(20px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

/* Modal Header - Viper10 Style */
.agame-modal-header {
    background: var(--agame-white);
    color: var(--agame-primary);
    padding: 20px 24px;
    border-bottom: 1px solid var(--agame-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
}

.agame-modal-header h2 {
    margin: 0;
    font-size: var(--agame-font-size-xl);
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.agame-modal-header .agame-subtitle {
    font-size: var(--agame-font-size-sm);
    color: var(--agame-dark-gray);
    margin-top: 4px;
    text-transform: none;
    letter-spacing: normal;
}

/* Progress Steps - Viper10 Style */
.agame-progress-indicator {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 24px;
    padding: 0;
    background: var(--agame-white);
    border: 1px solid var(--agame-border);
    border-radius: var(--agame-radius);
    overflow: hidden;
}

/* Horizontal separator below progress steps */
.agame-progress-indicator::after {
    content: '';
    display: block;
    height: 1px;
    background: #000;
    margin: 10px 0;
}

.agame-progress-step {
    display: flex;
    align-items: center;
    padding: 16px 20px;
    background: var(--agame-white);
    border: 1px solid var(--agame-border);
    border-radius: var(--agame-radius);
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
    min-height: 60px;
    margin-bottom: 2px;
    font-weight: var(--agame-font-weight-medium);
}

.agame-progress-step::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: transparent;
    transition: all 0.3s ease;
}

.agame-progress-step:hover {
    border-color: var(--agame-secondary);
    transform: translateX(4px);
    box-shadow: var(--agame-shadow-lg);
}

.agame-progress-step:hover::before {
    background: var(--agame-secondary);
}

.agame-progress-step.active {
    background: var(--agame-secondary);
    border-color: var(--agame-secondary);
    color: var(--agame-white);
    box-shadow: var(--agame-shadow);
    font-weight: var(--agame-font-weight-demi);
}

.agame-progress-step.active::before {
    background: var(--agame-white);
    width: 6px;
}

.agame-progress-step.completed {
    background: var(--agame-success);
    border-color: var(--agame-success);
    color: var(--agame-white);
}

.agame-progress-step.completed::before {
    background: var(--agame-secondary);
    width: 6px;
}

.agame-progress-step .step-number {
    width: 32px;
    height: 32px;
    border-radius: 4px;
    background: var(--agame-light-gray);
    color: var(--agame-dark-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--agame-font-weight-demi);
    font-size: 14px;
    margin-right: 16px;
    flex-shrink: 0;
    position: relative;
    transition: all 0.2s ease;
}

.agame-progress-step.active .step-number {
    background: rgba(255, 255, 255, 0.25);
    color: var(--agame-white);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.agame-progress-step.completed .step-number {
    background: rgba(255, 255, 255, 0.2);
    color: var(--agame-white);
}

.agame-progress-step.completed .step-number::after {
    content: '✓';
    position: absolute;
    font-size: 18px;
    font-weight: var(--agame-font-weight-heavy);
}

.agame-progress-step .step-label {
    font-weight: var(--agame-font-weight-demi);
    font-size: var(--agame-font-size-base);
    text-transform: uppercase;
    letter-spacing: 1px;
    flex: 1;
    line-height: 1.2;
}

.agame-progress-step .step-description {
    font-size: 13px;
    opacity: 0.8;
    margin-top: 4px;
    font-weight: var(--agame-font-weight-book);
    text-transform: none;
    letter-spacing: 0.3px;
}

.header-right {
    display: flex;
    align-items: center;
    gap: 12px;
}

.agame-modal-close {
    background: none;
    border: 1px solid var(--agame-border);
    color: var(--agame-dark-gray);
    width: 40px;
    height: 40px;
    cursor: pointer;
    border-radius: var(--agame-radius);
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.agame-modal-close:hover {
    background: var(--agame-light-gray);
    border-color: var(--agame-secondary);
    color: var(--agame-secondary);
}

.agame-config-panel .agame-loading-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.9);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    backdrop-filter: blur(2px);
}

.agame-config-panel .agame-loading-overlay .agame-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--agame-medium-gray);
    border-top: 3px solid var(--agame-secondary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-bottom: 15px;
}

.agame-config-panel .agame-loading-overlay p {
    margin: 0;
    color: var(--agame-dark-gray);
    font-size: var(--agame-font-size-sm);
    font-weight: var(--agame-font-weight-medium);
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Preview Panel - Unified gradient to match content seamlessly */
.agame-preview-panel {
    flex: 1 !important;
    border: none !important;
    display: flex;
    flex-direction: column;
    min-width: 0 !important;
    max-width: 65% !important;
    box-sizing: border-box !important;
    padding-bottom: 180px; /* Aumentado para cubrir sombra y controles */
    padding-left: 0;
    padding-right: 0;
    padding-top: 0;
    background: linear-gradient(to bottom, #d9dde2 0%, #d4d8dc 25%, #eaeff5 50%, #f0f3f7 75%, #f5f7fa 100%);
    position: relative;
}

.agame-preview-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--agame-border);
}

.agame-preview-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
}

.agame-preview-controls {
    display: flex;
    gap: 8px;
}

.agame-preview-btn {
    width: 36px;
    height: 36px;
    border: 1px solid var(--agame-border);
    background: var(--agame-white);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    color: var(--agame-primary);
}

#agame-garment-preview {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    position: relative;
}

/* Ensure SVG container has proper overflow handling */
.agame-garment-container {
    overflow: visible;
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Allow overflow in dual view to accommodate larger overlays */
.agame-preview-dual .agame-garment-container {
    overflow: visible !important;
    width: 780px !important;
    max-width: 780px !important;
    height: 468px !important;
    max-height: 468px !important;
}

/* Apply clip-path to SVG to prevent any bleeding */
.agame-garment-container svg {
    clip-path: inset(0 0 0 0);
    /* Consistent size for all templates */
    width: 390px;
    height: 468px;
    max-width: 390px;
    max-height: 468px;
    isolation: isolate; /* Create stacking context */
}

/* Additional styling for front/back views to prevent bleeding */
.agame-garment-container svg.view-front {
    overflow: hidden;
    /* Consistent size for all templates */
    width: 390px;
    height: 468px;
    max-width: 390px;
    max-height: 468px;
    /* Ensure front view doesn't show any back elements */
    /* TEMPORARILY DISABLED - CAUSING SVG TO BE INVISIBLE */
    /* mask: url(#front-mask); */
    /* -webkit-mask: url(#front-mask); */
}

.agame-garment-container svg.view-back {
    overflow: hidden;
    /* Consistent size for all templates */
    width: 390px;
    height: 468px;
    max-width: 390px;
    max-height: 468px;
    /* Ensure back view doesn't show any front elements */
    /* TEMPORARILY DISABLED - CAUSING SVG TO BE INVISIBLE */
    /* mask: url(#front-mask); */
    /* -webkit-mask: url(#front-mask); */
}

.agame-garment-container svg.view-dual {
    overflow: visible;
    /* Dual view: each half = 390x468 (same as single view), total = 780x468 */
    max-width: 780px !important;
    max-height: 468px !important;
    width: 780px !important;
    height: 468px !important;
}

/* Hide any potential overflow from SVG elements */
.agame-garment-container svg * {
    transform-box: fill-box;
    transform-origin: center;
}

.agame-preview-placeholder {
    text-align: center;
    color: var(--agame-text-light);
}

.agame-placeholder-icon {
    margin-bottom: 20px;
    color: var(--agame-border);
}

.agame-preview-placeholder h4 {
    margin: 0 0 10px 0;
    font-size: 18px;
    color: var(--agame-primary);
}

.agame-preview-placeholder p {
    margin: 0;
    font-size: 14px;
    color: var(--agame-text-light);
}

.XXagame-preview-footer {
    background: var(--agame-white);
    padding: 5px;
    border-radius: 8px;
    border: none !important;
}

.agame-design-info {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.agame-info-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.agame-info-label {
    font-size: 12px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-text-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.agame-info-value {
    font-size: 14px;
    font-weight: var(--agame-font-weight-medium);
    color: var(--agame-primary);
}

/* Modal Body */
.agame-modal-body {
    flex: 1 !important;
    overflow: auto !important;
    padding: 20px !important;
    display: flex !important;
    flex-direction: row !important; /* Default horizontal layout */
    gap: 20px !important;
}

/* Configurator Layout within Modal - New Layout */
.agame-modal .agame-configurator-layout {
    display: flex !important;
    width: 100% !important;
    height: 100% !important;
}

/* Preview Panel (Left Side) */
.agame-modal .agame-preview-panel {
    flex: 0 0 400px !important;
    min-width: 400px !important;
    display: flex !important;
    flex-direction: column !important;
    order: 1 !important;
}

/* Config Panel (Center) */
.agame-modal .agame-config-panel {
    flex: 1 !important;
    max-height: 100% !important;
    overflow-y: auto !important;
    padding: 0 30px 0 20px !important;
    order: 2 !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
}

/* Steps Panel (Right Side) */
.agame-modal .agame-steps-panel {
    flex: 0 0 200px !important;
    min-width: 200px !important;
    padding: 20px !important;
    background: var(--agame-light-gray) !important;
    order: 3 !important;
    overflow-y: auto !important;
}

.agame-config-step {
    border-bottom: none !important;
    display: none;
}

.agame-config-step.active {
    display: block;
}

/* Duplicate selector removed - consolidated above */

.agame-config-step:not(:first-child) .agame-step-header {
    border-top: 1px solid #d7dfe4;
    margin-left: -30px;
    margin-right: -30px;
    padding-left: 30px;
    padding-right: 30px;
}

.agame-step-header p {
    margin: 0;
    font-size: 14px;
    color: var(--agame-text-light);
}

/* Duplicate selector removed - consolidated above */

/* Sport Grid Styling */
.agame-sport-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 15px;
}

.agame-sport-option {
    background: var(--agame-white);
    border: 2px solid var(--agame-border);
    border-radius: 0;
    padding: 15px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.agame-sport-option:hover {
    border-color: var(--agame-secondary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(10, 197, 226, 0.2);
}

.agame-sport-option.selected {
    border-color: var(--agame-secondary);
    background: rgba(10, 197, 226, 0.1);
}

.agame-sport-icon {
    margin-bottom: 10px;
    color: var(--agame-secondary);
}

.agame-sport-icon img {
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.agame-sport-name h4 {
    margin: 0 0 5px 0;
    font-size: 14px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
}

.agame-sport-name p {
    margin: 0;
    font-size: 12px;
    color: var(--agame-text-light);
}

/* Template Grid  */
.agame-template-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, 80px);
        gap: 15px;
        margin-bottom: 24px;
        position: relative;
        justify-content: start;
    }

.agame-template-option {
        background: var(--agame-white);
        border: 1px solid var(--agame-border);
        border-radius: var(--agame-radius);
        padding: 4px;
        text-align: center;
        cursor: pointer;
        transition: all 0.2s ease;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2px;
        width: 80px;
        height: auto;
        position: relative;
        box-shadow: none;
    }

.agame-template-option:hover {
    border-color: var(--agame-secondary);
    transform: none;
    box-shadow: var(--agame-shadow);
}

.agame-template-option.selected {
    border-color: var(--agame-secondary);
    box-shadow: var(--agame-shadow);
    transform: none;
    background: rgba(10, 197, 226, 0.1);
}

.agame-template-option.selected::after {
    content: '✓';
    position: absolute;
    top: 6px;
    right: 6px;
    width: 18px;
    height: 18px;
    background: var(--agame-secondary);
    color: var(--agame-white);
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: var(--agame-font-weight-demi);
    z-index: 2;
}

.agame-template-option svg {
    max-width: 100%;
    height: auto;
    max-height: 120px;
    width: auto;
    transition: transform 0.2s ease;
}

.agame-template-option:hover svg {
    transform: scale(1.05);
}

.agame-template-option h4 {
    display: none;
}

.agame-template-preview {
    width: 100%;
    height: 80px;
    background: var(--agame-light-gray);
    border-radius: 5px;
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.agame-template-preview svg {
    max-width: 80%;
    max-height: 80%;
}

.agame-template-preview img.agame-template-thumbnail {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 3px;
}

.agame-template-name {
    display: none;
}

/* Loading and Empty States */
.agame-loading-state {
    text-align: center;
    padding: 40px 20px;
    color: var(--agame-text-light);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(255, 255, 255, 0.9);
    border-radius: 8px;
    z-index: 10;
    min-width: 200px;
}

.agame-spinner {
    display: inline-block;
    width: 40px;
    height: 40px;
    border: 4px solid var(--agame-border);
    border-radius: 50%;
    border-top-color: var(--agame-secondary);
    animation: agame-spin 1s ease-in-out infinite;
    margin-bottom: 15px;
}

.agame-empty-state {
    text-align: center;
    padding: 40px 20px;
    color: var(--agame-text-light);
}

.agame-empty-icon {
    margin-bottom: 15px;
    color: var(--agame-border);
}

.agame-empty-state h4 {
    margin: 0 0 10px 0;
    font-size: 16px;
    color: var(--agame-primary);
}

.agame-empty-state p {
    margin: 0;
    font-size: 14px;
}

/* Color Customization */
.agame-color-zones {
    margin-bottom: 20px;
    margin-top: 0; /* Fixed overlap issue with separator line */
}

.agame-color-zone {
    margin-bottom: 5px; /* Reduced from 15px to 5px (10px less) */
    padding: 0 5px;
    background: white;
    border-radius: 0;
    border: 1px solid #e3e3e3;
}

.agame-zone-label {
    font-size: 14px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
    margin-bottom: 0;
    display: flex;
    align-items: center;
    height: 30px;
    cursor: pointer;
    position: relative;
    padding-right: 20px;
}

.agame-zone-label::after {
    content: '';
    position: absolute;
    right: 10px;
    top: 50%;
    width: 6px;
    height: 6px;
    border-right: 2px solid #000;
    border-bottom: 2px solid #000;
    transform: translateY(-50%) rotate(-45deg);
    transition: transform 0.3s ease;
}

.agame-color-zone.open .agame-zone-label::after {
    transform: translateY(-50%) rotate(45deg);
}

.agame-color-zone.open .agame-zone-label {
    background: var(--agame-light-gray);
}

.agame-color-zone.open {
    background: var(--agame-light-gray);
}

/* Dropdown body for each color zone - closed by default */
.agame-color-zone .agame-zone-body { display: none; }
.agame-color-zone.open .agame-zone-body { display: block; }

.agame-color-options {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    background: var(--agame-light-gray);
    padding: 8px;
    border-radius: 4px;
}

.agame-color-option {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid var(--agame-white);
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

.agame-color-option:hover {
    transform: scale(1.05);
    border-color: var(--agame-primary);
}

.agame-color-option.selected {
    border-color: var(--agame-primary);
    transform: scale(1.05);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    border-width: 3px;
}



/* Detail Zones - Same styling as Color Zones */
.agame-detail-zone {
    margin-bottom: 5px;
    padding: 0 5px;
    background: white;
    border-radius: 0;
    border: 1px solid #e3e3e3;
}

.agame-detail-zone .agame-zone-label {
    font-size: 14px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
    margin-bottom: 0;
    display: flex;
    align-items: center;
    height: 30px;
    cursor: pointer;
    position: relative;
    padding-right: 20px;
}

.agame-detail-zone .agame-zone-label::after {
    content: '';
    position: absolute;
    right: 10px;
    top: 50%;
    width: 6px;
    height: 6px;
    border-right: 2px solid #000;
    border-bottom: 2px solid #000;
    transform: translateY(-50%) rotate(-45deg);
    transition: transform 0.3s ease;
}

.agame-detail-zone.open .agame-zone-label::after {
    transform: translateY(-50%) rotate(45deg);
}

.agame-detail-zone.open .agame-zone-label {
    background: var(--agame-light-gray);
}

.agame-detail-zone.open {
    background: var(--agame-light-gray);
}

/* Dropdown body for each detail zone - closed by default */
.agame-detail-zone .agame-zone-body { display: none; }
.agame-detail-zone.open .agame-zone-body { display: block; }

.agame-detail-options {
    background: var(--agame-light-gray);
    padding: 10px;
    border-radius: 4px;
}

/* Position and Bib Color Palettes - Match other color zones */
#position-color-palette,
#bib-color-palette {
    margin-bottom: 20px;
}

#position-color-palette .agame-zone-label,
#bib-color-palette .agame-zone-label {
    font-size: 14px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
    margin-bottom: 10px;
    display: block;
    letter-spacing: 0.5px;
}

#position-color-palette .agame-color-options,
#bib-color-palette .agame-color-options {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}

/* Personalization */
.agame-personalization {
    margin-bottom: 20px;
}

.agame-personalization-group {
    margin-bottom: 20px;
    padding: 15px;
    background: var(--agame-light-gray);
    border-radius: 8px;
}

.agame-personalization-label {
    font-size: 14px;
    font-weight: var(--agame-font-weight-demi);
    color: var(--agame-primary);
    margin-bottom: 10px;
    display: block;
}

.agame-personalization input {
    width: 100%;
    padding: 10px 15px;
    border: 1px solid var(--agame-border);
    border-radius: 5px;
    font-size: 14px;
    transition: border-color 0.3s ease;
}

.agame-personalization input:focus {
    outline: none;
    border-color: var(--agame-secondary);
    box-shadow: 0 0 0 2px rgba(10, 197, 226, 0.2);
}

.agame-font-options {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 10px;
    margin-top: 10px;
}

.agame-font-option {
    background: var(--agame-white);
    border: 2px solid var(--agame-border);
    border-radius: 5px;
    padding: 10px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 14px;
}

.agame-font-option:hover {
    border-color: var(--agame-secondary);
}

.agame-font-option.selected {
    border-color: var(--agame-secondary);
    background: rgba(10, 197, 226, 0.1);
}

.agame-price-display {
    font-size: 24px;
    font-weight: bold;
    color: var(--agame-primary);
}

.agame-modal-actions {
    display: flex;
    gap: 15px;
}

/* Buttons - Brand Compliant */
.agame-btn {
    padding: 12px 24px;
    border: none;
    border-radius: 0px;
    font-size: var(--agame-font-size-base);
    font-weight: var(--agame-font-weight-bold);
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    position: relative;
    min-height: 44px;
    background: var(--agame-secondary);
    color: var(--agame-white);
    box-shadow: var(--agame-shadow);
}

.agame-btn:hover {
    background: var(--agame-secondary);
    box-shadow: var(--agame-shadow-lg);
    transform: translateY(-1px);
}

.agame-btn-primary {
    background: var(--agame-primary);
    color: var(--agame-white);
    border: 1px solid var(--agame-primary);
}

.agame-btn-primary:hover {
    background: var(--agame-primary);
    color: var(--agame-secondary);
    box-shadow: var(--agame-shadow-lg);
    transform: translateY(-1px);
}

.agame-btn-secondary {
    background: var(--agame-secondary);
    color: var(--agame-white);
}

.agame-btn-secondary:hover {
    background: var(--agame-secondary);
    color: var(--agame-primary);
    box-shadow: var(--agame-shadow-lg);
    transform: translateY(-1px);
}

.agame-btn-outline {
    background: transparent;
    border: 1px solid var(--agame-secondary);
    color: var(--agame-secondary);
    padding: 12px 24px;
    min-width: 60px;
    font-size: var(--agame-font-size-base);
    min-height: 44px;
}

.agame-btn-outline:hover {
    background: var(--agame-secondary);
    color: var(--agame-white);
    box-shadow: var(--agame-shadow);
    transform: translateY(-1px);
}

.agame-btn-ghost {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: var(--agame-white);
    backdrop-filter: blur(10px);
}

.agame-btn-ghost:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.4);
}

.agame-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}



.agame-btn-large {
    padding: 18px 36px;
    font-size: var(--agame-font-size-lg);
    min-height: 56px;
}

.agame-btn-small {
    padding: 10px 20px;
    font-size: var(--agame-font-size-sm);
    min-height: 40px;
}

/* Navigation Buttons */
.agame-step-navigation {
    padding: 20px 20px 20px 0;
    margin-right: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    box-sizing: border-box;
    overflow: visible;
}

.agame-step-navigation .agame-btn {
    flex: 1;
    min-height: 38px; /* 3px less */
}

/* Ensure consistent button sizing at all breakpoints */
.agame-step-navigation .agame-btn,
#template-navigation .agame-btn {
    flex: 1;
    min-width: 0;
    max-width: none;
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 600;
}

/* Preview controls footer */
.preview-controls-footer {
    display: flex;
    justify-content: center;
    gap: 10px;
    align-items: center;
}

/* View toggle container */
.agame-view-toggle-container {
    display: none;
}

/* Template navigation */
#template-navigation {
    display: none;
    margin-top: 20px;
    justify-content: flex-end;
}

#template-navigation.agame-step-navigation {
    display: flex;
    justify-content: flex-end;
}

/* Design step next button - specific styling */
#template-navigation .agame-btn {
    flex: 0 0 auto;
    width: 50%;
    min-width: 0;
    max-width: 50%;
}

/* Color navigation buttons */
.color-navigation-buttons.agame-step-navigation {
    margin-top: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* Step navigation containers */
.step-navigation.agame-step-navigation {
    margin-top: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.agame-nav-btn {
    background: var(--agame-white);
    border: 2px solid var(--agame-border);
    color: var(--agame-dark-gray);
    padding: 12px 24px;
    border-radius: 8px;
    font-weight: var(--agame-font-weight-demi);
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.agame-nav-btn:hover {
    border-color: var(--agame-main-btn);
    color: var(--agame-main-btn);
    transform: translateY(-1px);
    box-shadow: var(--agame-shadow);
}

.agame-nav-btn.next {
    background: var(--agame-secondary);
    border-color: var(--agame-secondary);
    color: var(--agame-white);
}

.agame-nav-btn.next:hover {
    background: #0bb5d1;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(10, 197, 226, 0.3);
}

/* Loading States */
.agame-loading {
    display: inline-block;
    width: 40px;
    height: 40px;
    border: 4px solid var(--agame-border);
    border-radius: 50%;
    border-top-color: var(--agame-secondary);
    animation: agame-spin 1s ease-in-out infinite;
}

/* Hide loading states that get stuck */
.agame-loading-state:has(.agame-template-grid:not(:empty)) {
    display: none !important;
}

.agame-loading-text {
    display: none !important;
}

/* Hide inline configurator when modal is open */
.agame-modal-open main .agame-configurator-layout {
    display: none !important;
}

/* Subtle Color Transitions - Ultra smooth without visible effects */
#agame-garment-preview svg path[id*="zone"],
#agame-garment-preview svg g[id*="zone"] path {
    transition: fill 0.15s linear;
}

/* Prevent any transitions during initial load */
#agame-garment-preview.initial-load svg * {
    transition: none !important;
}

/* SVG Blend Modes */
#agame-garment-preview g[blend-mode="screen"] { mix-blend-mode: screen; }
#agame-garment-preview g[blend-mode="multiply"] { mix-blend-mode: multiply; }
#agame-garment-preview g[blend-mode="color-burn"] { mix-blend-mode: color-burn; }

/* PNG Overlay System for Realistic Shadows and Highlights */
.agame-garment-container {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    isolation: isolate;
}

/* SVG sizing within garment container - consistent size for all templates */
.agame-garment-container svg {
    max-width: 390px;
    max-height: 468px !important;
    width: 390px;
    height: 468px !important;
    display: block;
    margin: 0 auto;
}

/* Fixed-canvas templates (1000x600 artboard, 500x600 per side) — larger display size */
.agame-garment-container svg.fixed-canvas.view-front,
.agame-garment-container svg.fixed-canvas.view-back {
    width: 390px !important;
    height: 468px !important;
    max-width: 390px !important;
    max-height: 468px !important;
}

.agame-overlay-layer {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    max-width: 390px;
    max-height: 468px;
    pointer-events: none;
    z-index: 10;
    background-color: transparent;
    animation: agameOverlayFadeIn 0.3s ease-in;
}

@keyframes agameOverlayFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* Overlay size for fixed-canvas templates */
.agame-garment-container:has(svg.fixed-canvas) .agame-overlay-layer {
    max-width: 390px;
    max-height: 468px;
}

/* Fix SVG alignment for back view - compensate for viewBox shift */
.agame-preview-back .agame-overlay-layer {
    transform: translate(-50%, -50%);
}

.agame-overlay-layer img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
}

/* Overlay Blend Modes */
.agame-overlay-screen {
    mix-blend-mode: screen;
}

.agame-overlay-multiply {
    mix-blend-mode: multiply;
}

.agame-overlay-color-burn {
    mix-blend-mode: color-burn;
}

/* View-specific overlays */
.agame-overlay-front {
    display: block;
}

.agame-overlay-back {
    display: none;
}

.agame-preview-back .agame-overlay-front {
    display: none;
}

.agame-preview-back .agame-overlay-back {
    display: block;
}

/* Base dual view overlay styles - positioned relative to SVG container to follow on resize */
.agame-preview-dual .agame-overlay-layer {
    display: block !important;
    position: absolute !important;
    top: 50%;
    left: 50%;
    pointer-events: none !important;
    z-index: 10 !important;
}

/* Front overlays in dual view - positioned to left side of center 
.agame-preview-dual .agame-overlay-layer.agame-overlay-front {

}

Back overlays in dual view - positioned to right side of center
.agame-preview-dual .agame-overlay-layer.agame-overlay-back {

}  */

/* Specific overlay types - front (maintain same blend modes as single view) */
.agame-preview-dual .agame-overlay-layer.agame-overlay-front.agame-overlay-shadow,
.agame-preview-dual .agame-overlay-layer.agame-overlay-front.agame-overlay-highlight,
.agame-preview-dual .agame-overlay-layer.agame-overlay-front.agame-overlay-overlay {
    /* Position front overlays anchored to the center of the left half */
    left: 25%;
    top: 50%;
    transform: translate(-50%, -50%) !important;
    width: 50% !important;
    max-width: 50% !important;
    height: 100% !important;
    max-height: 100% !important;
}

/* Specific overlay types - back (maintain same blend modes as single view) */
.agame-preview-dual .agame-overlay-layer.agame-overlay-back.agame-overlay-shadow,
.agame-preview-dual .agame-overlay-layer.agame-overlay-back.agame-overlay-highlight,
.agame-preview-dual .agame-overlay-layer.agame-overlay-back.agame-overlay-overlay {
    /* Position back overlays anchored to the center of the right half */
    left: 75%;
    top: 50%;
    transform: translate(-50%, -50%) !important;
    width: 50% !important;
    max-width: 50% !important;
    height: 100% !important;
    max-height: 100% !important;
}

/* Dual view overlays will inherit blend modes from JavaScript based on garment color */
/* Blend modes are dynamically set by updateOverlayBlendModes() function */

/* Fix overlay positioning stability at responsive breakpoints */
@media (max-width: 1200px) {
    .agame-preview-dual .agame-overlay-layer.agame-overlay-front.agame-overlay-shadow,
    .agame-preview-dual .agame-overlay-layer.agame-overlay-front.agame-overlay-highlight,
    .agame-preview-dual .agame-overlay-layer.agame-overlay-front.agame-overlay-overlay {
        /* Ensure consistent positioning regardless of container changes */
        position: absolute !important;
        transform: translate(-50%, -50%) !important;
        top: 50% !important;
        left: 25% !important;
        will-change: transform;
    }
    
    .agame-preview-dual .agame-overlay-layer.agame-overlay-back.agame-overlay-shadow,
    .agame-preview-dual .agame-overlay-layer.agame-overlay-back.agame-overlay-highlight,
    .agame-preview-dual .agame-overlay-layer.agame-overlay-back.agame-overlay-overlay {
        /* Ensure consistent positioning regardless of container changes */
        position: absolute !important;
        transform: translate(-50%, -50%) !important;
        top: 50% !important;
        left: 75% !important;
        /* Add will-change to optimize positioning performance */
        will-change: transform;
    }
    
    /* Ensure preview content maintains stable dimensions */
    .agame-preview-content {
        /* Force consistent height calculation */
        min-height: 400px !important;
        height: auto !important;
        /* Prevent layout shifts */
        contain: layout style !important;
    }
}

@keyframes agame-spin {
    to { transform: rotate(360deg); }
}

/* Single view shadow - BAJADA MAS PARA QUE NO SE CORTE */
.agame-single-shadow {
    position: absolute !important;
    bottom: -140px !important;
    left: 50% !important;
    transform: translate(-50%, 0) scaleX(1.2) scaleY(0.15) !important;
    width: 300px !important;
    height: 200px !important;
    background: radial-gradient(circle, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.2) 40%, transparent 70%) !important;
    border-radius: 50% !important;
    filter: blur(5px) !important;
    z-index: 1 !important;
}

/* HIDE PSEUDO-ELEMENT SHADOWS ONLY IN DUAL VIEW - THEY CONFLICT WITH DUAL SHADOWS */
.agame-preview-content.agame-preview-dual::before,\n.agame-preview-content.agame-preview-dual::after {
    display: none !important;
    content: none !important;
    visibility: hidden !important;
    background: none !important;
}

/* Hide single shadow in dual view */
.agame-preview-dual .agame-single-shadow {
    display: none !important;
}

/* Dual shadow elements - positioned under each garment view */
.agame-dual-shadow {
    position: absolute !important;
    bottom: -128px !important;
    width: 200px !important;
    height: 180px !important;
    background: radial-gradient(circle, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.2) 40%, transparent 70%) !important;
    border-radius: 50% !important;
    filter: blur(10px) !important;
    transform: scaleX(1.1) scaleY(0.15); 
    z-index: 1 !important;
}

/* Screens under 768px */
@media screen and (max-width: 768px) {
    .agame-dual-shadow {
        bottom: -128px !important;
    }
    
    .preview-controls-overlay {
        bottom: -165px !important;
    }
    
    .agame-preview-dual .preview-controls-overlay {
        bottom: -160px !important;
    }
}

@media screen and (max-width: 480px) {
    .agame-dual-shadow {
        bottom: -128px !important;
    }
}

/* JavaScript-controlled responsive positioning - no fixed percentages */
.agame-dual-front-shadow {
    /* Will be set dynamically by JavaScript */
}

.agame-dual-back-shadow {
    /* Will be set dynamically by JavaScript */
}


.quote-display-box {
    margin-top: 10px;
    margin-bottom: 20px;
    margin-right: 20px;
    padding: 20px;
    background: #ffffff;
    color: #191919;
    font-family: 'Futura PT', 'Avenir Next', 'Avenir', 'Century Gothic', 'Trebuchet MS', sans-serif;
    box-shadow: 0 4px 15px rgba(25, 25, 25, 0.2);
    animation: slideInUp 0.4s ease-out;
    width: auto !important;
    min-width: 300px !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* WordPress Theme Override for Quote Display - Responsive Modal */
body.agame-modal-open .quote-display-box,
.wp-site-blocks .quote-display-box,
.site-content .quote-display-box {
    width: auto !important;
    min-width: 300px !important;
    max-width: 400px !important;
    box-sizing: border-box !important;
    margin-left: -10px !important;
    margin-right: auto !important;
    margin-top: 10px !important;
    margin-bottom: 20px !important;
}

/* Responsive Quote Display - Media Queries for Better Viewport Adaptation */
@media screen and (min-width: 768px) {
    body.agame-modal-open .quote-display-box,
    .wp-site-blocks .quote-display-box,
    .site-content .quote-display-box {
        max-width: 500px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
}

@media screen and (min-width: 1024px) {
    body.agame-modal-open .quote-display-box,
    .wp-site-blocks .quote-display-box,
    .site-content .quote-display-box {
        max-width: 600px !important;
    }
}

@media screen and (min-width: 1200px) {
    body.agame-modal-open .quote-display-box,
    .wp-site-blocks .quote-display-box,
    .site-content .quote-display-box {
        max-width: 700px !important;
    }
}

@media screen and (min-width: 1440px) {
    body.agame-modal-open .quote-display-box,
    .wp-site-blocks .quote-display-box,
    .site-content .quote-display-box {
        max-width: 800px !important;
    }
}

.quote-title {
    text-align: center;
    margin-bottom: 12px;
    color: #0BB3EB;
    font-weight: 600;
    font-size: 12px;
    text-transform: uppercase;
}

.quote-details-section {
    background: rgba(255, 255, 255, 0.95);
    padding: 15px;
    border-radius: 0px;
    color: #191919;
}

.quote-row {
    display: flex;
    align-items: baseline;
    margin-bottom: 4px;
    font-size: 14px;
}

.quote-row span:first-child {
    color: #0BB3EB;
    font-weight: 600;
    width: 140px;
    flex-shrink: 0;
    margin-right: 15px;
    text-align: left;
}

.quote-row span:last-child {
    color: #191919;
    font-weight: 500;
    flex: 1;
    text-align: left;
}

.quote-total {
    display: flex;
    align-items: baseline;
    font-size: 16px;
    font-weight: 700;
}

.quote-total span:first-child {
    color: #0BB3EB;
    width: 140px;
    flex-shrink: 0;
    margin-right: 15px;
    text-align: left;
}

.quote-total span:last-child {
    color: #191919;
    flex: 1;
    text-align: left;
}

.quote-actions {
    text-align: center;
    margin-top: 15px;
}

.quote-start-over-btn {
    background: rgba(10, 198, 227, 0.2);
    color: #0BB3EB;
    border: 2px solid rgba(10, 198, 227, 0.3);
    padding: 8px 16px;
    border-radius: 0px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    font-family: 'Futura PT', sans-serif;
    transition: all 0.3s ease;
}

.quote-start-over-btn:hover {
    background: rgba(10, 198, 227, 0.3);
    border-color: rgba(10, 198, 227, 0.5);
}

@keyframes slideInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.quote-message.error {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

/* WordPress Theme Override - Force modal dimensions - Full Width */
body.agame-modal-open .agame-modal-overlay .agame-modal,
.wp-site-blocks .agame-modal-overlay .agame-modal,
.site-content .agame-modal-overlay .agame-modal {
    width: 100vw !important;
    max-width: none !important;
    min-width: 320px !important;
    height: 95vh !important;
    margin: 0 !important;
    left: 0 !important;
    right: 0 !important;
    box-sizing: border-box !important;
    position: fixed !important;
    display: flex !important;
    flex-direction: column !important;
    z-index: 999999 !important;
}

/* Use flex column layout so steps can stretch */
.agame-modal .agame-steps-panel {
    display: flex !important;
    flex-direction: column !important;
}

/* Prevent unintended shrinking of steps */
.agame-modal .agame-steps-panel > .agame-config-step {
    flex-shrink: 0;
}

/* Allow last active step to grow */
.agame-modal .agame-steps-panel > .agame-config-step.active:last-child {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

/* Stretch its inner content */
.agame-modal .agame-steps-panel > .agame-config-step.active:last-child .agame-step-content {
    flex: 1 0 auto;
}

/* View Toggle Buttons */
.agame-view-toggle {
    display: flex;
    gap: 5px;
    margin-right: 10px;
}

.agame-view-btn {
    padding: 12px 18px;
    background: var(--agame-primary);
    color: var(--agame-white);
    border: none;
    border-radius: 0px;
    cursor: pointer;
    font-size: 14px;
    font-weight: var(--agame-font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
    min-width: 70px;
    text-align: center;
    min-height: 44px;
}

.agame-view-btn:hover {
    background: var(--agame-primary);
    color: var(--agame-secondary);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(22, 22, 22, 0.3);
}

.preview-controls-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: 15px;
    padding: 10px 0;
}

.agame-view-toggle-container {
    display: flex;
    align-items: center;
}

/* Side arrows for single view switching */
.agame-side-arrows {
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 20;
    right: 0;
    transform: translateY(-50%);
    pointer-events: none; /* container ignores events; buttons are interactive */
}

.agame-side-arrow {
    position: absolute;
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    cursor: pointer;
    color: var(--agame-gray);
    padding: 0;
    pointer-events: auto; /* enable clicks */
}

.agame-side-arrow svg {
    width: 42px;
    height: 42px;
    stroke: var(--agame-gray);
    stroke-width: 2.5;
}

.agame-side-arrow-left { left: 8px; }
.agame-side-arrow-right { right: 8px; }

.agame-side-arrow:hover svg {
    stroke: var(--agame-gray);
}

/* Hide arrows in dual view (quote step shows both sides) */
.agame-preview-dual .agame-side-arrows,
#agame-preview-content.agame-preview-dual .agame-side-arrows {
    display: none !important;
}

#template-navigation {
    display: flex;
    justify-content: flex-end;
    margin-top: 20px;
    padding: 15px 0;
}

.color-navigation-buttons.agame-step-navigation {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    padding: 15px 0;
    gap: 10px;
}

.step-navigation.agame-step-navigation {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    padding: 15px 0;
    gap: 10px;
}

.agame-configurator-layout.inline-layout {
    width: 100%;
    min-height: 600px;
    height: auto;
    display: flex;
    flex-direction: row;
    padding: 25px;
    background: white;
    border-radius: 0px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    overflow: visible;
}

.netball-kit-title {
    font-weight: bold;
    font-size: 24px;
    margin: 0 0 -19px 0;
    color: white;
    background-color: black;
    text-align: left;
    position: relative;
    top: -31px;
    padding: 12px 32px;
    margin-left: -32px;
    margin-right: -32px;
    border-radius: 0;
}

.step-title {
    font-weight: bold;
    font-size: 28px;
    margin: 0;
    margin-bottom: 10px;
}

.step-header-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    margin-bottom: 10px;
    padding-bottom: 0px;
}

.step-header-content .step-title {
    margin-bottom: 0;
    padding-bottom: 5px; /* Consistent vertical centering for all step titles */
}

.step-subtitle {
    font-size: 16px;
}

/* Dropdown arrow icon styles (replaced checkmark) */
.checkmark-icon {
    width: 20px;
    height: 20px;
    border: 2px solid var(--agame-main-btn);
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--agame-main-btn);
    flex-shrink: 0;
    margin-top: -2px;
    transition: transform 0.3s ease;
}

.checkmark-icon svg {
    width: 16px;
    height: 16px;
    stroke: white;
    stroke-width: 2;
    fill: none;
}

/* Rotate arrow when step is active/expanded */
.agame-config-step.active .checkmark-icon {
    transform: rotate(180deg);
}

/* Share button styles */
.agame-share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    border: none;
    background: var(--agame-primary);
    color: var(--agame-white);
    border-radius: 0px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-family: var(--agame-font-family);
    font-size: 14px;
    font-weight: var(--agame-font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    min-height: 44px;
    gap: 8px;
}

.agame-share-btn:hover {
    background: var(--agame-primary);
    color: var(--agame-secondary);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(22, 22, 22, 0.3);
}

/* Hidden elements by default */
#color-zones,
#color-empty,
#request-quote {
    display: none;
}

/* Previous button should be visible in colors step */
#prev-step-colors {
    display: inline-flex;
}

/* Show elements when needed */
#color-zones.show,
#color-empty.show,
#prev-step-colors.show,
#request-quote.show {
    display: block;
}

#prev-step-colors.show {
    display: inline-flex;
}

.quote-form {
background: #ffffff;
padding-top: 27px;
padding-right: 27px;
padding-bottom: 27px;
padding-left: 30px;
position: relative;
transform: translateZ(0);
box-shadow: 
    0 2px 10px rgba(0, 0, 0, 0.1),
    0 0 0 1px rgba(0, 0, 0, 0.05);
transition: all 0.3s ease;
border: 1px solid #e8e8e8;
margin-left: 0px;
flex: 1;
display: flex;
flex-direction: column;
}

.quote-form .form-section {
    margin-bottom: 20px;
}

.quote-form .form-section h4 {
    color: #0BB3EB;
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 15px;
    padding-bottom: 6px;
    border-bottom: 2px solid #0BB3EB;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.quote-form .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin-bottom: 15px;
}

.quote-form .form-group {
    display: flex;
    flex-direction: column;
}

.quote-form .form-group.full-width {
    grid-column: 1 / -1;
}

.quote-form label {
    color: #333333;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.agame-form-input {
    padding: 10px 14px;
    border: 2px solid #e8e8e8;
    border-radius: 0;
    font-size: 15px;
    font-family: inherit;
    background: #ffffff;
    transition: all 0.3s ease;
    outline: none;
}

.agame-form-input:focus {
    border-color: #0ac5e2;
    box-shadow: 0 0 0 3px rgba(10, 197, 226, 0.1);
    background: #fafbfc;
}

.agame-form-input:hover {
    border-color: #0ac5e2;
}

.agame-form-input::placeholder {
    color: #999999;
    font-style: italic;
}

/* Quote Form Layout */
.quote-form-container {
    display: flex;
    flex-direction: column;
    gap: 15px;
    width: 100%;
    margin-left: -15px;
}

.quote-form-container .form-group {
    width: 100%;
    margin-bottom: 0;
}

.quote-form-container .agame-form-input {
    width: 100%;
    box-sizing: border-box;
}

.form-help {
    font-size: 12px;
    color: #666;
    margin-top: 8px;
    font-style: italic;
}

/* Submit Button Styling */
.quote-form .agame-btn-primary {
    background: linear-gradient(135deg, #161616 0%, #444444 100%);
    border: none;
    padding: 12px 24px;
    font-size: var(--agame-font-size-base);
    font-weight: var(--agame-font-weight-demi);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(22, 22, 22, 0.3);
    transition: all 0.3s ease;
    min-height: 44px;
    margin-top: 0;
}

.quote-form .agame-btn-primary:hover {
    box-shadow: 0 6px 20px rgba(22, 22, 22, 0.4);
    transform: translateY(-2px);
}

.quote-form .agame-btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 2px 10px rgba(22, 22, 22, 0.3);
}



.quote-form .agame-btn-primary::before {
  position: absolute;
  content: "";
  width: calc(100% + 4px);
  height: calc(100% + 4px);
  left: -2px;
  top: -2px;
  background: linear-gradient(
    124deg,
    #ff2400,
    #e81d1d,
    #e8b71d,
    #e3e81d,
    #1de840,
    #1ddde8,
    #2b1de8,
    #dd00f3,
    #dd00f3
  );
  background-size: 400%;
  z-index: -1;
  filter: blur(5px);
  animation: move 20s linear infinite;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}

.quote-form .agame-btn-primary:hover::before {
  opacity: 1;
}

.quote-form .agame-btn-primary::after {
  z-index: -1;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #161616 0%, #444444 100%);
  left: 0;
  top: 0;
}

@keyframes move {
  0% {
    background-position: 0 0;
  }
  50% {
    background-position: 400% 0;
  }
  100% {
    background-position: 0 0;
  }
}




/* Quote Form Styles - NO RESPONSIVE RULES */

/* Fullscreen Preview Modal Styles */
.fullscreen-modal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0,0,0,0.9) !important;
    z-index: 10000 !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
}

.fullscreen-modal.show {
    display: flex !important;
}

.fullscreen-modal .fullscreen-content {
    position: relative !important;
    width: 357px !important;
    height: 600px !important;
    background: white !important;
    border-radius: 8px !important;
    padding: 20px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
}

.fullscreen-modal .fullscreen-header {
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    display: flex !important;
    gap: 10px !important;
    z-index: 10001 !important;
}

.fullscreen-modal .fullscreen-share {
    background: #0bb3eb !important;
    color: white;
    border: none;
    padding: 8px 12px;
    border-radius: 4px;
    cursor: pointer;
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
    font-family: var(--agame-font-family);
    font-size: 16px !important;
}

.fullscreen-modal .fullscreen-close {
    background: var(--agame-close-btn) !important;
    color: white !important;
    border: none !important;
    padding: 8px 12px !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    font-size: 20px !important;
}

.fullscreen-modal #fullscreen-preview-content {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 317px !important;
    height: 545px !important;
    margin: 5px auto 0 !important;
    overflow: visible !important;
    padding-top: 12px !important;
}

.fullscreen-modal #fullscreen-preview-content svg {
    width: 317px !important;
    height: 533px !important;
    max-width: 317px !important;
    max-height: 533px !important;
}

/* Vista frontal - solo ajuste vertical */
.fullscreen-modal #fullscreen-preview-content svg.view-front {
    transform: translateY(-14px) !important;
}

/* Vista trasera - ajuste horizontal y vertical para compensar el viewBox offset */
.fullscreen-modal #fullscreen-preview-content svg.view-back {
    transform: translate(0px, -8px) !important;
}

/* Share Options Modal Styles */
#share-options-modal {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    background: white !important;
    padding: 20px !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.3) !important;
    z-index: 10002 !important;
    min-width: 300px !important;
}

#share-options-modal h3 {
    margin: 0 0 15px 0 !important;
    text-align: center !important;
}

.share-buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.share-button {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 10px !important;
    color: white !important;
    text-decoration: none !important;
    border-radius: 4px !important;
    border: none !important;
    cursor: pointer !important;
}

.share-button.facebook {
    background: #1877f2 !important;
}

.share-button.twitter {
    background: #1da1f2 !important;
}

.share-button.whatsapp {
    background: #25d366 !important;
}

.share-button.copy {
    background: #6c757d !important;
}

.close-button {
    position: absolute !important;
    top: 5px !important;
    right: 10px !important;
    background: none !important;
    border: none !important;
    font-size: 20px !important;
    cursor: pointer !important;
}

/* ==========================================================================
   Fixed Canvas System (1000x600 Artboard)
   ========================================================================== */

.agame-garment-preview.agame-fixed-canvas-mode {
    aspect-ratio: 1000 / 600;
    max-width: 1000px;
    margin: 0 auto;
}

.agame-fixed-canvas-mode .agame-overlay-layer {
    position: absolute !important;
    pointer-events: none !important;
    z-index: 2 !important;
}

/* Dual View - Fixed Canvas */
.agame-preview-dual.agame-fixed-canvas-mode .agame-overlay-layer {
    /* JS handles precise pixel positioning, but we set some defaults */
    transition: none !important;
}

/* Single View - Fixed Canvas */
.agame-preview-front.agame-fixed-canvas-mode .agame-overlay-layer,
.agame-preview-back.agame-fixed-canvas-mode .agame-overlay-layer {
    /* Single view shows 500x600 block */
    width: 100% !important;
    height: 100% !important;
}

/* Grid helper for Admin (visible only when active) */
.agame-admin-fixed-grid {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10;
    border: 1px dashed rgba(11, 179, 235, 0.3);
    display: none;
}

.agame-fixed-canvas-mode.show-grid .agame-admin-fixed-grid {
    display: block;
}

.agame-admin-fixed-grid::after {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    width: 1px;
    height: 100%;
    background: repeating-linear-gradient(
        to bottom,
        #0BB3EB,
        #0BB3EB 5px,
        transparent 5px,
        transparent 10px
    );
}
