/* ============================================================
   CORES PRINCIPAIS
============================================================ */
:root {
    --cor-vermelho: #b30000;
    --cor-vermelho-hover: #7a0000;
    --cor-branco: #ffffff;
    --cor-preto: #000000;
}

/* ============================================================
   HEADER — BARRA BRANCA ATRÁS DOS MENUS
============================================================ */
header.ym-noprint,
header.ym-noprint .ym-wrapper,
header.ym-noprint .ym-wbox {
    background-color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
}

header.ym-noprint h1 {
    background-color: var(--cor-vermelho) !important;
    color: var(--cor-branco) !important;
}

/* ============================================================
   RESET / ESTRUTURA YAML
============================================================ */
#nav .ym-wrapper,
#nav .ym-hlist,
#nav .ym-wbox {
    width: auto !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding: 0 !important;
    display: block !important;
    overflow: visible !important;
}

.menu-wrapper {
    width: 100%;
    display: block !important;
    text-align: center !important;
    overflow: visible !important;
}

.menu-wrapper .ym-hlist {
    display: inline-block !important;
    width: auto !important;
    position: relative !important;
    overflow: visible !important;
}

/* ============================================================
   TOPBAR
============================================================ */
.topbar,
.topbar-inner {
    background: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
}

.topbar {
    width: 100%;
    display: flex;
    justify-content: center;
    overflow: visible !important;
    padding: 6px 0;
}

.topbar-inner {
    max-width: 900px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 90px;
    overflow: visible !important;
}

.topbar-left,
.topbar-center,
.topbar-right {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Botões circulares */
.btn-circle {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    min-height: 28px !important;
    background: var(--cor-vermelho);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 3px;
    padding: 0 !important;
    cursor: pointer;
    transition: background 0.2s;
    box-sizing: border-box;
    text-decoration: none;
}

.btn-circle:hover {
    background: var(--cor-vermelho-hover);
}

.btn-circle img {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
    max-width: 18px !important;
    max-height: 18px !important;
    display: block;
}

/* Botão lua/sol uniformizado */
#themeToggle,
#themeToggle2,
.theme-toggle {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    min-height: 28px !important;
    background: var(--cor-vermelho) !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 3px !important;
    box-sizing: border-box;
    cursor: pointer;
    transition: background 0.2s;
    text-decoration: none !important;
}

#themeToggle:hover,
#themeToggle2:hover,
.theme-toggle:hover {
    background: var(--cor-vermelho-hover) !important;
}

#themeIcon,
#themeIcon2,
#themeToggle img,
#themeToggle2 img,
.theme-toggle img {
    width: 14px !important;
    height: 14px !important;
    min-width: 14px !important;
    min-height: 14px !important;
    max-width: 14px !important;
    max-height: 14px !important;
    display: block;
}

/* Botões principais da topbar */
.btn-main {
    background: var(--cor-vermelho);
    color: var(--cor-branco);
    padding: 8px 14px;
    border-radius: 4px;
    font-weight: bold;
    display: inline-flex;
    align-items: center;
    transition: background 0.2s;
    text-decoration: none;
    border: none !important;
}

.btn-main:hover {
    background: var(--cor-vermelho-hover);
}

/* Botões sociais */
.btn-social {
    background: none !important;
    border-radius: 0 !important;
    padding: 0 2px !important;
    margin-left: 6px !important;
    display: inline-flex !important;
    align-items: center !important;
    text-decoration: none !important;
}

.btn-social img {
    width: 22px !important;
    height: 22px !important;
    filter: none !important;
    display: block;
}

/* ============================================================
   NAV CONTAINER
============================================================ */
#nav {
    width: 100%;
    display: flex;
    justify-content: center;
    background: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
    overflow: visible !important;
    margin-top: 8px !important;
}

/* Neutralizar YAML */
#nav .ym-grid > [class*="ym-g"],
#nav .ym-clearfix:before,
#nav .ym-clearfix:after,
.ym-hlist {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

/* ============================================================
   MENU PRINCIPAL
============================================================ */
#menu {
    display: inline-flex !important;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 3px;
    max-width: 900px;
    margin: 0 auto;
    padding: 0;
    list-style: none;
    overflow: visible !important;
}

#menu > li {
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
}

#menu > li > a {
    display: block;
    padding: 6px 10px !important;
    background: var(--cor-vermelho) !important;
    color: var(--cor-branco) !important;
    text-decoration: none;
    font-weight: bold;
    font-size: 1em;
    white-space: nowrap;
    border: none !important;
    border-radius: 6px !important;
    margin-right: 0 !important;
    line-height: 16px !important;
    transition: background 0.2s, color 0.2s;
}

#menu > li > a:hover {
    background: var(--cor-vermelho-hover) !important;
    border-radius: 6px !important;
}

/* Indicadores + / – */
#menu li.has-submenu > a::after {
    content: "+";
    margin-left: 6px;
    font-weight: bold;
    color: #ffffff !important;
}

#menu li.open > a::after {
    content: "\2212";
}

/* ============================================================
   SUBMENUS
============================================================ */
#menu li {
    position: relative !important;
}

#menu li ul.submenu,
#menu .submenu {
    display: none !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    min-width: 200px;
    background: #ffffff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    z-index: 999999 !important;
    overflow: visible !important;
    flex-direction: column !important;
}

/* desktop: hover e .open */
#menu li.has-submenu:hover > ul.submenu,
#menu li.open > ul.submenu,
#menu > li:hover > .submenu {
    display: block !important;
}

#menu .submenu li {
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
    list-style: none !important;
    line-height: 0 !important;
}

#menu li ul.submenu li a,
#menu .submenu li a {
    display: block;
    padding: 6px 12px !important;
    margin: 0 !important;
    background: var(--cor-vermelho) !important;
    color: var(--cor-branco) !important;
    font-size: 0.95em;
    font-weight: bold;
    white-space: nowrap;
    text-decoration: none;
    border: none !important;
    border-radius: 6px !important;
    line-height: 16px !important;
    transition: background 0.2s;
}

#menu li ul.submenu li a:hover,
#menu .submenu li a:hover {
    background: var(--cor-vermelho-hover) !important;
}

/* Submenu do submenu */
#menu li ul.submenu li ul.submenu,
#menu .submenu .submenu {
    display: none !important;
    position: absolute !important;
    top: 0 !important;
    left: calc(100% - 2px) !important;
    margin: 0 !important;
    padding-top: 0 !important;
    min-width: 220px !important;
    border-radius: 6px !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.25) !important;
    z-index: 999999 !important;
}

#menu li ul.submenu li.has-submenu:hover > ul.submenu,
#menu .submenu li:hover > .submenu {
    display: block !important;
}

/* ============================================================
   MOBILE
============================================================ */
/* ============================================================
   MOBILE
============================================================ */
@media (max-width: 900px) {

    .topbar {
        padding: 8px 0 !important;
    }

    .topbar-inner {
        width: 100%;
        max-width: 100%;
        margin: 0 auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 12px;
    }

    .topbar-left,
    .topbar-center,
    .topbar-right {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
        width: 100%;
    }

    .topbar-left,
    .topbar-center {
        gap: 8px;
    }

    .topbar-right {
        gap: 10px;
    }

    #nav {
        width: 100%;
    }

    .menu-wrapper,
    .menu-wrapper .ym-hlist,
    #nav .ym-wrapper {
        width: 100% !important;
        max-width: 100% !important;
    }

    #menu {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        justify-content: flex-start !important;
        width: 100% !important;
        max-width: 100% !important;
        gap: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    #menu li {
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow: visible !important;
    }

    #menu > li > a,
    #menu .submenu li > a {
        display: block !important;
        width: 100% !important;
        box-sizing: border-box !important;
        text-align: left !important;
        margin: 0 !important;
        border-radius: 0 !important;
    }

    #menu > li > a {
        padding: 14px 16px !important;
    }

    #menu .submenu li > a {
        padding: 12px 16px 12px 28px !important;
    }

    #menu .submenu .submenu li > a {
        padding-left: 40px !important;
    }

    #menu li.has-submenu > a {
        cursor: pointer !important;
    }

    /* no mobile, hover não deve mandar */
    #menu li.has-submenu:hover > ul.submenu,
    #menu > li:hover > .submenu,
    #menu .submenu li:hover > .submenu {
        display: none !important;
    }

    /* estado fechado */
    #menu ul.submenu,
    #menu .submenu,
    #menu li ul.submenu,
    #menu li ul.submenu li ul.submenu {
        position: static !important;
        display: none !important;
        width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
        box-shadow: none !important;
        border: none !important;
        margin: 0 !important;
        padding: 0 !important;
        float: none !important;
        left: auto !important;
        top: auto !important;
        visibility: visible !important;
        opacity: 1 !important;
        max-height: none !important;
        overflow: visible !important;
    }

    /* estado aberto - reforçado */
    body #nav #menu li[data-open="1"] > ul.submenu,
    body #nav #menu li[data-open="1"] > .submenu,
    body #nav #menu ul.submenu li[data-open="1"] > ul.submenu,
    body #nav #menu ul.submenu li[data-open="1"] > .submenu,
    body #nav #menu li.has-submenu[data-open="1"] > ul.submenu,
    body #nav #menu li.has-submenu[data-open="1"] > .submenu {
        display: block !important;
        position: static !important;
        width: 100% !important;
        visibility: visible !important;
        opacity: 1 !important;
        max-height: none !important;
        overflow: visible !important;
    }

    #menu li.has-submenu > a::after {
        content: "+" !important;
        float: right !important;
        margin-left: 0 !important;
        opacity: 0.9 !important;
    }

    #menu li[data-open="1"] > a::after {
        content: "\2212" !important;
    }
}
/* ============================================================
   DARK MODE
============================================================ */
.dark-mode #nav,
.dark-mode #nav .ym-wrapper,
.dark-mode #nav .ym-wbox {
    background: #222 !important;
}

.dark-mode #menu > li > a {
    background: var(--cor-vermelho) !important;
    color: var(--cor-branco) !important;
}

.dark-mode #menu > li > a:hover {
    background: var(--cor-vermelho-hover) !important;
}

.dark-mode .submenu,
.dark-mode #menu li ul.submenu {
    background: #333 !important;
    box-shadow: 0 2px 6px rgba(0,0,0,0.4);
}

.dark-mode .submenu li a,
.dark-mode #menu li ul.submenu li a {
    background: var(--cor-vermelho) !important;
    color: var(--cor-branco) !important;
}

.dark-mode .submenu li a:hover,
.dark-mode #menu li ul.submenu li a:hover {
    background: var(--cor-vermelho-hover) !important;
}

/* barra uniforme modo escuro */
.dark-mode .topbar {
    background: #333 !important;
}

.dark-mode .topbar-inner,
.dark-mode .topbar-center {
    background: transparent !important;
}

.dark-mode .btn-social img {
    filter: invert(1) !important;
}