/**
 * GGA Enhanced Controls - Universal Styling System
 * Provides comprehensive styling options for all GGA widgets
 */

/* Universal Glass Widget Structure */
.gga-widget {
    position: relative;
    overflow: hidden;
}

/* Background and Glass Effects */
.gga-widget .elementor-widget-container {
    position: relative;
    z-index: 1;
}

/* Universal Hover Effects */
.gga-widget.gga-hover-lift {
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), 
                box-shadow 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gga-widget.gga-hover-lift:hover {
    transform: translateY(-8px);
}

.gga-widget.gga-hover-scale {
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gga-widget.gga-hover-scale:hover {
    transform: scale(1.03);
}

.gga-widget.gga-hover-glow {
    transition: filter 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gga-widget.gga-hover-glow:hover {
    filter: drop-shadow(0 0 20px rgba(59, 130, 246, 0.4));
}

/* Enhanced Icon Animations */
.gga-glass-icon,
.gga-glass-number {
    transition: transform 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.gga-hover-lift:hover .gga-glass-icon,
.gga-hover-lift:hover .gga-glass-number {
    transform: scale(1.05) rotate(2deg);
}

.gga-hover-scale:hover .gga-glass-icon,
.gga-hover-scale:hover .gga-glass-number {
    transform: scale(1.1);
}

/* Button Enhanced Animations */
.gga-glass-button-icon {
    transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gga-glass-button:hover .gga-glass-button-icon.icon-right {
    transform: translateX(4px);
}

.gga-glass-button:hover .gga-glass-button-icon.icon-left {
    transform: translateX(-4px);
}

.gga-glass-button:active {
    transform: scale(0.98);
}

/* Testimonial Enhanced Animations */
.gga-glass-client-avatar {
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gga-glass-testimonial:hover .gga-glass-client-avatar {
    transform: scale(1.05);
}

.gga-star {
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gga-glass-testimonial:hover .gga-star.filled {
    color: #FFED4A;
    text-shadow: 0 0 8px rgba(255, 237, 74, 0.6);
    transform: scale(1.1);
}

/* Heading Enhanced Animations */
.gga-glass-heading-main {
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gga-glass-heading-wrapper:hover .gga-glass-heading-main {
    transform: translateY(-3px);
}

/* Universal Focus States */
.gga-widget:focus-visible,
.gga-glass-button:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

/* Smooth transitions for all text elements */
.gga-glass-title,
.gga-glass-description,
.gga-glass-subtitle,
.gga-glass-button-text {
    transition: color 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                text-shadow 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Enhanced Ripple Effect */
.gga-glass-button-ripple {
    position: absolute;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.4);
    transform: scale(0);
    pointer-events: none;
    z-index: 1;
}

/* Performance optimizations */
.gga-widget {
    will-change: transform;
}

.gga-widget:hover {
    will-change: transform, box-shadow, filter;
}

/* Reduced motion respect */
@media (prefers-reduced-motion: reduce) {
    .gga-widget,
    .gga-glass-icon,
    .gga-glass-number,
    .gga-glass-button-icon,
    .gga-glass-client-avatar,
    .gga-star,
    .gga-glass-heading-main {
        transition: none !important;
        animation: none !important;
    }
    
    .gga-widget:hover {
        transform: none !important;
    }
}

/* Mobile optimizations */
@media (max-width: 768px) {
    .gga-widget.gga-hover-lift:hover {
        transform: translateY(-4px);
    }
    
    .gga-widget.gga-hover-scale:hover {
        transform: scale(1.02);
    }
}

/* Touch device optimizations */
@media (hover: none) and (pointer: coarse) {
    .gga-widget:hover {
        transform: none;
    }
    
    .gga-hover-lift:hover .gga-glass-icon,
    .gga-hover-lift:hover .gga-glass-number {
        transform: none;
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .gga-widget {
        border-width: 2px !important;
    }
    
    .gga-glass-title,
    .gga-glass-description {
        text-shadow: none !important;
    }
}