/* ============================================
   Contact Page Styles
   Dark-themed design matching the design system
   ============================================ */

.contact-page {
    padding-bottom: var(--space-12);
}

/* Hero Section */
.contact-page .hero-section {
    background: linear-gradient(135deg, var(--color-bg-secondary) 0%, var(--color-bg-tertiary) 100%);
    padding: var(--space-12) 0;
    margin-bottom: var(--space-8);
}

.contact-page .hero-title {
    font-size: var(--font-size-6xl);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
    margin-bottom: var(--space-4);
    color: var(--color-text-primary);
}

.contact-page .hero-description {
    font-size: var(--font-size-lg);
    color: var(--color-text-secondary);
    max-width: 600px;
    margin: 0 auto;
}

/* Contact Card */
.contact-page .contact-card {
    background: var(--gradient-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
}

.contact-page .contact-card h3 {
    color: var(--color-text-primary);
    margin-bottom: var(--space-5);
}

/* Contact Method */
.contact-page .contact-method {
    padding: var(--space-4) 0;
    border-bottom: 1px solid var(--color-border);
}

.contact-page .contact-method:last-child {
    border-bottom: none;
}

/* Contact Icon */
.contact-page .contact-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(214, 240, 141, 0.1);
    border-radius: var(--radius-lg);
    color: var(--color-accent-lime);
    margin-bottom: var(--space-3);
}

.contact-page .contact-method strong {
    display: block;
    color: var(--color-text-primary);
    margin-bottom: var(--space-2);
}

.contact-page .contact-method a {
    color: var(--color-accent-lime);
}

.contact-page .contact-method a:hover {
    color: var(--color-accent-lime-hover);
}

/* Lime Button */
.contact-page .btn-lime {
    background: var(--gradient-accent);
    color: var(--color-text-inverse);
    border: none;
}

.contact-page .btn-lime:hover {
    background: var(--color-accent-lime-hover);
    color: var(--color-text-inverse);
    transform: translateY(-2px);
}

/* Form Styles - Dark Theme */
.contact-page .form-label {
    color: var(--color-text-primary);
    font-weight: var(--font-weight-medium);
}

.contact-page .form-control,
.contact-page .form-select {
    color: var(--color-text-primary);
    background-color: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-page .form-control:focus,
.contact-page .form-select:focus {
    color: var(--color-text-primary);
    background-color: var(--color-bg-elevated);
    border-color: var(--color-accent-lime);
    box-shadow: 0 0 0 3px rgba(var(--color-accent-lime-rgb), 0.2);
}

.contact-page .form-control::placeholder {
    color: var(--color-text-tertiary);
}

.contact-page .form-control.is-invalid {
    border-color: #dc3545;
}

.contact-page .invalid-feedback {
    display: block;
    color: #dc3545;
    font-size: var(--font-size-sm);
    margin-top: var(--space-1);
}

/* Alert Container */
.contact-page #alertContainer {
    margin-bottom: var(--space-4);
}

.contact-page #alertContainer:empty {
    margin-bottom: 0;
}

/* Alert Styles */
.contact-page .alert {
    border-radius: 8px;
    padding: 16px 48px 16px 20px;
    margin-bottom: 0;
    border: 1px solid transparent;
    position: relative;
}

.contact-page .alert > span {
    display: block;
    font-size: 1rem;
    line-height: 1.5;
    color: inherit;
}

.contact-page .alert.alert-success {
    background-color: rgba(34, 197, 94, 0.15);
    border-color: rgba(34, 197, 94, 0.3);
    color: #4ade80;
}

.contact-page .alert.alert-success > span {
    color: #4ade80;
}

.contact-page .alert.alert-danger {
    background-color: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.3);
    color: #f87171;
}

.contact-page .alert.alert-danger > span {
    color: #f87171;
}

/* Alert close button for dark theme */
.contact-page .alert .btn-close {
    position: absolute;
    top: 50%;
    right: 12px;
    transform: translateY(-50%);
    filter: invert(1) grayscale(100%) brightness(200%);
    opacity: 0.7;
    padding: 8px;
    background-size: 12px;
}

.contact-page .alert .btn-close:hover {
    opacity: 1;
}

/* Calendar Link */
.contact-page .calendar-link h4 {
    color: var(--color-text-primary);
    margin-bottom: var(--space-2);
}

/* Map Container */
.map-container {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
}

.map-container iframe {
    width: 100%;
    height: 400px;
    border: none;
}

/* Spinner */
.contact-page .spinner-border {
    width: 1.25rem;
    height: 1.25rem;
    border-width: 0.2rem;
    margin-right: 0.5rem;
}

/* Form Select Dropdown Arrow Fix for Dark Theme */
.contact-page .form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23a0a0b0' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}

@media (max-width: 991px) {
    .contact-page .hero-title {
        font-size: var(--font-size-5xl);
    }

    .contact-page .hero-description {
        font-size: var(--font-size-base);
    }
}

@media (max-width: 767px) {
    .contact-page .hero-title {
        font-size: var(--font-size-4xl);
    }

    .contact-page .hero-description {
        font-size: var(--font-size-sm);
    }
}
