/* Custom CSS for ProPlumber Website */

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

/* 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;
}

/* 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" %}');
}