/* Paleta de colores */
:root {
    --color-primary: #002e63;
    --color-secondary: #d4b012;
    --color-light-accent: #e1e0bd;
    --color-text: rgba(0,0,0,0.87);
}

/* Estilos generales del cuerpo y enlaces */
html, body {
    font-family: Corbel;
    font-size: 14px;
    line-height: 1.43rem;
    color: var(--color-text);
    background: rgb(174 171 74 / 20%);
    text-align: justify;
}

a {
    color: var(--color-primary);
    text-decoration: none;
}

a:hover, a:focus {
    color: var(--color-secondary);
}

b, strong {
    font-weight: bolder;
    color: var(--color-primary);
}

/* Estilos de la cabecera (Header) */
.pkp_structure_head {
    background-color: var(--color-light-accent);
    border-bottom: 1px solid #ddd;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 20px;
    position: relative;
}

/* Contenedores de navegación */
.pkp_site_name_wrapper,
.has_site_logo .pkp_site_name,
.has_site_logo .pkp_navigation_primary_wrapper {
    background-color: var(--color-primary);
    width: auto;
}

.pkp_navigation_primary_wrapper {
    padding-left: 0;
    padding-right: 0;
    background-color: var(--color-secondary);
}

/* Estilo para los botones del menú principal */
.pkp_navigation_primary > li {
    position: relative; /* Clave para posicionar el submenú */
}

.pkp_navigation_primary > li > a {
    color: #fff;
    background-color: var(--color-primary);
    transition: background-color 0.3s ease, color 0.3s ease;
    padding: 10px 15px;
    display: block;
}

.pkp_navigation_primary > li > a:hover,
.pkp_navigation_primary > li > a:focus {
    color: #fff;
    background-color: var(--color-secondary);
    outline: 0;
    border-color: var(--color-primary);
}

.pkp_site_nav_menu .pkp_nav_list {
    padding-left: 0;
    margin-left: 2rem;
}

/* Estilos para los submenús */
.pkp_nav_list ul {
    display: none; /* Oculto por defecto en escritorio */
    position: absolute;
    top: 100%; /* Aparece justo debajo del elemento padre */
    left: 0;
    list-style: none;
    padding: 0;
    margin: 0;
    background-color: #f1f1f1;
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
    z-index: 1;
}

.pkp_nav_list ul a {
    background: none;
    color: #002e63;
    padding: 8px 15px;
    display: block;
}

.pkp_nav_list ul a:hover,
.pkp_nav_list ul a:focus {
    outline: 0;
    background: #ddd;
    border-color: #006798;
    color: #002e63;
}

.pkp_nav_list li:hover > ul {
    display: block;
}

/* Estilos de navegación de usuario */
.pkp_navigation_user {
    margin: 0;
    padding: 0;
    border: none;
    background-color: transparent;
    align-self: flex-end;
    display: flex;
    list-style: none;
}

/* Estilo para los botones de la barra de usuario */
.pkp_navigation_user > li > a {
    padding-top: 0.357rem;
    padding-bottom: 0.357rem;
    line-height: 1.43rem;
    background-color: var(--color-primary);
    color: #fff;
    transition: background-color 0.3s ease, color 0.3s ease;
    display: block;
}

.pkp_navigation_user > li > a:hover,
.pkp_navigation_user > li > a:focus {
    background-color: var(--color-secondary);
    color: #fff;
}

/* Estilos del contenido principal y pie de página */
.pkp_structure_content {
    padding-top: 2.143rem;
    background-color: white;
}

.pkp_structure_footer_wrapper {
    background: var(--color-light-accent);
}

.pkp_structure_footer {
    text-align: center;
    background-color: var(--color-primary);
}

.pkp_footer_content {
    padding: 2.143rem;
    text-align: left;
    border-top: 10px solid;
    border-color: var(--color-secondary);
}

.pkp_brand_footer a {
    float: right;
    display: block;
    max-width: 150px;
    filter: invert(1);
}

/* Oculta el botón de menú en pantallas grandes */
.menu-toggle {
    display: none;
}

---

### Media Query para el menú móvil

```css
@media (max-width: 991px) {
    /* El menú principal se colapsa y se convierte en menú lateral */
    .pkp_navigation_primary_wrapper {
        background-color: var(--color-primary);
        width: 100%;
    }
    
    .pkp_navigation_primary {
        display: none;
        position: fixed;
        top: 0;
        left: -100%;
        width: 250px;
        height: 100%;
        background-color: var(--color-primary);
        padding-top: 2rem;
        transition: left 0.3s ease;
        z-index: 1000;
        box-shadow: 2px 0 5px rgba(0,0,0,0.5);
        list-style: none;
        margin: 0;
        padding-left: 0;
    }

    /* Estilo para los ítems del menú móvil */
    .pkp_navigation_primary > li {
        width: 100%;
    }

    .pkp_navigation_primary > li > a {
        padding: 15px 20px;
        width: 100%;
        box-sizing: border-box;
    }

    /* Regla clave: los submenús ahora se muestran por defecto en el menú móvil */
    .pkp_navigation_primary ul {
        display: block;
        position: static;
        background-color: transparent;
        box-shadow: none;
        padding-left: 20px;
    }

    .pkp_navigation_primary.is-open {
        left: 0;
        display: block;
    }

    /* Muestra el botón de menú "hamburguesa" */
    .menu-toggle {
        display: block;
        background: none;
        border: none;
        color: #fff;
        font-size: 2rem;
        cursor: pointer;
        z-index: 1001;
    }
    
    /* La barra de usuario se mantiene en la esquina superior derecha */
    .pkp_navigation_user {
        display: flex;
        position: absolute;
        top: 10px;
        right: 10px;
        z-index: 999;
    }

    .pkp_navigation_user li {
        margin-left: 10px;
    }

    /* Ajuste para los enlaces de usuario en móvil */
    .pkp_navigation_user > li > a {
        background-color: var(--color-primary);
        color: #fff;
        padding: 8px 12px;
        border-radius: 4px;
        display: inline-block;
    }

    .pkp_navigation_user > li > a:hover,
    .pkp_navigation_user > li > a:focus {
        background-color: var(--color-secondary);
        color: #fff;
    }
}