.fmv-tabs-wrapper {
    display: flex;
    gap: 20px;
    font-family: sans-serif;
}

/* --- Layout Horizontal --- */
.fmv-tabs-wrapper.fmv-layout-horizontal {
    flex-direction: column;
}
.fmv-layout-horizontal .fmv-tabs-nav {
    display: flex;
    flex-wrap: wrap;
    border-bottom: 2px solid #eaeaea;
    gap: 15px;
}

/* --- Layout Vertical --- */
.fmv-tabs-wrapper.fmv-layout-vertical {
    flex-direction: row;
}
.fmv-layout-vertical .fmv-tabs-nav {
    display: flex;
    flex-direction: column;
    min-width: 250px;
    border-right: 2px solid #eaeaea;
    gap: 10px;
    padding-right: 20px;
}
.fmv-layout-vertical .fmv-tabs-content-wrapper {
    flex-grow: 1;
}

/* --- Botones / Pestañas --- */
.fmv-tab-button {
    background: none;
    border: none;
    padding: 10px 15px;
    font-size: 16px;
    font-weight: 500;
    color: #555;
    cursor: pointer;
    transition: all 0.3s ease;
    border-bottom: 3px solid transparent; /* Para horizontal */
    text-align: left;
}
.fmv-layout-vertical .fmv-tab-button {
    border-bottom: none;
    border-left: 3px solid transparent; /* Para vertical */
}

/* Hover & Active States (Basado en el verde de tus imágenes) */
.fmv-tab-button:hover,
.fmv-tab-button.active {
    color: #1b8259; /* Verde de la malla curricular */
}
.fmv-layout-horizontal .fmv-tab-button.active {
    border-bottom: 3px solid #1b8259;
}
.fmv-layout-vertical .fmv-tab-button.active {
    border-left: 3px solid #1b8259;
    background-color: #f9f9f9;
}

/* --- Paneles de Contenido --- */
.fmv-tab-pane {
    display: none;
    animation: fadeIn 0.4s ease;
    padding: 15px 0;
}
.fmv-tab-pane.active {
    display: block;
}

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

/* --- Responsividad (Mobile) --- */
@media (max-width: 768px) {
    .fmv-tabs-wrapper.fmv-layout-vertical {
        flex-direction: column; /* Apila todo en móvil */
    }
    .fmv-layout-vertical .fmv-tabs-nav {
        border-right: none;
        border-bottom: 2px solid #eaeaea;
        padding-right: 0;
        padding-bottom: 10px;
        min-width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
    }
    .fmv-layout-vertical .fmv-tab-button {
        border-left: none;
        border-bottom: 3px solid transparent;
    }
    .fmv-layout-vertical .fmv-tab-button.active {
        border-left: none;
        border-bottom: 3px solid #1b8259;
    }
}