/* --- ESTILOS BASE (ESCRITORIO / GLOBAL) --- */
.aostmm-nav-wrapper {
    position: relative;
}
.aostmm-nav-wrapper a {
    text-decoration: none !important;
}

/* El botón hamburguesa se oculta por defecto. 
   Solo se mostrará si cargamos el archivo 'public-mobile.css' */
.aostmm-mobile-toggle {
    display: none;
}

.aostmm-nav {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
}
.aostmm-menu-item {
    position: relative;
    list-style: none;
}
.aostmm-menu-item > a {
    display: block;
    padding: 10px 15px;
    white-space: nowrap;
    position: relative;
}
.aostmm-menu-item .dashicons {
    margin-right: 5px;
    vertical-align: middle;
}

/* --- MEGA MENÚ (Dropdown) --- */
.aostmm-mega-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    border: 1px solid #ddd;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}
.aostmm-menu-item:hover > .aostmm-mega-menu {
    display: flex;
}

/* Estilos para cuando no hay contenido (solo pestañas) */
.aostmm-mega-menu.no-content {
    min-width: auto !important;
    width: fit-content;
    padding: 0;
}
.aostmm-mega-menu.no-content .aostmm-tabs-nav {
    padding: 10px;
    border-right: none;
}

/* --- LAYOUTS (Horizontal vs Vertical) --- */
.layout--horizontal .aostmm-mega-menu {
    flex-direction: column;
}
.layout--horizontal .aostmm-tabs-nav {
    display: flex;
    flex-direction: row;
    border-bottom: 1px solid #eee;
}

.layout--vertical .aostmm-mega-menu {
    flex-direction: row;
}
.layout--vertical .aostmm-tabs-nav {
    display: flex;
    flex-direction: column;
    border-right: 1px solid #eee;
    min-width: 180px;
}

/* --- PESTAÑAS (Tabs) --- */
.aostmm-tabs-nav a {
    padding: 10px 15px;
    display: block;
    border: 1px solid transparent;
    position: relative;
}
.layout--horizontal .aostmm-tabs-nav a {
    border-bottom: 0;
}
.layout--vertical .aostmm-tabs-nav a {
    border-right: 0;
}

/* --- CONTENIDO --- */
.aostmm-tabs-content {
    padding: 20px;
    flex-grow: 1;
}
.aostmm-tab-pane {
    display: none;
}
.aostmm-tab-pane.active {
    display: block;
}

/* Columnas internas */
.aostmm-content-columns {
    display: flex;
    gap: 20px;
    flex-wrap: wrap; 
}
.aostmm-column {
    flex: 1 0 200px;
    min-width: 0;
}

/* Listas de enlaces dentro del contenido */
.aostmm-tab-pane ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.aostmm-tab-pane ul li {
    position: relative;
}
.aostmm-tab-pane ul > li > a {
    display: block;
    position: relative; 
}

/* Sub-enlaces */
.aostmm-sublink-list {
    padding-left: 20px;
}
.aostmm-sublink-list li {
    margin-bottom: 4px;
}
.aostmm-sublink-list a {
    font-weight: normal;
}

/* --- UTILIDADES --- */
.aostmm-nav-wrapper a.icon-only .aostmm-menu-title {
    display: none !important;
}
.aostmm-nav-wrapper a.icon-only .dashicons {
    margin-right: 0 !important;
}

/* Asegurar visibilidad de Dashicons */
.aostmm-menu-item .dashicons,
.aostmm-tab-link .dashicons {
    width: 20px;
    height: 20px;
    font-size: 20px;
    vertical-align: middle;
    margin-right: 5px;
    display: inline-block;
    line-height: 1;
}

/* Si es "solo icono", ocultamos el texto pero dejamos el icono */
.aostmm-menu-item > a.icon-only .aostmm-menu-title,
.aostmm-tab-link.icon-only .aostmm-menu-title {
    display: none;
}

/* NOTA: Toda la lógica móvil ha sido movida a 'public-mobile.css' 
   para cargarla condicionalmente y mejorar el rendimiento. */