/* =============================================
   user.css - Patria de Martí - Joomla 5
   Actualizado: 2026-05-31
   ============================================= */

/* Reset body background */
body {
    background-color: #f4f4f4 !important;
    gap: 0 !important;
}

/* Header y Main sin espacios */
header.header { margin-bottom: 0 !important; }
main.main-content { margin-top: 0 !important; }

/* Ocultar navbar por defecto de Joomla */
.navbar, .navbar-inner, #navbar, .header.sticky-top, .container-header {
    display: none !important;
}

/* --- FIX IMÁGENES EN MÓVIL --- */
img, .com-content-article img, .item-image img, picture img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
}

.com-content-article {
    overflow: hidden !important;
    width: 100% !important;
}

/* --- TÍTULOS H1 --- */
h1, .page-header h1, .com-content-article__title {
    font-size: 21px !important;
    line-height: 1.2 !important;
    color: #030b68 !important;
    font-weight: bold !important;
    margin-top: 0px !important;
}

/* --- BREADCRUMB --- */
.breadcrumb-wrapper .breadcrumb {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 13px !important;
}
.breadcrumb-wrapper .breadcrumb-item a {
    color: #030B68 !important;
    text-decoration: none !important;
}
.breadcrumb-wrapper .breadcrumb-item a:hover { color: #dd002b !important; }
.breadcrumb-wrapper .breadcrumb-item.active { color: #666 !important; }
.breadcrumb-wrapper {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

/* --- SOCIAL LINKS FOOTER --- */
.social-links .fa-facebook { color: #1877F2; }
.social-links .fa-x-twitter { color: #ffffff; }
.social-links .fa-youtube { color: #FF0000; }
.social-links .social-item {
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    text-decoration: none;
    margin-bottom: 8px;
}
.social-links .social-item span {
    color: rgba(255, 255, 255, 0.8);
    margin-left: 10px;
    transition: color 0.3s ease;
}
.social-links .social-item:hover { transform: translateX(5px); }
.social-links .social-item:hover i,
.social-links .social-item:hover span { color: #ffffff !important; }

/* Logo mini de CubanAmerican Voice en footer */
.social-links .social-item img.cubanamericanvoice-logo {
    width: 20px !important;
    height: 20px !important;
    margin-right: 12px !important;
    border-radius: 3px;
    transition: all 0.3s ease-in-out;
}
.social-links .social-item:hover img.cubanamericanvoice-logo {
    transform: scale(1.2);
    filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.9)) !important;
}

/* --- ARTICLE INFO (Por Autor | Fecha) --- */
.article-info-custom {
    font-size: 13px !important;
    color: #666666 !important;
    margin: 5px 0 10px 0 !important;
    list-style: none !important;
}

/* --- NAVEGACIÓN ANTERIOR/SIGUIENTE --- */
nav.pagenavigation {
    margin: 30px 0 10px 0 !important;
    padding: 20px 0 !important;
    border-top: 2px solid #e0e0e0 !important;
}
nav.pagenavigation .pagination {
    display: flex !important;
    justify-content: space-between !important;
    align-items: stretch !important;
    gap: 15px !important;
    width: 100% !important;
}
nav.pagenavigation a.btn {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    background-color: #030B68 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 15px 20px !important;
    text-decoration: none !important;
    max-width: 45% !important;
    transition: background-color 0.3s ease !important;
    line-height: 1.4 !important;
}
nav.pagenavigation a.btn.next {
    align-items: flex-end !important;
    text-align: right !important;
    margin-left: auto !important;
}
nav.pagenavigation a.btn:hover {
    background-color: #dd002b !important;
    color: #ffffff !important;
}
nav.pagenavigation a.btn span[aria-hidden="true"] {
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: rgba(255,255,255,0.7) !important;
    margin-bottom: 5px !important;
    display: block !important;
}
nav.pagenavigation a.btn .visually-hidden {
    all: unset !important;
    font-size: 13px !important;
    font-weight: bold !important;
    color: #ffffff !important;
    display: block !important;
    white-space: normal !important;
    word-break: break-word !important;
}
nav.pagenavigation .icon-chevron-left,
nav.pagenavigation .icon-chevron-right {
    display: none !important;
}

/* Incrementa el tamaño de los párrafos */
p {
    font-size: 1.15rem;
    line-height: 1.6;
}

/* Reducir margen entre header y main-content */
header.header {
    margin-bottom: 0 !important;
}
main.main-content {
    margin-top: 0 !important;
    padding-top: 8px !important;
}
#mod-custom465 {
    margin-bottom: 0 !important;
    padding-bottom: 4px !important;
    padding-top: 4px !important;
}

/* === GOOGLE SEARCH MODULE - PATRIA STYLING === */
#mod-custom465,
.mod-custom.custom {
    margin: 0 auto !important;
    padding: 12px 20px !important;
    background-color: #ffffff !important;
    max-width: 1200px !important;
    box-sizing: border-box !important;
}
#mod-custom465 .gse {
    max-width: 700px !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: stretch !important;
    gap: 0 !important;
}
#mod-custom465 .search-wrap {
    flex: 1 !important;
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    background-color: #ffffff !important;
    border: 2px solid #030B68 !important;
    border-right: none !important;
    border-radius: 4px 0 0 4px !important;
    overflow: hidden !important;
}
#mod-custom465 .gse-searchbox {
    flex: 1 !important;
    width: 100% !important;
    height: 42px !important;
    border: none !important;
    background: transparent !important;
    padding: 0 12px !important;
    font-size: 15px !important;
    color: #333333 !important;
    outline: none !important;
    box-sizing: border-box !important;
}
#mod-custom465 .gse-searchbox::placeholder {
    color: #777777 !important;
    font-size: 14px !important;
}
#mod-custom465 .gse-mic {
    color: #030B68 !important;
    font-size: 18px !important;
    padding: 0 12px !important;
    cursor: pointer !important;
    transition: color 0.3s ease !important;
}
#mod-custom465 .gse-mic:hover {
    color: #dd002b !important;
}
#mod-custom465 .gse-search-icon {
    background-color: #dd002b !important;
    border: 2px solid #dd002b !important;
    border-radius: 0 4px 4px 0 !important;
    cursor: pointer !important;
    transition: background-color 0.3s ease !important;
    padding: 0 18px !important;
    height: 42px !important;
    min-width: 50px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
#mod-custom465 .gse-search-icon i.fa-search {
    color: #ffffff !important;
    font-size: 16px !important;
}
#mod-custom465 .gse-search-icon:hover {
    background-color: #aa0020 !important;
    border-color: #aa0020 !important;
}

/* === OCULTAR RESULTADOS INVISIBLES DE GOOGLE SEARCH === */
.gcse-searchresults-only { display: none !important; }
.gsc-results-wrapper-overlay { display: none !important; }
.gsc-results-wrapper-nooverlay:empty { display: none !important; }
.gsc-results-wrapper-visible:empty { display: none !important; }

/* === PAGINACION DE LISTADOS === */
.pagination {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 6px !important;
    list-style: none !important;
    padding: 20px 0 !important;
    margin: 30px 0 !important;
    border-top: 2px solid #e0e0e0 !important;
}
.pagination .page-item {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.pagination .page-item .page-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 44px !important;
    min-height: 44px !important;
    padding: 8px 14px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #030B68 !important;
    background-color: #ffffff !important;
    border: 2px solid #030B68 !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
    box-sizing: border-box !important;
}
.pagination .page-item.active .page-link {
    background-color: #030B68 !important;
    color: #ffffff !important;
    border-color: #030B68 !important;
    cursor: default !important;
}
.pagination .page-item:not(.active):not(.disabled) .page-link:hover {
    background-color: #dd002b !important;
    color: #ffffff !important;
    border-color: #dd002b !important;
}
.pagination .page-item.disabled .page-link {
    color: #999999 !important;
    background-color: #f5f5f5 !important;
    border-color: #cccccc !important;
    cursor: not-allowed !important;
    opacity: 0.6 !important;
}
@media (max-width: 991px) {
    .pagination {
        gap: 4px !important;
        padding: 15px 0 !important;
    }
    .pagination .page-item .page-link {
        min-width: 40px !important;
        min-height: 40px !important;
        padding: 6px 10px !important;
        font-size: 14px !important;
    }
}
.pagination-counter,
.com-content-category-blog__counter {
    display: block !important;
    text-align: center !important;
    font-size: 13px !important;
    color: #666 !important;
    margin: 15px 0 5px 0 !important;
}

/* === FIX ICONOS DE PAGINACION === */
.pagination .icon-angle-double-left,
.pagination .icon-angle-left,
.pagination .icon-angle-right,
.pagination .icon-angle-double-right {
    font-family: Arial, sans-serif !important;
    font-style: normal !important;
    font-size: 18px !important;
    line-height: 1 !important;
}
.pagination .icon-angle-double-left::before { content: "\00AB" !important; }
.pagination .icon-angle-left::before        { content: "\2039" !important; }
.pagination .icon-angle-right::before       { content: "\203A" !important; }
.pagination .icon-angle-double-right::before{ content: "\00BB" !important; }

/* === BLOCKQUOTE === */
blockquote {
    padding: 10px 20px;
    margin: 0 0 20px;
    font-size: 17.5px;
    border-left: 5px solid #030b68 !important;
}

/* === FIX PHOTOSWIPE - Z-INDEX === */
.pswp            { z-index: 99999  !important; }
.pswp__bg        { z-index: 99998  !important; }
.pswp__scroll-wrap { z-index: 99999 !important; }
.pswp__ui        { z-index: 100000 !important; }

/* === YOUTUBE EMBED === */
.youtube {
    background-color: #000;
    position: relative;
    padding-top: 56.25%;
    overflow: hidden;
    cursor: pointer;
    max-width: 100%;
}
.youtube img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    top: 0;
    left: 0;
    opacity: 0.7;
}
.youtube .play-button {
    width: 90px;
    height: 60px;
    background-color: #333;
    box-shadow: 0 0 30px rgba(0,0,0,0.6);
    z-index: 1;
    opacity: 0.8;
    border-radius: 6px;
}
.youtube .play-button:before {
    content: "";
    border-style: solid;
    border-width: 15px 0 15px 26px;
    border-color: transparent transparent transparent #fff;
}
.youtube img,
.youtube .play-button,
.youtube .play-button:before,
.youtube iframe {
    position: absolute;
}
.youtube .play-button,
.youtube .play-button:before {
    top: 50%;
    left: 50%;
    transform: translate3d(-50%, -50%, 0);
}
.youtube iframe {
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
}

/* Reader: texto del label en blanco */
div#text_plugin.scbasebin.screenreader.text.scr_customicon span.fr_label.startapp {
    color: rgb(255, 255, 255) !important;
}
div#accessibility-links.vertical { color: rgb(255, 255, 255) !important; }

/* ============================================================
   MENÚ PRINCIPAL - Basado en HTML real:
   ul.mod-menu.mod-list.nav
   ul.mod-menu__sub.list-unstyled.small
   li.nav-item.deeper.parent
   ============================================================ */

/* === DESKTOP (≥992px) === */
@media (min-width: 992px) {

    /* Nivel 1: barra horizontal */
    nav.main-menu ul.mod-menu.nav {
        display: flex !important;
        flex-wrap: nowrap !important;
        justify-content: flex-end !important;
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
        background-color: transparent !important;
        position: relative !important;
    }

    /* Items nivel 1 */
    nav.main-menu ul.mod-menu.nav > li.nav-item {
        position: relative !important;
    }

    /* Links nivel 1 */
    nav.main-menu ul.mod-menu.nav > li.nav-item > a {
        color: white !important;
        padding: 10px 6px !important;
        font-size: 14px !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        text-decoration: none !important;
        display: block !important;
        background-color: transparent !important;
        white-space: nowrap !important;
    }
    nav.main-menu ul.mod-menu.nav > li.nav-item > a:hover {
        background-color: #dd002b !important;
        border-radius: 4px !important;
        color: white !important;
    }

    /* Ocultar flecha móvil en desktop */
    nav.main-menu ul.mod-menu.nav > li.nav-item > a .mfp-mobile-arrow {
        display: none !important;
    }

    /* Submenú nivel 2: oculto por defecto */
    nav.main-menu ul.mod-menu.nav > li.nav-item > ul.mod-menu__sub {
        display: none !important;
        position: absolute !important;
        top: 100% !important;
        left: 0 !important;
        background: #030B68 !important;
        min-width: 240px !important;
        z-index: 11000 !important;
        border-top: 2px solid #dd002b !important;
        list-style: none !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Mostrar nivel 2 en hover nivel 1 */
    nav.main-menu ul.mod-menu.nav > li.nav-item.deeper:hover > ul.mod-menu__sub {
        display: block !important;
    }

    /* Links nivel 2 */
    nav.main-menu ul.mod-menu.nav > li.nav-item > ul.mod-menu__sub > li.nav-item > a {
        display: block !important;
        padding: 9px 14px !important;
        color: rgba(255,255,255,0.9) !important;
        font-size: 13px !important;
        text-transform: none !important;
        font-weight: normal !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    }
    nav.main-menu ul.mod-menu.nav > li.nav-item > ul.mod-menu__sub > li.nav-item > a:hover {
        background-color: #dd002b !important;
        color: white !important;
    }

    /* Ocultar flecha móvil en nivel 2 desktop */
    nav.main-menu ul.mod-menu__sub > li.nav-item > a .mfp-mobile-arrow {
        display: none !important;
    }

    /* Items nivel 2 con hijos: position relative */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper {
        position: relative !important;
    }

    /* Indicador visual flecha derecha en nivel 2 con hijos */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper > a::after {
        content: " \25B6" !important;
        font-size: 9px !important;
        opacity: 0.7 !important;
        float: right !important;
        margin-left: 8px !important;
    }

    /* Submenú nivel 3: oculto por defecto */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper > ul.mod-menu__sub {
        display: none !important;
        position: absolute !important;
        left: 100% !important;
        top: 0 !important;
        background: #030B68 !important;
        min-width: 220px !important;
        border-top: 2px solid #dd002b !important;
        z-index: 12000 !important;
        list-style: none !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Mostrar nivel 3 en hover nivel 2 */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper:hover > ul.mod-menu__sub {
        display: block !important;
    }

    /* Links nivel 3 */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper > ul.mod-menu__sub > li.nav-item > a {
        display: block !important;
        padding: 9px 14px !important;
        color: rgba(255,255,255,0.9) !important;
        font-size: 13px !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    }
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper > ul.mod-menu__sub > li.nav-item > a:hover {
        background-color: #dd002b !important;
        color: white !important;
    }

    /* Item current desktop */
    nav.main-menu ul.mod-menu.nav > li.current > a {
        background-color: #dd002b !important;
        color: white !important;
        border-radius: 4px !important;
    }
    nav.main-menu ul.mod-menu.nav > li.current > a:hover {
        background-color: #aa0020 !important;
    }

    /* Item current dentro de submenú */
    nav.main-menu ul.mod-menu__sub li.current > a {
        background-color: #dd002b !important;
        color: white !important;
    }
    nav.main-menu ul.mod-menu__sub li.current > a:hover {
        background-color: #aa0020 !important;
    }
}

/* === MÓVIL (≤991px) === */
@media (max-width: 991px) {

    /* Contenedor nivel 1: columna vertical */
    nav.main-menu ul.mod-menu.nav {
        display: block !important;
        list-style: none !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Quitar bullets en todos los niveles */
    nav.main-menu ul.mod-menu.nav,
    nav.main-menu ul.mod-menu__sub {
        list-style: none !important;
        padding-left: 0 !important;
        margin-left: 0 !important;
    }

    /* Links nivel 1 */
    nav.main-menu ul.mod-menu.nav > li.nav-item > a {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 16px 20px !important;
        color: white !important;
        text-decoration: none !important;
        border-bottom: 1px solid rgba(255,255,255,0.1) !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        font-size: 14px !important;
        min-height: 48px !important;
        cursor: pointer !important;
    }

    /* Flecha móvil nivel 1 */
    nav.main-menu ul.mod-menu.nav > li.nav-item.deeper > a .mfp-mobile-arrow {
        display: inline-block !important;
        color: #dd002b !important;
        font-size: 14px !important;
        transition: transform 0.2s ease !important;
        flex-shrink: 0 !important;
    }

    /* Submenú nivel 2: oculto por defecto */
    nav.main-menu ul.mod-menu.nav > li.nav-item > ul.mod-menu__sub {
        display: none !important;
        background: rgba(0,0,0,0.25) !important;
        padding: 0 !important;
        list-style: none !important;
    }

    /* Submenú nivel 2 visible con .submenu-open */
    nav.main-menu ul.mod-menu.nav > li.nav-item.submenu-open > ul.mod-menu__sub {
        display: block !important;
    }

    /* Links nivel 2 */
    nav.main-menu ul.mod-menu.nav > li.nav-item > ul.mod-menu__sub > li.nav-item > a {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 13px 20px 13px 36px !important;
        color: rgba(255,255,255,0.85) !important;
        font-size: 13px !important;
        text-decoration: none !important;
        border-bottom: 1px solid rgba(255,255,255,0.06) !important;
        min-height: 44px !important;
    }

    /* Flecha móvil nivel 2 */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper > a .mfp-mobile-arrow {
        display: inline-block !important;
        color: #dd002b !important;
        font-size: 12px !important;
        flex-shrink: 0 !important;
    }

    /* Submenú nivel 3: oculto por defecto */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper > ul.mod-menu__sub {
        display: none !important;
        background: rgba(0,0,0,0.2) !important;
        list-style: none !important;
        padding: 0 !important;
    }

    /* Submenú nivel 3 visible con .submenu-open */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper.submenu-open > ul.mod-menu__sub {
        display: block !important;
    }

    /* Links nivel 3 */
    nav.main-menu ul.mod-menu__sub > li.nav-item.deeper > ul.mod-menu__sub > li.nav-item > a {
        display: block !important;
        padding: 11px 20px 11px 52px !important;
        color: rgba(255,255,255,0.75) !important;
        font-size: 13px !important;
        text-decoration: none !important;
        border-bottom: 1px solid rgba(255,255,255,0.05) !important;
        min-height: 40px !important;
    }

    /* Item current móvil */
    nav.main-menu ul.mod-menu.nav > li.current > a {
        background-color: rgba(221,0,43,0.15) !important;
        border-left: 4px solid #dd002b !important;
        padding-left: 16px !important;
    }

    /* Item current dentro de submenú móvil */
    nav.main-menu ul.mod-menu__sub li.current > a {
        background-color: rgba(221,0,43,0.15) !important;
        border-left: 4px solid #dd002b !important;
    }
}
