.contact-page {
    min-height: calc(100vh - 120px);
}

.contact-page .container-lg {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.contact-hero {
    border-radius: var(--radius-xl);
    background: linear-gradient(135deg, var(--bg-white) 0%, var(--primary-green-lighter) 100%);
}

.contact-hero h1 {
    margin-top: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    font-size: var(--font-3xl);
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
}

.contact-form-wrap {
    border-radius: var(--radius-xl);
}

.contact-form-wrap .card-header {
    margin-bottom: var(--spacing-md);
}

.contact-form-wrap .card-header p {
    margin: 0;
}

.contact-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

.form-alert {
    grid-column: 1 / -1;
    width: 100%;
    margin: 0 0 var(--spacing-sm);
    box-sizing: border-box;
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    font-size: var(--font-sm);
}

.alert-success {
    background: rgba(34, 197, 94, 0.12);
    color: var(--success-green);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.alert-error {
    background: rgba(239, 68, 68, 0.12);
    color: var(--danger-red);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.message-group textarea {
    min-height: 140px;
}

.contact-info-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.contact-info-card,
.contact-hours-card {
    border-radius: var(--radius-xl);
}

.contact-details {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-md);
}

.contact-details li {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
}

.contact-details i {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    background: var(--primary-green-lighter);
    color: var(--primary-green-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-lg);
    flex-shrink: 0;
}

.contact-details p {
    color: var(--text-dark);
    font-weight: var(--font-medium);
}

.hours-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--border-light);
}

.hours-row span {
    color: var(--text-medium);
    font-weight: var(--font-medium);
}

.hours-row strong {
    color: var(--text-dark);
    font-size: var(--font-sm);
}

.hours-note {
    margin-top: var(--spacing-md);
    font-size: var(--font-sm);
}

@media (min-width: 640px) {
    .contact-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--spacing-lg);
    }

    .contact-form .message-group,
    .contact-form .btn-block {
        grid-column: 1 / -1;
    }
}

@media (max-width: 640px) {
    .contact-hero,
    .contact-form-wrap,
    .contact-info-card,
    .contact-hours-card {
        margin-inline: -20px;
    }
}

@media (min-width: 1024px) {
    .contact-grid {
        grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.85fr);
        gap: var(--spacing-xl);
        align-items: start;
    }

    .contact-info-wrap {
        position: sticky;
        top: calc(var(--spacing-xl) + 90px);
    }

    .contact-hero h1 {
        font-size: var(--font-4xl);
    }
}
