/* =================================================================
   EL ABETO — abeto-home.css
   Rediseño home v4 · Dirección: "Innox pero más limpio"
   Más aire, tipografía con jerarquía, paleta sobria.
   Pensado para montarse con bloques nativos de UX Builder (Flatsome)
   + estas clases aplicadas en el campo "Class" de cada elemento.
   ================================================================= */

:root {
    --ab-navy:        #14304d;   /* navy principal del logo */
    --ab-navy-deep:   #0c1f33;   /* navy más oscuro */
    --ab-blue:        #2b6cb0;   /* azul medio */
    --ab-blue-light:  #4a90d9;   /* azul claro acento */
    --ab-ice:         #f3f6fa;   /* gris azulado muy claro (fondos) */
    --ab-line:        #e2e8f0;   /* bordes */
    --ab-ink:         #1a2b3c;   /* texto principal */
    --ab-muted:       #5b6b7d;   /* texto secundario */
    --ab-font-display:'Montserrat', system-ui, sans-serif;
    --ab-font-body:   'Open Sans', system-ui, sans-serif;
    --ab-ease:        cubic-bezier(0.22, 1, 0.36, 1);
}

/* -----------------------------------------------------------------
   0. RESET SUAVE para la home (page-id-1906)
   ----------------------------------------------------------------- */
.page-id-1906 #content { padding: 0 !important; }
.page-id-1906 .entry-content { margin: 0 !important; }
.page-id-1906 .entry-content > p:empty { display: none !important; }

/* Tipografía base de las secciones Abeto */
.abeto-sec {
    font-family: var(--ab-font-body);
    color: var(--ab-ink);
}
.abeto-sec h1, .abeto-sec h2, .abeto-sec h3, .abeto-sec h4 {
    font-family: var(--ab-font-display);
}


/* =================================================================
   1. ELEMENTOS DE TEXTO REUTILIZABLES
   ================================================================= */

/* Etiqueta superior (eyebrow) — línea + texto */
.abeto-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.7em;
    font-family: var(--ab-font-display);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.26em;
    text-transform: uppercase;
    color: var(--ab-blue);
    margin: 0 0 1.25rem;
}
.abeto-eyebrow::before {
    content: '';
    width: 32px;
    height: 2px;
    background: var(--ab-blue-light);
    display: inline-block;
}
.abeto-eyebrow--light { color: var(--ab-blue-light); }
.abeto-eyebrow--center { justify-content: center; }

/* Título de sección */
.abeto-title {
    font-family: var(--ab-font-display);
    font-weight: 800;
    font-size: clamp(2rem, 3.6vw, 3.25rem);
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--ab-navy);
    margin: 0 0 1.25rem;
}
.abeto-title--light { color: #fff; }
.abeto-title .hl { color: var(--ab-blue-light); }

/* Párrafo lead */
.abeto-lead {
    font-size: 1.08rem;
    line-height: 1.7;
    color: var(--ab-muted);
    margin: 0 0 1.5rem;
}
.abeto-lead--light { color: rgba(255,255,255,0.8); }


/* =================================================================
   2. HERO — imagen impactante + overlay + texto claro
   Aplicar .abeto-hero al [ux_banner]
   ================================================================= */
.abeto-hero .img-overlay,
.abeto-hero .banner-bg::after {
    background: linear-gradient(
        100deg,
        rgba(12,31,51,0.94) 0%,
        rgba(12,31,51,0.82) 38%,
        rgba(12,31,51,0.42) 70%,
        rgba(12,31,51,0.20) 100%
    ) !important;
}

.abeto-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.7em;
    font-family: var(--ab-font-display);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--ab-blue-light);
    margin: 0 0 1.5rem;
}
.abeto-hero__eyebrow::before {
    content: '';
    width: 40px; height: 2px;
    background: var(--ab-blue-light);
    display: inline-block;
}

.abeto-hero__title {
    font-family: var(--ab-font-display) !important;
    font-weight: 800 !important;
    font-size: clamp(2.4rem, 5vw, 4.6rem) !important;
    line-height: 1.06 !important;
    letter-spacing: -0.03em !important;
    color: #fff !important;
    margin: 0 0 1.5rem !important;
}
.abeto-hero__title .hl { color: var(--ab-blue-light); }

.abeto-hero__sub {
    font-family: var(--ab-font-body) !important;
    font-size: clamp(1.02rem, 1.3vw, 1.2rem) !important;
    line-height: 1.65 !important;
    color: rgba(255,255,255,0.85) !important;
    max-width: 46ch;
    margin: 0 0 2.25rem !important;
}

/* Fila de datos rápidos bajo el hero */
.abeto-hero__facts {
    display: flex;
    gap: 2.5rem;
    flex-wrap: wrap;
    margin-top: 2.5rem;
    padding-top: 2rem;
    border-top: 1px solid rgba(255,255,255,0.18);
}
.abeto-hero__fact strong {
    display: block;
    font-family: var(--ab-font-display);
    font-weight: 800;
    font-size: 1.8rem;
    color: #fff;
    line-height: 1;
}
.abeto-hero__fact span {
    display: block;
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ab-blue-light);
    margin-top: 0.4rem;
}


/* =================================================================
   2b. MARQUEE TOP BAR — tira de beneficios que corre fluida
   (técnica: track flex con items flex-shrink:0, igual que alfie.com.mx)
   ================================================================= */
#top-bar .flex-col.flex-center { flex: 1 1 100% !important; }
#top-bar .nav-center {
    width: 100% !important;
    flex-wrap: nowrap !important;
}
#top-bar li.html_topbar_left {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
}
#top-bar li.html_topbar_left::before,
#top-bar li.html_topbar_left::after { display: none !important; }

.abeto-marquee {
    width: 100%;
    overflow: hidden;
}
.abeto-marquee__track {
    display: flex !important;
    flex-wrap: nowrap !important;
    white-space: nowrap !important;
    width: max-content;
    will-change: transform;
    animation: abeto-marquee 38s linear infinite;
}
.abeto-marquee:hover .abeto-marquee__track { animation-play-state: paused; }
.abeto-marquee__track > span {
    flex-shrink: 0 !important;
    display: inline-flex !important;
    align-items: center;
    font-family: var(--ab-font-display) !important;
    font-size: 0.73rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
    color: #fff !important;
    padding: 0 1.6rem !important;
    line-height: 1 !important;
}
.abeto-marquee__track > span::before {
    content: '▲';
    font-size: 0.62em;
    margin-right: 1.6rem;
    color: var(--ab-blue-light);
}
@keyframes abeto-marquee {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}


/* =================================================================
   3. BOTONES
   ================================================================= */

/* Separación entre botones — sin wrapper, robusto ante UX Builder.
   Cada botón lleva su propio margen, así nunca se enciman ni se pegan. */
.abeto-btn.button {
    margin: 0 16px 12px 0 !important;
}
.abeto-btn.button:last-child { margin-right: 0 !important; }

/* Compatibilidad si quedara algún wrapper viejo */
.abeto-btn-row {
    display: flex !important;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
}
.abeto-btn-row.is-center { justify-content: center; }
.abeto-btn-row .abeto-btn.button { margin: 0 !important; }
.abeto-btn.button {
    font-family: var(--ab-font-display) !important;
    font-weight: 700 !important;
    font-size: 0.82rem !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    border-radius: 3px !important;
    padding: 0.5rem 0.5rem !important;
    margin: 0 !important;
    transition: transform 0.25s var(--ab-ease), box-shadow 0.25s var(--ab-ease) !important;
}
.abeto-btn.button.primary,
.abeto-btn-primary.button {
    background: var(--ab-blue-light) !important;
    border-color: var(--ab-blue-light) !important;
    color: #fff !important;
}
.abeto-btn-primary.button:hover {
    background: var(--ab-blue) !important;
    border-color: var(--ab-blue) !important;
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(43,108,176,0.3);
}
.abeto-btn-ghost.button {
    background: transparent !important;
    border: 2px solid rgba(255,255,255,0.45) !important;
    color: #fff !important;
}
.abeto-btn-ghost.button:hover {
    background: #fff !important;
    border-color: #fff !important;
    color: var(--ab-navy) !important;
}
.abeto-btn-dark.button {
    background: var(--ab-navy) !important;
    border-color: var(--ab-navy) !important;
    color: #fff !important;
}
.abeto-btn-dark.button:hover {
    background: var(--ab-navy-deep) !important;
    border-color: var(--ab-navy-deep) !important;
    transform: translateY(-2px);
}


/* =================================================================
   4. TRUST STRIP — banda de datos clave debajo del hero
   Aplicar .abeto-trust a la [section]
   ================================================================= */
.abeto-trust {
    border-bottom: 1px solid var(--ab-line);
}
.abeto-trust .col {
    padding-top: 1.2rem !important;
    padding-bottom: 1.2rem !important;
}
.abeto-trust__item {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    justify-content: center;
}
.abeto-trust__item .ico {
    flex: 0 0 42px;
    width: 42px; height: 42px;
    display: grid; place-items: center;
    border-radius: 50%;
    background: var(--ab-ice);
    color: var(--ab-blue);
}
.abeto-trust__item .ico svg { width: 20px; height: 20px; }
.abeto-trust__item .txt strong {
    display: block;
    font-family: var(--ab-font-display);
    font-weight: 700;
    font-size: 0.98rem;
    color: var(--ab-navy);
    line-height: 1.2;
}
.abeto-trust__item .txt span {
    display: block;
    font-size: 0.8rem;
    color: var(--ab-muted);
}


/* =================================================================
   5. SECCIÓN NOSOTROS — split imagen + texto
   ================================================================= */
.abeto-about__img {
    position: relative;
}
.abeto-about__img img {
    border-radius: 6px;
    display: block;
}
/* Tarjeta de "años" flotante sobre la imagen */
.abeto-about__badge {
    position: absolute;
    right: -24px;
    bottom: -24px;
    background: var(--ab-blue-light);
    color: #fff;
    padding: 1.5rem 1.75rem;
    border-radius: 6px;
    box-shadow: 0 20px 40px rgba(12,31,51,0.25);
    text-align: center;
}
.abeto-about__badge strong {
    display: block;
    font-family: var(--ab-font-display);
    font-weight: 800;
    font-size: 2.6rem;
    line-height: 1;
}
.abeto-about__badge span {
    display: block;
    font-size: 0.72rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    margin-top: 0.35rem;
    opacity: 0.9;
}

/* Lista con check */
.abeto-checklist {
    list-style: none !important;
    margin: 1.5rem 0 !important;
    padding: 0 !important;
}
.abeto-checklist li {
    position: relative;
    padding: 0 0 0.85rem 2rem;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--ab-ink);
}
.abeto-checklist li::before {
    content: '';
    position: absolute;
    left: 0; top: 2px;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: var(--ab-blue-light);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
}


/* =================================================================
   6. LÍNEAS / PILARES — 3 cards con imagen
   Aplicar .abeto-linea a cada [ux_banner]
   ================================================================= */
.abeto-linea .img-overlay {
    background: linear-gradient(180deg,
        rgba(12,31,51,0) 0%,
        rgba(12,31,51,0.35) 45%,
        rgba(12,31,51,0.92) 100%) !important;
    transition: background 0.4s var(--ab-ease) !important;
}
.abeto-linea:hover .img-overlay {
    background: linear-gradient(180deg,
        rgba(43,108,176,0.15) 0%,
        rgba(20,48,77,0.6) 45%,
        rgba(20,48,77,0.96) 100%) !important;
}
.abeto-linea__num {
    font-family: var(--ab-font-display);
    font-weight: 800;
    font-size: 0.8rem;
    letter-spacing: 0.2em;
    color: var(--ab-blue-light);
    margin: 0 0 0.4rem;
}
.abeto-linea__name {
    font-family: var(--ab-font-display) !important;
    font-weight: 800 !important;
    font-size: 1.6rem !important;
    line-height: 1.1 !important;
    color: #fff !important;
    margin: 0 0 0.5rem !important;
}
.abeto-linea__desc {
    font-size: 0.92rem !important;
    line-height: 1.5 !important;
    color: rgba(255,255,255,0.82) !important;
    margin: 0 0 1rem !important;
}
.abeto-linea__link {
    font-family: var(--ab-font-display);
    font-weight: 700;
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #fff;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}
.abeto-linea__link::after {
    content: '→';
    transition: transform 0.3s var(--ab-ease);
}
.abeto-linea:hover .abeto-linea__link::after { transform: translateX(6px); }


/* =================================================================
   7. SECCIÓN MAYOREO — banda navy con mensaje fuerte
   ================================================================= */
.abeto-mayoreo {
    position: relative;
    overflow: hidden;
}
.abeto-mayoreo__quote {
    font-family: var(--ab-font-display) !important;
    font-weight: 800 !important;
    font-size: clamp(1.8rem, 3.4vw, 3rem) !important;
    line-height: 1.18 !important;
    letter-spacing: -0.02em !important;
    color: #fff !important;
    margin: 0 0 1.5rem !important;
}
.abeto-mayoreo__quote .hl { color: var(--ab-blue-light); }


/* =================================================================
   8. INDUSTRIAS — grid de cards limpias
   ================================================================= */
.abeto-ind-card {
    background: #fff;
    border: 1px solid var(--ab-line);
    border-radius: 8px;
    padding: 2.25rem 1.85rem !important;
    height: 100%;
    transition: transform 0.3s var(--ab-ease), box-shadow 0.3s var(--ab-ease), border-color 0.3s var(--ab-ease);
}
.abeto-ind-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(12,31,51,0.1);
    border-color: var(--ab-blue-light);
}
.abeto-ind-card .ico {
    width: 54px; height: 54px;
    display: grid; place-items: center;
    border-radius: 12px;
    background: var(--ab-ice);
    color: var(--ab-blue);
    margin-bottom: 1.1rem;
    transition: background 0.3s var(--ab-ease), color 0.3s var(--ab-ease);
}
.abeto-ind-card:hover .ico {
    background: var(--ab-blue-light);
    color: #fff;
}
.abeto-ind-card .ico svg { width: 26px; height: 26px; }
.abeto-ind-card h3 {
    font-family: var(--ab-font-display);
    font-weight: 700;
    font-size: 1.15rem;
    color: var(--ab-navy);
    margin: 0 0 0.5rem;
}
.abeto-ind-card p {
    font-size: 0.93rem;
    line-height: 1.55;
    color: var(--ab-muted);
    margin: 0;
}


/* =================================================================
   9. CTA FINAL — imagen + overlay + mensaje
   ================================================================= */
.abeto-cta .img-overlay,
.abeto-cta .banner-bg::after {
    background: linear-gradient(180deg,
        rgba(12,31,51,0.9) 0%,
        rgba(20,48,77,0.85) 100%) !important;
}
.abeto-cta__title {
    font-family: var(--ab-font-display) !important;
    font-weight: 800 !important;
    font-size: clamp(2.2rem, 4.5vw, 3.8rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.025em !important;
    color: #fff !important;
    margin: 0 0 1.25rem !important;
}
.abeto-cta__title .hl { color: var(--ab-blue-light); }
.abeto-cta__sub {
    font-size: clamp(1rem, 1.3vw, 1.18rem) !important;
    line-height: 1.6 !important;
    color: rgba(255,255,255,0.85) !important;
    margin: 0 auto 2.25rem !important;
    max-width: 52ch;
}
.abeto-cta__contact {
    margin-top: 2.5rem;
    padding-top: 1.75rem;
    border-top: 1px solid rgba(255,255,255,0.18);
    display: flex;
    gap: 2rem;
    justify-content: center;
    flex-wrap: wrap;
}
.abeto-cta__contact a {
    color: rgba(255,255,255,0.85);
    font-family: var(--ab-font-display);
    font-weight: 600;
    font-size: 0.92rem;
    text-decoration: none;
}
.abeto-cta__contact a:hover { color: var(--ab-blue-light); }


/* =================================================================
   10. BOTÓN FLOTANTE WHATSAPP — propio, con onditas estilo durantia.mx
   ================================================================= */

/* Oculta el botón del plugin wpt-whatsapp para no duplicar */
#wptwa, .wptwa-flag, [id^="wptwa"] { display: none !important; }

.abeto-wa-fab {
    position: fixed;
    right: 24px;
    bottom: 24px;
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9998;
}
/* Círculo verde sólido (capa media) */
.abeto-wa-fab::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: #25d366;
    box-shadow: 0 8px 22px rgba(37,211,102,0.45);
    z-index: 2;
    transition: transform 0.25s var(--ab-ease), box-shadow 0.25s var(--ab-ease);
}
.abeto-wa-fab:hover::before {
    transform: scale(1.08);
    box-shadow: 0 12px 30px rgba(37,211,102,0.6);
}
/* Icono WhatsApp (capa superior) */
.abeto-wa-fab svg {
    position: relative;
    z-index: 3;
    width: 34px;
    height: 34px;
}
.abeto-wa-fab svg,
.abeto-wa-fab svg path {
    fill: #ffffff !important;
}

/* Onditas — anillos que se expanden detrás del círculo */
.abeto-wa-fab__ring {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: #25d366;
    z-index: 1;
    animation: abeto-wa-ripple 2.4s var(--ab-ease) infinite;
}
.abeto-wa-fab__ring--2 { animation-delay: 1.2s; }

@keyframes abeto-wa-ripple {
    0%   { transform: scale(1);   opacity: 0.6; }
    70%  { opacity: 0; }
    100% { transform: scale(2.3); opacity: 0; }
}

/* Tooltip "Cotiza aquí" que aparece al hover */
.abeto-wa-fab__tip {
    position: absolute;
    right: 74px;
    top: 50%;
    transform: translateY(-50%) translateX(8px);
    background: var(--ab-navy);
    color: #fff;
    font-family: var(--ab-font-display);
    font-weight: 700;
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    white-space: nowrap;
    padding: 0.6rem 0.95rem;
    border-radius: 6px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s var(--ab-ease), transform 0.25s var(--ab-ease);
}
.abeto-wa-fab__tip::after {
    content: '';
    position: absolute;
    right: -5px;
    top: 50%;
    transform: translateY(-50%);
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 6px solid var(--ab-navy);
}
.abeto-wa-fab:hover .abeto-wa-fab__tip {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

@media (max-width: 549px) {
    .abeto-wa-fab { width: 54px; height: 54px; right: 16px; bottom: 16px; }
    .abeto-wa-fab svg { width: 30px; height: 30px; }
    .abeto-wa-fab__tip { display: none; }
}
@media (prefers-reduced-motion: reduce) {
    .abeto-wa-fab__ring { animation: none; opacity: 0; }
}


/* =================================================================
   11. RESPONSIVE
   ================================================================= */
@media (max-width: 850px) {
    .abeto-hero__facts { gap: 1.5rem; }
    .abeto-about__badge { right: 16px; bottom: -20px; padding: 1.1rem 1.3rem; }
    .abeto-about__badge strong { font-size: 2rem; }
}
@media (max-width: 549px) {
    .abeto-hero__facts { gap: 1.25rem; }
    .abeto-hero__fact strong { font-size: 1.4rem; }
    .abeto-trust__item { justify-content: flex-start; }
}
