/* ===== NAVBAR ===== */
.navbar {
    position: absolute;
    top: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    align-items: center;
    gap: 10px;
    width: max-content;
    pointer-events: auto;
    font-family: Telegraf, system-ui, -apple-system;
}

.navbar-main {
    display: flex;
    gap: 5px;
    padding: 8px 30px;
    border-radius: 999px;
    background: rgba(180, 180, 180, 0.2);
    /* border: 1px solid rgba(255, 255, 255, .28);
    box-shadow: 0 8px 30px rgba(0, 0, 0, .25), inset 0 0 0 1px rgba(255, 255, 255, .06); */
}

.navbar-main .active {
    font-weight: 900;
}

.navbar-main a {
    position: relative;
    display: inline-block;
    padding: 10px 14px;
    border-radius: 999px;
    text-decoration: none;
    color: rgba(255, 255, 255, .92);
    font-weight: 600;
    font-size: 16px;
    letter-spacing: .01em;
    transition: opacity .15s ease, transform .12s ease;
}

.navbar-main a:hover {
    opacity: 1;
    transform: translateY(-1px);
    text-decoration: underline;
}

.navbar-main a.is-active {
    font-weight: 700;
}

.navbar-main a.is-active::after {
    content: "";
    position: absolute;
    left: 8px;
    right: 8px;
    bottom: 6px;
    height: 6px;
    background: rgba(255, 255, 255, .95);
    border-radius: 999px;
}

.navbar-sub {
    display: grid;
    place-items: center;
    width: 60px;
    height: 60px;
    padding: 5px 5px;
    border-radius: 50%;
    background: rgba(180, 180, 180, 0.2);
    /* border: 1px solid rgba(255, 255, 255, .28);
    box-shadow: 0 8px 30px rgba(0, 0, 0, .20), inset 0 0 0 1px rgba(255, 255, 255, .06); */
    transition: transform .12s ease, background-color .2s ease;
}

.navbar-sub:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, .22);
}

.navbar-sub img {
    width: 30px;
    height: 30px;
    opacity: .95;
}

.submenu {
    position: absolute;
    top: calc(100% + 10px);
    left: 50%;
    transform: translate(-50%, -6px) scale(.98);
    min-width: 240px;
    padding: 10px;
    background: rgba(255, 255, 255, .98);
    color: #111;
    border-radius: 18px;
    border: 1px solid rgba(0, 0, 0, .06);
    box-shadow: 0 20px 40px rgba(0, 0, 0, .25), inset 0 1px 0 rgba(255, 255, 255, .6);
    backdrop-filter: saturate(1.1) blur(4px);
    z-index: 40;

    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease, visibility .18s;
}

.submenu::before {
    content: "";
    position: absolute;
    top: -8px;
    left: 50%;
    width: 16px;
    height: 16px;
    background: inherit;
    border-left: 1px solid rgba(0, 0, 0, .06);
    border-top: 1px solid rgba(0, 0, 0, .06);
    transform: translateX(-50%) rotate(45deg);
    border-radius: 3px 0 0 0;
}

.submenu a {
    display: block;
    padding: 10px 14px;
    border-radius: 12px;
    text-decoration: none;
    color: #111;
    font-size: 13px;
    font-weight: 700;
}

.submenu a:hover {
    background: #f3f3f3;
}

.nav-item.is-open .submenu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translate(-50%, 0) scale(1);
}

.nav-item.has-submenu {
    position: relative;
}

@media (max-width: 560px) {
    .submenu {
        min-width: 200px;
    }
}

@media (max-width: 720px) {
    .navbar {
        top: 10px;
        gap: 8px;
    }

    .navbar-main {
        padding: 8px 10px;
    }

    .navbar-main a {
        padding: 8px 10px;
        font-size: 12px;
    }

    .navbar-main a.is-active::after {
        bottom: 5px;
        height: 5px;
    }

    .navbar-sub {
        width: 36px;
        height: 36px;
    }
}

/* ===== BURGER ===== */
.navbar-burger {
    display: none;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(127, 127, 127, .24);
    border: 1px solid rgba(255, 255, 255, .28);
    box-shadow: 0 8px 30px rgba(0, 0, 0, .20), inset 0 0 0 1px rgba(255, 255, 255, .06);
    cursor: pointer;
    z-index: 50;
    color: #f3f3f3;
    font-size: large;
    font-weight: 900;
}

/* stan X */
.navbar.is-open .navbar-burger span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}

.navbar.is-open .navbar-burger span:nth-child(2) {
    opacity: 0;
}

.navbar.is-open .navbar-burger span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

/* ===== MOBILE ===== */
@media (max-width: 880px) {
    .navbar {
        position: absolute;
        top: 14px;
        left: 16px;
        transform: none;
        width: auto;
        z-index: 50;
    }

    .navbar:not(.is-open) .submenu {
        display: none !important;
        pointer-events: none !important;
        visibility: hidden !important;
    }

    .navbar-burger {
        display: grid;
    }

    .navbar-main {
        position: fixed;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%) scale(.96);
        width: min(92vw, 520px);
        max-height: min(72vh, calc(100dvh - 120px));
        overflow: auto;

        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 6px;
        padding: 12px;

        background: rgba(255, 255, 255, .98);
        color: #111;
        border-radius: 18px;
        border: 1px solid rgba(0, 0, 0, .06);
        box-shadow: 0 20px 40px rgba(0, 0, 0, .25), inset 0 1px 0 rgba(255, 255, 255, .6);
        z-index: 40;

        opacity: 0;
        pointer-events: none;
        transform-origin: center;
        transition: opacity .18s ease, transform .18s ease;
    }

    .navbar.is-open .navbar-main {
        opacity: 1;
        pointer-events: auto;
        transform: translate(-50%, -50%) scale(1);
    }

    .navbar-main a {
        color: #111;
        text-decoration: none;
        padding: 12px 14px;
        border-radius: 12px;
        font-size: 16px;
    }

    .navbar-main a:hover {
        background: #f3f3f3;
        transform: none;
        text-decoration: none;
    }

    .navbar.is-open::after {
        content: "";
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, .35);
        z-index: 10;
    }

    .nav-item.has-submenu {
        position: static;
    }

    .submenu {
        position: static;
        background: transparent;
        border: 0;
        box-shadow: none;
        padding: 6px 40px 4px;
        margin-top: -2px;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: none;
    }

    .nav-item.is-open .submenu {
        display: block;
    }

    .navbar-sub {
        width: 44px;
        height: 44px;
    }

    .navbar-sub img {
        width: 20px;
        height: 20px;
    }
}

/* ===== Language switch ===== */
.navbar-lang {
    position: absolute;
    top: 30px;
    right: clamp(16px, calc(50% - 800px), 50%);
    z-index: 10;
    display: flex;
    align-items: center;
    gap: 10px;
    width: max-content;
    pointer-events: auto;
    font-family: Telegraf, system-ui, -apple-system;
}

.navbar-aux {
    display: flex;
    place-items: center;
    height: 60px;
    padding: 5px 5px;
    border-radius: 50px;
    color: rgba(255, 255, 255, .92);
    background: rgba(180, 180, 180, 0.2);
    /* border: 1px solid rgba(255, 255, 255, .28);
    box-shadow: 0 8px 30px rgba(0, 0, 0, .20), inset 0 0 0 1px rgba(255, 255, 255, .06); */
    transition: transform .12s ease, background-color .2s ease;
}

.navbar-aux a {
    position: relative;
    display: inline-block;
    padding: 5px 5px;
    border-radius: 999px;
    text-decoration: none;
    color: rgba(255, 255, 255, .92);
    font-weight: 600;
    font-size: 16px;
    letter-spacing: .01em;
    transition: opacity .15s ease, transform .12s ease;
}

.navbar-aux a:hover {
    opacity: 1;
    transform: translateY(-1px);
    text-decoration: underline;
}

@media (max-width: 1000px) {
    .navbar-lang {
        gap: 8px;
    }

    .navbar-aux {
        display: grid;
        padding: 0px;
        font-size: 10px;
        line-height: 0px;
        width: 60px;
    }

    .lang-sep {
        display: none;
    }

    .navbar-aux a {
        font-size: 10px;
    }
}

@media (max-width: 880px) {
    .navbar-lang {
        top: 10px;
        gap: 8px;
    }

    .navbar-aux {
        display: flex;
        height: 44px;
        width: auto;
        padding: 0px;
        font-size: 10px;
        line-height: 0px;
    }

    .lang-sep {
        display: block;
    }

    .navbar-aux a {
        font-size: 12px;
    }
}