/* ==========================================================================
   popup.css
   Banner institucional animado + mini popups dinamicos desde JSON.
   Archivo aislado para no tocar css legacy existentes.
   Compatible con index.html sin convertirlo a PHP.
   ========================================================================== */

/* --------------------------------------------------------------------------
   HERO / BANNER INSTITUCIONAL ANIMADO
   Referencia tecnica: banner animado de tarjeta.html
   -------------------------------------------------------------------------- */
.banner-area-index-motion {
    position: relative;
    min-height: 300px;
    overflow: hidden;
    background-color: #163525;
    background-image: url('../img/banner-index.jpg');
    background-repeat: repeat-x;
    background-position: 0 50%;
    background-size: auto 100%;
    animation: cesopolBannerMove 65s linear infinite;
}

.banner-area-index-motion .banner-index-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(6, 19, 13, 0.12) 0%, rgba(6, 19, 13, 0.26) 100%);
    pointer-events: none;
}

@keyframes cesopolBannerMove {
    0%   { background-position: 0 50%; }
    100% { background-position: 1200px 50%; }
}

.banner-area-index-motion .hero-scroll-arrow {
    position: absolute;
    left: 50%;
    bottom: 12px;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    background: transparent;
    border: 0;
    box-shadow: none;
    width: auto;
    height: auto;
    z-index: 2;
    font-size: 22px;
    line-height: 1;
    animation: cesopolArrowPulse 2.4s ease-in-out infinite;
}
@keyframes cesopolArrowPulse {
    0%, 100% { transform: translateX(-50%) translateY(0); opacity: 0.92; }
    50%      { transform: translateX(-50%) translateY(4px); opacity: 1; }
}

/* --------------------------------------------------------------------------
   STACK DE POPUPS DINAMICOS
   Eleccion visual:
   - esquina inferior izquierda para no chocar con WhatsApp
   - compactos, institucionales y no modales
   -------------------------------------------------------------------------- */
.popup-stack-root {
    position: fixed;
    left: 20px;
    bottom: 20px;
    z-index: 9980;
    width: 100%;
    max-width: 392px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    pointer-events: none;
}

.popup-stack-root:empty {
    display: none;
}

.popup-mini {
    position: relative;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid rgba(16, 43, 31, 0.12);
    border-radius: 12px;
    box-shadow: 0 14px 34px rgba(0,0,0,0.14);
    pointer-events: auto;
    transform: translateY(16px);
    opacity: 0;
    animation: popupMiniIn 0.35s ease-out forwards;
}

@keyframes popupMiniIn {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}

.popup-mini--alerta {
    border-left: 4px solid #c89d24;
}

.popup-mini--novedad {
    border-left: 4px solid #1f6f43;
}

.popup-mini__inner {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px 14px 14px;
}

.popup-mini__media {
    width: 78px;
    min-width: 78px;
    height: 78px;
    border-radius: 10px;
    overflow: hidden;
    background: #f4f6f5;
    border: 1px solid rgba(0,0,0,0.06);
}

.popup-mini__media img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.popup-mini__body {
    min-width: 0;
    flex: 1 1 auto;
}

.popup-mini__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 7px;
    font-size: 10px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: #5e6d63;
}

.popup-mini__eyebrow::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
    opacity: 0.75;
}

.popup-mini--alerta .popup-mini__eyebrow {
    color: #996f00;
}

.popup-mini--novedad .popup-mini__eyebrow {
    color: #1f6f43;
}

.popup-mini__title {
    margin: 0 0 6px 0;
    font-size: 15px;
    line-height: 1.28;
    font-weight: 700;
    color: #173222;
}

.popup-mini__desc {
    margin: 0;
    font-size: 13px;
    line-height: 1.45;
    color: #516158;
}

.popup-mini__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 11px;
}

.popup-mini__cta,
.popup-mini__more {
    text-decoration: none !important;
    transition: all 0.22s ease;
}

.popup-mini__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 8px 13px;
    border-radius: 999px;
    background: #1f6f43;
    color: #ffffff !important;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.popup-mini__cta:hover,
.popup-mini__cta:focus {
    background: #184f31;
    color: #ffffff !important;
}

.popup-mini--alerta .popup-mini__cta {
    background: #8f6d12;
}

.popup-mini--alerta .popup-mini__cta:hover,
.popup-mini--alerta .popup-mini__cta:focus {
    background: #76590b;
}

.popup-mini__more {
    font-size: 12px;
    font-weight: 600;
    color: #1f6f43 !important;
}

.popup-mini__more:hover,
.popup-mini__more:focus {
    color: #184f31 !important;
}

.popup-mini--alerta .popup-mini__more {
    color: #8f6d12 !important;
}

.popup-mini__close {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 28px;
    height: 28px;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: rgba(24, 40, 31, 0.06);
    color: #617168;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.popup-mini__close:hover,
.popup-mini__close:focus {
    background: rgba(24, 40, 31, 0.12);
    color: #22352a;
}

.popup-mini--sin-imagen .popup-mini__inner {
    gap: 0;
}

.popup-mini--sin-imagen .popup-mini__media {
    display: none;
}

@media (max-width: 991px) {
    .banner-area-index-motion {
        min-height: 340px;
        background-size: auto 100%;
        animation-duration: 56s;
    }
}

@media (max-width: 767px) {
    .banner-area-index-motion {
        min-height: 255px;
        background-size: auto 100%;
        animation-duration: 46s;
    }

    .banner-area-index-motion .hero-scroll-arrow {
        width: 38px;
        height: 38px;
        bottom: 14px;
    }

    .popup-stack-root {
        left: 12px;
        right: 12px;
        bottom: calc(12px + env(safe-area-inset-bottom));
        max-width: none;
        width: auto;
    }

    .popup-mini__inner {
        padding: 13px 14px;
        gap: 10px;
    }

    .popup-mini__media {
        width: 64px;
        min-width: 64px;
        height: 64px;
    }

    .popup-mini__title {
        font-size: 14px;
    }

    .popup-mini__desc {
        font-size: 12px;
    }

    .popup-mini__actions {
        gap: 8px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .banner-area-index-motion {
        animation: none;
    }

    .banner-area-index-motion .hero-scroll-arrow,
    .popup-mini {
        animation: none;
    }
}
