@charset "UTF-8";

/* -------------------------------- 

File#: _1_hiding-nav
Title: Auto Hiding Navigation
Descr: A Navigation container that auto-hides when the user scrolls down, and is revealed when they scrolls back up
Usage: codyhouse.co/license

-------------------------------- */
.hide-nav {
    --hide-nav-transition-duration: 0.3s;
    position: sticky !important;
    top: 0;
    will-change: transform;
    transition: transform var(--hide-nav-transition-duration), background-color var(--hide-nav-transition-duration)
}

.hide-nav--fixed {
    background-color: transparent
}

.hide-nav--has-bg {
    background-color: var(--color-bg)
}

/* -------------------------------- 

File#: _1_modal-window
Title: Modal Window
Descr: A modal dialog used to display critical information
Usage: codyhouse.co/license

-------------------------------- */
.modal {
    position: fixed;
    z-index: var(--z-index-overlay, 15);
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    opacity: 0;
    visibility: hidden
}

.modal:not(.modal--is-visible) {
    pointer-events: none;
    background-color: transparent
}

.modal--is-visible {
    opacity: 1;
    visibility: visible
}

/* close buttons */
.modal__close-btn {
    display: flex;
    flex-shrink: 0;
    border-radius: 50%;
    transition: 0.2s
}

.modal__close-btn .icon {
    display: block;
    margin: auto
}

.modal__close-btn--outer {
    /* close button - outside the modal__content */
    --size: 48px;
    width: var(--size);
    height: var(--size);
    position: fixed;
    top: var(--space-sm);
    right: var(--space-sm);
    z-index: var(--z-index-fixed-element, 10);
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.9);
    transition: 0.2s
}

.modal__close-btn--outer .icon {
    color: var(--color-white);
    /* icon color */
    transition: transform 0.3s var(--ease-out-back)
}

.modal__close-btn--outer:hover {
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 1)
}

.modal__close-btn--outer:hover .icon {
    transform: scale(1.1)
}

.modal__close-btn--inner {
    /* close button - inside the modal__content */
    --size: 32px;
    width: var(--size);
    height: var(--size);
    background-color: var(--color-bg-light);
    box-shadow: var(--inner-glow), var(--shadow-sm);
    transition: 0.2s
}

.modal__close-btn--inner .icon {
    color: inherit
        /* icon color */
}

.modal__close-btn--inner:hover {
    background-color: var(--color-bg-lighter);
    box-shadow: var(--inner-glow), var(--shadow-md)
}

/* animations */
:root {
    --modal-transition-duration: 0.2s
        /* fallback (i.e., unless specified differently in the variations 👇) */
}

@media (prefers-reduced-motion: no-preference) {
    .modal--animate-fade {
        --modal-transition-duration: 0.2s;
        transition: opacity var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s var(--modal-transition-duration)
    }

    .modal--animate-fade.modal--is-visible {
        transition: opacity var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s
    }

    .modal--animate-scale,
    .modal--animate-translate-up,
    .modal--animate-translate-down,
    .modal--animate-translate-right,
    .modal--animate-translate-left {
        --modal-transition-duration: 0.2s;
        transition: opacity var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s var(--modal-transition-duration)
    }

    .modal--animate-scale .modal__content,
    .modal--animate-translate-up .modal__content,
    .modal--animate-translate-down .modal__content,
    .modal--animate-translate-right .modal__content,
    .modal--animate-translate-left .modal__content {
        will-change: transform;
        transition: transform var(--modal-transition-duration) var(--ease-out)
    }

    .modal--animate-scale.modal--is-visible,
    .modal--animate-translate-up.modal--is-visible,
    .modal--animate-translate-down.modal--is-visible,
    .modal--animate-translate-right.modal--is-visible,
    .modal--animate-translate-left.modal--is-visible {
        transition: opacity var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s
    }

    .modal--animate-scale.modal--is-visible .modal__content,
    .modal--animate-translate-up.modal--is-visible .modal__content,
    .modal--animate-translate-down.modal--is-visible .modal__content,
    .modal--animate-translate-right.modal--is-visible .modal__content,
    .modal--animate-translate-left.modal--is-visible .modal__content {
        transform: scale(1)
            /* reset all transformations */
    }

    .modal--animate-slide-up,
    .modal--animate-slide-down,
    .modal--animate-slide-right,
    .modal--animate-slide-left {
        --modal-transition-duration: 0.3s;
        transition: opacity 0s var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s var(--modal-transition-duration)
    }

    .modal--animate-slide-up .modal__content,
    .modal--animate-slide-down .modal__content,
    .modal--animate-slide-right .modal__content,
    .modal--animate-slide-left .modal__content {
        will-change: transform;
        transition: transform var(--modal-transition-duration) var(--ease-out)
    }

    .modal--animate-slide-up.modal--is-visible,
    .modal--animate-slide-down.modal--is-visible,
    .modal--animate-slide-right.modal--is-visible,
    .modal--animate-slide-left.modal--is-visible {
        transition: background-color var(--modal-transition-duration), visibility 0s
    }

    .modal--animate-slide-up.modal--is-visible .modal__content,
    .modal--animate-slide-down.modal--is-visible .modal__content,
    .modal--animate-slide-right.modal--is-visible .modal__content,
    .modal--animate-slide-left.modal--is-visible .modal__content {
        transform: scale(1)
            /* reset all transformations */
    }

    /* scale */
    .modal--animate-scale .modal__content {
        transform: scale(0.95)
    }

    /* translate */
    .modal--animate-translate-up .modal__content {
        transform: translateY(40px)
    }

    .modal--animate-translate-down .modal__content {
        transform: translateY(-40px)
    }

    .modal--animate-translate-right .modal__content {
        transform: translateX(-40px)
    }

    .modal--animate-translate-left .modal__content {
        transform: translateX(40px)
    }

    /* slide */
    .modal--animate-slide-up .modal__content {
        transform: translateY(100%)
    }

    .modal--animate-slide-down .modal__content {
        transform: translateY(-100%)
    }

    .modal--animate-slide-right .modal__content {
        transform: translateX(-100%)
    }

    .modal--animate-slide-left .modal__content {
        transform: translateX(100%)
    }
}

/* load content - optional */
.modal--is-loading .modal__content {
    visibility: hidden
}

.modal--is-loading .modal__loader {
    display: flex
}

.modal__loader {
    /* loader icon */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
    display: none;
    pointer-events: none
}

/* --image */
.modal-img-btn {
    position: relative;
    cursor: pointer
}

.modal-img-btn::after {
    content: "";
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0);
    transition: background 0.2s
}

.modal-img-btn:hover::after {
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.7)
}

.modal-img-btn:hover .modal-img-btn__icon-wrapper {
    opacity: 1
}

.modal-img-btn__icon-wrapper {
    position: absolute;
    z-index: 2;
    top: calc(50% - 24px);
    left: calc(50% - 24px);
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.7);
    opacity: 0;
    transition: opacity 0.2s
}

.modal-img-btn__icon-wrapper .icon {
    color: var(--color-white)
}

/* -------------------------------- 

File#: _2_floating-navigation
Title: Floating Navigation
Descr: A header that auto-hides and controls an expanded modal navigation
Usage: codyhouse.co/license

-------------------------------- */
/* #region (Header) */
.float-nav-header {
    background-color: hsla(var(--color-bg-light-h), var(--color-bg-light-s), var(--color-bg-light-l), 0.13);
    backdrop-filter: blur(9px);
    -webkit-backdrop-filter: blur(9px);
    border-radius: calc(var(--radius-lg) * 1.2);
    padding: var(--space-xxxs) var(--space-xs);
    box-shadow: var(--inner-glow), var(--shadow-sm);
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: box-shadow var(--hide-nav-transition-duration, 0.3s);
}

.hide-nav--off-canvas .float-nav-header {
    box-shadow: var(--inner-glow)
}

.float-nav-header__logo {
    color: var(--color-contrast-higher);
    transition: 0.2s
}

.float-nav-header__logo:hover {
    color: var(--color-primary)
}

.float-nav-header__logo img {
    height: 3rem;
}

.float-nav-header__link {
    color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.8);
    text-decoration: none;
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: color 0.2s
}

.float-nav-header__link:hover {
    color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 1)
}

.float-nav-header__menu-btn {
    display: inline-flex;
    align-items: center;
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.1);
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-lg);
    transition: 0.2s
}

.float-nav-header__menu-btn .icon {
    font-size: 13px
}

.float-nav-header__menu-btn:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.075);
    color: var(--color-contrast-higher);
    cursor: pointer
}

@media (min-width: 64rem) {
    .float-nav-header__menu-btn {
        font-size: var(--text-sm)
    }
}

/* #endregion */
/* #region (Modal Window) */
.float-nav-modal__close-btn {
    height: 40px;
    width: 40px;
    border-radius: 50%;
    border: 2px solid hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.2);
    display: flex;
    flex-shrink: 0;
    cursor: pointer;
    transition: 0.2s
}

.float-nav-modal__close-btn .icon {
    display: block;
    margin: auto;
    font-size: 20px
}

.float-nav-modal__close-btn:hover {
    color: var(--color-contrast-higher);
    border-color: currentColor
}

.float-nav-modal__close-btn:hover .float-nav-modal__close-icon-g>* {
    stroke-dashoffset: 48
}

.float-nav-modal__close-icon-g>* {
    transform-origin: 50% 50%;
    stroke-dashoffset: 0;
    stroke-dasharray: 24;
    transition: stroke-dashoffset 0.5s var(--ease-in-out)
}

.float-nav-modal__close-icon-g>*:last-child {
    transition-delay: 0.1s
}

.float-nav-modal__list {
    counter-reset: list-items
}

.float-nav-modal__list li {
    counter-increment: list-items
}

.float-nav-modal__link {
    display: inline-flex;
    padding: var(--space-4xs) 0;
    color: var(--color-contrast-higher);
    text-decoration: none;
    font-size: var(--text-xl);
    line-height: 1;
    transition: 0.2s
}

.float-nav-modal__link::before {
    content: "0" counter(list-items) "";
    width: 2em;
    margin-right: var(--space-md);
    color: var(--color-contrast-medium);
    font-size: 0.3em;
    font-variant-numeric: slashed-zero;
    font-feature-settings: "tnum";
    line-height: inherit;
    transition: inherit;
    transform: translateY(0.3em);
    display: none
}

.float-nav-modal__link:hover {
    color: var(--color-primary)
}

.float-nav-modal__link:hover span {
    color: currentColor
}

@media (min-width: 32rem) {
    .float-nav-modal__link {
        font-size: var(--text-xl)
    }
}

@media (min-width: 64rem) {
    .float-nav-modal__link {
        font-size: var(--text-xxl)
    }

    .float-nav-modal__link::before {
        display: inline
    }
}

.float-nav-modal__social-btn {
    color: var(--color-contrast-medium);
    transition: 0.2s
}

.float-nav-modal__social-btn .icon {
    display: block;
    font-size: 16px
}

.float-nav-modal__social-btn:hover {
    color: var(--color-contrast-higher)
}

/* #endregion */
А