/* ============================================================
   menu.css — D-FILM · Design final
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@400;500;600&display=swap');

/* ── RESET ESCOPO ── */
.menu-superior *,
.menu-superior *::before,
.menu-superior *::after {
    box-sizing: border-box;
}

/* ── BARRA PRINCIPAL ── */
.menu-superior {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-color: #0F0F0F;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 30px;
    height: 64px;
    z-index: 1000;
    border-bottom: 2px solid #FFD400;
    box-shadow: 0 4px 20px rgba(0,0,0,.70);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* shimmer no topo */
.menu-superior::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, #FFD400, #E5B800, #FFD400);
    background-size: 200% 100%;
    animation: shimmer 3s linear infinite;
    pointer-events: none;
}

@keyframes shimmer {
    0%   { background-position: -200% 0; }
    100% { background-position:  200% 0; }
}

.menu-superior.hidden {
    transform: translateY(-100%);
    box-shadow: none;
}

/* ── LOGO ── */
.menu-esquerda {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.logo-link {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: #FFFFFF;
    font-family: 'Syne', sans-serif;
    font-size: 1.35em;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: color .35s ease, transform .4s cubic-bezier(.68,-.55,.27,1.55);
}

.logo-link:hover {
    color: #FFD400;
    transform: scale(1.06) rotate(1deg);
}

.logo-icon {
    flex-shrink: 0;
    transition: filter .35s ease;
}

.logo-link:hover .logo-icon {
    filter: drop-shadow(0 0 6px #FFD400);
}

.logo-img {
    height: 42px;
    width: auto;
    max-width: 90px;
    object-fit: contain;
    border-radius: 0;
    flex-shrink: 0;
    transition: filter .35s ease;
}

.logo-link:hover .logo-img {
    filter: drop-shadow(0 0 6px #FFD400);
}

/* ── MENU CENTRAL ── */
.menu-central {
    list-style: none;
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: nowrap;
    margin: 0;
    padding: 0;
}

.menu-central > li {
    position: relative;
}

.menu-central > li > a {
    display: flex;
    align-items: center;
    gap: 4px;
    text-decoration: none;
    color: #FFFFFF;
    font-family: 'Syne', sans-serif;
    font-size: .82em;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    padding: 8px 14px;
    border-radius: 6px;
    background: linear-gradient(145deg, #2B2B2B, #0F0F0F);
    box-shadow: 0 2px 6px rgba(0,0,0,.30);
    white-space: nowrap;
    transition:
        background .3s ease,
        color .3s ease,
        transform .35s cubic-bezier(.25,.46,.45,.94),
        box-shadow .3s ease;
}

.menu-central > li > a:hover,
.menu-central > li > a.active {
    background: linear-gradient(135deg, #FFD400, #E5B800);
    color: #0F0F0F;
    transform: translateY(-3px) scale(1.04);
    box-shadow: 0 6px 16px rgba(255,212,0,.55);
}

/* botão de agendamento com destaque pulsante */
.destaque-nav {
    background: linear-gradient(135deg, #FFD400, #E5B800) !important;
    color: #0F0F0F !important;
    box-shadow: 0 3px 12px rgba(255,212,0,.45) !important;
    animation: pulseNav 2.5s ease-in-out infinite;
}

@keyframes pulseNav {
    0%, 100% { box-shadow: 0 3px 12px rgba(255,212,0,.45); }
    50%       { box-shadow: 0 6px 22px rgba(255,212,0,.80); }
}

.destaque-nav:hover {
    background: linear-gradient(135deg, #FFFFFF, #E5E5E5) !important;
    color: #0F0F0F !important;
    transform: translateY(-3px) scale(1.05) !important;
}

/* setas indicadoras */
.seta, .seta-sub {
    font-size: .7em;
    opacity: .65;
    transition: transform .25s ease;
    line-height: 1;
}

.dropdown:hover > a .seta           { transform: rotate(180deg); }
.dropdown-submenu:hover > a .seta-sub { transform: translateX(3px); }

/* ═══════════════════════════════════════════════════════════
   DROPDOWN — NÍVEL 1
   O truque do "bridge": o pseudo-elemento ::after do link pai
   cria uma área invisível que cobre o espaço entre o botão
   e o painel, impedindo que o mouse "caia fora" ao descer.
═══════════════════════════════════════════════════════════ */
.dropdown .submenu {
    visibility: hidden;
    pointer-events: none;
    position: absolute;
    top: 100%;
    left: 0;
    margin-top: 0;          /* zero: o bridge já garante continuidade */
    background-color: #1A1A1A;
    list-style: none;
    width: max-content;
    min-width: 200px;
    border: 1px solid #2B2B2B;
    border-top: 3px solid #FFD400;
    border-radius: 0 0 8px 8px;
    opacity: 0;
    transform: translateY(6px) scale(.97);
    transition:
        opacity .22s ease,
        transform .32s cubic-bezier(.68,-.55,.27,1.55),
        visibility 0s linear .22s;
    z-index: 100;
    padding: 6px 0;
    box-shadow: 0 12px 28px rgba(0,0,0,.55);
}

/* bridge invisível que fecha o gap */
.dropdown > a {
    position: relative;
}
.dropdown > a::after {
    content: '';
    position: absolute;
    bottom: -12px;   /* altura = gap entre link e submenu */
    left: 0;
    width: 100%;
    height: 12px;
    background: transparent;
}

.dropdown:hover .submenu,
.dropdown:focus-within .submenu {
    visibility: visible;
    pointer-events: auto;
    opacity: 1;
    transform: translateY(0) scale(1);
    transition:
        opacity .22s ease,
        transform .32s cubic-bezier(.68,-.55,.27,1.55),
        visibility 0s linear 0s;
}

/* ── ITENS DO SUBMENU ── */
.dropdown-submenu {
    position: relative;
}

.dropdown-submenu > a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 20px;
    color: #CCCCCC;
    font-family: 'DM Sans', sans-serif;
    font-size: .88em;
    font-weight: 500;
    text-decoration: none;
    transition: background .2s ease, color .2s ease, padding-left .2s ease;
    white-space: nowrap;
}

.dropdown-submenu > a:hover {
    background: rgba(255,212,0,.12);
    color: #FFD400;
    padding-left: 26px;
}

/* ═══════════════════════════════════════════════════════════
   SUB-SUBMENU — NÍVEL 2
   Mesmo truque de bridge lateral.
═══════════════════════════════════════════════════════════ */
.dropdown-submenu .subsubmenu {
    visibility: hidden;
    pointer-events: none;
    position: absolute;
    top: -6px;
    left: 100%;
    margin-left: 0;
    background-color: #1A1A1A;
    list-style: none;
    width: max-content;
    min-width: 250px;
    border: 1px solid #2B2B2B;
    border-left: 3px solid #FFD400;
    border-radius: 0 8px 8px 8px;
    opacity: 0;
    transform: translateX(6px) scale(.97);
    transition:
        opacity .22s ease,
        transform .32s cubic-bezier(.68,-.55,.27,1.55),
        visibility 0s linear .22s;
    z-index: 101;
    padding: 6px 0;
    box-shadow: 8px 10px 24px rgba(0,0,0,.55);
    max-height: 70vh;
    overflow-y: auto;
}

/* bridge lateral */
.dropdown-submenu > a {
    position: relative;
}
.dropdown-submenu > a::after {
    content: '';
    position: absolute;
    top: 0;
    right: -10px;   /* cobre o gap lateral */
    width: 10px;
    height: 100%;
    background: transparent;
}

.dropdown-submenu:hover .subsubmenu,
.dropdown-submenu:focus-within .subsubmenu {
    visibility: visible;
    pointer-events: auto;
    opacity: 1;
    transform: translateX(0) scale(1);
    transition:
        opacity .22s ease,
        transform .32s cubic-bezier(.68,-.55,.27,1.55),
        visibility 0s linear 0s;
}

.subsubmenu li a {
    display: block;
    padding: 9px 20px;
    color: #BBBBBB;
    font-family: 'DM Sans', sans-serif;
    font-size: .86em;
    text-decoration: none;
    transition: background .2s ease, color .2s ease, padding-left .2s ease;
    white-space: nowrap;
}

.subsubmenu li a:hover {
    background: rgba(255,212,0,.10);
    color: #FFD400;
    padding-left: 28px;
}

/* scrollbar do sub-submenu */
.subsubmenu::-webkit-scrollbar       { width: 4px; }
.subsubmenu::-webkit-scrollbar-track { background: #1A1A1A; }
.subsubmenu::-webkit-scrollbar-thumb { background: #FFD400; border-radius: 2px; }

/* ── BOTÃO LOGIN ── */
.menu-direita {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.botao-login {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    text-decoration: none;
    color: #0F0F0F;
    background: linear-gradient(135deg, #FFD400, #E5B800);
    font-family: 'Syne', sans-serif;
    font-size: .82em;
    font-weight: 800;
    letter-spacing: .5px;
    text-transform: uppercase;
    padding: 9px 18px;
    border-radius: 6px;
    white-space: nowrap;
    box-shadow: 0 2px 10px rgba(255,212,0,.35);
    transition:
        background .3s ease,
        color .3s ease,
        transform .35s cubic-bezier(.25,.46,.45,.94),
        box-shadow .3s ease;
}

.botao-login:hover {
    background: linear-gradient(135deg, #FFFFFF, #E5E5E5);
    color: #0F0F0F;
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 8px 20px rgba(255,212,0,.50);
}

/* ── HAMBÚRGUER ── */
.hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    background: none;
    border: 2px solid #2B2B2B;
    border-radius: 6px;
    cursor: pointer;
    padding: 7px 9px;
    transition: border-color .3s ease, transform .3s ease;
}

.hamburger:hover {
    border-color: #FFD400;
    transform: scale(1.08);
}

.hamburger span {
    display: block;
    width: 20px;
    height: 2px;
    background: #FFFFFF;
    border-radius: 2px;
    transition: background .3s ease, transform .35s ease, opacity .3s ease;
}

.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.hamburger:hover span             { background: #FFD400; }

/* ── RESPONSIVIDADE ── */
@media (max-width: 900px) {
    .menu-superior {
        padding: 0 16px;
        height: auto;
        min-height: 56px;
        flex-wrap: wrap;
    }

    .hamburger {
        display: flex;
    }

    .menu-central {
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 4px;
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        background-color: #0F0F0F;
        padding: 12px 16px 18px;
        border-top: 2px solid #FFD400;
        box-shadow: 0 12px 24px rgba(0,0,0,.55);
        z-index: 999;
        max-height: calc(100vh - 56px);
        overflow-y: auto;
    }

    .menu-central.active { display: flex; }

    .menu-central > li { width: 100%; }

    .menu-central > li > a {
        width: 100%;
        justify-content: space-between;
    }

    /* submenus: estáticos e colapsáveis no mobile */
    .dropdown .submenu,
    .dropdown-submenu .subsubmenu {
        display: none;
        visibility: visible;
        opacity: 1;
        pointer-events: auto;
        position: static;
        transform: none;
        width: 100%;
        min-width: 0;
        margin: 2px 0 0;
        border: none;
        border-left: 3px solid #FFD400;
        border-radius: 0;
        background-color: rgba(26,26,26,.95);
        box-shadow: none;
        padding: 4px 0 4px 14px;
        max-height: none;
        overflow: visible;
    }

    .dropdown.mob-open > .submenu           { display: block; }
    .dropdown-submenu.mob-open > .subsubmenu { display: block; }

    /* seta vira quando aberto em mobile */
    .dropdown.mob-open > a .seta { transform: rotate(180deg); }
    .dropdown-submenu.mob-open > a .seta-sub { transform: rotate(90deg); }

    /* remove pseudo-bridges em mobile */
    .dropdown > a::after,
    .dropdown-submenu > a::after { display: none; }

    .subsubmenu li a { white-space: normal; }
    .menu-central > li > a:hover { transform: none; }
}

/* ============================================================
   ESTILOS DO MENU INTERNO (menu.php — área autenticada)
   Reutiliza o mesmo menu.css do site público
   ============================================================ */

/* ── BOTÃO COROA (admin / master) ── */
.botao-coroa {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: linear-gradient(145deg, #2B2B2B, #0F0F0F);
    border: 1px solid #2B2B2B;
    color: #6B6B6B;
    font-size: 1em;
    text-decoration: none;
    flex-shrink: 0;
    transition:
        background .3s ease,
        color .3s ease,
        border-color .3s ease,
        transform .4s cubic-bezier(.68,-.55,.27,1.55),
        box-shadow .3s ease;
}

.botao-coroa:hover {
    background: linear-gradient(145deg, #2B2B2B, #1A1A1A);
    color: #FFD400;
    border-color: #FFD400;
    transform: translateY(-3px) scale(1.12) rotate(8deg);
    box-shadow: 0 6px 16px rgba(255,212,0,.45);
}

/* coroa do master tem brilho permanente */
.botao-coroa--master {
    color: #FFD400;
    border-color: rgba(255,212,0,.35);
    box-shadow: 0 0 10px rgba(255,212,0,.25);
    animation: coroaPulse 2.5s ease-in-out infinite;
}

@keyframes coroaPulse {
    0%, 100% { box-shadow: 0 0 8px  rgba(255,212,0,.25); }
    50%       { box-shadow: 0 0 18px rgba(255,212,0,.55); }
}

/* ── BLOCO DO USUÁRIO ── */
.usuario-wrap {
    position: relative;
    flex-shrink: 0;
}

.usuario-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(145deg, #2B2B2B, #0F0F0F);
    border: 1px solid #2B2B2B;
    border-radius: 22px;          /* pílula */
    color: #FFFFFF;
    font-family: 'Syne', sans-serif;
    font-size: .82em;
    font-weight: 700;
    letter-spacing: .4px;
    padding: 7px 14px 7px 10px;
    cursor: pointer;
    white-space: nowrap;
    transition:
        background .3s ease,
        border-color .3s ease,
        box-shadow .3s ease,
        transform .3s ease;
}

.usuario-btn:hover {
    background: linear-gradient(145deg, #333, #1A1A1A);
    border-color: #FFD400;
    box-shadow: 0 4px 14px rgba(255,212,0,.30);
    transform: translateY(-1px);
}

.usuario-btn .fa-circle-user {
    font-size: 1.25em;
    color: #FFD400;
}

.seta-usr {
    font-size: .75em;
    color: #6B6B6B;
    transition: transform .3s ease, color .3s ease;
}

.usuario-btn:hover .seta-usr { color: #FFD400; }

/* ── DROPDOWN DO USUÁRIO ── */
.usuario-dropdown {
    visibility: hidden;
    pointer-events: none;
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    min-width: 220px;
    background-color: #1A1A1A;
    border: 1px solid #2B2B2B;
    border-top: 3px solid #FFD400;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 12px 28px rgba(0,0,0,.60);
    opacity: 0;
    transform: translateY(8px) scale(.97);
    transition:
        opacity .22s ease,
        transform .3s cubic-bezier(.68,-.55,.27,1.55),
        visibility 0s linear .22s;
    z-index: 200;
    overflow: hidden;
}

/* bridge invisível */
.usuario-wrap::after {
    content: '';
    position: absolute;
    top: 100%;
    right: 0;
    width: 100%;
    height: 10px;
    background: transparent;
}

.usuario-dropdown.open {
    visibility: visible;
    pointer-events: auto;
    opacity: 1;
    transform: translateY(0) scale(1);
    transition:
        opacity .22s ease,
        transform .3s cubic-bezier(.68,-.55,.27,1.55),
        visibility 0s linear 0s;
}

/* cabeçalho do dropdown */
.usr-cabecalho {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    background: rgba(255,212,0,.05);
}

.usr-avatar {
    font-size: 2em;
    color: #FFD400;
    line-height: 1;
    flex-shrink: 0;
}

.usr-nome-comp {
    font-family: 'Syne', sans-serif;
    font-size: .88em;
    font-weight: 700;
    color: #FFFFFF;
    line-height: 1.3;
}

.usr-nivel {
    display: inline-block;
    margin-top: 4px;
    font-family: 'DM Sans', sans-serif;
    font-size: .72em;
    font-weight: 600;
    letter-spacing: .8px;
    text-transform: uppercase;
    padding: 2px 8px;
    border-radius: 3px;
}

.usr-nivel.nivel-master   { background: rgba(255,212,0,.2);  color: #FFD400; }
.usr-nivel.nivel-admin    { background: rgba(224,90,43,.2);  color: #E05A2B; }
.usr-nivel.nivel-operador { background: rgba(64,192,160,.15);color: #40C0A0; }

/* divisória */
.usr-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, #2B2B2B, transparent);
    margin: 2px 0;
}

/* links do dropdown */
.usr-link {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 10px 16px;
    background: none;
    border: none;
    color: #CCCCCC;
    font-family: 'DM Sans', sans-serif;
    font-size: .88em;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    text-align: left;
    transition: background .2s ease, color .2s ease, padding-left .2s ease;
}

.usr-link i {
    width: 16px;
    text-align: center;
    color: #6B6B6B;
    transition: color .2s ease;
    flex-shrink: 0;
}

.usr-link:hover {
    background: rgba(255,212,0,.10);
    color: #FFD400;
    padding-left: 22px;
}

.usr-link:hover i { color: #FFD400; }

/* botão Sair com cor vermelha suave */
.usr-sair       { color: #CC4444; }
.usr-sair i     { color: #CC4444; }
.usr-sair:hover { background: rgba(204,68,68,.12); color: #FF6666; padding-left: 22px; }
.usr-sair:hover i { color: #FF6666; }

/* ── RESPONSIVIDADE (menu interno) ── */
@media (max-width: 900px) {
    .botao-coroa { width: 34px; height: 34px; font-size: .9em; }

    .usuario-btn .usr-nome { display: none; }   /* esconde nome em mobile, fica só ícone + seta */

    .usuario-dropdown {
        right: 0;
        min-width: 200px;
    }
}
