/* =========================================================================
   CONTACTO — hero + tarjeta elevada (formulario claro / datos en grafito)
   + mapa a pantalla completa con pastilla flotante.
   Reutiliza los tokens de style.css.
   ========================================================================= */

/* ------------------------------------------------------------------- hero */
.cpeis-phero--contacto::before {
    background-image: url("imagenes/contacto-estacion.jpg");
    background-position: center 35%;
}
.cpeis-phero--contacto {
    min-height: min(64vh, 580px);
    padding-bottom: clamp(3rem, 6vw, 5rem);
}

/* --------------------------------------------------------------- sección */
/* Especificidad (.cpeis-consorcio .cpeis-contacto) para ganar a la regla
   genérica `.cpeis-consorcio section { padding-block: … }` de consorcio.css.
   Relleno SOLO arriba (aire entre el banner y el formulario); abajo 0 para que
   el mapa quede a ras del footer y no aparezca la franja clara. */
.cpeis-consorcio .cpeis-contacto {
    position: relative;
    background: var(--cpeis-fondo-alt);
    padding-block: clamp(3rem, 6vw, 5rem) 0;
}

/* Tarjeta elevada del formulario (con aire respecto al banner, sin solape) */
.cpeis-contacto__panel {
    position: relative;
    z-index: 3;
    margin-top: 0;
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    background: var(--cpeis-fondo);
    border-radius: clamp(18px, 2.4vw, 28px);
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(15, 15, 20, 0.28);
}
@media (max-width: 900px) {
    .cpeis-contacto__panel { grid-template-columns: 1fr; }
}

.cpeis-contacto__form-col {
    padding: clamp(1.75rem, 3.6vw, 3.25rem);
}

.cpeis-section-head--left {
    text-align: left;
    margin-inline: 0;
    max-width: 46ch;
}

/* ------------------------------------------------------------------- form */
.cpeis-form { margin-top: clamp(1.5rem, 3vw, 2.25rem); }

.cpeis-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--cpeis-space-3);
}
@media (max-width: 560px) {
    .cpeis-form__row { grid-template-columns: 1fr; }
}

.cpeis-field { margin-bottom: var(--cpeis-space-3); display: flex; flex-direction: column; }

.cpeis-field label {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--cpeis-texto);
    margin-bottom: 0.5rem;
}
.cpeis-req { color: var(--cpeis-acento); font-weight: 700; }
.cpeis-opt { color: var(--cpeis-texto-secundario); font-weight: 400; font-size: 0.82em; }

.cpeis-field input,
.cpeis-field select,
.cpeis-field textarea {
    width: 100%;
    font: inherit;
    font-size: 1rem;
    color: var(--cpeis-texto);
    background-color: var(--cpeis-fondo-alt);
    border: 1px solid transparent;
    border-radius: var(--cpeis-radius);
    padding: 0.85rem 1rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
    -webkit-appearance: none;
    appearance: none;
}
.cpeis-field textarea { resize: vertical; min-height: 150px; line-height: 1.55; }

.cpeis-field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236E6E73' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.9rem center;
    padding-right: 2.5rem;
    cursor: pointer;
}

.cpeis-field input:hover,
.cpeis-field select:hover,
.cpeis-field textarea:hover { background-color: #eef0f3; }

.cpeis-field input:focus,
.cpeis-field select:focus,
.cpeis-field textarea:focus {
    outline: none;
    background-color: var(--cpeis-fondo);
    border-color: var(--cpeis-acento);
    box-shadow: 0 0 0 3px rgba(206, 16, 25, 0.14);
}

.cpeis-field.has-error input,
.cpeis-field.has-error select,
.cpeis-field.has-error textarea { border-color: var(--cpeis-acento); background-color: #fff6f5; }

.cpeis-field__err {
    margin: 0.45rem 0 0;
    font-size: 0.84rem;
    color: var(--cpeis-acento);
    font-weight: 600;
}

/* Checkbox de consentimiento */
.cpeis-field--check { margin-top: 0.25rem; }
.cpeis-check {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--cpeis-texto-secundario);
    font-weight: 400;
    cursor: pointer;
}
.cpeis-check input {
    flex: 0 0 auto;
    width: 20px; height: 20px;
    margin-top: 0.1rem;
    accent-color: var(--cpeis-acento);
    cursor: pointer;
}
.cpeis-check a,
.cpeis-check strong { font-weight: 600; color: var(--cpeis-texto); }
.cpeis-check a { text-decoration: underline; text-underline-offset: 2px; }

.cpeis-form__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--cpeis-space-3);
    margin-top: var(--cpeis-space-2);
}
.cpeis-form .cpeis-btn { display: inline-flex; align-items: center; gap: 0.55rem; }
.cpeis-form .cpeis-btn svg { width: 18px; height: 18px; }
.cpeis-form__note { margin: 0; font-size: 0.82rem; color: var(--cpeis-texto-secundario); }

/* Mensajes de estado */
.cpeis-formmsg {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem 1.15rem;
    border-radius: var(--cpeis-radius);
    margin-bottom: var(--cpeis-space-3);
    font-size: 0.95rem;
    line-height: 1.5;
    border: 1px solid transparent;
}
.cpeis-formmsg svg { width: 22px; height: 22px; flex: 0 0 auto; margin-top: 1px; }
.cpeis-formmsg strong { font-weight: 700; }
.cpeis-formmsg--ok  { background: #ecfdf3; border-color: #abefc6; color: #067647; }
.cpeis-formmsg--ok svg  { color: #16a34a; }
.cpeis-formmsg--err { background: #fef3f2; border-color: #fecdc9; color: #b42318; }
.cpeis-formmsg--err svg { color: var(--cpeis-acento); }

/* Honeypot: fuera de pantalla */
.cpeis-hp {
    position: absolute !important;
    left: -9999px !important;
    width: 1px; height: 1px;
    overflow: hidden;
}

/* -------------------------------------------------- panel oscuro (datos) */
.cpeis-contacto__aside {
    position: relative;
    overflow: hidden;
    color: #fff;
    padding: clamp(1.85rem, 3.6vw, 3.25rem);
    background:
        linear-gradient(165deg, #2c2c32 0%, #161619 62%, #101012 100%);
}
.cpeis-aside__glow {
    position: absolute;
    top: -35%; right: -30%;
    width: 90%; aspect-ratio: 1;
    background: radial-gradient(circle, rgba(206, 16, 25, 0.34), transparent 70%);
    filter: blur(46px);
    pointer-events: none;
}
.cpeis-aside__inner { position: relative; z-index: 1; }

.cpeis-aside__eyebrow {
    display: inline-block;
    color: #ff8188;
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 0.6rem;
}
.cpeis-aside__title {
    color: #fff;
    font-size: clamp(1.5rem, 2.4vw, 1.95rem);
    line-height: 1.12;
    letter-spacing: -0.01em;
    margin: 0 0 clamp(1.5rem, 3vw, 2.25rem);
}

.cpeis-infolist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1.15rem; }
.cpeis-infolist li { display: flex; gap: 0.9rem; align-items: flex-start; }
.cpeis-infolist__ic {
    flex: 0 0 auto;
    width: 44px; height: 44px;
    display: grid; place-items: center;
    border-radius: 13px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: #ff8188;
}
.cpeis-infolist__ic svg { width: 22px; height: 22px; }
.cpeis-infolist li > span:last-child {
    font-size: 0.95rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.68);
}
.cpeis-infolist b {
    display: block;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 700;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.28rem;
}
.cpeis-infolist a { color: #fff; font-weight: 600; }
.cpeis-infolist a:hover { color: #ff8188; }
.cpeis-infolink {
    display: inline-block;
    margin-top: 0.4rem;
    font-size: 0.85rem;
    color: #ff8188 !important;
    font-weight: 600 !important;
}

/* Bloque de emergencias */
.cpeis-emergencia {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    margin-top: 1.6rem;
    padding: 1rem 1.15rem;
    border-radius: var(--cpeis-radius);
    background: rgba(206, 16, 25, 0.14);
    border: 1px solid rgba(255, 120, 130, 0.35);
}
.cpeis-emergencia__num {
    flex: 0 0 auto;
    font-size: 1.6rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: #fff;
    background: var(--cpeis-acento);
    border-radius: 12px;
    padding: 0.35rem 0.7rem;
    line-height: 1;
    box-shadow: 0 6px 18px rgba(206, 16, 25, 0.4);
}
.cpeis-emergencia__txt { font-size: 0.86rem; line-height: 1.45; color: rgba(255, 255, 255, 0.72); }
.cpeis-emergencia__txt strong { color: #fff; }

.cpeis-aside__social {
    margin-top: 1.6rem;
    padding-top: 1.4rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.cpeis-aside__social-label {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 700;
    margin-bottom: 0.7rem;
}

/* ---------------------------------------------------- mapa a pantalla completa */
.cpeis-map-band {
    position: relative;
    margin-top: clamp(3rem, 6vw, 5rem);
    height: clamp(380px, 54vh, 580px);
    background: var(--cpeis-escudo);
    overflow: hidden;
}
.cpeis-map__frame {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    border: 0;
    display: block;
}
/* Degradado sutil en los bordes para integrar el mapa */
.cpeis-map-band::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06),
                inset 0 -70px 90px -60px rgba(15, 15, 20, 0.5);
}

/* Pastilla flotante con la dirección */
.cpeis-map__chip {
    position: absolute;
    left: clamp(1rem, 4vw, 3.5rem);
    bottom: clamp(1rem, 4vw, 2.75rem);
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 0.9rem;
    max-width: min(90vw, 460px);
    padding: 0.9rem 1.1rem;
    background: rgba(255, 255, 255, 0.9);
    -webkit-backdrop-filter: saturate(1.4) blur(14px);
    backdrop-filter: saturate(1.4) blur(14px);
    border: 1px solid rgba(255, 255, 255, 0.6);
    border-radius: 16px;
    box-shadow: 0 16px 44px rgba(15, 15, 20, 0.28);
    color: var(--cpeis-texto);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.cpeis-map__chip:hover {
    color: var(--cpeis-texto);
    transform: translateY(-2px);
    box-shadow: 0 22px 54px rgba(15, 15, 20, 0.34);
}
.cpeis-map__chip-ic {
    flex: 0 0 auto;
    width: 42px; height: 42px;
    display: grid; place-items: center;
    border-radius: 12px;
    background: var(--cpeis-acento);
    color: #fff;
}
.cpeis-map__chip-ic svg { width: 22px; height: 22px; }
.cpeis-map__chip-txt {
    display: flex;
    flex-direction: column;
    font-size: 0.86rem;
    line-height: 1.35;
    color: var(--cpeis-texto-secundario);
}
.cpeis-map__chip-txt b {
    color: var(--cpeis-texto);
    font-size: 0.98rem;
    font-weight: 700;
}
.cpeis-map__chip-cta {
    flex: 0 0 auto;
    margin-left: auto;
    padding-left: 0.6rem;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--cpeis-acento);
    white-space: nowrap;
}
@media (max-width: 520px) {
    .cpeis-map__chip { left: 1rem; right: 1rem; bottom: 1rem; max-width: none; }
    .cpeis-map__chip-cta { display: none; }
}
