﻿@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat/static/Montserrat-Regular.ttf') format('truetype');
    font-weight: 400;
}
@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat/static/Montserrat-Medium.ttf') format('truetype');
    font-weight: 500;
}
@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat/static/Montserrat-SemiBold.ttf') format('truetype');
    font-weight: 600;
}
@font-face {
    font-family: 'Montserrat';
    src: url('fonts/Montserrat/static/Montserrat-Bold.ttf') format('truetype');
    font-weight: 700;
}

@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-LightItalic.ttf') format('truetype');
    font-weight: 300;
    font-style: italic;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-Italic.ttf') format('truetype');
    font-weight: 400;
    font-style: italic;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-MediumItalic.ttf') format('truetype');
    font-weight: 500;
    font-style: italic;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-SemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-SemiBoldItalic.ttf') format('truetype');
    font-weight: 600;
    font-style: italic;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-BoldItalic.ttf') format('truetype');
    font-weight: 700;
    font-style: italic;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-ExtraBold.ttf') format('truetype');
    font-weight: 800;
    font-style: normal;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/Open_Sans/static/OpenSans-ExtraBoldItalic.ttf') format('truetype');
    font-weight: 800;
    font-style: italic;
}

/* ===== Reset + layout base ===== */
*,
*::before,
*::after { box-sizing: border-box; }

html { block-size: 100%; }          /* garante 100% de altura raiz */

html, body {
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

body {
    background-color: #F2F2F2;
    font-family: 'Open Sans', sans-serif !important;
    /* ===== Sticky footer com CSS Grid (NÃO empurra a busca) ===== */
    min-block-size: 100svh;
    min-block-size: 100vh; 
    display: grid;
    grid-template-rows: auto 1fr auto; /* header | main que expande | footer */
}

header { margin: 0 0 20px 0; }

main {
    min-block-size: 0;              /* evita overflow forçar o grid a crescer */
    /* nada de margin/padding aqui – páginas específicas controlam isso */
}

/* ===== Menu do usuário ===== */
.user-menu {
    position: fixed;
    top: 10px;
    left: 10px;
    background-color: #fff;
    border-radius: 12px;
    box-shadow: 2px 0 10px rgba(0, 0, 0, 0.1);
    padding: 8px;
    transition: width 0.45s cubic-bezier(0.23, 1, 0.32, 1), padding 0.5s ease;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    width: clamp(60px, 20%, 230px);
    min-width: 210px;
}
.user-menu.closed {
    width: 60px;
    padding: 8px 4px;
    align-items: center;
    justify-content: center;
    min-width: 0;
}
.user-header {
    display: flex;
    align-items: center;
    gap: 10px;
    position: relative;
    transition: all 0.4s ease;
}
.avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    transition: margin 0.3s ease;
}
.user-menu.closed .avatar { margin-right: -6px; }

.username {
    font-weight: 600;
    color: #1f3a68;
    white-space: nowrap;
    overflow: hidden;
    transition: width 0.4s ease, opacity 0.4s ease, padding 0.4s ease;
}
.user-menu.closed .username { width: 0; opacity: 0; padding: 0; }

.menu-options {
    list-style: none;
    padding: 0;
    margin-top: 10px;
    transition: all 0.3s ease;
}
.menu-options li { margin: 8px 0; transition: margin 0.3s ease; }
.menu-options a {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #1f3a68;
    text-decoration: none;
    font-weight: 500;
    transition: width 0.4s ease, opacity 0.4s ease, padding 0.4s ease;
}
.menu-options img.icon {
    width: 25px;
    transition: filter 0.3s ease;
    filter: invert(38%) sepia(96%) saturate(668%) hue-rotate(338deg) brightness(96%) contrast(91%);
}
.user-menu.closed .menu-options span { display: none; }
.user-menu.closed .menu-options {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    height: 100%;
    margin-top: 0;
    width: 100%;
}
.user-menu.closed hr { width: 90%; }

.toggle-btn {
    background: none;
    border: none;
    padding: 4px;
    cursor: pointer;
    position: absolute;
    right: -10px;
    top: 50%;
    transform: translateY(-50%);
    border-radius: 50%;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: right 0.3s ease;
}
.user-menu.closed .toggle-btn { right: -30px; }

/* ===== Footer ===== */
.footer {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    background-color: #1C1B1F;
    color: #ffffff;
    text-align: center;
    padding: 40px 20px;      /* mantém visual do rodapé */
    font-family: Arial, sans-serif;
    /* no grid, o footer já ocupa a 3ª linha (não precisa de margin auto) */
    margin: 0;               /* zera margin-top que “abaixava” o conteúdo */
}
footer { margin: 0; position: static; } /* caso use o elemento <footer> */

.footer-top { margin-bottom: 24px; }
.footer-logo { max-width: 180px; height: auto; }

.footer-middle {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 60px;
    margin-bottom: 24px;
}
.footer-contact-item { display: flex; align-items: center; gap: 12px; }
.footer-icon { width: 24px; height: 24px; }
.footer-text { color: #ffffff; font-size: 16px; text-decoration: none; }

.footer-divider {
    border: none;
    border-top: 1px solid #444444;
    margin: 24px auto;
    width: 80%;
}

.footer-bottom { font-size: 12px; line-height: 1.5; color: #bbbbbb; }
.footer-bottom .footer-legal { margin: 4px 0; }

/* ===== Responsivo ===== */
@media (max-width: 768px) {
    .footer-middle {
        flex-direction: column;
        gap: 24px;
    }

    .user-menu.closed {
        border-radius: 50px;
        width: 50px;
        height: 50px;
        align-items: center;
    }
    .user-menu.closed .avatar { margin-right: -9px; }
    .user-menu.closed > .menu-options,
    .user-menu.closed > hr { display: none; }
    .user-menu.closed .toggle-btn { right: -25px; }
}

@media (max-width: 576px) {
    .footer { padding: 20px 10px; }
    .footer-logo { max-width: 140px; }
    .footer-contact-item { gap: 8px; }
    .footer-text { font-size: 14px; }
    .footer-divider { width: 100%; margin: 16px 0; }
    .footer-bottom { font-size: 12px; line-height: 1.4; }
}

/* Estilos para o avatar com iniciais */
.avatar-initials {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    transition: margin 0.3s ease;
}
.user-menu.closed .avatar-initials { margin-right: -6px; }

/* FIX: nunca centralizar verticalmente o main (se alguma página o fizer) */
body > main {
    align-items: center !important; /* se for flex */
    justify-content: flex-start !important;
    align-content: center !important; /* se for grid */
    min-height: 0; /* evita overflow "empurrar" */
}

    /* FIX: a primeira seção do main não cria espaçamento extra com o topo */
    body > main > *:first-child {
        margin-block-start: 0 !important;
    }



@media (max-width: 768px) {
    .user-menu.closed .avatar-initials { margin-right: -9px; }
}
