/* =============================================================
   Contact Us Page — page-contact.php
   ============================================================= */

/* ── Contact Info Bar ───────────────────────────────────────── */
.aceweld-cinfo {
    padding: 2.5rem 0;
    border-bottom: 1px solid var(--aceweld-border);
}

.aceweld-cinfo__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.aceweld-cinfo__item {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    text-align: left;
    padding: 1rem;
}

.aceweld-cinfo__icon {
    flex-shrink: 0;
    color: var(--aceweld-text);
    opacity: .75;
}

.aceweld-cinfo__body {
    display: flex;
    flex-direction: column;
    gap: .2rem;
}

.aceweld-cinfo__body strong {
    font-family: var(--aceweld-heading-font);
    font-size: .9375rem;
    font-weight: 700;
    color: var(--aceweld-text);
}

.aceweld-cinfo__body span {
    font-size: .8125rem;
    color: var(--aceweld-muted);
}

@media (max-width: 860px) {
    .aceweld-cinfo__grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .aceweld-cinfo__item {
        border-bottom: 1px solid var(--aceweld-border);
        padding-bottom: 1.25rem;
    }
}

@media (max-width: 480px) {
    .aceweld-cinfo__grid { grid-template-columns: 1fr; }
}

/* ── Offices + Form section ─────────────────────────────────── */
.aceweld-contact-body {
    padding: 4rem 0 5rem;
}

.aceweld-contact-body__inner {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 4rem;
    align-items: start;
}

/* ── Office Cards ───────────────────────────────────────────── */
.aceweld-contact-offices {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.aceweld-contact-office {
    border: 2px solid var(--aceweld-border);
    border-radius: 12px;
    overflow: hidden;
    transition: border-color .2s, box-shadow .2s;
}

.aceweld-contact-office:hover {
    border-color: #c0392b;
    box-shadow: 0 4px 20px rgba(200,50,30,.1);
}

.aceweld-contact-office__header {
    padding: 1.25rem 1.5rem 1rem;
    border-bottom: 2px solid var(--aceweld-border);
}

.aceweld-contact-office__name {
    font-family: var(--aceweld-heading-font);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--aceweld-text);
    margin: 0 0 .25rem;
}

.aceweld-contact-office__location {
    font-size: .875rem;
    color: var(--aceweld-muted);
    margin: 0;
}

.aceweld-contact-office__rows {
    padding: 1rem 1.5rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: .9rem;
}

.aceweld-contact-office__row {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
}

.aceweld-contact-office__row-icon {
    flex-shrink: 0;
    margin-top: 1.1rem;
    color: #c0392b;
    opacity: .85;
}

.aceweld-contact-office__label {
    display: block;
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--aceweld-muted);
    margin-bottom: .15rem;
}

.aceweld-contact-office__row a {
    font-size: .9375rem;
    font-weight: 500;
    color: var(--aceweld-text);
    text-decoration: none;
    transition: color .18s;
}

.aceweld-contact-office__row a:hover {
    color: #c0392b;
    text-decoration: underline;
}

/* ── Contact Form ───────────────────────────────────────────── */
.aceweld-contact-form-wrap__intro {
    font-size: 1rem;
    color: var(--aceweld-text);
    margin: 0 0 1.75rem;
    line-height: 1.65;
}

.aceweld-contact-form {
    display: flex;
    flex-direction: column;
    gap: .9rem;
}

.aceweld-contact-form__row {
    display: flex;
    flex-direction: column;
    gap: .9rem;
}

.aceweld-contact-form__row--2col {
    flex-direction: row;
    gap: 1rem;
}

.aceweld-contact-form__group {
    flex: 1;
}

.aceweld-contact-form__input,
.aceweld-contact-form__textarea {
    width: 100%;
    padding: .75rem 1rem;
    border: 1px solid var(--aceweld-border);
    border-radius: 6px;
    font: inherit;
    font-size: .9375rem;
    color: var(--aceweld-text);
    background: #fff;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
    appearance: none;
    -webkit-appearance: none;
}

.aceweld-contact-form__input:focus,
.aceweld-contact-form__textarea:focus {
    border-color: #1e3058;
    box-shadow: 0 0 0 3px rgba(30,48,88,.1);
}

.aceweld-contact-form__input::placeholder,
.aceweld-contact-form__textarea::placeholder {
    color: #aab0bc;
}

.aceweld-contact-form__textarea {
    resize: vertical;
    min-height: 120px;
}

.aceweld-contact-form__feedback {
    padding: .75rem 1rem;
    border-radius: 6px;
    font-size: .9rem;
    line-height: 1.5;
}

.aceweld-contact-form__feedback--success {
    background: #f0fdf4;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.aceweld-contact-form__feedback--error {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

.aceweld-contact-form__submit {
    align-self: flex-start;
    padding: .75rem 2.25rem;
    background: #c0392b;
    color: #fff;
    border: none;
    border-radius: 6px;
    font: inherit;
    font-family: var(--aceweld-heading-font);
    font-size: .9375rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s, transform .15s;
}

.aceweld-contact-form__submit:hover {
    background: #a93226;
    transform: translateY(-1px);
}

.aceweld-contact-form__submit:disabled {
    opacity: .65;
    cursor: not-allowed;
    transform: none;
}

@media (max-width: 900px) {
    .aceweld-contact-body__inner {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }
}

@media (max-width: 480px) {
    .aceweld-contact-form__row--2col {
        flex-direction: column;
    }
}

/* ── Google Map ─────────────────────────────────────────────── */
.aceweld-contact-map {
    line-height: 0;
}

.aceweld-contact-map iframe {
    width: 100%;
    height: 480px;
    border: 0;
    display: block;
}
