/* ---------- TOP BAR (for every page except for index page) ---------- */

.header-wrapper {
    position: relative;
    height: auto;
}

.header-container {
    width: 100%;
    height: auto;

    display: flex;
    align-items: flex-end;
    justify-content: center;
    transition: height 0.6s ease;

    position: relative;
    bottom: 0;
    left: 0;

    z-index: 99;
}

/* --- TOP BAR --- */

.topbar.not-index {
    position: absolute;

    width: 100%;
    height: auto;

    padding: var(--half-margin) var(--margin);

    display: flex;
    justify-content: space-between;
    align-items: flex-start;

    overflow: hidden;

    border-bottom: 1px solid black;

    transition:
        height 0.6s ease,
        padding 0.6s ease,
        background-color 0.4s ease;

    z-index: 5;
}

.col {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.topbar.not-index .col {
    justify-content: flex-start;
}


/* -- left column -- */

.topbar .left-col a {
    display: flex;
    align-items: flex-start;
    gap: 0;
}

.topbar .col:first-child {
    flex: 0 0 40%;
    justify-content: flex-start;
    align-items: start;
}

.logo-not-index {
    height: 50px;
    width: auto;
    object-fit: contain;

    transform: scale(1);
    opacity: 1;

    transform-origin: center;

    transition:
        height 0.6s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.6s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.4s ease;
}

.topbar.not-index:hover .logo-not-index {
    height: 80px;
}

.only-hover {
    opacity: 0;

    pointer-events: none;

    transition:
        height 0.6s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.6s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.4s ease;

    margin-left: 15px;
}

.topbar.not-index:hover .only-hover {
    opacity: 1;
}

/* -- center column -- */

.topbar .col:nth-child(2) {
    flex: 1;
    align-items: flex-end;
    justify-content: flex-start;
    text-align: right;
}

.col.center-col {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.lang-selector {
    display: flex;
    align-items: center;
}

.lang-selector a {
    text-decoration: none;
    margin: 0 5px;

    font-size: var(--main-font-size);
    color: black;

    opacity: var(--opacity-value);
    transition: color var(--opacity-value);

    cursor: pointer;
}

.lang-selector a.active {
    opacity: 1;
}

.lang-selector .separator {
    display: inline-block;
    margin: 0 3px;

    font-size: var(--main-font-size);
    color: black;

    opacity: var(--opacity-value);
    transition: transform 0.6s ease, color 0.4s ease;

    pointer-events: none;
}

.topbar.not-index .lang-selector {
    opacity: 0;

    pointer-events: none;

    transition:
        opacity 0.4s ease,
        transform 0.6s ease;
}

.topbar.not-index:hover .lang-selector {
    opacity: 1;

    pointer-events: auto;
}


/* -- right column -- */

.topbar .col:last-child {
    flex: 1;
    align-items: flex-end;
    justify-content: flex-end;
    text-align: right;
}

.topbar button {
    background: none;
    border: none;

    font-family: 'Switzer-Medium';
    font-size: var(--main-font-size);
    color: black;

    cursor: pointer;

    transition:
        font-size 0.6s cubic-bezier(.19, 1, .22, 1),
        color 0.4s ease;
}


/* ---------- MAIN CONTENT TRANSITIONS/ANIMATIONS WITH MENU OPENING AND CLOSING ---------- */

main {
    padding: 50px var(--margin) var(--margin) var(--margin);

    position: relative;
    height: auto;

    transform: translateY(0);

    transition:
        transform 1.2s cubic-bezier(0.22, 1, 0.36, 1),
        padding-top 0.9s cubic-bezier(.19, 1, .22, 1),
        opacity 0.6s ease;

    will-change: transform, opacity, padding-top;

    z-index: 0;
}

body.menu-aberto main {
    transition:
        transform 10s cubic-bezier(0.22, 1, 0.36, 1);
}


/* TOPBAR HOVER -> MAIN DOWN */

body:has(.topbar.not-index:hover) main {
    padding-top: 80px;
}

/* MENU OPEN -> MAIN DOWN */

body.menu-aberto main {
    transform: translateY(80vh);
}