/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */
/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */
/* × × × × × × × × × × CODEXBLAU  GMBH × × × × × × × × × × */
/* × × × × × × × × × × CORE STYLESHEET × × × × × × × × × × */
/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */
/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */

/************************************************************

$name      => CODEXBLAU GmbH
$author    => Nick Helfenbein <nick@codexblau.de>
$version   => Version 2 (2.0)
$year      => 2026
$copyright => 2026. CODEXBLAU GmbH. All rights reseved.

************************************************************/

/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */
/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */
/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */
/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */
/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */
/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × */



/*

//// CI Definitions:

==== Fonts: ====
- Main: Clash Display
- Secondary: JetBrains Mono

==== Colors: ====
- Main Color: RED

*/


/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × × 
 × × × × × × × × × FONTS × × × × × × × × × × × × × × × × × ×
× × × × × × × × × × × × × × × × × × × × × × × × × × × × × */


/* Clash Display */

@font-face {
    font-family: 'Clash Display';
    src: url('../fonts/ClashDisplay-Extralight.woff2') format('woff2'),
        url('../fonts/ClashDisplay-Extralight.woff') format('woff'),
        url('../fonts/ClashDisplay-Extralight.ttf') format('truetype');
    font-weight: 200;
    font-display: swap;
    font-style: normal;
}

@font-face {
    font-family: 'Clash Display';
    src: url('../fonts/clash-display/ClashDisplay-Light.woff2') format('woff2'),
        url('../fonts/clash-display/ClashDisplay-Light.woff') format('woff'),
        url('../fonts/clash-display/ClashDisplay-Light.ttf') format('truetype');
    font-weight: 300;
    font-display: swap;
    font-style: normal;
}

@font-face {
    font-family: 'Clash Display';
    src: url('../fonts/clash-display/ClashDisplay-Regular.woff2') format('woff2'),
        url('../fonts/clash-display/ClashDisplay-Regular.woff') format('woff'),
        url('../fonts/clash-display/ClashDisplay-Regular.ttf') format('truetype');
    font-weight: 400;
    font-display: swap;
    font-style: normal;
}

@font-face {
    font-family: 'Clash Display';
    src: url('../fonts/clash-display/ClashDisplay-Medium.woff2') format('woff2'),
        url('../fonts/clash-display/ClashDisplay-Medium.woff') format('woff'),
        url('../fonts/clash-display/ClashDisplay-Medium.ttf') format('truetype');
    font-weight: 500;
    font-display: swap;
    font-style: normal;
}

@font-face {
    font-family: 'Clash Display';
    src: url('../fonts/clash-display/ClashDisplay-Bold.woff2') format('woff2'),
        url('../fonts/clash-display/ClashDisplay-Bold.woff') format('woff'),
        url('../fonts/clash-display/ClashDisplay-Bold.ttf') format('truetype');
    font-weight: 700;
    font-display: swap;
    font-style: normal;
}

@font-face {
    font-family: 'Clash Display';
    src: url('../fonts/clash-display/ClashDisplay-Variable.woff2') format('woff2'),
        url('../fonts/clash-display/ClashDisplay-Variable.woff') format('woff'),
        url('../fonts/clash-display/ClashDisplay-Variable.ttf') format('truetype');
    font-weight: 200 700;
    font-display: swap;
    font-style: normal;
}


/* JetBrains Mono */

@font-face {
    font-family: 'JetBrains Mono';
    src: url('../fonts/jetbrains-mono/JetBrainsMono-Regular.woff2') format('woff2'),
        url('../fonts/jetbrains-mono/JetBrainsMono-Regular.woff') format('woff'),
        url('../fonts/jetbrains-mono/JetBrainsMono-Regular.ttf') format('truetype');
    font-weight: 400;
    font-display: swap;
    font-style: normal;
}

@font-face {
    font-family: 'JetBrains Mono';
    src: url('../fonts/jetbrains-mono/JetBrainsMono-Medium.woff2') format('woff2'),
        url('../fonts/jetbrains-mono/JetBrainsMono-Medium.woff') format('woff'),
        url('../fonts/jetbrains-mono/JetBrainsMono-Medium.ttf') format('truetype');
    font-weight: 500;
    font-display: swap;
    font-style: normal;
}



/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × × 
 × × × × × × × × × VARIABLES × × × × × × × × × × × × × × × × 
× × × × × × × × × × × × × × × × × × × × × × × × × × × × × */

[data-theme-codex="light"],
:root {

    /* × × × //// Colors //// × × × */

    --color-primary-rgb: 255, 0, 0;
    --color-primary: rgba(var(--color-primary-rgb), 1);

    --color-primary-dark-rgb: 100, 0, 0;
    --color-primary-dark: rgba(var(--color-primary-dark-rgb), 1);

    --color-secondary-rgb: 210, 0, 0;
    --color-secondary: rgba(var(--color-secondary-rgb), 1);

    --color-secondary-dark-rgb: 75, 0, 0;
    --color-secondary-dark: rgba(var(--color-secondary-dark-rgb), 1);



    /* Natrual */
    --color-natural-100-rgb: 255, 255, 255;
    --color-natural-100: rgba(var(--color-natural-100-rgb), 1);

    --color-natural-200-rgb: 240, 240, 240;
    --color-natural-200: rgba(var(--color-natural-200-rgb), 1);

    --color-natural-300-rgb: 225, 225, 225;
    --color-natural-300: rgba(var(--color-natural-300-rgb), 1);

    --color-natural-400-rgb: 200, 200, 200;
    --color-natural-400: rgba(var(--color-natural-400-rgb), 1);

    --color-natural-500-rgb: 160, 160, 160;
    --color-natural-500: rgba(var(--color-natural-500-rgb), 1);

    --color-natural-600-rgb: 120, 120, 120;
    --color-natural-600: rgba(var(--color-natural-600-rgb), 1);

    --color-natural-700-rgb: 90, 90, 90;
    --color-natural-700: rgba(var(--color-natural-700-rgb), 1);

    --color-natural-800-rgb: 60, 60, 60;
    --color-natural-800: rgba(var(--color-natural-800-rgb), 1);

    --color-natural-900-rgb: 30, 30, 30;
    --color-natural-900: rgba(var(--color-natural-900-rgb), 1);

    --color-natural-1000-rgb: 0, 0, 0;
    --color-natural-1000: rgba(var(--color-natural-1000-rgb), 1);


    --color-success-rgb: 40, 180, 60;
    --color-success: rgba(var(--color-success-rgb), 1);

    --color-success-light-rgb: 185, 225, 190;
    --color-success-light: rgba(var(--color-success-light-rgb), 1);

    --color-error-rgb: 220, 50, 50;
    --color-error: rgba(var(--color-error-rgb), 1);

    --color-error-light-rgb: 230, 180, 180;
    --color-error-light: rgba(var(--color-error-light-rgb), 1);


    /* Shortcuts */
    --color-text: var(--color-natural-800);
    --color-black: var(--color-natural-1000);
    --color-white: var(--color-natural-100);
    --color-background: var(--color-white);
    --color-navigation: var(--color-white);
    --color-selection: var(--color-white);


    /* × × × //// Scaling Core //// × × × */

    --size-unit: 16;
    --size-container-ideal: 1520;
    --size-container-min: 992px;
    --size-container-max: 1920px;
    --size-container: clamp(var(--size-container-min), 100vw, var(--size-container-max));
    --size-font: calc(var(--size-container) / (var(--size-container-ideal) / var(--size-unit)));

    --size-container-normal-min: 992px;
    --size-container-normal-max: 1280px;
    --size-container-normal: clamp(var(--size-container-normal-min), 100vw, var(--size-container-normal-max));

    --size-container-medium-min: 768px;
    --size-container-medium-max: 991px;
    --size-container-medium: clamp(var(--size-container-medium-min), 100vw, var(--size-container-medium-max));

    --size-container-small-min: 480px;
    --size-container-small-max: 767px;
    --size-container-small: clamp(var(--size-container-small-min), 100vw, var(--size-container-small-max));

    --padding-container: calc(var(--size-container) / (var(--size-container-ideal) / var(--size-unit)));

    --size-dynamic: clamp(1em, calc(var(--size-container) / (var(--size-container-ideal) / var(--size-unit))), 4em);

    --padding-section: calc(var(--size-dynamic) * 7.5);
    --padding-section-small: calc(var(--size-dynamic) * 6);

    --gap: calc(var(--size-dynamic) * 1);
    --row-gap: calc(var(--size-dynamic) * 1);
    --col-gap: calc(var(--size-dynamic) * 1);

    /* × × × //// Font Settings //// × × × */

    --font-sans: 'Clash Display', sans-serif;
    --font-mono: 'JetBrains Mono', monospace;
    --font-input: var(--font-sans);

    --font-size-h1: 6em;
    --font-size-h2: 4.5em;
    --font-size-h3: 3.75em;
    --font-size-h4: 3.25em;
    --font-size-h5: 2.5em;
    --font-size-h6: 2em;

    --font-size-large: 1.75em;
    --font-size-medium: 1.5em;
    --font-size-p: 1.25em;
    --font-size-small: 1em;

    --line-height-main: 1.25;


    /* × × × //// Viewportheight //// × × × */

    --vh-in-px: 8px;
    --vh: var(--vh-in-px);


    /* × × × //// Animations //// × × × */

    /* Timing-Function */
    --ease-standard: cubic-bezier(0.625, 0.05, 0, 1);

    /* Durations */
    --time-longest: 1.2s;
    --time-long: 0.9s;
    --time-default: 0.6s;
    --time-short: 0.3s;
    --time-shortest: 0.15s;

    /* Animations */
    --animation-longest: var(--time-longest) var(--ease-standard);
    --animation-long: var(--time-long) var(--ease-standard);
    --animation-default: var(--time-default) var(--ease-standard);
    --animation-short: var(--time-short) var(--ease-standard);
    --animation-shortest: var(--time-shortest) var(--ease-standard);

    /* Ease-Only */
    --animation-ease-basic: 0.2s ease;
    --animation-ease-basic-long: 0.4s ease;
}

[data-theme-codex="blue"] {

    /* Natrual */
    --color-natural-100: rgba(var(--color-natural-1000-rgb), 1);
    --color-natural-200: rgba(var(--color-natural-900-rgb), 1);
    --color-natural-300: rgba(var(--color-natural-800-rgb), 1);
    --color-natural-400: rgba(var(--color-natural-700-rgb), 1);
    --color-natural-500: rgba(var(--color-natural-600-rgb), 1);
    --color-natural-600: rgba(var(--color-natural-500-rgb), 1);
    --color-natural-700: rgba(var(--color-natural-400-rgb), 1);
    --color-natural-800: rgba(var(--color-natural-300-rgb), 1);
    --color-natural-900: rgba(var(--color-natural-200-rgb), 1);
    --color-natural-1000: rgba(var(--color-natural-100-rgb), 1);

    /* Shortcuts */
    --color-text: var(--color-natural-800);
    --color-black: var(--color-natural-1000);
    --color-white: var(--color-natural-100);
    --color-background: var(--color-black);
    --color-navigation: var(--color-black);
    --color-selection: var(--color-black);
}

@media screen and (max-width: 991px) {
    :root {
        --size-container-ideal: 834;
        --size-container-min: 768px;
        --size-container-max: 991px;
    }
}

@media screen and (max-width: 767px) {
    :root {
        --size-container-ideal: 550;
        --size-container-min: 480px;
        --size-container-max: 767px;
    }
}

@media screen and (max-width: 479px) {
    :root {
        --size-container-ideal: 390;
        --size-container-min: 320px;
        --size-container-max: 479px;
    }
}

@media (hover: hover) {

    :root {
        --vh: 1vh;
    }

    @supports (height: 1svh) {
        :root {
            --vh: 1svh;
        }
    }
}


/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × × 
 × × × × × × × × × RESET × × × × × × × × × × × × × × × × × ×
× × × × × × × × × × × × × × × × × × × × × × × × × × × × × */

/* LENIS - Start */

html.lenis {
    height: auto;
}

.lenis.lenis-smooth {
    scroll-behavior: auto;
}

.lenis.lenis-smooth [data-lenis-prevent] {
    overscroll-behavior: contain;
}

.lenis.lenis-stopped {
    overflow: hidden;
}

.lenis.lenis-scrolling iframe {
    pointer-events: none;
}

/* Hide scrollbar for Chrome, Safari and Opera */
[data-lenis-prevent]::-webkit-scrollbar,
.no-scrollbar::-webkit-scrollbar {
    display: none;
}

/* Hide scrollbar for IE, Edge and Firefox */
[data-lenis-prevent],
.no-scrollbar {
    -ms-overflow-style: none;
    /* IE and Edge */
    scrollbar-width: none;
    /* Firefox */
}

/* LENIS - End */


*,
*:before,
*::before,
*:after,
*::after {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
}

html {
    scroll-behavior: initial;
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    margin: 0;
    padding: 0;
    scrollbar-width: none;
}

body {
    -webkit-font-smoothing: antialiased;
    font-family: var(--font-sans);
    line-height: var(--line-height-main);
    font-weight: 400;
    font-style: normal;
    font-size: var(--size-font);
    background-color: var(--color-background);
    margin: 0;
    padding: 0;
}

body::-webkit-scrollbar {
    display: none;
}

html,
body {
    width: 100%;
    height: auto;
    position: relative;
}

::selection {
    background-color: var(--color-primary);
    color: var(--color-selection);
    text-shadow: none;
}

::-moz-selection {
    background-color: var(--color-primary);
    color: var(--color-selection);
    text-shadow: none;
}

main {
    width: 100vw;
    box-sizing: border-box;
    background: var(--color-black);
}

.main-clip-window {
    position: relative;
    width: 100vw;
    overflow: visible;
    pointer-events: all;
    background: var(--color-black);
}

.main-clip-window.is-frozen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    pointer-events: none;
}

[data-navigation-status="active"] main {
    overflow: hidden;
}

.site-wrap {
    will-change: transform;
    box-sizing: border-box;
    background: var(--color-black);
}


/* General */
canvas,
img,
video,
picture,
figure {
    max-width: 100%;
    height: auto;
    box-sizing: border-box;
    display: block;
}

svg {
    max-width: none;
    height: auto;
    box-sizing: border-box;
}

audio,
canvas,
iframe,
img,
svg,
video,
picture,
figure {
    vertical-align: middle;
}


/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × × 
 × × × × × × × × × TYPOGRAPHY  × × × × × × × × × × × × × × ×
× × × × × × × × × × × × × × × × × × × × × × × × × × × × × */

li,
ol,
ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

h1,
.h1,
.text-h1 {
    font-size: var(--font-size-h1);
    margin: 0;
    padding: 0;
}

h2,
.h2,
.text-h2 {
    font-size: var(--font-size-h2);
    margin: 0;
    padding: 0;
}

h3,
.h3,
.text-h3 {
    font-size: var(--font-size-h3);
    margin: 0;
    padding: 0;
}

h4,
.h4,
.text-h4 {
    font-size: var(--font-size-h4);
    margin: 0;
    padding: 0;
}

h5,
.h5,
.text-h5 {
    font-size: var(--font-size-h5);
    margin: 0;
    padding: 0;
}

h6,
.h6,
.text-h6 {
    font-size: var(--font-size-h6);
    margin: 0;
    padding: 0;
}


p,
.p,
.text-normal {
    font-size: var(--font-size-p);
    margin: 0;
    padding: 0;
}

.text-large {
    font-size: var(--font-size-large);
}

.text-medium {
    font-size: var(--font-size-medium);
}

.text-small {
    font-size: var(--font-size-small);
}


.text-marked {
    position: relative;
    padding: .4em .5em;
    background: var(--color-primary);
    color: var(--color-white);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    width: max-content;
    display: inline;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

.text-marked.text-marked-white {
    background: var(--color-white);
    color: var(--color-black);
}

.text-marked.text-marked-red {
    background: var(--color-error);
    color: var(--color-white);
}

.subheading {
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-primary);
    font-size: .95em;
}


/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × × 
 × × × × × × × × × LAYOUT  × × × × × × × × × × × × × × × × ×
× × × × × × × × × × × × × × × × × × × × × × × × × × × × × */

/* Section*/

.section {
    padding-block: var(--padding-section);
    position: relative;
    width: 100vw;
    overflow-y: visible;
    overflow-x: hidden;
    background: black !important;
}

.section.small {
    padding-block: var(--padding-section-small);
}

.section-wrap {
    position: relative;
}

.section.full-height {
    padding-top: 0;
    padding-bottom: 0;
}

.section.no-padding-top {
    padding-top: 0;
}

.section.no-padding-bottom {
    padding-bottom: 0;
}

.section.no-padding {
    padding-top: 0;
    padding-bottom: 0;
}


/* Container */

.container {
    position: relative;
    max-width: var(--size-container-normal);
    margin-inline: auto;
    padding-inline: var(--padding-container);
}

.container.large {
    max-width: var(--size-container);
}

.container.medium {
    max-width: var(--size-container-medium);
}

.container.small {
    max-width: var(--size-container-small);
}


/* Row/Col */

.row {
    display: flex;
    width: 100%;
    position: relative;
}

.col {
    display: flex;
    flex-direction: column;
    position: relative;
}

.row.grid {
    flex-wrap: wrap;
    gap: var(--row-gap) var(--grid-gap);
    --grid-gap: var(--col-gap);
    --columns: 3;
}

.row.grid>.col {
    width: calc((99.99% / var(--columns)) - (var(--grid-gap) * ((var(--columns) - 1) / var(--columns))));
}


/* Overlay */

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}


/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × × 
 × × × × × × × × × BUTTONS × × × × × × × × × × × × × × × × ×
× × × × × × × × × × × × × × × × × × × × × × × × × × × × × */

.btn {
    margin: 0;
    padding: 0;
    position: relative;
    display: flex;
    outline: 0;
    border: 0;
    z-index: 10;
}

.btn-wrap {
    cursor: pointer;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: calc(var(--gap) * .75);
    background: var(--color-natural-300);
    color: var(--color-black);
    border-radius: .25em;
    text-decoration: none;
    overflow: hidden;
    z-index: 1;
}

.btn-wrap:has(.btn-icon):has(.btn-text) {
    gap: var(--gap);
}

.btn-wrap::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 0;
    height: 100%;
    background: var(--color-natural-400);
    border-radius: .25em;
    transition: var(--animation-default);
    z-index: -1;
}

.btn-wrap:hover::before {
    width: 100%;
    left: 0;
}

.btn-text {
    position: relative;
    display: block;
    overflow: hidden;
}

.btn-text .btn-text-inner {
    position: relative;
    display: inline-block;
    transition: var(--animation-default);
}

.btn-text .btn-text-inner.duplicate {
    position: absolute;
    left: 0;
    top: 100%;
}

.btn-wrap:hover .btn-text-inner {
    transform: translateY(-100%);
}

.btn-icon {
    position: relative;
    width: 1em;
    height: 1em;
    display: flex;
    justify-content: center;
    align-items: center;
}

.btn-icon * {
    width: 1em;
    height: 1em;
}


/* TYPE: Menu */

[data-btn-type="menu"] .btn-icon .btn-bars {
    position: relative;
    width: 1em;
    height: 1.5px;
}

[data-btn-type="menu"] .btn-icon .btn-bars::before,
[data-btn-type="menu"] .btn-icon .btn-bars::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 1em;
    height: 1.5px;
    background: var(--color-black);
    transition: var(--animation-default);
}

[data-btn-type="menu"] .btn-icon .btn-bars::before {
    transform: translateY(-200%);
}

[data-btn-type="menu"] .btn-icon .btn-bars::after {
    transform: translateY(200%);
}

[data-navigation-status="active"] .btn-icon .btn-bars::before,
[data-navigation-status="active"] .btn-icon .btn-bars::after {
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
}

[data-navigation-status="active"] .btn-icon .btn-bars::before {
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
}

[data-navigation-status="active"] .btn-icon .btn-bars::after {
    transform: translateX(-50%) translateY(-50%) rotate(-45deg);
}


/* TYPE: Icon */

[data-btn-type="icon"] .btn-wrap {
    border-radius: 50%;
    background: var(--color-primary);
    color: var(--color-white);
}

[data-btn-type="icon"] .btn-wrap::before {
    border-radius: 50%;
    background: var(--color-primary-dark);
}


/* TYPE: Icon + Close */

[data-btn-type="icon+close"] .btn-wrap {
    border-radius: 50%;
    background: var(--color-natural-200);
    color: var(--color-black);
}

[data-btn-type="icon+close"] .btn-wrap::before {
    border-radius: 50%;
    background: var(--color-natural-300);
}


/* TYPE: Icon + Text */

[data-btn-type="icon+text"] .btn-wrap {
    background: var(--color-secondary);
    color: var(--color-white);
}

[data-btn-type="icon+text"] .btn-wrap::before {
    background: var(--color-secondary-dark);
}


/* TYPE: Red */

[data-btn-type="red"] .btn-wrap {
    color: var(--color-error);
}


/* TYPE: Green */

[data-btn-type="green"] .btn-wrap {
    color: var(--color-success);
}



/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × × 
 × × × × × × × × × LINKS × × × × × × × × × × × × × × × × × ×
× × × × × × × × × × × × × × × × × × × × × × × × × × × × × */

.link {
    margin: 0;
    padding: 0;
    position: relative;
    display: flex;
    outline: 0;
    border: 0;
    z-index: 10;
}

.link-wrap {
    cursor: pointer;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--color-black);
    text-decoration: none;
    overflow: hidden;
    z-index: 1;
}

.link-wrap:has(.link-icon):has(.link-text) {
    gap: var(--gap);
}

.link-wrap::before {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 0;
    height: 1px;
    background: var(--color-black);
    transition: var(--animation-default);
    z-index: -1;
}

.link-wrap:hover::before {
    width: 100%;
    left: 0;
}

.link-text {
    position: relative;
    display: block;
    overflow: hidden;
}

.link-text .link-text-inner {
    position: relative;
    display: inline-block;
    transition: var(--animation-default);
}

.link-text .link-text-inner.duplicate {
    position: absolute;
    left: 0;
    top: 100%;
}

.link-wrap:hover .link-text-inner {
    transform: translateY(-100%);
}

.link-icon {
    position: relative;
    width: 1em;
    height: 1em;
    display: flex;
    justify-content: center;
    align-items: center;
}

.link-icon * {
    width: 1em;
    height: 1em;
}


/* TYPE: Large */

[data-link-type="large"] .link-wrap {
    font-size: var(--font-size-large);
}


/* TYPE: Medium */

[data-link-type="medium"] .link-wrap {
    font-size: var(--font-size-medium);
}


/* TYPE: Small */

[data-link-type="small"] .link-wrap {
    font-size: var(--font-size-small);
}


/* TYPE: Mono */

[data-link-type="mono"] .link-wrap {
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-white);
}

[data-link-type="mono"] .link-wrap .link-icon {
    position: relative;
    width: .75em;
    height: .75em;
}

[data-link-type="mono"] .link-wrap .link-icon .arrow {
    position: absolute;
    bottom: 0;
    left: 0;
    width: .75em;
    height: .75em;
    display: block;
    transform: scale(0);
    transform-origin: bottom left;
    transition: var(--animation-default);
}

[data-link-type="mono"] .link-wrap:hover .link-icon .arrow {
    transform: scale(1);
}

[data-link-type="mono"] .link-wrap .link-icon .arrow::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 1em;
    height: .5px;
    background: var(--color-primary);
    transform: translate(-50%, -50%) rotate(-45deg);
}

[data-link-type="mono"] .link-wrap .link-icon .arrow::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: .5em;
    height: .5em;
    border-top: .5px solid var(--color-primary);
    border-right: .5px solid var(--color-primary);
}


/* TYPE: Icon */

[data-link-type="icon"] .link-wrap {
    transition: var(--animation-default);
}

[data-link-type="icon"] .link-wrap::before {
    display: none;
}

[data-link-type="icon"] .link-wrap:hover {
    opacity: .5;
}

[data-link-type="icon"] .link-wrap .link-icon,
[data-link-type="icon"] .link-wrap .link-icon svg {
    position: relative;
    width: 1.5em;
    height: 1.5em;
}

/* TYPE: Background */

[data-link-type="bg"] .link-wrap {
    padding: .25em 1em;
    border-radius: 1000em;
    background: var(--color-primary);
    color: var(--color-white);
    transition: var(--animation-default);
}

[data-link-type="bg"] .link-wrap::before {
    display: none;
}

/* TYPE: Navigation */

[data-link-type="navigation"] .link-wrap {
    padding: .85em 1.25em;
    border-radius: 1000em;
    background: rgba(var(--color-natural-100-rgb), .25);
    color: var(--color-black);
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 700;
    transition: var(--animation-default);
}

[data-link-type="navigation"] .link-wrap:hover,
[data-link-type="navigation"][data-link-status="active"] .link-wrap:hover {
    color: var(--color-white);
}

[data-link-type="navigation"] .link-wrap::before {
    width: 0;
    height: 100%;
    background: var(--color-primary);
    border-radius: 1000em;
}

[data-link-type="navigation"] .link-wrap:hover::before,
[data-link-type="navigation"][data-link-status="active"] .link-wrap::before {
    width: 100%;
    left: 0;
}


/* × × × × × × × × × × × × × × × × × × × × × × × × × × × × × 
 × × × × × × × × × FORMS × × × × × × × × × × × × × × × × × ×
× × × × × × × × × × × × × × × × × × × × × × × × × × × × × */

.form * {
    font-family: var(--font-sans);
    font-size: inherit;
    display: grid;
    gap: calc(var(--gap) * 2);
}

.form .input-col {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--gap);
    width: 100%;
}

input,
textarea {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    -ms-progress-appearance: none;
    position: relative;
    width: 100%;
    border: 0;
    outline: 0;
    padding: 0;
    margin: 0;
    background: transparent;
    border: 0;
    font-family: var(--font-input) !important;
    font-size: 1em;
    color: inherit;
    vertical-align: middle;
}

.form .input-col .label {
    font-family: var(--font-mono);
    color: var(--color-white);
    opacity: .5;
}

.form .input-col .input {
    height: 3.5em;
    padding-inline: var(--gap);
    background: var(--color-natural-900);
    border: 1px solid var(--color-natural-700);
    color: var(--color-natural-300);
    transition: var(--animation-default);
}

.form .input-col .input.textarea {
    height: 9em;
    resize: none;
    padding: var(--gap);
}

.form .input-col .input:hover {
    border: 1px solid var(--color-natural-700);
    background: var(--color-natural-800);
}

.form .input-col .input:focus {
    border: 1px solid var(--color-natural-400);
    color: var(--color-text);
}

/* Textarea */
.form .input-col .input textarea {
    padding: calc(var(--gap) * 0.75) var(--gap);
    padding-right: calc(calc(var(--gap) * 2) + 1.25em);
    background: var(--color-white);
    border: 1px solid var(--color-natural-300);
    color: var(--color-natural-700);
    border-radius: .25em;
    transition: var(--animation-default);
    resize: none;
    min-height: 8em;
}

.form .input-col .input textarea:hover {
    border: 1px solid var(--color-natural-400);
    background: var(--color-natural-200);
}

.form .input-col .input textarea:focus {
    border: 1px solid var(--color-natural-400);
    color: var(--color-text);
}

/* Select */
.form .input-col .input select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    position: relative;
    height: 3em;
    width: 100%;
    padding-left: var(--gap);
    padding-right: calc(calc(var(--gap) * 2) + 1.25em);
    background: var(--color-white);
    border: 1px solid var(--color-natural-300);
    color: var(--color-natural-700);
    border-radius: .25em;
    transition: var(--animation-default);
    font-family: var(--font-input) !important;
    font-size: 1em;
    cursor: pointer;
    outline: 0;
}

.form .input-col .input select:hover {
    border: 1px solid var(--color-natural-400);
    background: var(--color-natural-200);
}

.form .input-col .input select:focus {
    border: 1px solid var(--color-natural-400);
    color: var(--color-text);
}

/* Das .icon beim Select zeigt einen Chevron statt dem default Arrow */
.form .input-col .input:has(select) .icon {
    pointer-events: none;
}

.form .input-col .input .icon {
    position: absolute;
    top: 50%;
    right: var(--gap);
    width: 1.25em;
    height: 1.25em;
    display: flex;
    justify-items: center;
    align-items: center;
    opacity: .5;
    transform: translateY(-50%);
}

.form .input-col .input .icon svg {
    width: 1.25em;
    height: 1.25em;
}

.form .input-col .errors {
    display: none;
    flex-direction: column;
    display: none;
}

.form .input-col .errors[data-error-status="active"] {
    display: flex;
}

.form .input-col .errors .error {
    display: none;
    width: max-content;
    text-transform: none;
    font-size: 75%;
}

.form .input-col .errors[data-error-status="active"] .error[data-single-error-status="active"] {
    display: block;
}

input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    position: relative;
    border-radius: 50%;
    border: 1.5px solid var(--color-natural-400);
    background: transparent;
    cursor: pointer;
    flex-shrink: 0;
    padding: 0 !important;
    height: unset !important;
    width: 1.5em;
    height: 1.5em !important;
    border-radius: 50% !important;
    transition: background var(--animation-default), border-color var(--animation-default);
}

input[type="checkbox"]::after {
    content: '';
    position: absolute;
    inset: 0;
    background-color: currentColor;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
    -webkit-mask-size: 65%;
    mask-size: 65%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    opacity: 0;
    transform: scale(0.5);
    transition: opacity var(--animation-default), transform var(--animation-default);
}

input[type="checkbox"]:checked {
    background: var(--color-natural-200) !important;
    border-color: var(--color-natural-400) !important;
}

input[type="checkbox"]:checked::after {
    opacity: 1;
    transform: scale(1);
}