/* ══════════════════════════════════════════
   CONTACT PAGE
══════════════════════════════════════════ */

/* ── Contact Layout ── */
.fe-contact-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: var(--fe-space-12);
    align-items: start;
}

/* ── CF7 Row Wrapper ── */
.fe-cf7-row {
    display: flex;
    flex-direction: column;
    gap: var(--fe-space-2);
    margin-block-end: var(--fe-space-5);
}

.fe-cf7-row label {
    font-size: var(--fe-text-sm);
    font-weight: var(--fe-weight-semibold);
    color: var(--fe-text);
    display: flex;
    flex-direction: column;
    gap: var(--fe-space-2);
}

.fe-cf7-row abbr {
    color: var(--fe-error);
    text-decoration: none;
    font-style: normal;
}

.fe-cf7-submit {
    margin-block-start: var(--fe-space-2);
}

/* ── CF7 Form Overrides ── */
.fe-contact-form .wpcf7-form {
    display: flex;
    flex-direction: column;
    gap: var(--fe-space-5);
}

.fe-contact-form .wpcf7-form-control-wrap {
    display: block;
    width: 100%;
}

.fe-contact-form input[type="text"],
.fe-contact-form input[type="email"],
.fe-contact-form input[type="tel"],
.fe-contact-form textarea {
    width: 100%;
    padding: var(--fe-space-3) var(--fe-space-4);
    border: 1.5px solid var(--fe-border);
    border-radius: var(--fe-radius);
    background: #ffffff;
    font-family: inherit;
    font-size: var(--fe-text-sm);
    color: var(--fe-text);
    transition: border-color var(--fe-transition), box-shadow var(--fe-transition);
    outline: none;
}

.fe-contact-form input[type="text"]:focus,
.fe-contact-form input[type="email"]:focus,
.fe-contact-form input[type="tel"]:focus,
.fe-contact-form textarea:focus {
    border-color: var(--fe-primary);
    box-shadow: 0 0 0 3px rgba(0, 38, 154, 0.12);
}

.fe-contact-form textarea {
    min-height: 150px;
    resize: vertical;
}

.fe-contact-form .wpcf7-submit {
    align-self: flex-start;
    padding: var(--fe-space-3) var(--fe-space-8);
    background: var(--fe-primary);
    color: #ffffff;
    border: none;
    border-radius: var(--fe-radius);
    font-family: inherit;
    font-size: var(--fe-text-sm);
    font-weight: 700;
    cursor: pointer;
    transition: background var(--fe-transition), transform var(--fe-transition);
}

.fe-contact-form .wpcf7-submit:hover {
    background: var(--fe-primary-dark);
    transform: translateY(-1px);
}

.fe-contact-form .wpcf7-not-valid-tip {
    font-size: var(--fe-text-xs);
    color: #dc2626;
    margin-block-start: var(--fe-space-1);
    display: block;
}

.fe-contact-form .wpcf7-response-output {
    padding: var(--fe-space-3) var(--fe-space-4);
    border-radius: var(--fe-radius);
    font-size: var(--fe-text-sm);
    margin-block-start: var(--fe-space-2);
    border: none;
}

.fe-contact-form .wpcf7-mail-sent-ok {
    background: rgba(34, 197, 94, 0.1);
    color: #15803d;
}

.fe-contact-form .wpcf7-mail-sent-ng,
.fe-contact-form .wpcf7-spam-blocked {
    background: rgba(220, 38, 38, 0.08);
    color: #dc2626;
}

/* ── Contact Details Sidebar ── */
.fe-contact-details {
    display: flex;
    flex-direction: column;
    gap: var(--fe-space-6);
}

.fe-contact-info-item {
    display: flex;
    align-items: flex-start;
    gap: var(--fe-space-4);
}

.fe-contact-info-item__icon {
    width: 44px;
    height: 44px;
    border-radius: var(--fe-radius);
    background: rgba(0, 38, 154, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--fe-primary);
    flex-shrink: 0;
}

.fe-contact-info-item__icon svg {
    width: 20px;
    height: 20px;
}

.fe-contact-info-item__label {
    font-size: var(--fe-text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--fe-text-muted);
    margin-block-end: var(--fe-space-1);
}

.fe-contact-info-item__value {
    font-size: var(--fe-text-sm);
    color: var(--fe-text);
    font-weight: 500;
    line-height: 1.5;
}

.fe-contact-info-item__value a {
    color: var(--fe-primary);
    text-decoration: none;
}

.fe-contact-info-item__value a:hover {
    text-decoration: underline;
}

/* ── WhatsApp Buttons ── */
.fe-contact-wa-btns {
    display: flex;
    flex-direction: column;
    gap: var(--fe-space-3);
}

/* ── Map ── */
.fe-contact-map {
    margin-block-start: var(--fe-space-12);
    border-radius: var(--fe-radius-lg);
    overflow: hidden;
    border: 1px solid var(--fe-border);
}

.fe-contact-map iframe {
    display: block;
    width: 100%;
    height: 400px;
    border: 0;
}

/* ── Responsive ── */
@media (max-width: 1023px) {
    .fe-contact-grid {
        grid-template-columns: 1fr;
        gap: var(--fe-space-8);
    }

    .fe-contact-map iframe {
        height: 300px;
    }
}
