/**
 * Ewellcon Portal Theme
 * Professional blue water solutions theme
 */

:root {
    --ewellcon-blue: #0066cc;
    --ewellcon-light-blue: #4da6ff;
    --ewellcon-dark-blue: #004d99;
    --water-blue: #00b4d8;
}

/* Backgrounds */
.gradient-bg {
    background: linear-gradient(135deg, #0066cc 0%, #0099ff 50%, #00b4d8 100%);
}

.water-gradient {
    background: linear-gradient(to bottom, rgba(0, 180, 216, 0.1) 0%, rgba(255, 255, 255, 1) 100%);
}

.auth-bg {
    background: linear-gradient(135deg, #0066cc 0%, #00b4d8 100%);
    background-attachment: fixed;
}

/* Glass Effect */
.glass-effect {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
}

/* Cards */
.stat-card {
    transition: all 0.3s ease;
    border-left: 4px solid transparent;
}

.stat-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 28px rgba(0, 102, 204, 0.15);
    border-left-color: var(--ewellcon-blue);
}

/* Animations */
.pulse-dot {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: .5; }
}

.water-ripple {
    position: relative;
    overflow: hidden;
}

.water-ripple::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(0, 180, 216, 0.1) 0%, transparent 70%);
    animation: ripple 8s linear infinite;
}

@keyframes ripple {
    0% { transform: translate(0, 0) scale(0.5); opacity: 0.8; }
    100% { transform: translate(50%, 50%) scale(1.5); opacity: 0; }
}

/* Buttons */
.btn-primary {
    background: linear-gradient(135deg, var(--ewellcon-blue), var(--ewellcon-light-blue));
    transition: all 0.3s ease;
}

.btn-primary:hover {
    box-shadow: 0 8px 16px rgba(0, 102, 204, 0.3);
    transform: translateY(-2px);
}

/* Logo */
.logo-container {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Desktop Logo Sizes - Larger for better visibility */
.logo-img {
    height: 56px !important;
    width: auto !important;
    max-width: 100% !important;
}

.logo-img-large {
    height: 90px !important;
    width: auto !important;
    max-width: 100% !important;
}

/* Mobile Logo Display Control - Strong specificity */
.logo-desktop {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
}

.logo-mobile {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    position: absolute !important;
    pointer-events: none !important;
}

/* Tablet and Mobile Sizes */
@media (max-width: 1024px) {
    .logo-img {
        height: 52px !important;
    }
    
    .logo-img-large {
        height: 80px !important;
    }
}

@media (max-width: 768px) {
    .logo-desktop {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
        position: absolute !important;
        pointer-events: none !important;
    }
    
    .logo-mobile {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        position: relative !important;
        pointer-events: auto !important;
    }
    
    .logo-img {
        height: 48px !important;
    }
    
    .logo-img-large {
        height: 72px !important;
    }
}

@media (max-width: 480px) {
    .logo-img {
        height: 44px !important;
    }
    
    .logo-img-large {
        height: 64px !important;
    }
}

.logo-fallback {
    background: linear-gradient(135deg, var(--ewellcon-blue), var(--ewellcon-light-blue));
    padding: 0.75rem;
    border-radius: 0.5rem;
}

.logo-fallback i {
    color: white;
    font-size: 1.5rem;
}

