body { margin: 0; font-family: sans-serif; }


.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 60px; /* Altura de tu cabecera */
    background-color: #f8f8f8; /* Color de tu marca */
    color: #0056b3;
    display: flex;
    align-items: center;
    padding: 0 20px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    z-index: 1000; /* Asegura que la cabecera esté encima */
}
    .header img.logo {
        height: 40px; /* Tamaño de tu logo */
        margin-right: 15px;
    }
    .header h1 {
        width: 80%;
        margin-left: 35px;
        font-size: 1.5em;
    }

    .header-buttons {
        display: flex; /* Permite alinear los botones en una fila */
        gap: 15px; /* Espacio entre los botones */
        align-items: center; /* Centra verticalmente los botones */
        flex-shrink: 0; /* Evita que los botones se encojan */
        padding-left: 10px;
    }

    .doc-switch-button {
        display: flex; /* Permite alinear el logo y el texto dentro del botón */
        align-items: center; /* Centra verticalmente el logo y el texto */
        text-decoration: none; /* Elimina el subrayado del enlace */
        color: #555; /* Color de texto por defecto */
        font-size: 0.9em; /* Tamaño de fuente del texto del botón */
        padding: 5px 10px; /* Espaciado interno del botón */
        border: 1px solid #ddd; /* Borde del botón */
        border-radius: 5px; /* Bordes redondeados */
        transition: all 0.3s ease; /* Transición suave para efectos hover */
        white-space: nowrap; /* Evita que el texto se envuelva */
        background-color: #fff; /* Fondo blanco para los botones */
    }

    .doc-switch-button:hover {
        background-color: #eef; /* Fondo al pasar el ratón */
        border-color: #bbb; /* Borde al pasar el ratón */
        color: #333; /* Color de texto al pasar el ratón */
        cursor: pointer; /* Cambia el cursor a una mano */
    }

    .doc-switch-button .doc-logo {
        width: 20px; /* Ancho del logo */
        height: 20px; /* Alto del logo */
        margin-right: 8px; /* Espacio entre el logo y el texto */
    }

    /* Estilos para el botón de la documentación actual (no clicable) */
    .doc-switch-button.current-doc {
        background-color: #007bff; /* Un color distintivo para el botón activo */
        color: white; /* Texto blanco para el botón activo */
        border-color: #007bff; /* Borde del mismo color que el fondo */
        cursor: default; /* Cursor por defecto para indicar que no es clicable */
        pointer-events: none; /* Deshabilita los eventos de clic */
    }

    .doc-switch-button.current-doc .doc-logo {
        filter: brightness(0) invert(1); /* Hace que el logo sea blanco si el fondo es oscuro */
    }

/* Estilos para el contenedor de servidores (scheme-container) cuando está en la cabecera */
.header .scheme-container {
    display: flex;
    align-items: center;
    margin: 0;
    padding: 0;
    background: none;
    box-shadow: none;
}

    .header .scheme-container span.servers-title{
        display: none;
    }

    .header .scheme-container .servers > label {
        margin-right: 10px;
        font-size: 0.9em;
        font-weight: bold;
        color: #333;
    }

    .header .scheme-container .servers select {
        padding: 5px 8px;
        border-radius: 4px;
        border: 1px solid #ccc;
        background-color: #fff;
        font-size: 0.9em;
        max-width: 350px; /* Evita que se haga demasiado ancho */
    }

    .header .scheme-container .auth-wrapper {
        margin-left: 15px; /* Espacio entre el selector de servidor y el botón de autorización */
    }

.main-container {
    display: flex;
    height: calc(100vh - 60px); /* Altura total menos la altura de la cabecera */
    margin-top: 60px; /* Margen para la cabecera */
}

.left-menu {
    width: 320px; /* Ancho de tu menú lateral */
    background-color: #f8f8f8;
    overflow-y: auto; /* Scroll para el menú */
    padding: 20px 0;
    box-shadow: 2px 0 5px rgba(0,0,0,0.1);
}

    /* Estilos para los elementos del menú que crearemos en JS */
    .left-menu-item {
        padding: 8px 20px;
        cursor: pointer;
        border-bottom: 1px solid #eee;
        font-size: 0.80em;
        color: #333;
        transition: background-color 0.2s ease, color 0.2s ease; /* Transición suave */
    }

    .left-menu-item:hover {
        background-color: #e9e9e9;
    }

    .left-menu-item.category { /* Para los nombres de tags/categorías */
        font-weight: bold;
        padding-top: 15px;
        padding-bottom: 5px;
        background-color: #f0f0f0;
        position: sticky; /* Sticky para categorías */
        top: 0;
        z-index: 5;
        color: #000; /* Asegura un buen contraste */
    }

    .left-menu-item.operation-item {
        padding-left: 30px; /* Indentación para las operaciones */
    }

    .left-menu-item.operation-item .operation-method {
        font-weight: bold;
        margin-right: 10px;
        padding: 2px 8px;
        border-radius: 3px;
        color: white;
        min-width: 60px;
        display: inline-block;
        text-align: center;
        text-transform: uppercase;
    }

    .left-menu-item.operation-item .operation-method.get {
        background-color: #4CAF50; /* Verde */
    }

    .left-menu-item.operation-item .operation-method.post {
        background-color: #2196F3; /* Azul */
    }

    .left-menu-item.operation-item .operation-method.put {
        background-color: #ff9800; /* Naranja */
    }

    .left-menu-item.operation-item .operation-method.delete {
        background-color: #f44336; /* Rojo */
    }

    .left-menu-item.operation-item .operation-path {
        color: #555;
    }

    .left-menu-item.active {
        background-color: #007bff; /* Color de tu marca */
        color: white;
        font-weight: bold;
        border-color: #0056b3;
    }

    .left-menu-item.active .operation-path {
        color: white;
    }

    .left-menu-item.category.active { /* Ajuste si la categoría activa también debe tener un estilo diferente */
        background-color: #0056b3;
    }

.right-content {
    flex-grow: 1; /* Ocupa el espacio restante */
    overflow-y: auto; /* Scroll para el contenido */
    padding: 20px;
}

    .right-content .swagger-ui .swagger-ui .markdown p, .swagger-ui .markdown pre, .swagger-ui .renderedMarkdown p, .swagger-ui .renderedMarkdown pre, .swagger-ui ul, .swagger-ui ol, .swagger-ui ul li, .swagger-ui ol li,
    .swagger-ui .info ul, .swagger-ui .info ol, .swagger-ui .info ul li, .swagger-ui .info ol li, .swagger-ui .response-col_status,.swagger-ui .response-col_description, .swagger-ui .opblock .opblock-section-header h4, .swagger-ui table thead tr td, .swagger-ui table thead tr th{
        margin: 10px 0 0 0;
        font-size: 1rem;
        line-height: 1.5em;
    }

    .right-content .swagger-ui .opblock-tag-section{
        margin-bottom: 20px;
    }
    .right-content .swagger-ui .opblock-tag{
        display: block;
        padding: 10px 0 10px 0; 
        border: none;
    }

    .right-content .swagger-ui .expand-methods, .swagger-ui .expand-operation{
        display: none;
    }

    /*
     * Elimina el efecto hover (color de fondo) que aparece al pasar el ratón
     * sobre la cabecera de un servicio.
    */
    .swagger-ui .opblock-tag-section .opblock-tag:hover {
        background: transparent;
    }

    /* Fuerza a que el cuerpo de la operación esté siempre expandido y no se pueda contraer */
    .swagger-ui .opblock-tag-section .opblock-tag {
        display: block;
    }

    .swagger-ui .response-col_links{
        display: none;
    }

    .swagger-ui .tab{
        margin-bottom: 10px;
        justify-content: flex-end;
    }

        .swagger-ui .tab li button.tablinks{
           align-items: center; /* Centra verticalmente el logo y el texto */
            text-decoration: none; /* Elimina el subrayado del enlace */
            color: #555; /* Color de texto por defecto */
            font-size: 0.9em; /* Tamaño de fuente del texto del botón */
            padding: 5px 10px; /* Espaciado interno del botón */
            border: 1px solid #ddd; /* Borde del botón */
            border-radius: 5px; /* Bordes redondeados */
            transition: all 0.3s ease; /* Transición suave para efectos hover */
            white-space: nowrap; /* Evita que el texto se envuelva */
            background-color: #fff; /* Fondo blanco para los botones */
        }

            .swagger-ui .tab li button.tablinks:hover {
                background-color: #eef; /* Fondo al pasar el ratón */
                border-color: #bbb; /* Borde al pasar el ratón */
                color: #333; /* Color de texto al pasar el ratón */
                cursor: pointer; /* Cambia el cursor a una mano */
            }

            .swagger-ui .tab li button.tablinks[aria-selected="true"] {
                background-color: #007bff; /* Un color distintivo para el botón activo */
                color: white; /* Texto blanco para el botón activo */
                border-color: #007bff; /* Borde del mismo color que el fondo */
                cursor: default; /* Cursor por defecto para indicar que no es clicable */
                pointer-events: none; /* Deshabilita los eventos de clic */
            }

    .swagger-ui .model-example{
        margin-bottom: 1em;
    }

        .swagger-ui .model-example .model-container{
            background: rgba(0,0,0,.1);
        }

    .swagger-ui .model-box{
        background: none;
    }

    .swagger-ui .json-schema-2020-12-body .markdown p, .swagger-ui .json-schema-2020-12-body .renderedMarkdown p{
        margin-left: 20px;
        font-size: 12px;
    }

        .swagger-ui .json-schema-2020-12__constraint--string
        {
            font-size: 12px;
        }

    .swagger-ui .responses-table tr{
        border-bottom: 1px dotted #61affe;
    }

        .swagger-ui .responses-table tr:last-child{
            border-bottom: none;
        }