/* ============================================================
   CONTACT — glass form panel + info strip
   ============================================================ */

.contact {
    padding: var(--s-8) 0;
    background: var(--ink);
}

.contact-content.centered {
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* ── Form container ── */
#contactForm {
    width: 100%;
    max-width: 760px;
    background: rgba(20,20,20,0.6);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
    border: 1px solid var(--glass-border);
    box-shadow: inset 0 1px 0 var(--glass-edge), var(--shadow-md);
    border-radius: var(--r-lg);
    padding: var(--s-5) var(--s-6);
}

/* ── Form structure ── */
.form-row {
    display: flex;
    gap: var(--s-3);
    width: 100%;
}

.form-group {
    flex: 1 1 0;
    margin-bottom: var(--s-3);
    min-width: 0;
}

.form-group.half-width { flex: 1 1 50%; }
.form-group.full-width { flex: 1 1 100%; width: 100%; }

/* ── Labels ── */
.form-group label {
    display: block;
    margin-bottom: 0.4rem;
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--smoke-3);
}

.center-label label { text-align: center; }

/* ── Inputs ── */
.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 0.75rem var(--s-2);
    background: rgba(10,10,10,0.6);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.07);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
    border-radius: var(--r-sm);
    color: var(--smoke);
    font-size: var(--text-sm);
    font-family: inherit;
    box-sizing: border-box;
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
    -webkit-appearance: none;
    appearance: none;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--smoke-3);
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: rgba(249,106,44,0.55);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.03),
        0 0 0 3px rgba(249,106,44,0.1);
}

.form-group textarea {
    resize: vertical;
    min-height: 96px;
    max-height: 200px;
    line-height: 1.6;
}

.form-group select option {
    background: var(--ink-3);
    color: var(--smoke);
}

#contactForm .btn-full {
    margin-top: var(--s-1);
}

/* ── Success ── */
#successMessage {
    width: 100%;
    max-width: 760px;
    margin: var(--s-2) auto 0;
    display: none;
    justify-content: center;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-3) var(--s-4);
    background: rgba(40,167,69,0.14);
    border: 1px solid rgba(40,167,69,0.25);
    border-radius: var(--r-md);
    color: #4ade80;
    font-size: var(--text-sm);
    font-weight: 500;
}

/* ── Contact info strip ── */
.contact-info.full-width-contact {
    width: 100%;
    max-width: 760px;
    margin: var(--s-2) auto 0;
    background: rgba(20,20,20,0.5);
    backdrop-filter: blur(14px) saturate(130%);
    -webkit-backdrop-filter: blur(14px) saturate(130%);
    border: 1px solid var(--glass-border);
    box-shadow: inset 0 1px 0 var(--glass-edge);
    border-radius: var(--r-md);
    padding: var(--s-3) var(--s-5);
}

.contact-info-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-3);
    flex-wrap: wrap;
}

.contact-info-main .contact-title {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--smoke);
    margin-bottom: 0.2rem;
    letter-spacing: -0.01em;
}

.contact-info-main .contact-email {
    font-size: var(--text-xs);
    color: var(--smoke-3);
}

.contact-social-official {
    display: flex;
    gap: var(--s-1);
    align-items: center;
}

.social-btn-official {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--r-sm);
    background: rgba(255,255,255,0.05);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid var(--glass-border);
    box-shadow: inset 0 1px 0 var(--glass-edge);
    text-decoration: none;
    transition:
        background var(--transition),
        border-color var(--transition);
}

.social-btn-official:first-child:hover {
    background: #3b5998;
    border-color: transparent;
}

.social-btn-official:last-child:hover {
    background: #e4405f;
    border-color: transparent;
}

.social-logo {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

/* ── Legacy items ── */
.contact-item {
    display: flex;
    align-items: flex-start;
    gap: var(--s-2);
    margin-bottom: var(--s-3);
    padding: var(--s-3);
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--wire);
    border-radius: var(--r-md);
}
.contact-item i { color: var(--ember); font-size: 1.2rem; opacity: 0.8; }
.contact-item h4 { color: var(--smoke); font-size: var(--text-sm); margin-bottom: 0.25rem; }
.contact-item p  { color: var(--smoke-2); margin: 0; font-size: var(--text-sm); }

.social-links { display: flex; gap: var(--s-1); margin-top: var(--s-3); }
.social-link {
    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--wire);
    border-radius: var(--r-sm);
    color: var(--smoke-2);
    text-decoration: none;
    font-size: 0.9rem;
    transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.social-link:hover {
    background: var(--ember);
    color: #fff;
    border-color: transparent;
}

/* ── Responsive ── */
@media (max-width: 700px) {
    #contactForm { padding: var(--s-4) var(--s-3); }
    .contact-info.full-width-contact { padding: var(--s-3); }
    .form-row { flex-direction: column; gap: 0; }
    .contact-info-content { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
    #contactForm,
    .contact-info.full-width-contact { padding: var(--s-3) var(--s-2); }
}
