/* Contact section and form styling */
.contact-section {
    padding: var(--space-xl) 0;
}

.contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 1rem;
    align-items: stretch;
}

.contact-side {
    padding: 1.45rem;
    display: flex;
    flex-direction: column;
}

.contact-side .section-title {
    margin-top: 0.9rem;
}

.contact-side .section-copy {
    margin-top: 1rem;
}

.contact-benefits {
    margin-top: 1.1rem;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.contact-benefits li {
    font-size: var(--fs-sm);
    color: hsl(var(--text-muted));
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
}

.contact-benefits li::before {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 50%;
    margin-top: 0.38rem;
    background: hsl(var(--secondary-accent));
    box-shadow: 0 0 10px hsla(var(--secondary-accent), 0.4);
    flex-shrink: 0;
}

.contact-meta {
    margin-top: auto;
    color: hsl(var(--text-dim));
    padding-top: 1.15rem;
}

.contact-form {
    padding: 1.45rem;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

.form-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    align-items: start;
}

.form-row-3 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    align-items: start;
}

.form-row > *,
.form-row-3 > * {
    min-width: 0;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 0.44rem;
    min-width: 0;
    max-width: 100%;
}

.form-group-spacing {
    margin-top: 0.25rem;
}

.form-label {
    font-size: var(--fs-xs);
    font-family: var(--font-mono);
    color: hsl(var(--text-muted));
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.form-input,
.form-select,
.form-textarea {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;

    padding: 0.95rem 1rem;
    border-radius: 12px;
    border: 1px solid var(--glass-border);
    background: rgba(255, 255, 255, 0.03);
    color: #fff;
    font-family: var(--font-body);
    font-size: var(--fs-base);
    outline: none;
    transition: var(--transition-smooth);
    appearance: none;
}

.form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.8rem center;
    background-size: 1.1em;
    padding-right: 2.8rem;
}

.form-select option {
    background-color: #0d131d;
    color: #fff;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    border-color: hsla(var(--primary-accent), 0.8);
    background: rgba(255, 255, 255, 0.05);
    box-shadow: 0 0 0 2px hsla(var(--primary-accent), 0.2);
}

input[type="tel"] {
    white-space: nowrap;
    text-overflow: ellipsis;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
}

.form-textarea {
    min-height: 138px;
    resize: vertical;
}

.form-submit-btn {
    width: 100%;
    margin-top: 0.4rem;
}

.form-error-msg {
    font-size: 0.75rem;
    color: #ff7777;
    margin-top: 0.12rem;
    display: none;
}

.form-group.error .form-input,
.form-group.error .form-select,
.form-group.error .form-textarea {
    border-color: #ff7777;
}

.form-group.error .form-error-msg {
    display: block;
}

.form-success-overlay {
    margin-top: 0.75rem;
    background: rgba(6, 11, 18, 0.92);
    border: 1px solid var(--glass-border);
    border-radius: 14px;
    padding: 1rem;
    text-align: center;
    display: none;
}

.form-success-title {
    font-size: var(--fs-lg);
}

.form-success-overlay p {
    margin-top: 0.45rem;
    color: hsl(var(--text-muted));
    font-size: var(--fs-sm);
}

.form-success-overlay a {
    color: hsl(var(--secondary-accent));
}

@media (max-width: 1100px) {
    .contact-layout {
        grid-template-columns: 1fr;
    }

    .contact-meta {
        margin-top: 1rem;
    }

    .form-row-3 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .form-row-3 .form-group:nth-child(3) {
        grid-column: span 2;
    }
}

@media (max-width: 760px) {
    .contact-form,
    .contact-side {
        padding: 1rem;
    }

    .form-row,
    .form-row-3 {
        grid-template-columns: 1fr;
    }

    .form-row-3 .form-group:nth-child(3) {
        grid-column: span 1;
    }
}