/* ============================================
   FOOTER REDESIGN - STANDALONE CSS
   ============================================
   Modern footer with 4-column layout
   Loaded separately to ensure proper cascading
   ============================================ */

.redesigned-footer {
    background: #ffffff !important;
    padding: 80px 0 0 0 !important;
    position: relative !important;
    width: 100% !important;
}

.redesigned-footer .container {
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

/* Main Grid Layout */
.redesigned-footer .footer-grid {
    display: grid !important;
    grid-template-columns: 600px 1fr !important;
    gap: 80px !important;
    margin-bottom: 40px !important;
}

@media (min-width: 1200px) {
    .redesigned-footer .footer-grid {
        grid-template-columns: 650px 1fr !important;
    }
}

/* Left Column: Brand + CTAs + Offices */
.redesigned-footer .footer-brand-column {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
}

/* Footer Logo - Combined Horizontal Logo */
.redesigned-footer .footer-brand-link {
    display: inline-flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    transition: opacity 0.2s ease !important;
    line-height: 0 !important;
}

.redesigned-footer .footer-brand-link:hover {
    opacity: 0.8 !important;
}

.redesigned-footer .footer-brand-logo {
    height: 55px !important;
    width: auto !important;
    display: block !important;
}

.redesigned-footer .footer-tagline {
    font-size: 48px !important;
    line-height: 1.1 !important;
    font-weight: 400 !important;
    color: #192615 !important;
    margin: 0 !important;
    font-family: 'Recoleta', serif !important;
}

.redesigned-footer .footer-description {
    font-size: 18px !important;
    line-height: 1.6 !important;
    color: #4a4a4a !important;
    margin: 0 !important;
    max-width: 480px !important;
}

/* Footer CTAs - HORIZONTAL LAYOUT */
.redesigned-footer .footer-ctas {
    display: flex !important;
    flex-direction: row !important;
    gap: 16px !important;
    margin-top: 8px !important;
    align-items: center !important;
}

.redesigned-footer .footer-ctas .btn {
    padding: 16px 28px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    text-align: center !important;
    transition: all 0.2s ease !important;
    display: inline-block !important;
    width: fit-content !important;
    box-sizing: border-box !important;
    white-space: nowrap !important;
}

.redesigned-footer .footer-ctas .btn-primary-green {
    background: #014921 !important;
    color: #ffffff !important;
    border: 2px solid #014921 !important;
}

.redesigned-footer .footer-ctas .btn-primary-green:hover {
    background: #013619 !important;
    border-color: #013619 !important;
}

/* Phone Outline Button - Icon + Number */
.redesigned-footer .btn-phone-outline {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 16px 28px !important;
    background: transparent !important;
    color: #192615 !important;
    border: 2px solid #192615 !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    white-space: nowrap !important;
}

.redesigned-footer .btn-phone-outline:hover {
    background: #014921 !important;
    color: #ffffff !important;
}

.redesigned-footer .btn-phone-outline svg {
    width: 20px !important;
    height: 20px !important;
    display: block !important;
    flex-shrink: 0 !important;
}

/* Our Offices Section */
.redesigned-footer .footer-offices {
    margin-top: 32px !important;
    padding: 24px 32px !important;
    border: 2px solid #192615 !important;
    border-radius: 12px !important;
    background: #ffffff !important;
}

/* Header row - subtitle and offices header side by side */
.redesigned-footer .offices-header-row {
    display: flex !important;
    align-items: center !important;
    gap: 24px !important;
    margin-bottom: 12px !important;
}

.redesigned-footer .offices-header {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.redesigned-footer .offices-header svg {
    flex-shrink: 0 !important;
    width: 24px !important;
    height: 24px !important;
}

.redesigned-footer .offices-header h3 {
    font-size: 32px !important;
    font-weight: 400 !important;
    color: #192615 !important;
    margin: 0 !important;
    font-family: 'Recoleta', serif !important;
    white-space: nowrap !important;
}

.redesigned-footer .offices-cities {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 10px !important;
    margin-bottom: 0 !important;
    width: 100% !important;
}

.redesigned-footer .city-badge {
    padding: 10px 12px !important;
    background: #ffffff !important;
    border: 2px solid #192615 !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: #192615 !important;
    display: block !important;
    text-decoration: none !important;
    text-align: center !important;
    transition: all 0.2s ease !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    box-sizing: border-box !important;
}

.redesigned-footer .city-badge:hover {
    background: #014921 !important;
    color: #ffffff !important;
    border-color: #014921 !important;
    transform: translateY(-2px) !important;
}

/* Service Areas button - styled differently within grid */
.redesigned-footer .city-badge-button {
    background: #014921 !important;
    color: #ffffff !important;
    border-color: #014921 !important;
    font-weight: 600 !important;
    white-space: nowrap !important;
}

.redesigned-footer .city-badge-button:hover {
    background: #013619 !important;
    border-color: #013619 !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
}

.redesigned-footer .offices-subtitle {
    font-size: 14px !important;
    font-style: italic !important;
    color: #192615 !important;
    margin: 0 !important;
    text-align: left !important;
    white-space: nowrap !important;
}

/* Right Side: 3 Columns */
.redesigned-footer .footer-links-columns {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 60px !important;
}

.redesigned-footer .footer-links-column {
    display: flex !important;
    flex-direction: column !important;
}

.redesigned-footer .footer-column-title {
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #192615 !important;
    margin: 0 0 20px 0 !important;
    font-family: 'Monument Grotesk', sans-serif !important;
}

.redesigned-footer .footer-column-links {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.redesigned-footer .footer-column-links li {
    margin: 0 !important;
    padding: 0 !important;
}

.redesigned-footer .footer-column-links a {
    font-size: 16px !important;
    color: #4a4a4a !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
    line-height: 1.5 !important;
}

.redesigned-footer .footer-column-links a:hover {
    color: #014921 !important;
}

/* Sticky CTA Spacer */
.redesigned-footer .footer-sticky-spacer {
    height: 80px !important;
    display: block !important;
}

/* Tablet Responsive */
@media (max-width: 1150px) {
    .redesigned-footer .footer-grid {
        grid-template-columns: 500px 1fr !important;
        gap: 40px !important;
    }

    .redesigned-footer .footer-links-columns {
        gap: 30px !important;
    }

    .redesigned-footer .footer-tagline {
        font-size: 40px !important;
    }
}

/* Medium screens - 3 columns for cities */
@media (max-width: 1100px) {
    .redesigned-footer .offices-cities {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* Smaller tablets - stack to 1 column */
@media (max-width: 950px) {
    .redesigned-footer .footer-grid {
        grid-template-columns: 1fr !important;
        gap: 60px !important;
    }

    .redesigned-footer .footer-links-columns {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 40px !important;
    }

    .redesigned-footer .offices-cities {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .redesigned-footer {
        padding: 60px 0 0 0 !important;
    }

    .redesigned-footer .footer-grid {
        gap: 40px !important;
    }

    .redesigned-footer .footer-tagline {
        font-size: 32px !important;
    }

    .redesigned-footer .footer-description {
        font-size: 16px !important;
    }

    /* Stack CTA buttons vertically on mobile */
    .redesigned-footer .footer-ctas {
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    .redesigned-footer .footer-ctas .btn {
        width: 100% !important;
    }

    .redesigned-footer .btn-phone-icon {
        align-self: flex-start !important;
    }

    .redesigned-footer .footer-offices {
        padding: 24px !important;
    }

    .redesigned-footer .offices-header h3 {
        font-size: 24px !important;
    }

    .redesigned-footer .offices-cities {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }

    .redesigned-footer .city-badge {
        font-size: 14px !important;
        padding: 10px 8px !important;
    }

    .redesigned-footer .offices-header-row {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 8px !important;
        margin-bottom: 12px !important;
    }

    .redesigned-footer .offices-subtitle {
        font-size: 12px !important;
    }

    .redesigned-footer .footer-links-columns {
        grid-template-columns: 1fr !important;
        gap: 40px !important;
    }

    .redesigned-footer .footer-column-title {
        font-size: 16px !important;
    }

    .redesigned-footer .footer-column-links a {
        font-size: 15px !important;
    }

    .redesigned-footer .footer-sticky-spacer {
        height: 100px !important;
    }
}

/* Very Small Mobile - Stack cities to 1 column */
@media (max-width: 480px) {
    .redesigned-footer .offices-cities {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
    }

    .redesigned-footer .city-badge {
        font-size: 15px !important;
        padding: 12px 16px !important;
        text-align: center !important;
    }

    .redesigned-footer .footer-offices {
        padding: 20px 24px !important;
    }
}
