/* ==========================================
   ADMIN BAR - GLOBAL
   ========================================== */

.admin-bar {
    padding-top: 40px !important;
}

body.admin-bar {
    padding-top: 40px !important;
}

#wpadminbar {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 99999 !important;
    width: 100% !important;
    height: 46px !important;
}

#wpadminbar .ab-sub-wrapper {
    max-height: 40vh !important;
    overflow-y: auto !important;
    position: relative !important;
    box-sizing: border-box !important;
}

#wpadminbar .ab-submenu {
    max-height: 35vh !important;
    overflow-y: auto !important;
}

/* Native Posts Grid Styles */

.npg-grid {
    display: grid;
    gap: 20px;
    margin: 30px 0;
    width: 100%;
}

.npg-col-1 { grid-template-columns: 1fr; }
.npg-col-2 { grid-template-columns: repeat(2, 1fr); }
.npg-col-3 { grid-template-columns: repeat(3, 1fr); }
.npg-col-4 { grid-template-columns: repeat(4, 1fr); }

/* Magazine Template Grids */
.magazine-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin: 30px 0;
    width: 100%;
}

.magazine-section-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin: 20px 0;
    width: 100%;
}

.npg-item {
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,0.1);
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.npg-item:hover {
    transform: translateY(-8px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}

.npg-image-wrap {
    position: relative;
    width: 100%;
    padding-bottom: 66.67%;
    overflow: hidden;
    background: #1a1a1a;
}

.npg-image-link {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    overflow: hidden;
}

.npg-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.npg-item:hover .npg-image {
    transform: scale(1.12);
}

.npg-no-image {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #999;
    font-size: 14px;
    text-align: center;
    width: 100%;
}

.npg-content {
    padding: 0;
    margin: 0;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.npg-title {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.5;
    color: #222;
}

.npg-title a {
    color: #222;
    text-decoration: none;
    transition: color 0.2s;
}

.npg-title a:hover {
    color: #0073aa;
}

/* Logo sizing - limitar tamaño del logo */
.site-logo {
    max-width: 200px !important;
    width: auto !important;
}

.site-logo img,
.header-image {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
}

/* MENÚ Y HEADER A 100% - SIN LÍMITE DE ANCHO */
.main-navigation,
.main-navigation.grid-container {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.site-header,
.site-header.grid-container {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Language switcher alignment */
.main-navigation .menu-item-lang a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
}

.main-navigation .menu-item-lang img {
    margin: 0 !important;
}

/* ========================================
   MOBILE RESPONSIVE - EROTISMOSEXUAL
   ======================================== */

@media (max-width: 1024px) {
    .npg-col-4 { grid-template-columns: repeat(3, 1fr) !important; }
    .magazine-grid,
    .magazine-section-grid { grid-template-columns: repeat(3, 1fr) !important; }
}

@media (max-width: 768px) {
    /* Ocultar logo SOLO si está en el menú de navegación */
    .main-navigation .site-logo,
    .main-navigation .site-logo img,
    .main-navigation .menu-item-logo,
    .main-navigation .menu-item-logo img {
        display: none !important;
        visibility: hidden !important;
    }

    /* GRID RESPONSIVO */
    .npg-col-1 { grid-template-columns: 1fr !important; }
    .npg-col-2 { grid-template-columns: 1fr !important; }
    .npg-col-3,
    .npg-col-4 { grid-template-columns: repeat(2, 1fr) !important; }

    .npg-grid { gap: 15px !important; }
    .npg-content { padding: 12px !important; }
    .npg-title { font-size: 14px !important; }

    /* Magazine grids responsivo */
    .magazine-grid,
    .magazine-section-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 15px !important; }

    /* RESTO DE ESTILOS MÓVILES */
    /* ADMIN BAR FIX */
    #wpadminbar {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 99999 !important;
        max-height: 100vh !important;
        overflow-y: auto !important;
    }

    #wpadminbar .ab-submenu {
        max-height: 60vh !important;
        overflow-y: auto !important;
        position: relative !important;
    }

    .admin-bar body {
        padding-top: 70px !important;
        margin-top: 0 !important;
    }

    .admin-bar .site-header {
        margin-top: 40px !important;
    }

    /* HEADER FIX */
    .admin-bar .site-header {
        margin-top: 0 !important;
        padding-top: 10px !important;
        background-color: #000 !important;
    }

    .site-header {
        padding: 20px 0 !important;
        background-color: #000 !important;
        margin-top: 15px !important;
        margin-bottom: -15px !important;
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
    }

    .site-branding {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .site-logo img {
        width: 80px !important;
        height: auto !important;
    }

    .site-title {
        color: #fff !important;
        font-weight: bold !important;
        display: inline-block !important;
        margin: 0 !important;
        margin-left: 10px !important;
    }

    .site-description {
        display: none !important;
    }

    /* LOGO */
    .site-logo {
        display: inline-block !important;
        margin: 0 !important;
    }

    .site-logo img,
    .header-image {
        max-width: 100px !important;
        height: auto !important;
        display: inline-block !important;
    }

    .main-navigation img {
        display: none !important;
    }

    .main-navigation .menu-item-lang a {
        display: inline-flex !important;
        align-items: center !important;
        gap: 5px !important;
    }

    .main-navigation .menu-item-lang img {
        display: inline !important;
        margin: 0 !important;
    }

    .site-title {
        font-size: 18px !important;
    }

    /* MENU - ROJO */
    .inside-header {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        width: 100% !important;
        gap: 0 !important;
    }

    .menu-toggle {
        background-color: #cc3333 !important;
        color: #fff !important;
        border: none !important;
        opacity: 1 !important;
        filter: none !important;
        -webkit-appearance: none !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        order: 1 !important;
        padding: 8px 15px !important;
        margin: 0 !important;
        height: auto !important;
    }

    /* Ocultar lupa del header */
    .search-item {
        display: none !important;
    }

    /* Ocultar lupa del header - YA HECHO */

    .main-navigation {
        background-color: #cc3333 !important;
        padding: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        width: 100% !important;
        margin-bottom: 20px !important;
        max-width: 100% !important;
        max-height: none !important;
    }

    .main-navigation ul {
        width: 100% !important;
        text-align: center !important;
    }

    .main-navigation a {
        color: #fff !important;
        padding: 10px 15px !important;
        display: block !important;
        text-align: center !important;
        line-height: 1.8 !important;
        margin: 0 !important;
    }

    .main-navigation li {
        float: none !important;
        display: block !important;
        width: 100% !important;
        text-align: center !important;
        margin: 0 !important;
    }

    .main-navigation .menu-item-has-children > a::after,
    .main-navigation .menu-item-has-children > a::before,
    .main-navigation .menu-item-has-children::after,
    .main-navigation .menu-item-has-children::before {
        display: none !important;
        visibility: hidden !important;
        width: 0 !important;
        height: 0 !important;
    }

    .main-navigation .menu-item-has-children > button,
    .main-navigation .menu-item-has-children button,
    .main-navigation .menu-item-has-children span {
        display: none !important;
        visibility: hidden !important;
        width: 0 !important;
        height: 0 !important;
    }

    .main-navigation .menu-item-has-children > a {
        padding-right: 15px !important;
        padding-left: 15px !important;
    }

    .main-navigation li {
        float: none !important;
        display: block !important;
        width: 100% !important;
    }

    .main-navigation ul {
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .main-navigation {
        display: flex !important;
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        width: 100% !important;
        margin-bottom: 20px !important;
    }

    .main-navigation .menu-toggle {
        order: 1 !important;
    }

    .main-navigation > a {
        order: 2 !important;
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        color: #fff !important;
        text-decoration: none !important;
        padding: 8px 15px !important;
        margin: 0 !important;
    }

    .main-navigation > a::before {
        content: "Buscar" !important;
        font-size: 14px !important;
        color: #fff !important;
    }

    .main-navigation ul ul {
        display: none !important;
        width: 100% !important;
        position: static !important;
        box-shadow: none !important;
        visibility: hidden !important;
    }

    .main-navigation.toggled ul ul {
        display: none !important;
        visibility: hidden !important;
    }

    .main-navigation ul ul li a {
        padding-left: 30px !important;
    }

    /* Menu a 100% sin margen */
    .main-navigation,
    .inside-navigation {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        left: 0 !important;
        right: 0 !important;
    }

    /* CONTENT */
    body,
    .site-content,
    .site-main,
    .inside-article,
    .entry-content,
    .site-grid-container,
    .hfeed,
    .post,
    .page {
        padding: 0 8px !important;
        margin: 0 !important;
        width: 100% !important;
    }

    .container,
    .container.grid-container,
    .site-grid-container.container,
    .magazine-home {
        max-width: 100% !important;
        width: 100% !important;
        padding: 0 8px !important;
        margin: 0 !important;
    }

    /* Remover padding de contenedores anidados */
    .post .post-content,
    .page .page-content,
    .entry-content > *,
    .inside-article > * {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* Listas sin sangría excesiva en tablet */
    ul,
    ol {
        margin: 15px 0 15px 0 !important;
        padding-left: 20px !important;
        width: 100% !important;
    }

    .post,
    .page {
        padding: 0 !important;
        margin: 0 !important;
    }

    /* IMAGES */
    img {
        max-width: 100% !important;
        height: auto !important;
    }

    .wp-post-image,
    .entry-content img,
    .featured-image {
        width: 100% !important;
        height: auto !important;
    }

    /* TYPOGRAPHY */
    body {
        font-size: 14px !important;
    }

    h1 {
        font-size: 20px !important;
    }

    h2 {
        font-size: 18px !important;
    }

    h3 {
        font-size: 16px !important;
    }

    /* SIDEBAR */
    .sidebar {
        display: none !important;
    }

    /* FOOTER */
    .site-footer {
        padding: 15px !important;
    }

    .site-info {
        padding: 10px !important;
        font-size: 12px !important;
    }

    /* BUTTONS */
    .button,
    .wp-block-button__link {
        width: 100% !important;
        padding: 12px 15px !important;
        display: block !important;
    }

    /* Language switcher - show menu-item-lang in mobile */
    .main-navigation li.menu-item-lang a {
        display: block !important;
    }
}

@media (max-width: 480px) {
    /* REMOVER TODO PADDING EN MÓVIL */
    * {
        padding: 0 !important;
        margin: 0 !important;
    }

    body,
    html {
        font-size: 13px !important;
        width: 100% !important;
        overflow-x: hidden !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    h1 { font-size: 18px !important; }
    h2 { font-size: 16px !important; }
    h3 { font-size: 14px !important; }

    /* Contenedor principal */
    .site,
    .site-header,
    .site-content,
    .site-footer {
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Menu a 100% */
    .main-navigation,
    .inside-navigation,
    .inside-header {
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Contenido SIN MARGIN A LOS LADOS - MISMO ANCHO QUE MENU */
    .site-main,
    .inside-article,
    .entry-content,
    .post,
    .page,
    .site-content,
    .container,
    .container.grid-container,
    .magazine-home,
    .hfeed {
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Listas sin sangría - bullet adentro */
    ul,
    ol {
        padding: 0 !important;
        margin: 15px 0 !important;
        width: 100% !important;
        list-style-position: inside !important;
    }

    li {
        margin: 8px 0 !important;
        padding: 0 !important;
    }

    /* GRID RESPONSIVO */
    .npg-col-1,
    .npg-col-2,
    .npg-col-3,
    .npg-col-4 { grid-template-columns: 1fr !important; }

    .npg-grid { gap: 12px !important; margin: 20px 0 !important; }
    .npg-content { padding: 10px !important; }
    .npg-title { font-size: 13px !important; }

    .magazine-grid,
    .magazine-section-grid { grid-template-columns: 1fr !important; gap: 12px !important; }
}

/* ==========================================
   FIX RESPONSIVE - POSTS Y PÁGINAS
   ========================================== */

/* Asegurar que el contenido no se desborde */
body,
html {
    overflow-x: hidden !important;
    width: 100% !important;
}

.entry-content,
.post,
.page,
.inside-article,
.site-content,
.site-main {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
}

.container,
.site-grid-container,
.container.grid-container {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
}

/* SOLUCIÓN SIMPLE: Limitar ancho máximo de toda la página a 1200px - SOLO DESKTOP */
@media (min-width: 769px) {
    #page.site.grid-container.container.hfeed {
        max-width: 1200px !important;
        width: auto !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    body {
        max-width: 1200px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
}

/* Padding para desktop */
@media (min-width: 769px) {
    .entry-content,
    .post,
    .page,
    .inside-article,
    .site-content,
    .site-main,
    .container,
    .site-grid-container,
    .container.grid-container {
        padding: 0 20px !important;
    }
}

img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
}

.wp-post-image,
.entry-content img,
.featured-image {
    max-width: 100% !important;
    height: auto !important;
}

/* Box-sizing para todos los elementos */
*,
*:before,
*:after {
    box-sizing: border-box !important;
}

/* FIX MENU Z-INDEX */
.main-navigation {
    position: relative !important;
    z-index: 1000 !important;
}

.main-navigation ul ul {
    z-index: 1001 !important;
}

/* FIX FEATURED IMAGE WIDTH - Normalizar ancho de imagen destacada */
.featured-image.page-header-image {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.featured-image.page-header-image-single {
    width: 100% !important;
    margin: 20px 0 !important;
    padding: 0 !important;
}

/* Prevenir que .alignfull expanda el contenido */
.entry-content .alignfull,
.entry-content .alignwide {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    max-width: 100% !important;
}

/* Hacer que los figure sean responsive */
figure {
    width: 100% !important;
    max-width: 100% !important;
}

.entry-content figure {
    width: 100% !important;
    max-width: 100% !important;
}

div[style*="calc(100% + 80px)"] {
    width: 100% !important;
    margin: 0 0 20px 0 !important;
}

/* FIX YOUTUBE VIDEOS - Mantener proporción 800x450 */
iframe[src*="youtube"],
iframe[src*="youtu.be"],
iframe[src*="vimeo"],
iframe[src*="dailymotion"] {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 16 / 9 !important;
    display: block !important;
    margin: 20px 0 !important;
}

