:root {
    color-scheme: light dark;
    --darken: 10%;
    --darken-h: 15%;
    --vibrance: 25%;
    --contrast: 5;
    --alpha: 100%;
    --white-h: 0;
    --white-s: 0%;
    --white-l: 100%;
    --alternate-h: 83;
    --alternate-s: 94.1%;
    --alternate-l: 66.7%;
    --claret-h: 358;
    --claret-s: 71.3%;
    --claret-l: 38.2%;
    --blue-h: 187;
    --blue-s: 75%;
    --blue-l: 76.5%;
    --cerise-h: 341;
    --cerise-s: 76.1%;
    --cerise-l: 52.4%;
    --purple-h: 302;
    --purple-s: 75.8%;
    --purple-l: 32.4%;
    --blue-dark-h: 212;
    --blue-dark-s: 61.4%;
    --blue-dark-l: 22.4%;
    --gray-light-h: 0;
    --gray-light-s: 0%;
    --gray-light-l: 93.7%;
    --gray-medium-h: 0;
    --gray-medium-s: 0%;
    --gray-medium-l: 65.9%;
    --accent-h: 51;
    --accent-s: 100%;
    --accent-l: 56.5%;
    --semantic-danger-h: 346;
    --semantic-danger-s: 100%;
    --semantic-danger-l: 62.9%;
    --semantic-info-h: 216;
    --semantic-info-s: 100%;
    --semantic-info-l: 63.3%;
    --semantic-success-h: 155;
    --semantic-success-s: 100%;
    --semantic-success-l: 44.5%;
    --semantic-warning-h: 65;
    --semantic-warning-s: 100%;
    --semantic-warning-l: 50%;
    --color-aedu-play: hsla(187, 77.5%, 58.2%, 1);
    --color-aedu-play-60: hsla(187, 77.5%, 58.2%, 0.6);
    --color-aedu-play-20: hsla(187, 77.5%, 58.2%, 0.2);
    --color-lfg-first: hsla(163, 42.7%, 65.1%, 1);
    --color-lfg-first-60: hsla(163, 42.7%, 65.1%, 0.6);
    --color-lfg-first-20: hsla(163, 42.7%, 65.1%, 0.2);
    --color-lfg-second: hsla(240, 41.2%, 43.3%, 1);
    --color-lfg-second-60: hsla(240, 41.2%, 43.3%, 0.6);
    --color-lfg-second-20: hsla(240, 41.2%, 43.3%, 0.2);
    --color-lfg-third: hsla(240, 90.8%, 25.7%);
    --color-lfg-third-60: hsla(240, 90.8%, 25.7%, 0.6);
    --color-lfg-third-20: hsla(240, 90.8%, 25.7%, 0.2);
}
@media (prefers-color-scheme: light) {
    :root {
        --color-border: hsl(220, 10%, 88.2%);
        --color-border-30: hsla(220, 10%, 88.2%, 0.3);
        --color-field: hsl(0, 0%, 100%);
        --color-bg-default: hsl(0, 0%, 95.7%);
        --color-bg-color-contrast: hsl(30, 5%, 92.2%);
        --color-bg-color-default: hsl(40, 4.6%, 87.3%);
        --contrast-h: 0;
        --contrast-s: 0%;
        --contrast-l: 100%;
        --color-text-light: hsl(0, 0%, 42.4%);
        --color-text-default: hsl(0, 0%, 30.2%);
        --color-text-contrast: hsl(0, 0%, 14.5%);
    }
}
@media (prefers-color-scheme: dark) {
    :root {
        --color-border: hsl(234, 6.1%, 32.2%);
        --color-border-30: hsla(234, 6.1%, 32.2%, 0.3);
        --color-field: hsl(228, 5.2%, 19%);
        --color-bg-default: hsl(228, 7.2%, 13.5%);
        --color-bg-color-contrast: hsl(240, 1.4%, 14.3%);
        --contrast-h: 240;
        --contrast-s: 1.4%;
        --contrast-l: 14.3%;
        --color-bg-color-default: hsl(225, 2.4%, 33.3%);
        --color-text-light: hsl(225, 5.3%, 70.6%);
        --color-text-default: hsl(224, 20.8%, 89.6%);
        --color-text-contrast: hsl(0, 0%, 100%);
    }
}
[data-alpha="90"] {
    --alpha: 90%;
}
[data-alpha="80"] {
    --alpha: 80%;
}
[data-alpha="70"] {
    --alpha: 70%;
}
[data-alpha="60"] {
    --alpha: 60%;
}
[data-alpha="50"] {
    --alpha: 50%;
}
[data-alpha="40"] {
    --alpha: 40%;
}
[data-alpha="30"] {
    --alpha: 30%;
}
[data-alpha="20"] {
    --alpha: 20%;
}
[data-alpha="10"] {
    --alpha: 10%;
}
body {
    --color-white: hsla(
        var(--white-h),
        var(--white-s),
        var(--white-l),
        var(--alpha)
    );
    --color-white-100: var(--color-white);
    --color-white-80: hsla(var(--white-h), var(--white-s), var(--white-l), 80%);
    --color-white-60: hsla(var(--white-h), var(--white-s), var(--white-l), 60%);
    --color-white-50: hsla(var(--white-h), var(--white-s), var(--white-l), 50%);
    --color-white-30: hsla(var(--white-h), var(--white-s), var(--white-l), 30%);
    --color-white-20: hsla(var(--white-h), var(--white-s), var(--white-l), 20%);
    --color-white-10: hsla(var(--white-h), var(--white-s), var(--white-l), 10%);
    --color-contrast: hsla(
        var(--contrast-h),
        var(--contrast-s),
        var(--contrast-l),
        var(--alpha)
    );
    --color-contrast-100: var(--color-contrast);
    --color-contrast-80: hsla(
        var(--contrast-h),
        var(--contrast-s),
        var(--contrast-l),
        80%
    );
    --color-contrast-60: hsla(
        var(--contrast-h),
        var(--contrast-s),
        var(--contrast-l),
        60%
    );
    --color-contrast-50: hsla(
        var(--contrast-h),
        var(--contrast-s),
        var(--contrast-l),
        50%
    );
    --color-contrast-30: hsla(
        var(--contrast-h),
        var(--contrast-s),
        var(--contrast-l),
        30%
    );
    --color-contrast-20: hsla(
        var(--contrast-h),
        var(--contrast-s),
        var(--contrast-l),
        20%
    );
    --color-contrast-10: hsla(
        var(--contrast-h),
        var(--contrast-s),
        var(--contrast-l),
        10%
    );
    --color-alternate: hsla(
        var(--alternate-h),
        var(--alternate-s),
        var(--alternate-l),
        var(--alpha)
    );
    --color-alternate-100: var(--color-alternate);
    --color-alternate-80: hsla(
        var(--alternate-h),
        var(--alternate-s),
        var(--alternate-l),
        80%
    );
    --color-alternate-60: hsla(
        var(--alternate-h),
        var(--alternate-s),
        var(--alternate-l),
        60%
    );
    --color-alternate-50: hsla(
        var(--alternate-h),
        var(--alternate-s),
        var(--alternate-l),
        50%
    );
    --color-alternate-30: hsla(
        var(--alternate-h),
        var(--alternate-s),
        var(--alternate-l),
        30%
    );
    --color-alternate-20: hsla(
        var(--alternate-h),
        var(--alternate-s),
        var(--alternate-l),
        20%
    );
    --color-alternate-10: hsla(
        var(--alternate-h),
        var(--alternate-s),
        var(--alternate-l),
        10%
    );
    --color-gradient-vertical-claret: linear-gradient(
        to bottom,
        hsl(var(--alternate-h), var(--alternate-s), var(--alternate-l)) 0%,
        hsl(
                var(--alternate-h),
                var(--alternate-s),
                calc(var(--alternate-l) - var(--vibrance))
            )
            100%
    );
    --color-gradient-diagonal-alternate: linear-gradient(
        45deg,
        hsl(var(--alternate-h), var(--alternate-s), var(--alternate-l)) 0%,
        hsl(
                var(--alternate-h),
                var(--alternate-s),
                calc(var(--alternate-l) - var(--vibrance))
            )
            100%
    );
    --color-claret: hsla(
        var(--claret-h),
        var(--claret-s),
        var(--claret-l),
        var(--alpha)
    );
    --color-claret-100: var(--color-claret);
    --color-claret-80: hsla(
        var(--claret-h),
        var(--claret-s),
        var(--claret-l),
        80%
    );
    --color-claret-60: hsla(
        var(--claret-h),
        var(--claret-s),
        var(--claret-l),
        60%
    );
    --color-claret-50: hsla(
        var(--claret-h),
        var(--claret-s),
        var(--claret-l),
        50%
    );
    --color-claret-30: hsla(
        var(--claret-h),
        var(--claret-s),
        var(--claret-l),
        30%
    );
    --color-claret-20: hsla(
        var(--claret-h),
        var(--claret-s),
        var(--claret-l),
        20%
    );
    --color-claret-10: hsla(
        var(--claret-h),
        var(--claret-s),
        var(--claret-l),
        10%
    );
    --color-gradient-vertical-claret: linear-gradient(
        to bottom,
        hsl(var(--claret-h), var(--claret-s), var(--claret-l)) 0%,
        hsl(
                var(--claret-h),
                var(--claret-s),
                calc(var(--claret-l) - var(--vibrance))
            )
            100%
    );
    --color-gradient-diagonal-claret: linear-gradient(
        45deg,
        hsl(var(--claret-h), var(--claret-s), var(--claret-l)) 0%,
        hsl(
                var(--claret-h),
                var(--claret-s),
                calc(var(--claret-l) - var(--vibrance))
            )
            100%
    );
    --color-blue: hsla(
        var(--blue-h),
        var(--blue-s),
        var(--blue-l),
        var(--alpha)
    );
    --color-blue-100: var(--color-blue);
    --color-blue-80: hsla(var(--blue-h), var(--blue-s), var(--blue-l), 80%);
    --color-blue-60: hsla(var(--blue-h), var(--blue-s), var(--blue-l), 60%);
    --color-blue-50: hsla(var(--blue-h), var(--blue-s), var(--blue-l), 50%);
    --color-blue-30: hsla(var(--blue-h), var(--blue-s), var(--blue-l), 30%);
    --color-blue-20: hsla(var(--blue-h), var(--blue-s), var(--blue-l), 20%);
    --color-blue-10: hsla(var(--blue-h), var(--blue-s), var(--blue-l), 10%);
    --color-gradient-vertical-blue: linear-gradient(
        to bottom,
        hsl(var(--blue-h), var(--blue-s), var(--blue-l)) 0%,
        hsl(var(--blue-h), var(--blue-s), calc(var(--blue-l) - var(--vibrance)))
            100%
    );
    --color-gradient-diagonal-blue: linear-gradient(
        45deg,
        hsl(var(--blue-h), var(--blue-s), var(--blue-l)) 0%,
        hsl(var(--blue-h), var(--blue-s), calc(var(--blue-l) - var(--vibrance)))
            100%
    );
    --color-cerise: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        var(--alpha)
    );
    --color-cerise-100: var(--color-cerise);
    --color-cerise-80: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        80%
    );
    --color-cerise-60: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        60%
    );
    --color-cerise-50: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        50%
    );
    --color-cerise-30: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        30%
    );
    --color-cerise-20: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        20%
    );
    --color-cerise-10: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        10%
    );
    --color-gradient-vertical-cerise: linear-gradient(
        to bottom,
        hsl(var(--cerise-h), var(--cerise-s), var(--cerise-l)) 0%,
        hsl(
                var(--cerise-h),
                var(--cerise-s),
                calc(var(--cerise-l) - var(--vibrance))
            )
            100%
    );
    --color-gradient-diagonal-cerise: linear-gradient(
        45deg,
        hsl(var(--cerise-h), var(--cerise-s), var(--cerise-l)) 0%,
        hsl(
                var(--cerise-h),
                var(--cerise-s),
                calc(var(--cerise-l) - var(--vibrance))
            )
            100%
    );
    --color-purple: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        var(--alpha)
    );
    --color-purple-100: var(--color-purple);
    --color-purple-80: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        80%
    );
    --color-purple-60: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        60%
    );
    --color-purple-50: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        50%
    );
    --color-purple-30: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        30%
    );
    --color-purple-20: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        20%
    );
    --color-purple-10: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        10%
    );
    --color-gradient-vertical-purple: linear-gradient(
        to bottom,
        hsl(var(--purple-h), var(--purple-s), var(--purple-l)) 0%,
        hsl(
                var(--purple-h),
                var(--purple-s),
                calc(var(--purple-l) - var(--vibrance))
            )
            100%
    );
    --color-gradient-diagonal-purple: linear-gradient(
        45deg,
        hsl(var(--purple-h), var(--purple-s), var(--purple-l)) 0%,
        hsl(
                var(--purple-h),
                var(--purple-s),
                calc(var(--purple-l) - var(--vibrance))
            )
            100%
    );
    --color-blue-dark: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        var(--alpha)
    );
    --color-blue-dark-100: var(--color-blue-dark);
    --color-blue-dark-80: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        80%
    );
    --color-blue-dark-60: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        60%
    );
    --color-blue-dark-50: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        50%
    );
    --color-blue-dark-30: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        30%
    );
    --color-blue-dark-20: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        20%
    );
    --color-blue-dark-10: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        10%
    );
    --color-gray-light: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        var(--alpha)
    );
    --color-gray-light-100: var(--color-gray-light);
    --color-gray-light-80: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        80%
    );
    --color-gray-light-60: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        60%
    );
    --color-gray-light-50: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        50%
    );
    --color-gray-light-30: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        30%
    );
    --color-gray-light-20: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        20%
    );
    --color-gray-light-10: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        10%
    );
    --color-gray-medium: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        var(--alpha)
    );
    --color-gray-medium-100: var(--color-gray-medium);
    --color-gray-medium-80: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        80%
    );
    --color-gray-medium-60: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        60%
    );
    --color-gray-medium-50: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        50%
    );
    --color-gray-medium-30: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        30%
    );
    --color-gray-medium-20: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        20%
    );
    --color-gray-medium-10: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        10%
    );
    --color-accent-default: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha)
    );
    --color-accent-default-100: var(--color-accent);
    --color-accent-default-80: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha),
        80%
    );
    --color-accent-default-60: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha),
        60%
    );
    --color-accent-default-50: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha),
        50%
    );
    --color-accent-default-30: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha),
        30%
    );
    --color-accent-default-20: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha),
        20%
    );
    --color-accent-default-10: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha),
        10%
    );
    --color-accent-soft: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) - var(--vibrance)),
        calc(var(--accent-l) + var(--darken)),
        var(--alpha)
    );
    --color-accent-soft-100: var(--color-accent-soft);
    --color-accent-soft-80: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) - var(--vibrance)),
        calc(var(--accent-l) + var(--darken)),
        80%
    );
    --color-accent-soft-60: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) - var(--vibrance)),
        calc(var(--accent-l) + var(--darken)),
        60%
    );
    --color-accent-soft-50: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) - var(--vibrance)),
        calc(var(--accent-l) + var(--darken)),
        50%
    );
    --color-accent-soft-30: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) - var(--vibrance)),
        calc(var(--accent-l) + var(--darken)),
        30%
    );
    --color-accent-soft-10: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) - var(--vibrance)),
        calc(var(--accent-l) + var(--darken)),
        10%
    );
    --color-accent-contrast: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) + var(--vibrance)),
        calc(var(--accent-l) - var(--darken)),
        var(--alpha)
    );
    --color-accent-contrast-100: var(--color-accent-contrast);
    --color-accent-contrast-80: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) + var(--vibrance)),
        calc(var(--accent-l) - var(--darken)),
        80%
    );
    --color-accent-contrast-60: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) + var(--vibrance)),
        calc(var(--accent-l) - var(--darken)),
        60%
    );
    --color-accent-contrast-50: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) + var(--vibrance)),
        calc(var(--accent-l) - var(--darken)),
        50%
    );
    --color-accent-contrast-30: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) + var(--vibrance)),
        calc(var(--accent-l) - var(--darken)),
        30%
    );
    --color-accent-contrast-10: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) + var(--vibrance)),
        calc(var(--accent-l) - var(--darken)),
        10%
    );
    --color-gradient-vertical-accent: linear-gradient(
        to bottom,
        var(--color-accent-contrast) 0%,
        var(--color-accent-default) 100%
    );
    --color-gradient-diagonal-accent: linear-gradient(
        to bottom,
        var(--color-accent-contrast) 0%,
        var(--color-accent-default) 100%
    );
    --color-semantic-danger: hsla(
        var(--semantic-danger-h),
        var(--semantic-danger-s),
        var(--semantic-danger-l),
        var(--alpha)
    );
    --color-semantic-danger-100: var(--color-semantic-danger);
    --color-semantic-danger-80: hsla(
        var(--semantic-danger-h),
        var(--semantic-danger-s),
        var(--semantic-danger-l),
        80%
    );
    --color-semantic-danger-60: hsla(
        var(--semantic-danger-h),
        var(--semantic-danger-s),
        var(--semantic-danger-l),
        60%
    );
    --color-semantic-danger-50: hsla(
        var(--semantic-danger-h),
        var(--semantic-danger-s),
        var(--semantic-danger-l),
        50%
    );
    --color-semantic-danger-30: hsla(
        var(--semantic-danger-h),
        var(--semantic-danger-s),
        var(--semantic-danger-l),
        30%
    );
    --color-semantic-danger-10: hsla(
        var(--semantic-danger-h),
        var(--semantic-danger-s),
        var(--semantic-danger-l),
        1%
    );
    --color-semantic-info: hsla(
        var(--semantic-info-h),
        var(--semantic-info-s),
        var(--semantic-info-l),
        var(--alpha)
    );
    --color-semantic-info-100: var(--color-semantic-info);
    --color-semantic-info-80: hsla(
        var(--semantic-info-h),
        var(--semantic-info-s),
        var(--semantic-info-l),
        80%
    );
    --color-semantic-info-60: hsla(
        var(--semantic-info-h),
        var(--semantic-info-s),
        var(--semantic-info-l),
        50%
    );
    --color-semantic-info-50: hsla(
        var(--semantic-info-h),
        var(--semantic-info-s),
        var(--semantic-info-l),
        30%
    );
    --color-semantic-info-30: hsla(
        var(--semantic-info-h),
        var(--semantic-info-s),
        var(--semantic-info-l),
        30%
    );
    --color-semantic-info-10: hsla(
        var(--semantic-info-h),
        var(--semantic-info-s),
        var(--semantic-info-l),
        10%
    );
    --color-semantic-success: hsla(
        var(--semantic-success-h),
        var(--semantic-success-s),
        var(--semantic-success-l),
        var(--alpha)
    );
    --color-semantic-success-100: var(--color-semantic-success);
    --color-semantic-success-80: hsla(
        var(--semantic-success-h),
        var(--semantic-success-s),
        var(--semantic-success-l),
        80%
    );
    --color-semantic-success-60: hsla(
        var(--semantic-success-h),
        var(--semantic-success-s),
        var(--semantic-success-l),
        60%
    );
    --color-semantic-success-50: hsla(
        var(--semantic-success-h),
        var(--semantic-success-s),
        var(--semantic-success-l),
        50%
    );
    --color-semantic-success-30: hsla(
        var(--semantic-success-h),
        var(--semantic-success-s),
        var(--semantic-success-l),
        30%
    );
    --color-semantic-success-10: hsla(
        var(--semantic-success-h),
        var(--semantic-success-s),
        var(--semantic-success-l),
        10%
    );
    --color-semantic-warning: hsla(
        var(--semantic-warning-h),
        var(--semantic-warning-s),
        var(--semantic-warning-l),
        var(--alpha)
    );
    --color-semantic-warning-100: var(--color-semantic-warning);
    --color-semantic-warning-80: hsla(
        var(--semantic-warning-h),
        var(--semantic-warning-s),
        var(--semantic-warning-l),
        80%
    );
    --color-semantic-warning-60: hsla(
        var(--semantic-warning-h),
        var(--semantic-warning-s),
        var(--semantic-warning-l),
        60%
    );
    --color-semantic-warning-50: hsla(
        var(--semantic-warning-h),
        var(--semantic-warning-s),
        var(--semantic-warning-l),
        50%
    );
    --color-semantic-warning-30: hsla(
        var(--semantic-warning-h),
        var(--semantic-warning-s),
        var(--semantic-warning-l),
        30%
    );
    --color-semantic-warning-10: hsla(
        var(--semantic-warning-h),
        var(--semantic-warning-s),
        var(--semantic-warning-l),
        10%
    );
    --color-primary-default: hsla(
        var(--primary-color-h),
        var(--primary-color-s),
        var(--primary-color-l),
        var(--alpha)
    );
    --color-primary-default-100: var(--color-primary-default);
    --color-primary-default-80: hsla(
        var(--primary-color-h),
        var(--primary-color-s),
        var(--primary-color-l),
        80%
    );
    --color-primary-default-60: hsla(
        var(--primary-color-h),
        var(--primary-color-s),
        var(--primary-color-l),
        60%
    );
    --color-primary-default-50: hsla(
        var(--primary-color-h),
        var(--primary-color-s),
        var(--primary-color-l),
        50%
    );
    --color-primary-default-30: hsla(
        var(--primary-color-h),
        var(--primary-color-s),
        var(--primary-color-l),
        30%
    );
    --color-primary-default-10: hsla(
        var(--primary-color-h),
        var(--primary-color-s),
        var(--primary-color-l),
        10%
    );
    --color-primary-contrast: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken)),
        var(--alpha)
    );
    --color-primary-contrast-100: var(--color-primary-contrast);
    --color-primary-contrast-80: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken)),
        80%
    );
    --color-primary-contrast-60: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken)),
        60%
    );
    --color-primary-contrast-50: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken)),
        50%
    );
    --color-primary-contrast-30: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken)),
        30%
    );
    --color-primary-contrast-10: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken)),
        10%
    );
    --color-primary-high-contrast: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken-h)),
        var(--alpha)
    );
    --color-primary-high-contrast-100: var(--color-primary-high-contrast);
    --color-primary-high-contrast-80: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken-h)),
        80%
    );
    --color-primary-high-contrast-60: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken-h)),
        60%
    );
    --color-primary-high-contrast-50: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken-h)),
        50%
    );
    --color-primary-high-contrast-30: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken-h)),
        30%
    );
    --color-primary-high-contrast-10: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken-h)),
        10%
    );
    --color-gradient-vertical-primary-default: linear-gradient(
        to bottom,
        var(--color-primary-default) 0%,
        var(--color-primary-high-contrast) 100%
    );
    --color-gradient-diagonal-primary-inverted: linear-gradient(
        45deg,
        var(--color-primary-default) 0%,
        var(--color-primary-high-contrast) 100%
    );
    --color-gradient-diagonal-primary-default: linear-gradient(
        45deg,
        var(--color-primary-high-contrast) 0%,
        var(--color-primary-default) 100%
    );
    --color-gradient-vertical-primary-inverted: linear-gradient(
        to bottom,
        var(--color-primary-high-contrast) 0%,
        var(--color-primary-default) 100%
    );
    --color-secondary: hsla(
        var(--secondary-color-h),
        var(--secondary-color-s),
        var(--secondary-color-l),
        var(--alpha)
    );
    --color-secondary-100: var(--color-secondary);
    --color-secondary-80: hsla(
        var(--secondary-color-h),
        var(--secondary-color-s),
        var(--secondary-color-l),
        80%
    );
    --color-secondary-60: hsla(
        var(--secondary-color-h),
        var(--secondary-color-s),
        var(--secondary-color-l),
        60%
    );
    --color-secondary-50: hsla(
        var(--secondary-color-h),
        var(--secondary-color-s),
        var(--secondary-color-l),
        50%
    );
    --color-secondary-30: hsla(
        var(--secondary-color-h),
        var(--secondary-color-s),
        var(--secondary-color-l),
        30%
    );
    --color-secondary-10: hsla(
        var(--secondary-color-h),
        var(--secondary-color-s),
        var(--secondary-color-l),
        10%
    );
}
.anhanguera,
body {
    --primary-color-h: 22;
    --primary-color-s: 100%;
    --primary-color-l: 57%;
    --secondary-color-h: 212;
    --secondary-color-s: 61%;
    --secondary-color-l: 22%;
}
.pitagoras {
    --primary-color-h: 16;
    --primary-color-s: 87%;
    --primary-color-l: 54%;
    --secondary-color-h: 0;
    --secondary-color-s: 0%;
    --secondary-color-l: 30%;
}
.unopar {
    --primary-color-h: 358;
    --primary-color-s: 85%;
    --primary-color-l: 52%;
    --secondary-color-h: 213;
    --secondary-color-s: 100%;
    --secondary-color-l: 22%;
}
.unime {
    --primary-color-h: 358;
    --primary-color-s: 85%;
    --primary-color-l: 52%;
    --secondary-color-h: 240;
    --secondary-color-s: 1%;
    --secondary-color-l: 30%;
}
.uniderp {
    --primary-color-h: 76;
    --primary-color-s: 60%;
    --primary-color-l: 52%;
    --secondary-color-h: 212;
    --secondary-color-s: 96%;
    --secondary-color-l: 32%;
}
.unic {
    --primary-color-h: 207;
    --primary-color-s: 100%;
    --primary-color-l: 31%;
    --secondary-color-h: 196;
    --secondary-color-s: 100%;
    --secondary-color-l: 47%;
}
:root {
    --font-heading: "apotek-variable", sans-serif;
    --font-body: "eigerdals", sans-serif;
}
html {
    font-size: clamp(14px, 2vw, 16px);
    scroll-behavior: smooth;
}
p {
    margin: 0.5rem 0 0 0;
}
:where(a[href]:not(.btn)) {
    color: var(--color-semantic-info);
}
:where(a[href]:not(.btn)):hover {
    color: var(--color-primary-default);
}
.link-text-more {
    font-size: 0.9rem;
    color: var(--color-lfg-second);
    text-decoration: underline;
}
.display-1 {
    font-size: 3.875rem;
    font-family: var(--font-body);
    font-weight: 700;
    font-style: normal;
    line-height: 0.9;
    letter-spacing: -0.04em;
    text-decoration: none;
    text-transform: none;
}
.display-2 {
    font-size: 3rem;
    font-family: var(--font-body);
    font-weight: 700;
    font-style: normal;
    line-height: 1.05;
    letter-spacing: -0.02em;
    text-decoration: none;
    text-transform: none;
}
h1,
.h1 {
    font-family: var(--font-heading);
    font-variation-settings: "wdth" 66, "wght" 550;
    font-weight: unset;
    line-height: 0.93;
    font-size: 4rem;
    text-transform: uppercase;
    margin: 0;
}
h1.black,
.h1.black {
    font-variation-settings: "wdth" 50, "wght" 900;
}
h2,
.h2 {
    font-family: var(--font-heading);
    font-size: 3rem;
    font-variation-settings: "wdth" 66, "wght" 633;
    font-weight: unset;
    font-style: normal;
    line-height: 0.9;
    text-decoration: none;
    text-transform: uppercase;
    margin: 0;
}
h3,
.h3 {
    font-family: var(--font-heading);
    font-size: 2.625rem;
    font-variation-settings: "wdth" 66, "wght" 550;
    font-weight: unset;
    font-style: normal;
    line-height: 0.9;
    text-decoration: none;
    text-transform: none;
    margin: 0;
}
h4,
.h4 {
    font-family: var(--font-heading);
    font-variation-settings: "wdth" 66, "wght" 550;
    font-weight: unset;
    font-size: 2rem;
    font-style: normal;
    line-height: 0.9;
    text-decoration: none;
    text-transform: none;
    margin: 0;
}
h5,
.h5 {
    font-family: var(--font-heading);
    font-variation-settings: "wdth" 66, "wght" 500;
    font-weight: unset;
    font-size: 1.625rem;
    font-style: normal;
    line-height: 1;
    text-decoration: none;
    text-transform: none;
    margin: 0;
}
h6,
.h6 {
    font-family: var(--font-heading);
    font-variation-settings: "wdth" 66, "wght" 633;
    font-weight: unset;
    font-size: 1.375rem;
    font-style: normal;
    line-height: 1;
    text-decoration: none;
    text-transform: none;
    margin: 0;
}
.no-wrap {
    white-space: nowrap;
}
.text-subtitle {
    font-size: 1.125rem;
    font-family: var(--font-body);
    font-weight: 500;
    font-style: normal;
    line-height: 1.3;
    letter-spacing: -0.02em;
    text-decoration: none;
    text-transform: none;
}
.text-page-title {
    font-size: 2.625rem;
    font-family: var(--font-body);
    font-weight: 500;
    font-style: normal;
    line-height: 1;
    letter-spacing: -0.03em;
    text-decoration: none;
    text-transform: none;
}
.text-subheader {
    font-family: var(--font-body);
    font-weight: 500;
    font-style: normal;
    line-height: 1.3;
    letter-spacing: 0.04em;
    text-decoration: none;
    text-transform: uppercase;
    font-size: 1.25rem;
}
.text-subheader.lg {
    font-size: 1.5rem;
}
.text-subheader.md {
    font-size: 1.25rem;
    letter-spacing: 0.05em;
}
.text-subheader.sm {
    font-size: 0.875rem;
    letter-spacing: 0.05em;
}
.text-caption {
    font-size: 0.75rem;
    font-family: var(--font-body);
    font-weight: 500;
    font-style: normal;
    line-height: 1.3;
    text-decoration: none;
    text-transform: none;
}
.text-title {
    font-family: var(--font-body);
    font-weight: 700;
    font-style: normal;
    line-height: 1.15;
    letter-spacing: -0.02em;
    text-decoration: none;
    text-transform: none;
}
.text-title.lg {
    font-size: 1.75rem;
}
.text-title.md {
    font-size: 1.5rem;
}
.text-title.sm {
    font-size: 1.25rem;
}
.text-body {
    font-family: var(--font-body);
    font-style: normal;
    line-height: 1.5;
    text-transform: none;
}
.text-body.xs {
    font-size: 0.75rem;
}
.text-body.sm {
    font-size: 0.875rem;
}
.text-body.md {
    font-size: 1rem;
}
.text-body.lg {
    font-size: 1.125rem;
}
.text-body.xl {
    font-size: 1.25rem;
}
.text-menu {
    font-size: 0.875rem;
    font-family: var(--font-body);
    font-weight: 400;
    font-style: normal;
    line-height: 1.3;
    letter-spacing: -0.01em;
    text-decoration: none;
    text-transform: uppercase;
}
.fw-100 {
    font-weight: 100 !important;
}
.fw-300 {
    font-weight: 300 !important;
}
.fw-400 {
    font-weight: 400 !important;
}
.fw-500 {
    font-weight: 500 !important;
}
.fw-600 {
    font-weight: 600 !important;
}
.fw-700 {
    font-weight: 700 !important;
}
.fw-800 {
    font-weight: 800 !important;
}
.fw-900 {
    font-weight: 900 !important;
}
.f-variable {
    font-variation-settings: "wdth" var(--width, 66), "wght" var(--weight, 400) !important;
}
.text-center {
    text-align: center !important;
}
.text-right {
    text-align: right !important;
}
.text-color-primary-default {
    --color-primary-default: hsla(
        var(--primary-color-h),
        var(--primary-color-s),
        var(--primary-color-l),
        var(--alpha)
    );
    color: var(--color-primary-default) !important;
}
.text-color-primary-contrast {
    --color-primary-contrast: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken)),
        var(--alpha)
    );
    color: var(--color-primary-contrast) !important;
}
.text-color-primary-high-contrast {
    --color-primary-high-contrast: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken-h)),
        var(--alpha)
    );
    color: var(--color-primary-high-contrast) !important;
}
.text-color-secondary {
    --color-secondary: hsla(
        var(--secondary-color-h),
        var(--secondary-color-s),
        var(--secondary-color-l),
        var(--alpha)
    );
    color: var(--color-secondary) !important;
}
.text-color-white {
    --color-white: hsla(
        var(--white-h),
        var(--white-s),
        var(--white-l),
        var(--alpha)
    );
    color: var(--color-white) !important;
}
.text-color-white-80 {
    color: var(--color-white-80) !important;
}
.text-color-white-60 {
    color: var(--color-white-60) !important;
}
.text-color-white-50 {
    color: var(--color-white-50) !important;
}
.text-color-white-30 {
    color: var(--color-white-30) !important;
}
.text-color-white-20 {
    color: var(--color-white-20) !important;
}
.text-color-white-10 {
    color: var(--color-white-10) !important;
}
.text-color-alternate {
    --color-alternate: hsla(
        var(--alternate-h),
        var(--alternate-s),
        var(--alternate-l),
        var(--alpha)
    );
    color: var(--color-alternate) !important;
}
.text-color-claret {
    --color-claret: hsla(
        var(--claret-h),
        var(--claret-s),
        var(--claret-l),
        var(--alpha)
    );
    color: var(--color-claret) !important;
}
.text-color-blue {
    --color-blue: hsla(
        var(--blue-h),
        var(--blue-s),
        var(--blue-l),
        var(--alpha)
    );
    color: var(--color-blue) !important;
}
.text-color-cerise {
    --color-cerise: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        var(--alpha)
    );
    color: var(--color-cerise) !important;
}
.text-color-purple {
    --color-purple: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        var(--alpha)
    );
    color: var(--color-purple) !important;
}
.text-color-blue-dark {
    --color-blue-dark: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        var(--alpha)
    );
    color: var(--color-blue-dark) !important;
}
.text-color-gray-light {
    --color-gray-light: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        var(--alpha)
    );
    color: var(--color-gray-light) !important;
}
.text-color-gray-medium {
    --color-gray-medium: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        var(--alpha)
    );
    color: var(--color-gray-medium) !important;
}
.text-color-accent-soft {
    --color-accent: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) - var(--vibrance)),
        calc(var(--accent-l) + var(--darken)),
        var(--alpha)
    );
    color: var(--color-accent) !important;
}
.text-color-accent-default {
    --color-accent: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha)
    );
    color: var(--color-accent) !important;
}
.text-color-accent-contrast {
    --color-accent: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) + var(--vibrance)),
        calc(var(--accent-l) - var(--darken)),
        var(--alpha)
    );
    color: var(--color-accent) !important;
}
.text-color-lfg-first {
    color: var(--color-lfg-first) !important;
}
.text-color-lfg-second {
    color: var(--color-lfg-second) !important;
}
.text-color-lfg-third {
    color: var(--color-lfg-third) !important;
}
.text-color-aedu-play {
    color: var(--color-aedu-play) !important;
}
.text-color-semantic-danger {
    --color-semantic-danger: hsla(
        var(--semantic-danger-h),
        var(--semantic-danger-s),
        var(--semantic-danger-l),
        var(--alpha)
    );
    color: var(--color-semantic-danger) !important;
}
.text-color-semantic-info {
    --color-semantic-info: hsla(
        var(--semantic-info-h),
        var(--semantic-info-s),
        var(--semantic-info-l),
        var(--alpha)
    );
    color: var(--color-semantic-info) !important;
}
.text-color-semantic-success {
    --color-semantic-success: hsla(
        var(--semantic-success-h),
        var(--semantic-success-s),
        var(--semantic-success-l),
        var(--alpha)
    );
    color: var(--color-semantic-success) !important;
}
.text-color-semantic-warning {
    --color-warning-danger: hsla(
        var(--semantic-warning-h),
        var(--semantic-warning-s),
        var(--semantic-warning-l),
        var(--alpha)
    );
    color: var(--color-semantic-warning) !important;
}
.text-color-contrast {
    color: var(--color-text-contrast) !important;
}
.text-color-light {
    color: var(--color-text-light) !important;
}
.text-color-default {
    color: var(--color-text-default) !important;
}
.box {
    display: inline-block;
    align-self: flex-start;
    padding: 0.2em 0.75em;
    border-radius: 0.5rem;
}
.section-title {
    margin: 0 auto;
    max-width: 56ch;
    text-align: center;
    color: var(--color-text-default);
}
@media (max-width: 460px) {
    .section-title h2 {
        font-size: 2.25rem;
    }
}
.section-title .highlight {
    font-size: 1.2em;
    font-variation-settings: "wdth" 66, "wght" 900;
}
.fl-right {
    float: right;
}
.fl-left {
    float: left;
}
.row {
    box-sizing: border-box;
    margin: -1rem;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex: 0 1 auto;
    flex-direction: row;
    flex-wrap: wrap;
}
.row.reverse {
    flex-direction: row-reverse;
}
.row.natural-height {
    align-items: flex-start;
}
.row.flex-column {
    flex-direction: column;
}
.col {
    box-sizing: border-box;
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
    padding: 1rem;
}
.col.reverse {
    flex-direction: column-reverse;
}
.first {
    order: -1;
}
.last {
    order: 1;
}
.align-start {
    align-self: flex-start;
}
.align-end {
    align-self: flex-end;
}
.align-center {
    align-self: center;
}
.align-baseline {
    align-self: baseline;
}
.align-stretch {
    align-self: stretch;
}
.container {
    width: 100%;
    max-width: 1440px;
    margin-right: auto;
    margin-left: auto;
    padding-right: 1rem;
    padding-left: 1rem;
}
.container.xs {
    max-width: 640px;
}
.container.sm {
    max-width: 1024px;
}
.container.md {
    max-width: 1440px;
}
.container.lg {
    max-width: 1920px;
}
.container.fluid {
    max-width: unset;
}
.container > .row {
    margin-left: -1rem;
    margin-right: -1rem;
}
.container.flex-column {
    display: flex;
    flex-direction: column;
}
.col-xs {
    box-sizing: border-box;
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
    padding: 1rem;
}
.col-xs-1 {
    box-sizing: border-box;
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
    padding: 1rem;
}
.col-xs-offset-1 {
    margin-left: 8.3333333333%;
}
.col-xs-2 {
    box-sizing: border-box;
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
    padding: 1rem;
}
.col-xs-offset-2 {
    margin-left: 16.6666666667%;
}
.col-xs-3 {
    box-sizing: border-box;
    flex-basis: 25%;
    max-width: 25%;
    padding: 1rem;
}
.col-xs-offset-3 {
    margin-left: 25%;
}
.col-xs-4 {
    box-sizing: border-box;
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
    padding: 1rem;
}
.col-xs-offset-4 {
    margin-left: 33.3333333333%;
}
.col-xs-5 {
    box-sizing: border-box;
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
    padding: 1rem;
}
.col-xs-offset-5 {
    margin-left: 41.6666666667%;
}
.col-xs-6 {
    box-sizing: border-box;
    flex-basis: 50%;
    max-width: 50%;
    padding: 1rem;
}
.col-xs-offset-6 {
    margin-left: 50%;
}
.col-xs-7 {
    box-sizing: border-box;
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
    padding: 1rem;
}
.col-xs-offset-7 {
    margin-left: 58.3333333333%;
}
.col-xs-8 {
    box-sizing: border-box;
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
    padding: 1rem;
}
.col-xs-offset-8 {
    margin-left: 66.6666666667%;
}
.col-xs-9 {
    box-sizing: border-box;
    flex-basis: 75%;
    max-width: 75%;
    padding: 1rem;
}
.col-xs-offset-9 {
    margin-left: 75%;
}
.col-xs-10 {
    box-sizing: border-box;
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
    padding: 1rem;
}
.col-xs-offset-10 {
    margin-left: 83.3333333333%;
}
.col-xs-11 {
    box-sizing: border-box;
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
    padding: 1rem;
}
.col-xs-offset-11 {
    margin-left: 91.6666666667%;
}
.col-xs-12 {
    box-sizing: border-box;
    flex-basis: 100%;
    max-width: 100%;
    padding: 1rem;
}
.col-xs-offset-12 {
    margin-left: 100%;
}
.row.start-xs {
    justify-content: flex-start;
}
.row.center-xs {
    justify-content: center;
}
.row.end-xs {
    justify-content: flex-end;
}
.row.top-xs {
    align-items: flex-start;
}
.row.middle-xs {
    align-items: center;
}
.row.bottom-xs {
    align-items: flex-end;
}
.row.around-xs {
    justify-content: space-around;
}
.row.between-xs {
    justify-content: space-between;
}
.first-xs {
    order: -1;
}
.last-xs {
    order: 1;
}
@media only screen and (min-width: 641px) {
    .col-sm {
        box-sizing: border-box;
        flex-grow: 1;
        flex-basis: 0;
        max-width: 100%;
        padding: 1rem;
    }
    .col-sm-1 {
        box-sizing: border-box;
        flex-basis: 8.3333333333%;
        max-width: 8.3333333333%;
        padding: 1rem;
    }
    .col-sm-offset-1 {
        margin-left: 8.3333333333%;
    }
    .col-sm-2 {
        box-sizing: border-box;
        flex-basis: 16.6666666667%;
        max-width: 16.6666666667%;
        padding: 1rem;
    }
    .col-sm-offset-2 {
        margin-left: 16.6666666667%;
    }
    .col-sm-3 {
        box-sizing: border-box;
        flex-basis: 25%;
        max-width: 25%;
        padding: 1rem;
    }
    .col-sm-offset-3 {
        margin-left: 25%;
    }
    .col-sm-4 {
        box-sizing: border-box;
        flex-basis: 33.3333333333%;
        max-width: 33.3333333333%;
        padding: 1rem;
    }
    .col-sm-offset-4 {
        margin-left: 33.3333333333%;
    }
    .col-sm-5 {
        box-sizing: border-box;
        flex-basis: 41.6666666667%;
        max-width: 41.6666666667%;
        padding: 1rem;
    }
    .col-sm-offset-5 {
        margin-left: 41.6666666667%;
    }
    .col-sm-6 {
        box-sizing: border-box;
        flex-basis: 50%;
        max-width: 50%;
        padding: 1rem;
    }
    .col-sm-offset-6 {
        margin-left: 50%;
    }
    .col-sm-7 {
        box-sizing: border-box;
        flex-basis: 58.3333333333%;
        max-width: 58.3333333333%;
        padding: 1rem;
    }
    .col-sm-offset-7 {
        margin-left: 58.3333333333%;
    }
    .col-sm-8 {
        box-sizing: border-box;
        flex-basis: 66.6666666667%;
        max-width: 66.6666666667%;
        padding: 1rem;
    }
    .col-sm-offset-8 {
        margin-left: 66.6666666667%;
    }
    .col-sm-9 {
        box-sizing: border-box;
        flex-basis: 75%;
        max-width: 75%;
        padding: 1rem;
    }
    .col-sm-offset-9 {
        margin-left: 75%;
    }
    .col-sm-10 {
        box-sizing: border-box;
        flex-basis: 83.3333333333%;
        max-width: 83.3333333333%;
        padding: 1rem;
    }
    .col-sm-offset-10 {
        margin-left: 83.3333333333%;
    }
    .col-sm-11 {
        box-sizing: border-box;
        flex-basis: 91.6666666667%;
        max-width: 91.6666666667%;
        padding: 1rem;
    }
    .col-sm-offset-11 {
        margin-left: 91.6666666667%;
    }
    .col-sm-12 {
        box-sizing: border-box;
        flex-basis: 100%;
        max-width: 100%;
        padding: 1rem;
    }
    .col-sm-offset-12 {
        margin-left: 100%;
    }
    .row.start-sm {
        justify-content: flex-start;
    }
    .row.center-sm {
        justify-content: center;
    }
    .row.end-sm {
        justify-content: flex-end;
    }
    .row.top-sm {
        align-items: flex-start;
    }
    .row.middle-sm {
        align-items: center;
    }
    .row.bottom-sm {
        align-items: flex-end;
    }
    .row.around-sm {
        justify-content: space-around;
    }
    .row.between-sm {
        justify-content: space-between;
    }
    .first-sm {
        order: -1;
    }
    .last-sm {
        order: 1;
    }
}
@media only screen and (min-width: 1025px) {
    .col-md {
        box-sizing: border-box;
        flex-grow: 1;
        flex-basis: 0;
        max-width: 100%;
        padding: 1rem;
    }
    .col-md-1 {
        box-sizing: border-box;
        flex-basis: 8.3333333333%;
        max-width: 8.3333333333%;
        padding: 1rem;
    }
    .col-md-offset-1 {
        margin-left: 8.3333333333%;
    }
    .col-md-2 {
        box-sizing: border-box;
        flex-basis: 16.6666666667%;
        max-width: 16.6666666667%;
        padding: 1rem;
    }
    .col-md-offset-2 {
        margin-left: 16.6666666667%;
    }
    .col-md-3 {
        box-sizing: border-box;
        flex-basis: 25%;
        max-width: 25%;
        padding: 1rem;
    }
    .col-md-offset-3 {
        margin-left: 25%;
    }
    .col-md-4 {
        box-sizing: border-box;
        flex-basis: 33.3333333333%;
        max-width: 33.3333333333%;
        padding: 1rem;
    }
    .col-md-offset-4 {
        margin-left: 33.3333333333%;
    }
    .col-md-5 {
        box-sizing: border-box;
        flex-basis: 41.6666666667%;
        max-width: 41.6666666667%;
        padding: 1rem;
    }
    .col-md-offset-5 {
        margin-left: 41.6666666667%;
    }
    .col-md-6 {
        box-sizing: border-box;
        flex-basis: 50%;
        max-width: 50%;
        padding: 1rem;
    }
    .col-md-offset-6 {
        margin-left: 50%;
    }
    .col-md-7 {
        box-sizing: border-box;
        flex-basis: 58.3333333333%;
        max-width: 58.3333333333%;
        padding: 1rem;
    }
    .col-md-offset-7 {
        margin-left: 58.3333333333%;
    }
    .col-md-8 {
        box-sizing: border-box;
        flex-basis: 66.6666666667%;
        max-width: 66.6666666667%;
        padding: 1rem;
    }
    .col-md-offset-8 {
        margin-left: 66.6666666667%;
    }
    .col-md-9 {
        box-sizing: border-box;
        flex-basis: 75%;
        max-width: 75%;
        padding: 1rem;
    }
    .col-md-offset-9 {
        margin-left: 75%;
    }
    .col-md-10 {
        box-sizing: border-box;
        flex-basis: 83.3333333333%;
        max-width: 83.3333333333%;
        padding: 1rem;
    }
    .col-md-offset-10 {
        margin-left: 83.3333333333%;
    }
    .col-md-11 {
        box-sizing: border-box;
        flex-basis: 91.6666666667%;
        max-width: 91.6666666667%;
        padding: 1rem;
    }
    .col-md-offset-11 {
        margin-left: 91.6666666667%;
    }
    .col-md-12 {
        box-sizing: border-box;
        flex-basis: 100%;
        max-width: 100%;
        padding: 1rem;
    }
    .col-md-offset-12 {
        margin-left: 100%;
    }
    .row.start-md {
        justify-content: flex-start;
    }
    .row.center-md {
        justify-content: center;
    }
    .row.end-md {
        justify-content: flex-end;
    }
    .row.top-md {
        align-items: flex-start;
    }
    .row.middle-md {
        align-items: center;
    }
    .row.bottom-md {
        align-items: flex-end;
    }
    .row.around-md {
        justify-content: space-around;
    }
    .row.between-md {
        justify-content: space-between;
    }
    .first-md {
        order: -1;
    }
    .last-md {
        order: 1;
    }
}
@media only screen and (min-width: 1441px) {
    .col-lg {
        box-sizing: border-box;
        flex-grow: 1;
        flex-basis: 0;
        max-width: 100%;
        padding: 1rem;
    }
    .col-lg-1 {
        box-sizing: border-box;
        flex-basis: 8.3333333333%;
        max-width: 8.3333333333%;
        padding: 1rem;
    }
    .col-lg-offset-1 {
        margin-left: 8.3333333333%;
    }
    .col-lg-2 {
        box-sizing: border-box;
        flex-basis: 16.6666666667%;
        max-width: 16.6666666667%;
        padding: 1rem;
    }
    .col-lg-offset-2 {
        margin-left: 16.6666666667%;
    }
    .col-lg-3 {
        box-sizing: border-box;
        flex-basis: 25%;
        max-width: 25%;
        padding: 1rem;
    }
    .col-lg-offset-3 {
        margin-left: 25%;
    }
    .col-lg-4 {
        box-sizing: border-box;
        flex-basis: 33.3333333333%;
        max-width: 33.3333333333%;
        padding: 1rem;
    }
    .col-lg-offset-4 {
        margin-left: 33.3333333333%;
    }
    .col-lg-5 {
        box-sizing: border-box;
        flex-basis: 41.6666666667%;
        max-width: 41.6666666667%;
        padding: 1rem;
    }
    .col-lg-offset-5 {
        margin-left: 41.6666666667%;
    }
    .col-lg-6 {
        box-sizing: border-box;
        flex-basis: 50%;
        max-width: 50%;
        padding: 1rem;
    }
    .col-lg-offset-6 {
        margin-left: 50%;
    }
    .col-lg-7 {
        box-sizing: border-box;
        flex-basis: 58.3333333333%;
        max-width: 58.3333333333%;
        padding: 1rem;
    }
    .col-lg-offset-7 {
        margin-left: 58.3333333333%;
    }
    .col-lg-8 {
        box-sizing: border-box;
        flex-basis: 66.6666666667%;
        max-width: 66.6666666667%;
        padding: 1rem;
    }
    .col-lg-offset-8 {
        margin-left: 66.6666666667%;
    }
    .col-lg-9 {
        box-sizing: border-box;
        flex-basis: 75%;
        max-width: 75%;
        padding: 1rem;
    }
    .col-lg-offset-9 {
        margin-left: 75%;
    }
    .col-lg-10 {
        box-sizing: border-box;
        flex-basis: 83.3333333333%;
        max-width: 83.3333333333%;
        padding: 1rem;
    }
    .col-lg-offset-10 {
        margin-left: 83.3333333333%;
    }
    .col-lg-11 {
        box-sizing: border-box;
        flex-basis: 91.6666666667%;
        max-width: 91.6666666667%;
        padding: 1rem;
    }
    .col-lg-offset-11 {
        margin-left: 91.6666666667%;
    }
    .col-lg-12 {
        box-sizing: border-box;
        flex-basis: 100%;
        max-width: 100%;
        padding: 1rem;
    }
    .col-lg-offset-12 {
        margin-left: 100%;
    }
    .row.start-lg {
        justify-content: flex-start;
    }
    .row.center-lg {
        justify-content: center;
    }
    .row.end-lg {
        justify-content: flex-end;
    }
    .row.top-lg {
        align-items: flex-start;
    }
    .row.middle-lg {
        align-items: center;
    }
    .row.bottom-lg {
        align-items: flex-end;
    }
    .row.around-lg {
        justify-content: space-around;
    }
    .row.between-lg {
        justify-content: space-between;
    }
    .first-lg {
        order: -1;
    }
    .last-lg {
        order: 1;
    }
}
@media only screen and (min-width: 1921px) {
    .col-xl {
        box-sizing: border-box;
        flex-grow: 1;
        flex-basis: 0;
        max-width: 100%;
        padding: 1rem;
    }
    .col-xl-1 {
        box-sizing: border-box;
        flex-basis: 8.3333333333%;
        max-width: 8.3333333333%;
        padding: 1rem;
    }
    .col-xl-offset-1 {
        margin-left: 8.3333333333%;
    }
    .col-xl-2 {
        box-sizing: border-box;
        flex-basis: 16.6666666667%;
        max-width: 16.6666666667%;
        padding: 1rem;
    }
    .col-xl-offset-2 {
        margin-left: 16.6666666667%;
    }
    .col-xl-3 {
        box-sizing: border-box;
        flex-basis: 25%;
        max-width: 25%;
        padding: 1rem;
    }
    .col-xl-offset-3 {
        margin-left: 25%;
    }
    .col-xl-4 {
        box-sizing: border-box;
        flex-basis: 33.3333333333%;
        max-width: 33.3333333333%;
        padding: 1rem;
    }
    .col-xl-offset-4 {
        margin-left: 33.3333333333%;
    }
    .col-xl-5 {
        box-sizing: border-box;
        flex-basis: 41.6666666667%;
        max-width: 41.6666666667%;
        padding: 1rem;
    }
    .col-xl-offset-5 {
        margin-left: 41.6666666667%;
    }
    .col-xl-6 {
        box-sizing: border-box;
        flex-basis: 50%;
        max-width: 50%;
        padding: 1rem;
    }
    .col-xl-offset-6 {
        margin-left: 50%;
    }
    .col-xl-7 {
        box-sizing: border-box;
        flex-basis: 58.3333333333%;
        max-width: 58.3333333333%;
        padding: 1rem;
    }
    .col-xl-offset-7 {
        margin-left: 58.3333333333%;
    }
    .col-xl-8 {
        box-sizing: border-box;
        flex-basis: 66.6666666667%;
        max-width: 66.6666666667%;
        padding: 1rem;
    }
    .col-xl-offset-8 {
        margin-left: 66.6666666667%;
    }
    .col-xl-9 {
        box-sizing: border-box;
        flex-basis: 75%;
        max-width: 75%;
        padding: 1rem;
    }
    .col-xl-offset-9 {
        margin-left: 75%;
    }
    .col-xl-10 {
        box-sizing: border-box;
        flex-basis: 83.3333333333%;
        max-width: 83.3333333333%;
        padding: 1rem;
    }
    .col-xl-offset-10 {
        margin-left: 83.3333333333%;
    }
    .col-xl-11 {
        box-sizing: border-box;
        flex-basis: 91.6666666667%;
        max-width: 91.6666666667%;
        padding: 1rem;
    }
    .col-xl-offset-11 {
        margin-left: 91.6666666667%;
    }
    .col-xl-12 {
        box-sizing: border-box;
        flex-basis: 100%;
        max-width: 100%;
        padding: 1rem;
    }
    .col-xl-offset-12 {
        margin-left: 100%;
    }
    .row.start-xl {
        justify-content: flex-start;
    }
    .row.center-xl {
        justify-content: center;
    }
    .row.end-xl {
        justify-content: flex-end;
    }
    .row.top-xl {
        align-items: flex-start;
    }
    .row.middle-xl {
        align-items: center;
    }
    .row.bottom-xl {
        align-items: flex-end;
    }
    .row.around-xl {
        justify-content: space-around;
    }
    .row.between-xl {
        justify-content: space-between;
    }
    .first-xl {
        order: -1;
    }
    .last-xl {
        order: 1;
    }
}
.gutter-sm [class*="col-"] {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
}
.gutter-lg [class*="col-"] {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
}
.no-gutter [class*="col-"] {
    padding-left: 0;
    padding-right: 0;
}
@media only screen and (min-width: 0) {
    .col-xs-auto {
        flex-basis: auto;
        max-width: unset;
        min-width: unset;
    }
}
@media only screen and (min-width: 641px) {
    .col-sm-auto {
        flex-basis: auto;
        max-width: unset;
        min-width: unset;
    }
}
@media only screen and (min-width: 1025px) {
    .col-md-auto {
        flex-basis: auto;
        max-width: unset;
        min-width: unset;
    }
}
@media only screen and (min-width: 1441px) {
    .col-lg-auto {
        flex-basis: auto;
        max-width: unset;
        min-width: unset;
    }
}
@media only screen and (min-width: 1921px) {
    .col-xl-auto {
        flex-basis: auto;
        max-width: unset;
        min-width: unset;
    }
}
@media only screen and (min-width: 0) {
    .order-xs-first {
        order: -1;
    }
    .order-xs-last {
        order: 1;
    }
}
@media only screen and (min-width: 641px) {
    .order-sm-first {
        order: -1;
    }
    .order-sm-last {
        order: 1;
    }
}
@media only screen and (min-width: 1025px) {
    .order-md-first {
        order: -1;
    }
    .order-md-last {
        order: 1;
    }
}
@media only screen and (min-width: 1441px) {
    .order-lg-first {
        order: -1;
    }
    .order-lg-last {
        order: 1;
    }
}
@media only screen and (min-width: 1921px) {
    .order-xl-first {
        order: -1;
    }
    .order-xl-last {
        order: 1;
    }
}
@media only screen and (max-width: 640px) {
    .flex-xs-column {
        display: flex;
        flex-direction: column;
    }
}
form {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
form:invalid button[type="submit"] {
    filter: grayscale(1);
    opacity: 0.5;
    cursor: not-allowed;
    position: relative;
}
form:invalid button[type="submit"]:active {
    pointer-events: none;
}
.input-control {
    --height: 3.25rem;
    --bg: var(--color-contrast);
    --text-color: var(--color-text-light);
    --highlight-outline: hsla(
        var(--primary-default-h),
        var(--primary-default-s),
        var(--primary-default-l),
        30%
    );
    --highlight-border: var(--color-primary-default);
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    position: relative;
    isolation: isolate;
    user-select: none;
}
.input-control label {
    user-select: none;
    pointer-events: none;
    font-size: 0.875rem;
    position: absolute;
    top: 1rem;
    left: 0.65rem;
    color: var(--text-color);
    opacity: 0.8;
    line-height: 1.4;
    padding: 0 0.35rem;
    border-radius: 0.25rem 0.25rem 0.25rem 0;
    transform-origin: left center;
    z-index: 2;
    font-weight: 300;
}
.input-control label:before {
    content: attr(data-text);
}
.input-control label:after {
    content: "";
    position: absolute;
    right: 1rem;
    display: inline-block;
    width: 1.5rem;
    height: 1.5rem;
}
.input-control :is(input, textarea, select) {
    font-family: var(--font-body);
    appearance: none;
    height: var(--height);
    font-size: 0.875rem;
    padding: 0 3rem 0 1rem;
    font-weight: 300;
    border: 1px solid var(--bg);
    background-color: var(--bg);
    border-radius: 0.5rem;
    transition: border 0.3s;
    outline: none;
    box-shadow: inset 0 0 0 30px var(--bg);
    color: var(--text-color);
    z-index: 2;
}
.input-control :is(input, textarea, select):-webkit-autofill,
.input-control :is(input, textarea, select):-webkit-autofill:focus-visible,
.input-control :is(input, textarea, select):-webkit-autofill:hover {
    box-shadow: inset 0 0 0 30px var(--bg);
    -webkit-text-fill-color: var(--text-color) !important;
}
.input-control
    :is(input, textarea, select):hover:not(:focus-visible):not(:valid) {
    box-shadow: inset 0 0 1px 300px var(--bg);
}
.input-control :is(input, textarea, select)::placeholder {
    color: rgba(0, 0, 0, 0);
}
.input-control :is(input, textarea, select):not(:placeholder-shown) + label {
    opacity: 0;
}
.input-control :is(input, textarea, select):focus-visible {
    color: var(--text-color);
    box-shadow: 0 0 0 4px var(--highlight-outline);
    border: 1px solid var(--highlight-border);
}
.input-control
    :is(input, textarea, select):focus-visible:placeholder-shown
    + label {
    translate: 30% 0;
    opacity: 0;
    transition: translate 0.3s, opacity 0.3s, border 0.3s;
}
.input-control :is(input, textarea, select):not([value]):not(:focus) + label {
    transition: translate 0.3s, opacity 0.3s, border 0.3s;
}
.input-control
    :is(input, textarea, select):required:invalid:not(:-webkit-autofill):not(
        :placeholder-shown
    ):not(:focus-visible) {
    color: var(--color-semantic-danger);
    border: 1px solid var(--color-semantic-danger);
    animation: 0.4s shake cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}
.input-control
    :is(input, textarea, select):required:invalid:not(:-webkit-autofill):not(
        :placeholder-shown
    ):not(:focus-visible)
    ~ .hint {
    translate: 0;
    height: 1.2em;
    opacity: 1;
}
.input-control
    :is(input, textarea, select):required:invalid:not(:-webkit-autofill):not(
        :placeholder-shown
    ):not(:focus-visible)
    + label {
    opacity: 1;
    color: rgba(0, 0, 0, 0);
    right: 0;
    left: unset;
}
.input-control
    :is(input, textarea, select):required:invalid:not(:-webkit-autofill):not(
        :placeholder-shown
    ):not(:focus-visible)
    + label:after {
    mask: url('data:image/svg+xml;charset=UTF-8, <svg xmlns="http://www.w3.org/2000/svg" height="24" width="24"><path d="M12 16.725q.35 0 .575-.225.225-.225.225-.575t-.225-.575q-.225-.225-.575-.225t-.575.225q-.225.225-.225.575t.225.575q.225.225.575.225Zm-.75-3.65h1.5v-6h-1.5ZM12 21.5q-1.975 0-3.712-.75Q6.55 20 5.275 18.725T3.25 15.712Q2.5 13.975 2.5 12t.75-3.713Q4 6.55 5.275 5.275T8.288 3.25Q10.025 2.5 12 2.5t3.713.75q1.737.75 3.012 2.025t2.025 3.012q.75 1.738.75 3.713t-.75 3.712q-.75 1.738-2.025 3.013t-3.012 2.025q-1.738.75-3.713.75Zm0-1.5q3.35 0 5.675-2.325Q20 15.35 20 12q0-3.35-2.325-5.675Q15.35 4 12 4 8.65 4 6.325 6.325 4 8.65 4 12q0 3.35 2.325 5.675Q8.65 20 12 20Zm0-8Z" fill="black"/></svg>')
        no-repeat center/contain;
    -webkit-mask: url('data:image/svg+xml;charset=UTF-8, <svg xmlns="http://www.w3.org/2000/svg" height="24" width="24"><path d="M12 16.725q.35 0 .575-.225.225-.225.225-.575t-.225-.575q-.225-.225-.575-.225t-.575.225q-.225.225-.225.575t.225.575q.225.225.575.225Zm-.75-3.65h1.5v-6h-1.5ZM12 21.5q-1.975 0-3.712-.75Q6.55 20 5.275 18.725T3.25 15.712Q2.5 13.975 2.5 12t.75-3.713Q4 6.55 5.275 5.275T8.288 3.25Q10.025 2.5 12 2.5t3.713.75q1.737.75 3.012 2.025t2.025 3.012q.75 1.738.75 3.713t-.75 3.712q-.75 1.738-2.025 3.013t-3.012 2.025q-1.738.75-3.713.75Zm0-1.5q3.35 0 5.675-2.325Q20 15.35 20 12q0-3.35-2.325-5.675Q15.35 4 12 4 8.65 4 6.325 6.325 4 8.65 4 12q0 3.35 2.325 5.675Q8.65 20 12 20Zm0-8Z" fill="black"/></svg>')
        no-repeat center/contain;
    background-color: var(--color-semantic-danger);
}
.input-control
    :is(input, textarea, select):required:invalid:not(:-webkit-autofill):not(
        :placeholder-shown
    ):not(:focus-visible):is(select) {
    color: var(--text-color);
    border: 1px solid var(--bg);
}
.input-control
    :is(input, textarea, select):required:invalid:not(:-webkit-autofill):not(
        :placeholder-shown
    ):not(:focus-visible):is(select)
    + label {
    opacity: 0;
}
.input-control
    :is(input, textarea, select):required:invalid:not(:-webkit-autofill):not(
        :placeholder-shown
    ):-webkit-autofill:focus
    + label {
    opacity: 0;
}
.input-control :is(input, textarea, select):-webkit-autofill {
    font-size: 0.875rem;
    transition: 0.3s;
}
.input-control :is(input, textarea, select):valid:not(select) + label {
    right: 0;
    left: unset;
    opacity: 1;
    transition: border 0.3s;
}
.input-control :is(input, textarea, select):valid:not(select) + label:before {
    content: "";
}
.input-control :is(input, textarea, select):valid:not(select) + label:after {
    mask: url('data:image/svg+xml;charset=UTF-8, <svg xmlns="http://www.w3.org/2000/svg" height="24" width="24"><path d="m9.55 18-5.7-5.7 1.425-1.425L9.55 15.15l9.175-9.175L20.15 7.4Z" fill="black"/></svg>')
        no-repeat center/contain;
    -webkit-mask: url('data:image/svg+xml;charset=UTF-8, <svg xmlns="http://www.w3.org/2000/svg" height="24" width="24"><path d="m9.55 18-5.7-5.7 1.425-1.425L9.55 15.15l9.175-9.175L20.15 7.4Z" fill="black"/></svg>')
        no-repeat center/contain;
    background-color: var(--color-semantic-success);
}
.input-control :is(input, textarea, select):valid:not(select):focus-visible {
    color: var(--text-color);
    border: 1px solid var(--color-semantic-success);
    box-shadow: inset 0 0 0 30px var(--bg),
        0 0 0 4px
            hsla(
                var(--semantic-success-h),
                var(--semantic-success-s),
                var(--semantic-success-l),
                30%
            );
}
.input-control
    :is(input, textarea, select):valid:not(
        select
    ):focus-visible:-webkit-autofill {
    -webkit-text-fill-color: var(--text-color) !important;
}
.input-control textarea {
    resize: none;
    padding: 1rem 3rem 1rem 1rem;
    height: unset;
}
.input-control select {
    background-image: var(
        --arrow,
        url('data:image/svg+xml;charset=UTF-8,<svg width="14" height="8" viewBox="0 0 14 8" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M1 1L7 7L13 1" stroke="gray" stroke-linecap="round" stroke-linejoin="round"/></svg>')
    );
    background-position: right 1rem center;
    padding-right: 2.5rem;
    background-repeat: no-repeat;
    background-size: 12px;
    box-shadow: unset;
    cursor: pointer;
}
@media (hover: hover) {
    .input-control select:hover {
        border-color: var(--highlight-border);
    }
}
.input-control .hint {
    white-space: nowrap;
    line-height: 1.2;
    font-size: 0.765rem;
    color: var(--color-semantic-danger);
    transition: 0.6s ease 0.6s;
    z-index: 1;
    translate: 0 -1.5em;
    height: 0;
    opacity: 0;
    text-align: right;
}
.input-control.sm :is(input, textarea, select) {
    --height: 2rem;
}
.input-control.md :is(input, textarea, select) {
    --height: 2.5rem;
}
.input-control.lg :is(input, textarea, select) {
    --height: 3.25rem;
}
.input-control .color-blue-dark {
    --bg: var(--color-blue-dark);
    --text-color: var(--color-white);
    --highlight-outline: var(--color-aedu-play-20);
    --highlight-border: var(--color-aedu-play);
    --arrow: url('data:image/svg+xml;charset=UTF-8,<svg width="14" height="8" viewBox="0 0 14 8" opacity=".8" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M1 1L7 7L13 1" stroke="white" stroke-linecap="round" stroke-linejoin="round"/></svg>');
    border: 1px solid var(--color-white-10);
    font-weight: 500;
}
.submit-message {
    display: none;
    visibility: visible;
    opacity: 0;
    animation: fadeBlock 1s ease forwards;
}
.sending > * {
    display: none !important;
}
.sending .submit-message {
    display: block !important;
}
@keyframes fadeBlock {
    to {
        visibility: visible;
        opacity: 1;
        translate: 0;
    }
}
header {
    background-color: #fff;
    box-shadow: 0px 2px 8px rgba(0, 0, 0, 0.15);
    z-index: 9;
    position: sticky;
    top: 0;
    color: var(--color-text-default);
}
header .top-menu {
    display: flex;
    gap: clamp(0.7rem, 3vw, 1rem);
    justify-content: flex-end;
    border-bottom: 1px solid var(--color-border);
}
header .top-menu-item {
    padding: 0.5rem 0;
    display: block;
    color: var(--color-text-default);
    display: flex;
    gap: 0.5rem;
    text-decoration: none;
    font-size: 0.75rem;
    font-weight: 500;
    align-items: center;
    transition: color 0.3s;
    position: relative;
}
@media (hover: hover) {
    header .top-menu-item:hover {
        color: var(--color-primary-default);
    }
}
@media (max-width: 450px) {
    header .top-menu-item {
        color: var(--color-white);
    }
}
header .top-menu-item.highlight {
    font-weight: 600;
    color: var(--color-primary-contrast);
}
@media (hover: hover) {
    header .top-menu-item.highlight:hover {
        color: var(--color-primary-high-contrast);
    }
}
@media (max-width: 450px) {
    header .top-menu {
        justify-content: center;
        background-color: var(--color-primary-default);
        margin: 0 -1rem;
    }
    header .top-menu-item {
        padding: 0.5rem 1rem;
        font-size: 0.875rem;
    }
    header .top-menu-item:hover {
        color: var(--color-white);
        background-color: var(--color-primary-contrast);
    }
}
header .bottom-menu {
    display: flex;
    height: 4.625rem;
    gap: 1.5rem;
    justify-content: space-between;
    align-items: center;
}
@media screen and (min-width: 768px) {
    header .bottom-menu {
        gap: 5rem;
        justify-content: center;
    }
}
header .bottom-menu input[type="checkbox"] {
    display: none;
}
header .bottom-menu input[type="checkbox"]:checked ~ .bottom-menu-nav {
    translate: 0 0;
    opacity: 1;
    visibility: visible;
}
header .bottom-menu input[type="checkbox"]:checked + label {
    background-color: var(--color-border-30);
}
header .bottom-menu input[type="checkbox"]:checked + label:before {
    content: "";
}
header .bottom-menu .menu-button {
    background-color: rgba(0, 0, 0, 0);
    width: 40px;
    height: 40px;
    color: var(--color-text-default);
    border: 0;
    align-self: center;
    display: none;
    margin-right: 0.5rem;
    place-items: center;
    border-radius: 0.5rem;
    transition: background-color 0.3s, color 0.3s;
    cursor: pointer;
}
header .bottom-menu .menu-button:before {
    content: "";
    font-family: "Font Awesome 6 Pro";
    font-size: 20px;
    line-height: 1;
    font-weight: 300;
}
@media (max-width: 767px) {
    header .bottom-menu .menu-button {
        display: grid;
    }
}
@media (hover: hover) {
    header .bottom-menu .menu-button:hover {
        color: var(--color-primary-default);
    }
}
header .bottom-menu-nav {
    flex-grow: 1;
    display: flex;
    gap: clamp(1rem, 3vw, 3rem);
    justify-content: center;
    padding: 0 2rem;
}
@media (max-width: 767px) {
    header .bottom-menu-nav {
        position: absolute;
        left: 1rem;
        top: 100%;
        flex-direction: column;
        background-color: var(--color-contrast);
        padding: 0.5rem 0;
        width: calc(100% - 2rem);
        max-width: 390px;
        border-radius: 0 0 0.5rem 0.5rem;
        gap: 0;
        box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.3);
        translate: 0 -1rem;
        opacity: 0;
        transition: 0.3s;
        z-index: -1;
        visibility: hidden;
    }
    header .bottom-menu-nav a {
        font-size: 1rem;
        padding: 1rem;
    }
    header .bottom-menu-nav a:not(:last-child) {
        --alpha: 30%;
        border-bottom: 0.5px solid var(--color-white);
    }
}
header .bottom-menu-item {
    padding: 0.5rem 0 0;
    display: flex;
    align-items: center;
    color: var(--color-text-default);
    text-decoration: none;
    font-size: clamp(0.65rem, 1.3vw, 0.875rem);
    font-weight: 500;
    text-transform: uppercase;
    transition: color 0.3s;
    position: relative;
    white-space: nowrap;
}
header .bottom-menu-item:not([href=""])::after {
    content: "";
    position: absolute;
    display: block;
    inset: auto 50% 0 50%;
    height: 2px;
    background-color: var(--color-primary-default);
    transition: inset 0.3s;
}
@media (hover: hover) {
    header .bottom-menu-item:hover {
        color: var(--color-primary-default);
    }
    header .bottom-menu-item:hover:not([href=""])::after {
        inset: auto 0 0 0;
    }
}
header .logo {
    flex-shrink: 0;
    align-self: center;
    width: clamp(110px, 18vw, 146px);
    height: auto;
}
.nav-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: var(--color-bg-default);
    box-shadow: 0px -2px 8px rgba(0, 0, 0, 0.08);
    padding: 0 1rem;
}
.nav-bar nav {
    display: flex;
    gap: 0.5rem;
    height: 3rem;
}
@media (max-width: 450px) {
    .nav-bar nav {
        gap: 0.25rem;
    }
}
.nav-bar nav a {
    --color: var(--color-primary-contrast);
    display: flex;
    align-items: center;
    text-decoration: none;
    color: var(--color-text-default);
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    padding: 0 1rem;
    border-radius: 0.5rem;
    position: relative;
    transition: background-color 0.3s, box-shadow 0.3s;
}
.nav-bar nav a::after {
    content: "";
    position: absolute;
    inset: auto 0 100% 0;
    margin: auto;
    width: 30px;
    height: 21px;
    opacity: 0;
    background-color: var(--color);
    transition: opacity 0.3s;
    transform-origin: bottom center;
    mask: url('data:image/svg+xml;charset=UTF-8, <svg width="30" height="21" viewBox="0 0 30 21" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M0 21C0 21 3.89822 19.9586 6.92308 17.8C10.0898 15.5401 12.5942 10.6894 13.9314 7.65094C14.3126 6.78481 15.6874 6.78481 16.0686 7.65094C17.4058 10.6894 19.9102 15.5401 23.0769 17.8C26.1018 19.9586 30 21 30 21H0Z" fill="black"/><circle cx="15" cy="2" r="2" fill="black"/></svg>');
    -webkit-mask: url('data:image/svg+xml;charset=UTF-8, <svg width="30" height="21" viewBox="0 0 30 21" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M0 21C0 21 3.89822 19.9586 6.92308 17.8C10.0898 15.5401 12.5942 10.6894 13.9314 7.65094C14.3126 6.78481 15.6874 6.78481 16.0686 7.65094C17.4058 10.6894 19.9102 15.5401 23.0769 17.8C26.1018 19.9586 30 21 30 21H0Z" fill="black"/><circle cx="15" cy="2" r="2" fill="black"/></svg>');
}
@media (hover: hover) {
    .nav-bar nav a:hover {
        background-color: var(--color);
        color: var(--color-white);
        box-shadow: 0 0 1rem var(--color);
    }
    .nav-bar nav a:hover::after {
        opacity: 1;
    }
}
.nav-bar .go-to-top {
    padding: 0;
    width: 28px;
    height: 28px;
    align-self: center;
    margin: 0 0.5rem;
    background-color: var(--color-purple);
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-position: center;
    -webkit-mask-position: center;
    flex-shrink: 0;
    mask: url('data:image/svg+xml;charset=UTF-8,<svg width="28" height="28" viewBox="0 0 28 28" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M3 14.2543L14 3M14 3L25 14.2543M14 3V25" stroke="currentColor" stroke-width="6" stroke-linecap="round" stroke-linejoin="round"/></svg>');
    -webkit-mask: url('data:image/svg+xml;charset=UTF-8,<svg width="28" height="28" viewBox="0 0 28 28" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M3 14.2543L14 3M14 3L25 14.2543M14 3V25" stroke="currentColor" stroke-width="6" stroke-linecap="round" stroke-linejoin="round"/></svg>');
}
@media (max-width: 450px) {
    .nav-bar .go-to-top {
        display: none;
    }
}
.btn {
    --color: var(--color-primary-defaut);
    font-family: var(--font-heading);
    font-weight: 500;
    font-style: normal;
    line-height: 1;
    letter-spacing: 0.01em;
    text-decoration: none;
    text-transform: uppercase;
    border: 2px solid var(--color-white);
    box-shadow: inset 0 0 0 2px #000;
    border-radius: 0.5em;
    padding: 0 1.25em;
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    justify-content: center;
    gap: 8px;
    font-size: 1.25rem;
    height: 2.5rem;
    flex-shrink: 0;
    white-space: nowrap;
    color: var(--color-white);
    font-variation-settings: "wdth" 66, "wght" 550;
    background-color: var(--color);
    transition: box-shadow 0.3s;
    cursor: pointer;
    position: relative;
}
@media (hover: hover) {
    .btn:hover {
        box-shadow: inset 0 0 0 2px #000, 0 0 1em var(--color),
            inset 0 0 2em rgba(0, 0, 0, 0.15);
    }
}
.btn.loading {
    text-indent: -9999ch;
    pointer-events: none;
}
.btn.loading::before {
    content: "";
    position: absolute;
    text-indent: 0;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 2px solid currentColor;
    border-top-color: rgba(0, 0, 0, 0);
    animation: loading 1s linear infinite;
}
.btn.outlined {
    background-color: rgba(0, 0, 0, 0);
    color: var(--color) !important;
    border: 1px solid var(--color);
    box-shadow: none;
}
.btn.outlined:after {
    content: "";
    position: absolute;
    inset: -4px;
    border-radius: 0.6em;
    transition: 0.3s;
    border: 7px solid var(--color);
    filter: blur(3px);
    opacity: 0;
}
@media (hover: hover) {
    .btn.outlined:hover:after {
        opacity: 0.3;
    }
}
.btn.rounded {
    border-radius: 3rem;
}
.btn.text {
    border: none;
    background-color: rgba(0, 0, 0, 0);
    box-shadow: unset;
    padding: 0;
    height: initial;
    color: var(--color);
}
.btn.block {
    width: 100%;
}
.btn.sm {
    font-size: 1rem;
    height: 2rem;
}
.btn.sm.btn-icon {
    width: 2rem;
}
.btn.md {
    font-size: 1.25rem;
    height: 2.5rem;
}
.btn.md.btn-icon {
    width: 2.5rem;
}
.btn.lg {
    font-size: 1.375rem;
    height: 3rem;
}
.btn.lg.btn-icon {
    width: 3rem;
}
.btn.xl {
    font-size: 1.5rem;
    height: 3.5rem;
}
.btn.xl.btn-icon {
    width: 3.5rem;
}
.btn.btn-icon {
    border-radius: 50%;
    padding: 0;
    flex-shrink: 0;
    aspect-ratio: 1/1;
}
.btn.btn-icon * {
    font-size: 18px;
}
.btn.primary-default {
    --color: var(--color-primary-default);
}
.btn.primary-medium {
    --color: var(--color-primary-medium);
}
.btn.primary-contrast {
    --color: var(--color-primary-contrast);
}
.btn.primary-high-contrast {
    --color: var(--color-primary-high-contrast);
}
.btn.accent-soft {
    --color: var(--color-accent-soft);
    color: var(--color-claret);
}
.btn.accent-default {
    --color: var(--color-accent-default);
    color: var(--color-claret);
}
.btn.accent-contrast {
    --color: var(--color-accent-contrast);
    color: var(--color-claret);
}
.btn.lfg-first {
    --color: var(--color-lfg-first);
    color: var(--color-blue-dark);
}
.btn.lfg-second {
    --color: var(--color-lfg-second);
}
.btn.lfg-third {
    --color: var(--color-lfg-third);
}
.btn.aedu-play {
    --color: var(--color-aedu-play);
    color: var(--color-blue-dark);
}
.btn.semantic-danger {
    --color: var(--color-semantic-danger);
}
.btn.semantic-info {
    --color: var(--color-semantic-info);
}
.btn.semantic-success {
    --color: var(--color-semantic-success);
}
.btn.semantic-warning {
    --color: var(--color-semantic-warning);
    color: var(--color-claret);
}
.btn.claret {
    --color: var(--color-claret);
}
.btn.alternate {
    --color: var(--color-alternate);
    color: var(--color-blue-dark);
}
.btn.blue {
    --color: var(--color-blue);
}
.btn.cerise {
    --color: var(--color-cerise);
}
.btn.purple {
    --color: var(--color-purple);
}
.btn.blue-dark {
    --color: var(--color-blue-dark);
}
.btn.gray-light {
    --color: var(--color-gray-light);
    color: var(--color-blue-dark);
}
.btn.gray-medium {
    --color: var(--color-gray-medium);
}
.btn.white {
    --color: var(--color-white);
}
.btn.disabled,
.btn:disabled {
    pointer-events: none;
    opacity: 0.5;
}
@keyframes loading {
    to {
        rotate: 2turn;
    }
}
.icon img {
    width: 100%;
    object-fit: contain;
}
.m-1 {
    margin: 1rem 1rem !important;
}
.mx-1 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
}
.my-1 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
}
.mt-1 {
    margin-top: 1rem !important;
}
.mr-1 {
    margin-right: 1rem !important;
}
.mb-1 {
    margin-bottom: 1rem !important;
}
.ml-1 {
    margin-left: 1rem !important;
}
.m-2 {
    margin: 1.5rem 1.5rem !important;
}
.mx-2 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
}
.my-2 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
}
.mt-2 {
    margin-top: 1.5rem !important;
}
.mr-2 {
    margin-right: 1.5rem !important;
}
.mb-2 {
    margin-bottom: 1.5rem !important;
}
.ml-2 {
    margin-left: 1.5rem !important;
}
.m-3 {
    margin: 2rem 2rem !important;
}
.mx-3 {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
}
.my-3 {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
}
.mt-3 {
    margin-top: 2rem !important;
}
.mr-3 {
    margin-right: 2rem !important;
}
.mb-3 {
    margin-bottom: 2rem !important;
}
.ml-3 {
    margin-left: 2rem !important;
}
.m-4 {
    margin: 3.5rem 3.5rem !important;
}
.mx-4 {
    margin-left: 3.5rem !important;
    margin-right: 3.5rem !important;
}
.my-4 {
    margin-top: 3.5rem !important;
    margin-bottom: 3.5rem !important;
}
.mt-4 {
    margin-top: 3.5rem !important;
}
.mr-4 {
    margin-right: 3.5rem !important;
}
.mb-4 {
    margin-bottom: 3.5rem !important;
}
.ml-4 {
    margin-left: 3.5rem !important;
}
.m-5 {
    margin: 4rem 4rem !important;
}
.mx-5 {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
}
.my-5 {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
}
.mt-5 {
    margin-top: 4rem !important;
}
.mr-5 {
    margin-right: 4rem !important;
}
.mb-5 {
    margin-bottom: 4rem !important;
}
.ml-5 {
    margin-left: 4rem !important;
}
.m-6 {
    margin: 4.5rem 4.5rem !important;
}
.mx-6 {
    margin-left: 4.5rem !important;
    margin-right: 4.5rem !important;
}
.my-6 {
    margin-top: 4.5rem !important;
    margin-bottom: 4.5rem !important;
}
.mt-6 {
    margin-top: 4.5rem !important;
}
.mr-6 {
    margin-right: 4.5rem !important;
}
.mb-6 {
    margin-bottom: 4.5rem !important;
}
.ml-6 {
    margin-left: 4.5rem !important;
}
.m-7 {
    margin: 5rem 5rem !important;
}
.mx-7 {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
}
.my-7 {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
}
.mt-7 {
    margin-top: 5rem !important;
}
.mr-7 {
    margin-right: 5rem !important;
}
.mb-7 {
    margin-bottom: 5rem !important;
}
.ml-7 {
    margin-left: 5rem !important;
}
.m-8 {
    margin: 5.5rem 5.5rem !important;
}
.mx-8 {
    margin-left: 5.5rem !important;
    margin-right: 5.5rem !important;
}
.my-8 {
    margin-top: 5.5rem !important;
    margin-bottom: 5.5rem !important;
}
.mt-8 {
    margin-top: 5.5rem !important;
}
.mr-8 {
    margin-right: 5.5rem !important;
}
.mb-8 {
    margin-bottom: 5.5rem !important;
}
.ml-8 {
    margin-left: 5.5rem !important;
}
.m-9 {
    margin: 6rem !important;
}
.mx-9 {
    margin-left: 6rem !important;
    margin-right: 6rem !important;
}
.my-9 {
    margin-top: !important;
    margin-bottom: !important;
}
.mt-9 {
    margin-top: !important;
}
.mr-9 {
    margin-right: 6rem !important;
}
.mb-9 {
    margin-bottom: !important;
}
.ml-9 {
    margin-left: 6rem !important;
}
.m-10 {
    margin: 7rem 7rem !important;
}
.mx-10 {
    margin-left: 7rem !important;
    margin-right: 7rem !important;
}
.my-10 {
    margin-top: 7rem !important;
    margin-bottom: 7rem !important;
}
.mt-10 {
    margin-top: 7rem !important;
}
.mr-10 {
    margin-right: 7rem !important;
}
.mb-10 {
    margin-bottom: 7rem !important;
}
.ml-10 {
    margin-left: 7rem !important;
}
.m-0 {
    margin: 0 0 !important;
}
.mx-0 {
    margin-left: 0 !important;
    margin-right: 0 !important;
}
.my-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}
.mt-0 {
    margin-top: 0 !important;
}
.mr-0 {
    margin-right: 0 !important;
}
.mb-0 {
    margin-bottom: 0 !important;
}
.ml-0 {
    margin-left: 0 !important;
}
.m-xs {
    margin: 0.25rem 0.25rem !important;
}
.mx-xs {
    margin-left: 0.25rem !important;
    margin-right: 0.25rem !important;
}
.my-xs {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
}
.mt-xs {
    margin-top: 0.25rem !important;
}
.mr-xs {
    margin-right: 0.25rem !important;
}
.mb-xs {
    margin-bottom: 0.25rem !important;
}
.ml-xs {
    margin-left: 0.25rem !important;
}
.m-sm {
    margin: 0.5rem 0.5rem !important;
}
.mx-sm {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
}
.my-sm {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
}
.mt-sm {
    margin-top: 0.5rem !important;
}
.mr-sm {
    margin-right: 0.5rem !important;
}
.mb-sm {
    margin-bottom: 0.5rem !important;
}
.ml-sm {
    margin-left: 0.5rem !important;
}
.m-h {
    margin: 0.5rem 0.5rem !important;
}
.mx-h {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
}
.my-h {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
}
.mt-h {
    margin-top: 0.5rem !important;
}
.mr-h {
    margin-right: 0.5rem !important;
}
.mb-h {
    margin-bottom: 0.5rem !important;
}
.ml-h {
    margin-left: 0.5rem !important;
}
.ml-auto {
    margin-left: auto !important;
}
.mr-auto {
    margin-right: auto !important;
}
.mx-auto {
    margin-right: auto !important;
    margin-left: auto !important;
}
.m-auto {
    margin: auto !important;
}
.p-1 {
    padding: 1rem 1rem !important;
}
.px-1 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
}
.py-1 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
}
.pt-1 {
    padding-top: 1rem !important;
}
.pr-1 {
    padding-right: 1rem !important;
}
.pb-1 {
    padding-bottom: 1rem !important;
}
.pl-1 {
    padding-left: 1rem !important;
}
.p-2 {
    padding: 1.5rem 1.5rem !important;
}
.px-2 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}
.py-2 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
}
.pt-2 {
    padding-top: 1.5rem !important;
}
.pr-2 {
    padding-right: 1.5rem !important;
}
.pb-2 {
    padding-bottom: 1.5rem !important;
}
.pl-2 {
    padding-left: 1.5rem !important;
}
.p-3 {
    padding: 2rem 2rem !important;
}
.px-3 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
}
.py-3 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
}
.pt-3 {
    padding-top: 2rem !important;
}
.pr-3 {
    padding-right: 2rem !important;
}
.pb-3 {
    padding-bottom: 2rem !important;
}
.pl-3 {
    padding-left: 2rem !important;
}
.p-4 {
    padding: 3.5rem 3.5rem !important;
}
.px-4 {
    padding-left: 3.5rem !important;
    padding-right: 3.5rem !important;
}
.py-4 {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
}
.pt-4 {
    padding-top: 3.5rem !important;
}
.pr-4 {
    padding-right: 3.5rem !important;
}
.pb-4 {
    padding-bottom: 3.5rem !important;
}
.pl-4 {
    padding-left: 3.5rem !important;
}
.p-5 {
    padding: 4rem 4rem !important;
}
.px-5 {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
}
.py-5 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
}
.pt-5 {
    padding-top: 4rem !important;
}
.pr-5 {
    padding-right: 4rem !important;
}
.pb-5 {
    padding-bottom: 4rem !important;
}
.pl-5 {
    padding-left: 4rem !important;
}
.p-6 {
    padding: 4.5rem 4.5rem !important;
}
.px-6 {
    padding-left: 4.5rem !important;
    padding-right: 4.5rem !important;
}
.py-6 {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
}
.pt-6 {
    padding-top: 4.5rem !important;
}
.pr-6 {
    padding-right: 4.5rem !important;
}
.pb-6 {
    padding-bottom: 4.5rem !important;
}
.pl-6 {
    padding-left: 4.5rem !important;
}
.p-7 {
    padding: 5rem 5rem !important;
}
.px-7 {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
}
.py-7 {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
}
.pt-7 {
    padding-top: 5rem !important;
}
.pr-7 {
    padding-right: 5rem !important;
}
.pb-7 {
    padding-bottom: 5rem !important;
}
.pl-7 {
    padding-left: 5rem !important;
}
.p-8 {
    padding: 5.5rem 5.5rem !important;
}
.px-8 {
    padding-left: 5.5rem !important;
    padding-right: 5.5rem !important;
}
.py-8 {
    padding-top: 5.5rem !important;
    padding-bottom: 5.5rem !important;
}
.pt-8 {
    padding-top: 5.5rem !important;
}
.pr-8 {
    padding-right: 5.5rem !important;
}
.pb-8 {
    padding-bottom: 5.5rem !important;
}
.pl-8 {
    padding-left: 5.5rem !important;
}
.p-9 {
    padding: 6rem !important;
}
.px-9 {
    padding-left: 6rem !important;
    padding-right: 6rem !important;
}
.py-9 {
    padding-top: !important;
    padding-bottom: !important;
}
.pt-9 {
    padding-top: !important;
}
.pr-9 {
    padding-right: 6rem !important;
}
.pb-9 {
    padding-bottom: !important;
}
.pl-9 {
    padding-left: 6rem !important;
}
.p-10 {
    padding: 7rem 7rem !important;
}
.px-10 {
    padding-left: 7rem !important;
    padding-right: 7rem !important;
}
.py-10 {
    padding-top: 7rem !important;
    padding-bottom: 7rem !important;
}
.pt-10 {
    padding-top: 7rem !important;
}
.pr-10 {
    padding-right: 7rem !important;
}
.pb-10 {
    padding-bottom: 7rem !important;
}
.pl-10 {
    padding-left: 7rem !important;
}
.p-0 {
    padding: 0 0 !important;
}
.px-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.py-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
.pt-0 {
    padding-top: 0 !important;
}
.pr-0 {
    padding-right: 0 !important;
}
.pb-0 {
    padding-bottom: 0 !important;
}
.pl-0 {
    padding-left: 0 !important;
}
.p-xs {
    padding: 0.25rem 0.25rem !important;
}
.px-xs {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
}
.py-xs {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
}
.pt-xs {
    padding-top: 0.25rem !important;
}
.pr-xs {
    padding-right: 0.25rem !important;
}
.pb-xs {
    padding-bottom: 0.25rem !important;
}
.pl-xs {
    padding-left: 0.25rem !important;
}
.p-sm {
    padding: 0.5rem 0.5rem !important;
}
.px-sm {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
}
.py-sm {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
}
.pt-sm {
    padding-top: 0.5rem !important;
}
.pr-sm {
    padding-right: 0.5rem !important;
}
.pb-sm {
    padding-bottom: 0.5rem !important;
}
.pl-sm {
    padding-left: 0.5rem !important;
}
.p-h {
    padding: 0.5rem 0.5rem !important;
}
.px-h {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
}
.py-h {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
}
.pt-h {
    padding-top: 0.5rem !important;
}
.pr-h {
    padding-right: 0.5rem !important;
}
.pb-h {
    padding-bottom: 0.5rem !important;
}
.pl-h {
    padding-left: 0.5rem !important;
}
.pl-auto {
    padding-left: auto !important;
}
.pr-auto {
    padding-right: auto !important;
}
.px-auto {
    padding-right: auto !important;
    padding-left: auto !important;
}
.p-auto {
    padding: auto !important;
}
.skew {
    transform: skew(-8deg, 0);
}
.line-divider {
    border: none;
    border-top: 1px solid var(--color-border-30);
    margin: 0;
}
@media (max-width: 450px) {
    .smartphone-hide {
        display: none !important;
    }
}
.p-relative {
    position: relative !important;
}
.p-absolute {
    position: absolute;
}
.d-flex {
    display: flex !important;
}
.flex-column {
    flex-direction: column !important;
}
.flex-grow-0 {
    flex-grow: 0 !important;
}
.flex-grow-1 {
    flex-grow: 1 !important;
}
.flex-shrink-0 {
    flex-shrink: 0 !important;
}
.flex-shrink-1 {
    flex-shrink: 1 !important;
}
.flex-wrap {
    flex-wrap: wrap !important;
}
.align-self-start {
    align-self: flex-start !important;
}
.align-self-center {
    align-self: center !important;
}
.align-self-end {
    align-self: flex-end !important;
}
.align-self-stretch {
    align-self: stretch !important;
}
.align-items-center {
    align-items: center !important;
}
.align-items-baseline {
    align-items: baseline !important;
}
.align-items-start {
    align-items: flex-start !important;
}
.align-items-stretch {
    align-items: stretch !important;
}
.align-items-end {
    align-items: flex-end !important;
}
.justify-start {
    justify-content: flex-start !important;
}
.justify-end {
    justify-content: flex-end !important;
}
.justify-between {
    justify-content: space-between !important;
}
.justify-center {
    justify-content: center !important;
}
.uppercase {
    text-transform: uppercase;
}
.capitalize {
    text-transform: capitalize;
}
.gap-xs {
    gap: 0.25rem !important;
}
.gap-sm {
    gap: 0.5rem !important;
}
.gap-md {
    gap: 1rem !important;
}
.gap-lg {
    gap: 1.5rem !important;
}
.gap-xl {
    gap: 2rem !important;
}
.gap-xxl {
    gap: 3rem !important;
}
.truncate {
    overflow: hidden;
    display: -webkit-box;
}
.truncate-after {
    position: relative;
    -webkit-box-orient: vertical;
}
.truncate-after.lines-1 {
    -webkit-line-clamp: 1;
    max-height: 2em;
}
.truncate-after.lines-2 {
    -webkit-line-clamp: 2;
    max-height: 3em;
}
.truncate-after.lines-3 {
    -webkit-line-clamp: 3;
    max-height: 4em;
}
.truncate-after.lines-4 {
    -webkit-line-clamp: 4;
    max-height: 5em;
}
.truncate-after.lines-5 {
    -webkit-line-clamp: 5;
    max-height: 6em;
}
.truncate-after.lines-6 {
    -webkit-line-clamp: 6;
    max-height: 7em;
}
.truncate-after.lines-7 {
    -webkit-line-clamp: 7;
    max-height: 8em;
}
.truncate-after.lines-8 {
    -webkit-line-clamp: 8;
    max-height: 9em;
}
.truncate-after.lines-9 {
    -webkit-line-clamp: 9;
    max-height: 10em;
}
.truncate-after.lines-10 {
    -webkit-line-clamp: 10;
    max-height: 11em;
}
.truncate-after.lines-11 {
    -webkit-line-clamp: 11;
    max-height: 12em;
}
.truncate-after.lines-12 {
    -webkit-line-clamp: 12;
    max-height: 13em;
}
.truncate-after.lines-13 {
    -webkit-line-clamp: 13;
    max-height: 14em;
}
.truncate-after.lines-14 {
    -webkit-line-clamp: 14;
    max-height: 15em;
}
.selo {
    width: 44px;
    height: 44px;
    clip-path: path(
        evenodd,
        "M44 0H0V44H44V0ZM17.5628 16.4693C17.5628 16.4693 19.6769 15.2942 21.1367 14.7301C22.3951 14.2131 24.6602 13.602 24.6602 13.602C24.9119 13.508 25.0629 13.273 24.9119 13.0379L22.7978 9.46554C22.3448 8.80747 21.6904 8.85448 21.2877 9.55956L17.3615 16.3283C17.2105 16.5163 17.3112 16.6103 17.5628 16.4693ZM27.8316 18.0205L28.2343 18.7256C28.3349 18.9606 28.2342 19.1486 27.9322 19.1956C27.9322 19.1956 23.5027 19.9007 21.0865 20.4648C21.0865 20.5118 21.0362 20.5118 20.9859 20.5118C18.8214 21.0288 16.7576 21.6869 14.8952 22.439C14.3415 22.627 13.8381 22.862 13.8381 22.862C13.5865 22.9561 13.4858 22.862 13.6368 22.627L15.5496 19.4307C15.7006 19.2426 16.0026 18.9136 16.2039 18.7256C16.2039 18.7256 16.9086 18.2085 17.714 17.6915C19.1738 16.7514 22.1939 15.4822 25.2644 14.6361C25.5161 14.5421 25.8181 14.6361 25.9691 14.8711L27.8316 18.0205ZM31.2542 24.8363C31.5562 24.8363 31.6569 24.6012 31.5059 24.3662L29.2408 20.5118C29.0898 20.2767 28.7878 20.1357 28.4857 20.1827L24.0058 20.8878C23.7541 20.9348 23.6031 21.1698 23.7541 21.4049L25.7676 24.8833C25.9186 25.1183 26.2206 25.3063 26.5226 25.2593L31.2542 24.8363ZM16.1536 23.1441C13.9388 23.9432 12.8817 24.5072 12.8817 24.5072C12.63 24.6482 12.328 24.9303 12.177 25.1653L10.5159 28.0326C10.3649 28.2677 10.4656 28.4087 10.7676 28.3147C10.7676 28.3147 11.4723 28.1266 12.1267 27.9386C13.7374 27.5156 16.7073 26.8105 16.7073 26.8105C16.9589 26.7635 17.3113 26.5285 17.4623 26.2934L19.8281 22.298C19.9791 22.063 19.8784 21.9219 19.5764 22.016C19.5261 22.016 17.865 22.533 16.1536 23.1441ZM32.6134 26.2464L35.0295 30.3829C35.3819 31.0879 34.9792 31.652 34.1235 31.605H10.0125C9.15681 31.605 8.80446 31.0879 9.10648 30.3359C9.15681 30.2418 9.15681 30.1948 9.15681 30.1948C9.43532 29.8047 9.62821 29.7344 9.85391 29.6521C9.87283 29.6452 9.8924 29.638 9.91185 29.6308C9.91185 29.6308 11.2709 29.2077 12.4287 28.8787C16.3045 27.7976 22.8482 26.3874 31.808 25.8233H32.0094C32.2107 25.8233 32.4624 26.0114 32.6134 26.2464Z"
    );
    backdrop-filter: blur(16px);
    background-color: rgba(30, 30, 40, 0.2);
    border-radius: 8px;
}
.bg-blur-sm {
    backdrop-filter: blur(16px);
}
.bg-blur-md {
    backdrop-filter: blur(24px);
}
.bg-blur-lg {
    backdrop-filter: blur(32px);
}
.btn-switch {
    display: flex;
    gap: 0.5rem;
    margin: 2rem 0;
    justify-content: center;
}
.btn-switch input {
    display: none;
}
.btn-switch input:checked + label {
    opacity: 1;
    background-color: var(--color-primary-default);
    color: var(--color-white);
    border-color: var(--color-primary-default);
}
.btn-switch label {
    border-radius: 0.5rem;
    border: 1px solid var(--color-white);
    color: var(--color-white);
    font-weight: 600;
    padding: 0.5rem 1rem;
    opacity: 0.5;
    transition: 0.3s;
    cursor: pointer;
}
.columns-2 {
    columns: 2;
    column-gap: 0.5rem;
}
@media (max-width: 450px) {
    .columns-2 {
        columns: 1;
    }
}
.opacity-0 {
    opacity: 0;
}
.opacity-10 {
    opacity: 0.1;
}
.opacity-20 {
    opacity: 0.2;
}
.opacity-30 {
    opacity: 0.3;
}
.opacity-40 {
    opacity: 0.4;
}
.opacity-50 {
    opacity: 0.5;
}
.opacity-60 {
    opacity: 0.6;
}
.opacity-70 {
    opacity: 0.7;
}
.opacity-80 {
    opacity: 0.8;
}
.opacity-90 {
    opacity: 0.9;
}
.opacity-100 {
    opacity: 1;
}
.bg-color-primary-default {
    --color-primary-default: hsla(
        var(--primary-color-h),
        var(--primary-color-s),
        var(--primary-color-l),
        var(--alpha)
    );
    background-color: var(--color-primary-default) !important;
}
.bg-color-primary-contrast {
    --color-primary-contrast: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken)),
        var(--alpha)
    );
    background-color: var(--color-primary-contrast) !important;
}
.bg-color-primary-high-contrast {
    --color-primary-high-contrast: hsla(
        calc(var(--primary-color-h) - var(--contrast)),
        calc(var(--primary-color-s) + var(--vibrance)),
        calc(var(--primary-color-l) - var(--darken-h)),
        var(--alpha)
    );
    background-color: var(--color-primary-high-contrast) !important;
}
.bg-color-cerise {
    --color-cerise: hsla(
        var(--cerise-h),
        var(--cerise-s),
        var(--cerise-l),
        var(--alpha)
    );
    background-color: var(--color-cerise) !important;
}
.bg-color-blue {
    background-color: var(--color-blue) !important;
}
.bg-color-alternate {
    background-color: var(--color-alternate) !important;
}
.bg-color-purple {
    --color-purple: hsla(
        var(--purple-h),
        var(--purple-s),
        var(--purple-l),
        var(--alpha)
    );
    background-color: var(--color-purple) !important;
}
.bg-color-blue-dark {
    --color-blue-dark: hsla(
        var(--blue-dark-h),
        var(--blue-dark-s),
        var(--blue-dark-l),
        var(--alpha)
    );
    background-color: var(--color-blue-dark) !important;
}
.bg-color-gray-light {
    --color-gray-light: hsla(
        var(--gray-light-h),
        var(--gray-light-s),
        var(--gray-light-l),
        var(--alpha)
    );
    background-color: var(--color-gray-light) !important;
}
.bg-color-gray-medium {
    --color-gray-medium: hsla(
        var(--gray-medium-h),
        var(--gray-medium-s),
        var(--gray-medium-l),
        var(--alpha)
    );
    background-color: var(--color-gray-medium) !important;
}
.bg-color-accent-soft {
    --color-accent: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) - var(--vibrance)),
        calc(var(--accent-l) + var(--darken)),
        var(--alpha)
    );
    background-color: var(--color-accent-soft) !important;
}
.bg-color-accent-default {
    --color-accent: hsla(
        var(--accent-h),
        var(--accent-s),
        var(--accent-l),
        var(--alpha)
    );
    background-color: var(--color-accent-default) !important;
}
.bg-color-accent-contrast {
    --color-accent: hsla(
        calc(var(--accent-h) - var(--contrast)),
        calc(var(--accent-s) + var(--vibrance)),
        calc(var(--accent-l) - var(--darken)),
        var(--alpha)
    );
    background-color: var(--color-accent-contrast) !important;
}
.bg-color-lfg-first {
    background-color: var(--color-lfg-first) !important;
}
.bg-color-lfg-second {
    background-color: var(--color-lfg-second) !important;
}
.bg-color-lfg-third {
    background-color: var(--color-lfg-third) !important;
}
.bg-color-aedu-play {
    background-color: var(--color-aedu-play) !important;
}
.bg-color-semantic-danger {
    --color-semantic-danger: hsla(
        var(--semantic-danger-h),
        var(--semantic-danger-s),
        var(--semantic-danger-l),
        var(--alpha)
    );
    background-color: var(--color-semantic-danger) !important;
}
.bg-color-semantic-info {
    --color-semantic-info: hsla(
        var(--semantic-info-h),
        var(--semantic-info-s),
        var(--semantic-info-l),
        var(--alpha)
    );
    background-color: var(--color-semantic-info) !important;
}
.bg-color-semantic-success {
    --color-semantic-success: hsla(
        var(--semantic-success-h),
        var(--semantic-success-s),
        var(--semantic-success-l),
        var(--alpha)
    );
    background-color: var(--color-semantic-success) !important;
}
.bg-color-semantic-warning {
    --color-warning-danger: hsla(
        var(--semantic-warning-h),
        var(--semantic-warning-s),
        var(--semantic-warning-l),
        var(--alpha)
    );
    background-color: var(--color-semantic-warning) !important;
}
.bg-color-white {
    --color-white: hsla(
        var(--white-h),
        var(--white-s),
        var(--white-l),
        var(--alpha)
    );
    background-color: var(--color-white) !important;
}
.crop {
    overflow: hidden;
}
[src*="cea1ce73-6626-4524-a7e8-1e26cec268ca"] {
    opacity: 0;
}
.text-ribbon {
    --space: 0.5rem;
    display: flex;
    gap: var(--space);
    align-items: center;
    font-family: var(--font-heading);
    text-transform: uppercase;
    font-size: clamp(1rem, 1.5vw, 1.375rem);
    font-weight: 633;
    font-variation-settings: "wdth" 66;
    line-height: 0.95;
    letter-spacing: 0.01em;
    white-space: nowrap;
}
.text-ribbon span {
    transform: skew(-8deg);
    color: var(--color);
}
.text-ribbon span:not(:last-child)::after {
    content: "•";
    display: inline-block;
    padding-left: var(--space);
    color: var(--color-white);
}
.text-ribbon span:nth-child(1) {
    --color: var(--color-primary-default);
}
.text-ribbon span:nth-child(2) {
    --color: var(--color-accent-default);
}
.text-ribbon span:nth-child(3) {
    --color: var(--color-lfg-first);
}
.price-box {
    --bg: var(--color-lfg-third);
    --bg-head: var(--color-purple);
    --text-color: var(--color-white);
    --border: var(--color-accent-default);
    --text-border: var(--color-purple);
    display: inline-flex;
    align-self: flex-start;
    flex-direction: column;
    font-family: var(--font-heading);
    color: var(--text-color);
    text-transform: uppercase;
    font-size: clamp(1.1rem, 2vw, 1.5rem);
    isolation: isolate;
    filter: drop-shadow(0.1em 0.45em 0.25em rgba(0, 0, 0, 0.25));
}
.price-box-head {
    border-radius: 0.75em 0.75em 0 0;
    line-height: 0.9;
    background-color: var(--bg-head);
    border-bottom: 1px solid var(--border);
    border-left: 1px solid var(--border);
    border-top: 1px solid var(--border);
    border-right: 4px solid var(--border);
    font-variation-settings: "wdth" 66, "wght" 700;
    padding: 0.2em 0.3rem;
    font-size: 1em;
    text-align: center;
    z-index: 1;
}
.price-box-head span {
    font-size: 1.1em;
    border-radius: 50%;
    margin: -0.45em 0;
    aspect-ratio: 1/1;
    width: 1.8em;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: var(--bg);
    border: 1px solid var(--border);
    box-shadow: 2px 2px 0 var(--border);
}
.price-box-value {
    font-size: 4.5em;
    font-variation-settings: "wdth" 66, "wght" 800;
    border-radius: 0 0 1rem 2.5rem;
    background-color: var(--bg);
    border-left: 1px solid var(--border);
    border-right: 4px solid var(--border);
    border-bottom: 4px solid var(--border);
    display: flex;
    align-items: start;
    line-height: 0.65;
    padding: 0.15em 0.15em;
    gap: 0.025em;
    text-shadow: 1px 1px 0px var(--bg), 2px 2px 0.25rem rgba(0, 0, 0, 0.45);
}
.price-box-value span {
    font-size: 0.3em;
}
.price-box-value em {
    position: relative;
    font-style: normal;
    font-size: 0.4em;
}
.price-box-value em:after {
    content: "";
    position: absolute;
    display: block;
    width: calc(100% - 0.25em);
    height: 0.15em;
    background-color: currentColor;
    bottom: -0.3em;
    right: 0;
}
.section-divider {
    --color: var(--color-white);
    width: 100%;
    z-index: 2;
}
.section-divider svg {
    display: block;
    width: 100%;
    height: auto !important;
}
.section-divider.absolute {
    position: absolute;
}
.section-divider.top {
    top: -1px;
    scale: 1 -1;
    transform-origin: center;
}
.section-divider.bottom {
    bottom: -1px;
    transform-origin: bottom center;
}
.section-divider.lg {
    scale: 1 2;
}
.section-divider.xl {
    scale: 1 3;
}
.new-slider {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    user-select: none;
    max-width: 100%;
    scrollbar-width: none;
}
.new-slider::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
}
@media (hover: hover) {
    .new-slider {
        scroll-snap-type: x proximity;
        cursor: grab;
    }
}
.new-slider-v {
    overflow-y: auto;
    scroll-snap-type: y proximity;
    user-select: none;
}
.new-slider-v::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
}
@media (hover: hover) {
    .new-slider-v {
        scroll-snap-type: y proximity;
        cursor: grab;
    }
}
.cards-carousel .cards-wrapper {
    display: flex;
    gap: 1rem;
    padding: 2rem;
    width: 100%;
}
.cards-carousel .cards-wrapper:before,
.cards-carousel .cards-wrapper:after {
    content: "";
    flex-grow: 1;
    flex-shrink: 1;
}
.cards-carousel .cards-wrapper:after {
    order: 99;
}
.cards-carousel .cards-wrapper .card {
    animation: fadeIn 0.5s forwards;
    opacity: 0;
    translate: 20px 0;
    scroll-snap-align: center;
}
.cards-carousel .cards-wrapper .card:nth-child(1) {
    animation-delay: 0;
}
.cards-carousel .cards-wrapper .card:nth-child(2) {
    animation-delay: 0.2s;
}
.cards-carousel .cards-wrapper .card:nth-child(3) {
    animation-delay: 0.4s;
}
.cards-carousel .cards-wrapper .card:nth-child(4) {
    animation-delay: 0.6s;
}
.cards-carousel .cards-wrapper .card:nth-child(5) {
    animation-delay: 0.8s;
}
.cards-carousel .cards-wrapper .card:nth-child(6) {
    animation-delay: 1s;
}
.cards-carousel .cards-wrapper .card:nth-child(7) {
    animation-delay: 1.2s;
}
.cards-carousel .cards-wrapper .card:nth-child(8) {
    animation-delay: 1.4s;
}
.cards-carousel .cards-wrapper .card:nth-child(9) {
    animation-delay: 1.6s;
}
.cards-carousel .cards-wrapper .card:nth-child(10) {
    animation-delay: 1.8s;
}
.cards-carousel .cards-wrapper .card:nth-child(11) {
    animation-delay: 2s;
}
@media (hover: hover) {
    .cards-carousel .cards-wrapper .card {
        scroll-snap-align: none;
    }
}
.cards-carousel .cards-wrapper .card.loader {
    display: none;
    align-items: center;
    justify-content: center;
}
.cards-carousel .cards-wrapper .card.loader:before {
    --alpha: 50%;
    content: "";
    width: 40px;
    height: 40px;
    position: absolute;
    border: 2px solid var(--loader-color, var(--color-white));
    border-top-color: rgba(0, 0, 0, 0);
    border-bottom-color: rgba(0, 0, 0, 0);
    border-radius: 50%;
    animation: loader 2s ease-in-out infinite;
}
.cards-carousel .cards-wrapper .card.loader:after {
    --alpha: 50%;
    content: "";
    width: 20px;
    height: 20px;
    position: absolute;
    border: 2px solid var(--loader-color, var(--color-white));
    border-top-color: rgba(0, 0, 0, 0);
    border-bottom-color: rgba(0, 0, 0, 0);
    border-radius: 50%;
    animation: loaderInvert 2s ease-in-out infinite;
}
.cards-carousel .cards-wrapper.loading .card.loader {
    display: flex !important;
}
@keyframes loader {
    to {
        rotate: 2turn;
    }
}
@keyframes loaderInvert {
    to {
        rotate: -2turn;
    }
}
@keyframes fadeIn {
    to {
        opacity: 1;
        translate: 0;
    }
}
.flt-elm {
    position: absolute;
    left: var(--left, unset);
    right: var(--right, unset);
    translate: var(--tx, 0) var(--ty, 0);
    background-color: var(--color, var(--color-claret));
    mask: var(--img);
    -webkit-mask: var(--img);
}
.flt-elm::after {
    content: var(--img);
    visibility: hidden;
}
.flt-elm.to-top {
    z-index: 2;
}
.flt-elm.to-back {
    z-index: -1;
}
[class*="anim-arrow"] {
    left: var(--left, unset);
    right: var(--right, unset);
    --color: var(--color-alternate);
    position: absolute;
    z-index: 1;
    width: 66px;
    height: 70px;
}
[class*="anim-arrow"] svg {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: drop-shadow(0.125rem 0.25rem 0.35rem rgba(0, 0, 0, 0.3));
}
[class*="arrow-down"] {
    top: -120px;
    animation: arrow-down 5s linear infinite;
}
@keyframes arrow-down {
    to {
        top: calc(100% + 80px);
    }
}
.dialog {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(34, 34, 37, 0.85) !important;
    backdrop-filter: blur(12px);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.3s;
    opacity: 0;
    visibility: hidden;
    z-index: 100;
}
.dialog-content {
    display: flex;
    flex-direction: column;
    transform: translateY(-20px);
    transition: opacity 0.3s;
    border-radius: 6px;
    background-color: var(--color-bg-color-contrast);
    position: relative;
    min-width: 280px;
    max-height: min(80vh, 700px);
    width: 100%;
    margin: 1rem;
    box-shadow: 0 16px 32px -8px rgba(0, 0, 0, 0.5);
}
@media (max-width: 450px) {
    .dialog-content {
        max-height: 100svh;
        max-height: -webkit-fill-available;
        margin: 0;
        border-radius: 0;
    }
}
.dialog-content-header {
    flex-grow: 0;
    flex-shrink: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 2rem 3rem 1.5rem 2rem;
    z-index: 90;
    position: relative;
    flex-shrink: 0;
    font-family: var(--font-body);
    color: var(--color-primary-default);
    min-height: 5rem;
}
.dialog-content-header-title {
    margin: 0;
    line-height: 1;
    color: var(--color-bg-color-contrast) !important;
    font-weight: 600 !important;
}
.dialog-content-header .close {
    font-size: 1.125rem;
    position: absolute;
    right: 1rem;
    top: 1rem;
    background-color: var(--color-bg-color-contrast);
    width: 24px;
    height: 24px;
    border-radius: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    position: absolute;
    color: var(--color-text-light);
}
.dialog-content-header .close i {
    font-size: 22px;
}
.dialog-content-body {
    padding: 0 2rem;
    flex-grow: 1;
}
.dialog-content-footer {
    padding: 1.5rem 2rem;
    flex-grow: 0;
    flex-shrink: 0;
    display: flex;
    justify-content: space-between;
}
.dialog-content.sm {
    max-width: 390px;
}
.dialog-content.md {
    max-width: 580px;
}
.dialog-content.lg {
    max-width: 780px;
}
.dialog-content h3 {
    color: var(--color-text-default);
}
.dialog-content.no-footer .dialog-content-footer {
    display: none;
}
.dialog-content.full-preview {
    max-width: unset;
    margin: -1rem;
    max-height: unset;
    border-radius: 0;
    box-shadow: none;
    height: 100vh;
    transition: 0.8s;
    transform: translateY(100%);
    display: flex;
    flex-direction: column;
}
.dialog-content.full-preview .dialog-content-header > * {
    flex-basis: 0;
    flex-grow: 1;
}
.dialog-content.full-preview .dialog-content-body {
    background-color: var(--color-bg-color-contrast);
    flex-grow: 1;
    padding: 0;
    height: 0;
}
.dialog-content.full-preview .dialog-content-footer {
    display: none;
}
.dialog.scrollable .dialog-content-header {
    padding: 1.5rem 3rem 1.5rem 1rem;
}
.dialog.scrollable .dialog-content-body {
    overflow-y: auto;
    padding: 1rem;
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: none;
    overscroll-behavior: none;
}
.dialog.scrollable .dialog-content-footer {
    padding: 1rem;
}
.dialog.active {
    opacity: 1;
    visibility: visible;
}
.dialog.active .dialog-content {
    transform: translateY(0);
}
.dialog.inscricao,
.dialog.full-dialog {
    display: flex;
    flex-direction: column;
}
.dialog.inscricao .close,
.dialog.full-dialog .close {
    position: absolute;
    top: -25px;
    right: 0;
    color: var(--color-text-light);
}
.dialog.inscricao .dialog-content-body,
.dialog.full-dialog .dialog-content-body {
    border-radius: 6px;
    overflow: hidden;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}
.dialog.inscricao .dialog-content-body iframe,
.dialog.full-dialog .dialog-content-body iframe {
    display: block;
    flex-grow: 1;
    height: 90svh;
}
.dialog .title-modal {
    color: var(--color-text-default);
    font-size: 1.6rem;
    text-transform: uppercase;
    font-weight: 600;
    margin-top: 1rem;
}
html {
    scroll-padding-top: 112px;
}
html *,
html * :before,
html *:after {
    box-sizing: border-box;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased !important;
    -moz-font-smoothing: antialiased !important;
    text-rendering: optimizelegibility !important;
}
body {
    overscroll-behavior-x: none;
    margin: 0;
    padding: 0;
    background-color: var(--color-bg-default);
    font-family: var(--font-body);
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
@media not all and (min-resolution: 0.001dpcm) {
    @supports (-webkit-appearance: none) {
        body::-webkit-scrollbar {
            width: 0.5rem !important;
        }
        body::-webkit-scrollbar-thumb {
            border: 2px solid rgba(0, 0, 0, 0);
        }
    }
}
section {
    scroll-snap-align: start;
    isolation: isolate;
}
::selection,
::-moz-selection {
    background-color: var(--color-primary-default);
    color: #fff;
}
.cookie {
    width: 100%;
    max-width: 340px;
    position: fixed;
    bottom: -100%;
    left: 1rem;
    z-index: 99999;
    background-color: var(--color-contrast);
    box-shadow: 0 1rem 2rem -0.5rem rgba(0, 0, 0, 0.6);
    border-radius: 16px;
    padding: 1rem;
    transition: all 0.3s ease;
}
.cookie.active {
    bottom: 1rem;
}
.cookie .cookie-body {
    position: relative;
}
.cookie .cookie-body svg {
    width: 40px;
    height: 40px;
    color: var(--color-primary-default);
    flex-shrink: 0;
}
.cookie .cookie-body p {
    display: block;
    gap: 0.5rem;
    font-size: 0.8125rem;
    font-family: var(--font-body);
    font-weight: 300;
    line-height: 1.5;
}
.cookie .cookie-body p a {
    color: var(--color-primary-default);
}
.cookie-footer {
    display: flex;
    justify-content: flex-end;
    padding-top: 1rem;
}
footer {
    padding: 1.5rem 1rem;
    border-top: 1px solid var(--White-10, rgba(255, 255, 255, 0.1));
    background: rgba(0, 0, 0, 0.5);
    font-size: 0.75rem;
}
@media screen and (min-width: 767px) {
    footer .docs {
        max-width: 350px;
        text-align: right;
    }
}
footer .docs .links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
}
@media screen and (min-width: 767px) {
    footer .docs .links {
        justify-content: flex-end;
    }
}
footer .docs .links a {
    color: currentColor;
    font-weight: 300;
}
