/* ═══════════════════════════════════════
   CONTACTO — CCL
   ═══════════════════════════════════════ */

.contact-section { background: var(--bg-light); }

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: 72px;
    align-items: start;
}

/* ── Panel izquierdo: info ── */
.contact-items { margin-top: 36px; display: flex; flex-direction: column; gap: 16px; }

.contact-item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 18px 20px;
    background: var(--blanco);
    border-radius: var(--radius-sm);
    border: var(--border);
    transition: box-shadow 0.2s;
}
.contact-item:hover { box-shadow: var(--shadow-sm); }

.ci-icon {
    font-size: 20px;
    width: 44px; height: 44px;
    background: #FEF3E8;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    border: 1px solid rgba(245,159,53,0.2);
}

.contact-item strong {
    display: block;
    font-size: 10px;
    font-weight: 700;
    color: var(--gris-carbono);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 3px;
}
.contact-item a,
.contact-item span {
    display: block;
    font-size: 14px;
    color: var(--negro);
    line-height: 1.6;
    font-weight: 500;
}
.contact-item a:hover { color: var(--naranja); }

/* ── Formulario ── */
.contact-form-wrap { position: sticky; top: 90px; }

.form-card {
    background: var(--blanco);
    border-radius: var(--radius-md);
    padding: 44px 40px;
    box-shadow: var(--shadow);
    border: var(--border);
}
.form-card h3 {
    font-size: 18px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--negro);
    margin-bottom: 6px;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}
.form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 18px;
}
.form-group label {
    font-size: 11px;
    font-weight: 700;
    color: var(--gris-carbono);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}
.required { color: var(--rojo); }

.form-group input,
.form-group select,
.form-group textarea {
    padding: 12px 14px;
    border: 1.5px solid rgba(87,87,86,0.2);
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-family: 'Montserrat', sans-serif;
    color: var(--negro);
    background: var(--blanco);
    transition: border-color 0.2s, box-shadow 0.2s;
    width: 100%;
    outline: none;
    -webkit-appearance: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--gris-medio); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    border-color: var(--naranja);
    box-shadow: 0 0 0 3px rgba(245,159,53,0.12);
}
.form-group textarea { resize: vertical; min-height: 110px; }
.form-group select { cursor: pointer; }

.btn-form {
    width: 100%;
    justify-content: center;
    font-size: 14px;
    padding: 15px;
    margin-top: 4px;
}

/* ── Estados ── */
.form-success-msg {
    text-align: center;
    padding: 40px 20px;
    animation: fadeUp 0.5s ease;
}
@keyframes fadeUp {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}
.success-icon {
    width: 60px; height: 60px;
    border-radius: 50%;
    background: var(--naranja);
    color: var(--blanco);
    display: flex; align-items: center; justify-content: center;
    font-size: 22px;
    font-weight: 700;
    margin: 0 auto 18px;
}
.form-success-msg h4 {
    font-size: 20px;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--negro);
    margin-bottom: 8px;
}
.form-success-msg p { font-size: 14px; color: var(--gris-carbono); }

.form-error-msg {
    background: #FFF0EE;
    border: 1px solid rgba(231,68,25,0.25);
    border-radius: var(--radius-sm);
    padding: 12px 16px;
    margin-top: 10px;
}
.form-error-msg p { font-size: 13px; color: var(--rojo); font-weight: 600; margin: 0; }

/* ── Responsive — Tablet ── */
@media (max-width: 991px) {
    .contact-grid       { grid-template-columns: 1fr; gap: 36px; }
    .contact-form-wrap  { position: static; }
    .contact-items      { gap: 12px; }
}

/* ── Responsive — Mobile ── */
@media (max-width: 600px) {
    .form-card          { padding: 24px 16px; border-radius: var(--radius-sm); box-shadow: none; border: var(--border); }
    .form-card h3       { font-size: 16px; }
    .form-row           { grid-template-columns: 1fr; gap: 0; }
    .form-group         { margin-bottom: 14px; }
    .form-group input,
    .form-group select,
    .form-group textarea { font-size: 15px; padding: 13px 12px; }
    .btn-form           { font-size: 14px; padding: 15px; }

    .contact-item       { padding: 14px 16px; }
    .ci-icon            { width: 38px; height: 38px; font-size: 17px; }
    .contact-item a,
    .contact-item span  { font-size: 13px; }
}
