/* Custom CSS for ProPlumber Website */

/* Define custom color variables */
:root {
    --primary-blue: #1e40af;
    --light-blue: #3b82f6;
    --dark-blue: #1e3a8a;
    --primary-green: #10b981;
    --dark-green: #059669;
    --primary-dark: #1f2937;
}

/* Custom color classes */
.bg-primary-blue {
    background-color: var(--primary-blue) !important;
}

.bg-light-blue {
    background-color: var(--light-blue) !important;
}

.bg-dark-blue {
    background-color: var(--dark-blue) !important;
}

.text-primary-blue {
    color: var(--primary-blue) !important;
}

.text-light-blue {
    color: var(--light-blue) !important;
}

.text-dark-blue {
    color: var(--dark-blue) !important;
}

.border-primary-blue {
    border-color: var(--primary-blue) !important;
}

.border-light-blue {
    border-color: var(--light-blue) !important;
}

.border-dark-blue {
    border-color: var(--dark-blue) !important;
}

/* Green color classes */
.bg-primary-green {
    background-color: var(--primary-green) !important;
}

.bg-dark-green {
    background-color: var(--dark-green) !important;
}

.bg-primary-dark {
    background-color: var(--primary-dark) !important;
}

.text-primary-green {
    color: var(--primary-green) !important;
}

.text-dark-green {
    color: var(--dark-green) !important;
}

.text-primary-dark {
    color: var(--primary-dark) !important;
}

.border-primary-green {
    border-color: var(--primary-green) !important;
}

.border-dark-green {
    border-color: var(--dark-green) !important;
}

.border-primary-dark {
    border-color: var(--primary-dark) !important;
}

/* Green color classes */
.bg-primary-green {
    background-color: var(--primary-green) !important;
}

.bg-dark-green {
    background-color: var(--dark-green) !important;
}

.bg-primary-dark {
    background-color: var(--primary-dark) !important;
}

.text-primary-green {
    color: var(--primary-green) !important;
}

.text-dark-green {
    color: var(--dark-green) !important;
}

.text-primary-dark {
    color: var(--primary-dark) !important;
}

.border-primary-green {
    border-color: var(--primary-green) !important;
}

.border-dark-green {
    border-color: var(--dark-green) !important;
}

.border-primary-dark {
    border-color: var(--primary-dark) !important;
}

/* Hover states */
.hover\:bg-primary-blue:hover {
    background-color: var(--primary-blue) !important;
}

.hover\:bg-light-blue:hover {
    background-color: var(--light-blue) !important;
}

.hover\:bg-dark-blue:hover {
    background-color: var(--dark-blue) !important;
}

.hover\:text-primary-blue:hover {
    color: var(--primary-blue) !important;
}

.hover\:text-light-blue:hover {
    color: var(--light-blue) !important;
}

.hover\:text-dark-blue:hover {
    color: var(--dark-blue) !important;
}

.hover\:border-primary-blue:hover {
    border-color: var(--primary-blue) !important;
}

/* Gradient classes */
.from-primary-blue {
    --tw-gradient-from: var(--primary-blue);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(30, 64, 175, 0));
}

.to-light-blue {
    --tw-gradient-to: var(--light-blue);
}

/* Hero section styling */
.hero-section {
    background: linear-gradient(135deg, var(--primary-blue) 0%, var(--light-blue) 100%);
    position: relative;
    overflow: hidden;
}

.hero-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    z-index: 1;
}

.hero-section > * {
    position: relative;
    z-index: 2;
}

/* Form styling improvements */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="datetime-local"],
select,
textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid #d1d5db;
    border-radius: 0.5rem;
    font-size: 1rem;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    background-color: white;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="datetime-local"]:focus,
select:focus,
textarea:focus {
    outline: none;
    border-color: var(--primary-blue);
    box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.1);
}

textarea {
    min-height: 120px;
    resize: vertical;
}

/* Radio button styling for ratings */
.rating-radio {
    margin-right: 0.5rem;
}

/* Form error styling */
.errorlist {
    color: #dc2626;
    font-size: 0.875rem;
    margin-top: 0.25rem;
    list-style: none;
    padding: 0;
}

.errorlist li {
    margin-bottom: 0.25rem;
}

/* Font family */
.font-poppins {
    font-family: 'Poppins', sans-serif;
}

/* Additional utility classes */
.transition-transform {
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

/* Fix for mobile menu animations */
.group-hover\:rotate-180 {
    transition: transform 0.2s ease-in-out;
}

.group:hover .group-hover\:rotate-180 {
    transform: rotate(180deg);
}

/* Smooth scrolling */
.scroll-smooth {
    scroll-behavior: smooth;
}

/* Hero background images */
.hero-bg-1 {
    background-image: url('{% static "images/heroimage.webp" %}');
}

.hero-bg-2 {
    background-image: url('{% static "images/heroimage2.webp" %}');
}

.hero-bg-3 {
    background-image: url('{% static "images/heroimage3.webp" %}');
}

.hero-bg-4 {
    background-image: url('{% static "images/heroimage4.webp" %}');
}

.fixed-bg-section {
    background-image: url('{% static "images/fixedimagesection1.jpeg" %}');
}

/* Responsive adjustments for hero slider */
@media (max-width: 768px) {
    .hero-image-slider {
        height: 300px;
    }
    
    .slider-image .absolute.bottom-6 {
        bottom: 1rem;
        left: 1rem;
    }
    
    .slider-image h3 {
        font-size: 1rem;
    }
    
    .slider-image p {
        font-size: 0.75rem;
    }
}

/* WhatsApp Widget Styling */
#whatsapp-chat {
    background-color: #1f2937 !important;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

#whatsapp-chat .bg-gray-800 {
    background-color: #1f2937 !important;
}

#whatsapp-chat .bg-gray-700 {
    background-color: #374151 !important;
}

#whatsapp-chat .text-white {
    color: #ffffff !important;
    font-weight: 500;
}

#whatsapp-chat .text-gray-300 {
    color: #d1d5db !important;
    font-weight: 400;
}

#whatsapp-chat .text-sm {
    font-size: 0.875rem !important;
    font-weight: 500 !important;
}

#whatsapp-chat .text-xs {
    color: #e5e7eb !important;
    font-weight: 400 !important;
}

#whatsapp-chat button:hover .text-white {
    color: #ffffff !important;
}

#whatsapp-chat button:hover .text-gray-300 {
    color: #f3f4f6 !important;
}

/* WhatsApp chat button icons */
#whatsapp-chat .text-red-400 {
    color: #f87171 !important;
}

#whatsapp-chat .text-blue-400 {
    color: #60a5fa !important;
}

#whatsapp-chat .text-green-400 {
    color: #4ade80 !important;
}

#whatsapp-chat .text-gray-400 {
    color: #9ca3af !important;
}

/* Hero Image Slider Styling */
.hero-image-slider {
    position: relative;
    overflow: hidden;
}

.slider-image {
    transition: opacity 1s ease-in-out;
}

.slider-image img {
    transition: transform 0.3s ease-in-out;
}

.slider-image:hover img {
    transform: scale(1.05);
}

.slider-dot {
    transition: all 0.3s ease;
    cursor: pointer;
}

.slider-dot:hover {
    transform: scale(1.2);
}

.slider-dot.active {
    background-color: white !important;
    transform: scale(1.1);
}

/* Navigation buttons hover effects */
.hero-image-slider button:hover {
    backdrop-filter: blur(8px);
    transform: scale(1.1);
}

/* Smooth fade transitions for slider text */
.slider-image .absolute.bottom-6 {
    transition: opacity 0.5s ease-in-out;
}