/* ============================================================================== */
/* =                                BREAKPOINTS                                 = */
/* ============================================================================== */
/* ============================================================================== */
/* =                                 FONT FACES                                 = */
/* ============================================================================== */
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/Satoshi-Variable.woff2") format("woff2"), url("../fonts/Satoshi-Variable.woff") format("woff"), url("../fonts/Satoshi-Variable.ttf") format("truetype");
  font-weight: 300 900;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/Satoshi-VariableItalic.woff2") format("woff2"), url("../fonts/Satoshi-VariableItalic.woff") format("woff"), url("../fonts/Satoshi-VariableItalic.ttf") format("truetype");
  font-weight: 300 900;
  font-display: swap;
  font-style: italic;
}
/* ============================================================================== */
/* =                                   TOKENS                                   = */
/* ============================================================================== */
:root {
  /* =============================== COLOR PALETTE ================================ */
  /* ---------------------------------- SURFACES ---------------------------------- */
  --bg-100: #526264;
  --bg-200: #405053;
  --bg-300: #35484B;
  --bg-400: #2A3F42;
  --bg-500: #213235;
  --bg-600: #192627;
  --bg-700: #0F1819;
  --bg-800: #0C1213;
  --bg-900: #080D0E;
  --surface-100: #AFC2AF;
  --surface-200: #7E9E7E;
  --surface-300: #678867;
  --surface-400: #577756;
  --surface-500: #486448;
  --surface-600: #3A523A;
  --surface-700: #2D412D;
  --surface-800: #1F2E1F;
  --surface-900: #121C12;
  /* ------------------------------------ TEXT ------------------------------------ */
  --text-1: #FFFFFF;
  --text-2: #D6E1DF;
  --text-3: #AAB7B5;
  --text-4: #89938F;
  --text-5: #6A7471;
  --text-mint-1: #E4F1E7;
  --text-mint-2: #CDDDCF;
  --text-mint-3: #AFC4AE;
  --text-mint-4: #B9C5B8;
  --text-mint-5: #91B491;
  /* ---------------------------------- BRANDING ---------------------------------- */
  --logo: #33D39D;
  --test: red;
  --test-2: magenta;
  --primary-100: #E3EFE3;
  --primary-200: #C7DEC7;
  --primary-300: #A9CAA9;
  --primary-400: #95BA95;
  --primary-500: #91B491;
  --primary-600: #769776;
  --primary-700: #5B7A5B;
  --primary-800: #405E40;
  --primary-900: #284028;
  --secondary-100: #CFF5E7;
  --secondary-200: #A6E7D1;
  --secondary-300: #7FD9BF;
  --secondary-400: #56B998;
  --secondary-500: #3B9F84;
  --secondary-600: #2F7D67;
  --secondary-700: #1F5545;
  --secondary-800: #153C30;
  --secondary-900: #0C2820;
  /* ---------------------------------- ACCENTS ----------------------------------- */
  --accent-rose-100: #f2d6dc;
  --accent-rose-200: #daa3b0;
  --accent-rose-300: #ba6b76;
  --accent-rose-400: #8d3d4e;
  --accent-rose-500: #6b2935;
  --accent-rose-600: #5a1f2b;
  --accent-rose-700: #49101f;
  --accent-rose-800: #320914;
  --accent-rose-900: #1b030a;
  --accent-orange-100: #FFE3CC;
  --accent-orange-200: #FFC699;
  --accent-orange-300: #FFAD70;
  --accent-orange-400: #FFB37A;
  --accent-orange-500: #FF8A3D;
  --accent-orange-600: #E26B1B;
  --accent-orange-700: #A64811;
  --accent-orange-800: #7A310B;
  --accent-orange-900: #4E1D06;
  --accent-peach-100: #FFE2CC;
  --accent-peach-200: #FFD1B5;
  --accent-peach-300: #FBB48B;
  --accent-peach-400: #F7B267;
  --accent-peach-500: #F79D65;
  --accent-peach-600: #F4845F;
  --accent-peach-700: #F27059;
  --accent-peach-800: #F25C54;
  --accent-peach-900: #C9433E;
  --accent-yellow-100: #FFF3CC;
  --accent-yellow-200: #FFE799;
  --accent-yellow-300: #F8D766;
  --accent-yellow-400: #EFCB48;
  --accent-yellow-500: #DDAE36;
  --accent-yellow-600: #B88C25;
  --accent-yellow-700: #946B18;
  --accent-yellow-800: #6B4D0E;
  --accent-yellow-900: #453108;
  --accent-brown-100: #E8E2D4;
  --accent-brown-200: #D8CBA7;
  --accent-brown-300: #C6B47F;
  --accent-brown-400: #B7A16B;
  --accent-brown-500: #A18F63;
  --accent-brown-600: #847551;
  --accent-brown-700: #695D42;
  --accent-brown-800: #4C4330;
  --accent-brown-900: #322B1F;
  --accent-seaglass-100: #EFF6E0;
  --accent-seaglass-200: #EAF2E5;
  --accent-seaglass-300: #D6E4CF;
  --accent-seaglass-400: #C3D6B9;
  --accent-seaglass-500: #AEC3B0;
  --accent-seaglass-600: #92A893;
  --accent-seaglass-700: #768C77;
  --accent-seaglass-800: #5D6F5D;
  --accent-seaglass-900: #434F44;
  --accent-blue-100: #E4EEF0;
  --accent-blue-200: #C1D4D8;
  --accent-blue-300: #93B2BA;
  --accent-blue-400: #598392;
  --accent-blue-500: #3E6C7A;
  --accent-blue-600: #124559;
  --accent-blue-700: #09313F;
  --accent-blue-800: #05232C;
  --accent-blue-900: #01161E;
  --accent-violet-100: #e7d9ea;
  --accent-violet-200: #c7abc9;
  --accent-violet-300: #9a749e;
  --accent-violet-400: #7c537d;
  --accent-violet-500: #6d4162;
  --accent-violet-600: #4d2844;
  --accent-violet-700: #320d1f;
  --accent-violet-800: #1d0813;
  --accent-violet-900: #0e0409;
  /* ================================ SITE ALIASES ================================ */
  /* ----------------------------------- COLORS ----------------------------------- */
  --bg: var(--bg-400);
  --bg-alt: var(--bg-600);
  --bg-nav: var(--bg-700);
  --bg-footer: var(--surface-900);
  --project-panel: var(--surface-900);
  --project-mask: var(--surface-800);
  --project-h3: var(--primary-400);
  --project-h4: var(--text-mint-3);
  --project-highlight: var(--secondary-300);
  --creative-card: var(--bg-500);
  --creative-role: var(--primary-400);
  --text: var(--text-1);
  --featured-label: var(--secondary-200);
  --button: var(--primary-700);
  --button-hover: var(--primary-600);
  --button-contact: var(--accent-orange-600);
  --button-contact-hover: var(--accent-orange-700);
  --button-footer-hover: var(--primary-600);
  --button-creative: var(--accent-seaglass-700);
  --button-creative-hover: var(--accent-seaglass-600);
  --nav: var(--text-1);
  --nav-hover: var(--primary-300);
  --hamburger: var(--primary-800);
  --hero-arrow: var(--primary-400);
  --accent: var(--accent-orange-500);
  /* ----------------------------------- FONTS ------------------------------------ */
  --font-system: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", sans-serif;
  --font-display: "Satoshi", "Inter", var(--font-system);
  --font-body: "Inter", var(--font-system);
  --font-arrow: "Kablammo", var(--font-arrow);
}

/* ============================================================================== */
/* =                        RESPONSIVE LAYOUT VARIABLES                         = */
/* ============================================================================== */
:root {
  --cols: 4;
  --unit: calc(100svw / var(--cols));
  --col: calc(var(--unit) * (4 / 5));
  --gutter: calc(var(--unit) * (1 / 5));
  --margin: calc(var(--gutter) / 2);
  --container: calc(100svw - (var(--gutter)));
  --project-section: calc(100svw - var(--unit));
  --project-image: calc(100svw - (var(--unit) * 2));
  --project-light: calc(100svw - (var(--gutter) * 2));
  --col-half: calc((var(--container) * 0.5) - (var(--gutter) * 0.5));
  --margin-h: 24px;
  --gutter-h: 48px;
  --gutter-2h: 96px;
  --container-h: calc(100svh - (var(--margin-h) * 2));
  --row-multiplier: 2;
  --topbar-height: calc(var(--gutter-h) * var(--row-multiplier));
  --featured-height: calc(var(--container) / 1.5);
}

/* ============================================================================== */
/* =                             RESPONSIVE LAYOUTS                             = */
/* ============================================================================== */
@media (orientation: lanscape) and (min-width: 768px) {
  :root {
    --cols: 16;
    --gutter-h: 96px;
    --row-multiplier: 1;
  }
}
@media (max-height: 480px) {
  :root {
    --gutter-h: 48px;
    --row-multiplier: 2;
  }
}
/* ============================================================================== */
/* =                              SITE BACKGROUND                               = */
/* ============================================================================== */
:root {
  --base: linear-gradient(180deg,
          color-mix(in srgb, var(--accent-blue-800) 70%, transparent) 0%,
          var(--bg-900) 100%);
  --mask-hero-mobile:
      radial-gradient(ellipse 700px 150px at 50% 20%,
          color-mix(in srgb,
              var(--primary-900) 95%,
              transparent 5%),
          transparent 100%),
      radial-gradient(ellipse 400px 300px at 50% 15%,
          color-mix(in srgb,
              var(--primary-700) 90%,
              transparent 10%),
          transparent 100%),
      radial-gradient(ellipse 500px 200px at 66% 45%,
          color-mix(in srgb,
              var(--surface-700) 90%,
              transparent 10%),
          transparent 100%),
      radial-gradient(ellipse 500px 200px at 45% 35%,
          color-mix(in srgb,
              var(--surface-800) 90%,
              transparent 10%),
          transparent 100%),
      linear-gradient(180deg,
          color-mix(in srgb, var(--surface-900) 100%, transparent) 0%,
          transparent 10%,
          transparent 25%,
          color-mix(in srgb, var(--surface-600) 50%, transparent) 85%,
          color-mix(in srgb, var(--surface-500) 75%, transparent) 95%,
          transparent 100%);
  --mask-hero-landscape:
      radial-gradient(ellipse 1200px 800px at 35% 20%,
          color-mix(in srgb,
              var(--primary-900) 90%,
              transparent 10%),
          transparent 100%),
      radial-gradient(ellipse 1200px 500px at 50% 15%,
          color-mix(in srgb,
              var(--primary-700) 90%,
              transparent 10%),
          transparent 90%),
      radial-gradient(ellipse 500px 200px at 66% 30%,
          color-mix(in srgb,
              var(--surface-700) 90%,
              transparent 10%),
          transparent 75%),
      radial-gradient(ellipse 800px 600px at 60% 10%,
          color-mix(in srgb,
              var(--surface-800) 90%,
              transparent 10%),
          transparent 90%),
      linear-gradient(to bottom,
          color-mix(in srgb, var(--surface-900) 100%, transparent) 0%,
          color-mix(in srgb, var(--surface-800) 90%, transparent) 5%,
          transparent 10%,
          transparent 25%,
          color-mix(in srgb, var(--surface-600) 50%, transparent) 85%,
          color-mix(in srgb, var(--surface-500) 75%, transparent) 95%,
          transparent 100%);
  --mask-creative: linear-gradient(90deg,
          transparent 0%,
          color-mix(in srgb, var(--bg-600) 90%, transparent) 5%,
          transparent 18%,
          color-mix(in srgb, var(--accent-blue-400) 50%, transparent) 20%,
          color-mix(in srgb, var(--bg-900) 90%, transparent) 25%,
          color-mix(in srgb, var(--bg-800) 90%, transparent) 30%,
          color-mix(in srgb, var(--accent-seaglass-700) 90%, transparent) 40%,
          color-mix(in srgb, var(--accent-blue-600) 90%, transparent) 45%,
          color-mix(in srgb, var(--bg-900) 90%, transparent) 50%,
          color-mix(in srgb, var(--accent-seaglass-900) 90%, transparent) 63%,
          color-mix(in srgb, var(--bg-900) 90%, transparent) 66%,
          color-mix(in srgb, var(--accent-blue-700) 90%, transparent) 70%,
          color-mix(in srgb, var(--bg-900) 90%, transparent) 80%,
          transparent 100%);
  --mask-project:
      linear-gradient(180deg,
          color-mix(in srgb, var(--surface-900) 50%, transparent) 0%,
          color-mix(in srgb, var(--surface-700) 85%, transparent) 5%,
          color-mix(in srgb, var(--surface-600) 95%, transparent) 25%,
          color-mix(in srgb, var(--surface-500) 75%, transparent) 30%,
          color-mix(in srgb, var(--surface-600) 75%, transparent) 90%,
          transparent 100%);
}

/* ============================== HELPER FUNCTIONS ============================== */
/* ============================================================================== */
/* =                                   MIXINS                                   = */
/* ============================================================================== */
/* ============================== SITE BACKGROUND =============================== */
/* ================================ FONT SIZING ================================= */
/* ================================ FRAME SIZES ================================= */
/* ============================================================================== */
/* =                                    BASE                                    = */
/* ============================================================================== */
* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  display: flex;
  justify-content: center;
}

p {
  margin: 0;
}

a {
  cursor: pointer;
}

:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 3px;
  border-radius: 8px;
}

.site-wrapper {
  width: 100%;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

/* ========================================================================== */
/* =                              SITE MAIN                                 = */
/* ========================================================================== */
.site-main {
  position: relative;
  isolation: isolate;
  min-height: 100svh;
}

.site-main > :not(.bg-layers) {
  z-index: 10;
}

.bg-layers {
  position: absolute;
  top: 0;
  left: 0;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-attachment: scroll;
}

/* =================================== GLOBAL =================================== */
/* ------------------------------------ Base ------------------------------------ */
.bg--base {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--base);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
  mix-blend-mode: normal;
  opacity: 1;
  z-index: 0;
}

/* ----------------------------------- Shadow ----------------------------------- */
.bg--repeat--shadow-brown {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--shadow-brown.webp");
  background-image: image-set(url("/assets/img/bg/repeat--shadow-brown.avif") type("image/avif"), url("/assets/img/bg/repeat--shadow-brown.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: multiply;
  opacity: 0.7;
  z-index: 1;
  background-size: calc(600px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--shadow-brown {
    background-size: 600px;
  }
}

/* ------------------------------------ Main ------------------------------------ */
.bg--repeat--mint {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--mint.webp");
  background-image: image-set(url("/assets/img/bg/repeat--mint.avif") type("image/avif"), url("/assets/img/bg/repeat--mint.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: soft-light;
  opacity: 1;
  z-index: 1;
  background-size: calc(1000px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--mint {
    background-size: 1000px;
  }
}

/* ============================== MAIN AND PROJECT ============================== */
/* ------------------------------------ Glow ------------------------------------ */
.bg--glow--bright-yellow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/glow--bright-yellow.webp");
  background-image: image-set(url("/assets/img/bg/glow--bright-yellow.avif") type("image/avif"), url("/assets/img/bg/glow--bright-yellow.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: lighten;
  opacity: 0.3;
  z-index: 1;
  background-size: calc(800px * 0.6);
}
@media (min-width: 768px) {
  .bg--glow--bright-yellow {
    background-size: 800px;
  }
}

.bg--glow--yellow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/glow--yellow.webp");
  background-image: image-set(url("/assets/img/bg/glow--yellow.avif") type("image/avif"), url("/assets/img/bg/glow--yellow.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: lighten;
  opacity: 0.3;
  z-index: 1;
  background-size: calc(800px * 0.6);
}
@media (min-width: 768px) {
  .bg--glow--yellow {
    background-size: 800px;
  }
}

/* ----------------------------------- Shadow ----------------------------------- */
.bg--repeat--shadow-orange {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--shadow-orange.webp");
  background-image: image-set(url("/assets/img/bg/repeat--shadow-orange.avif") type("image/avif"), url("/assets/img/bg/repeat--shadow-orange.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: multiply;
  opacity: 0.7;
  z-index: 1;
  background-size: calc(900px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--shadow-orange {
    background-size: 900px;
  }
}

.bg--repeat--shadow-green {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--shadow-green.webp");
  background-image: image-set(url("/assets/img/bg/repeat--shadow-green.avif") type("image/avif"), url("/assets/img/bg/repeat--shadow-green.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: multiply;
  opacity: 0.8;
  z-index: 1;
  background-size: calc(700px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--shadow-green {
    background-size: 700px;
  }
}

/* ------------------------------------ Main ------------------------------------ */
.bg--repeat--peach {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--peach.webp");
  background-image: image-set(url("/assets/img/bg/repeat--peach.avif") type("image/avif"), url("/assets/img/bg/repeat--peach.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: soft-light;
  opacity: 1;
  z-index: 1;
  background-size: calc(700px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--peach {
    background-size: 700px;
  }
}

.bg--repeat--orange {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--orange.webp");
  background-image: image-set(url("/assets/img/bg/repeat--orange.avif") type("image/avif"), url("/assets/img/bg/repeat--orange.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: soft-light;
  opacity: 1;
  z-index: 1;
  background-size: calc(700px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--orange {
    background-size: 700px;
  }
}

/* ---------------------------------- Overlay ----------------------------------- */
.bg--blend-main {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--blend-main);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
  mix-blend-mode: overlay;
  opacity: 1;
  z-index: 2;
}

.bg--mask-hero {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--mask-hero-mobile);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 1600px 1200px;
  mix-blend-mode: normal;
  opacity: 1;
  z-index: 3;
}

.bg--mask-project {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--mask-project);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 1600px 1200px;
  mix-blend-mode: normal;
  opacity: 1;
  z-index: 3;
}

/* ================================== CREATIVE ================================== */
/* ------------------------------------ Glow ------------------------------------ */
.bg--glow--white {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/glow--white.webp");
  background-image: image-set(url("/assets/img/bg/glow--white.avif") type("image/avif"), url("/assets/img/bg/glow--white.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: lighten;
  opacity: 0.3;
  z-index: 1;
  background-size: calc(700px * 0.6);
}
@media (min-width: 768px) {
  .bg--glow--white {
    background-size: 700px;
  }
}

.bg--glow--bright-white {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/glow--bright-white.webp");
  background-image: image-set(url("/assets/img/bg/glow--bright-white.avif") type("image/avif"), url("/assets/img/bg/glow--bright-white.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: lighten;
  opacity: 0.3;
  z-index: 1;
  background-size: calc(1000px * 0.6);
}
@media (min-width: 768px) {
  .bg--glow--bright-white {
    background-size: 1000px;
  }
}

/* ----------------------------------- Shadow ----------------------------------- */
.bg--repeat--shadow-gray {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--shadow-gray.webp");
  background-image: image-set(url("/assets/img/bg/repeat--shadow-gray.avif") type("image/avif"), url("/assets/img/bg/repeat--shadow-gray.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: multiply;
  opacity: 0.5;
  z-index: 1;
  background-size: calc(600px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--shadow-gray {
    background-size: 600px;
  }
}

.bg--repeat--shadow-blue {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--shadow-blue.webp");
  background-image: image-set(url("/assets/img/bg/repeat--shadow-blue.avif") type("image/avif"), url("/assets/img/bg/repeat--shadow-blue.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: multiply;
  opacity: 0.6;
  z-index: 1;
  background-size: calc(700px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--shadow-blue {
    background-size: 700px;
  }
}

/* ------------------------------------ Main ------------------------------------ */
.bg--repeat--seaglass {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--seaglass.webp");
  background-image: image-set(url("/assets/img/bg/repeat--seaglass.avif") type("image/avif"), url("/assets/img/bg/repeat--seaglass.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: soft-light;
  opacity: 1;
  z-index: 1;
  background-size: calc(550px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--seaglass {
    background-size: 550px;
  }
}

.bg--repeat--blue {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/assets/img/bg/repeat--blue.webp");
  background-image: image-set(url("/assets/img/bg/repeat--blue.avif") type("image/avif"), url("/assets/img/bg/repeat--blue.webp") type("image/webp"));
  background-repeat: repeat;
  background-position: 0 0;
  background-attachment: scroll;
  mix-blend-mode: hard-light;
  opacity: 1;
  z-index: 1;
  background-size: calc(600px * 0.6);
}
@media (min-width: 768px) {
  .bg--repeat--blue {
    background-size: 600px;
  }
}

/* ---------------------------------- Overlay ----------------------------------- */
.bg--mask-creative {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--mask-creative);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
  mix-blend-mode: multiply;
  opacity: 1;
  z-index: 2;
}

/* ============================== ABOUT -- SUNRISE ============================== */
/* ------------------------------------ Glow ------------------------------------ */
/* ----------------------------------- Shadow ----------------------------------- */
/* ------------------------------------ Main ------------------------------------ */
/* ---------------------------------- Overlay ----------------------------------- */
/* ================================ ABOUT -- DAY ================================ */
/* ------------------------------------ Glow ------------------------------------ */
/* ----------------------------------- Shadow ----------------------------------- */
/* ------------------------------------ Main ------------------------------------ */
/* ---------------------------------- Overlay ----------------------------------- */
/* ============================== ABOUT -- SUNSET =============================== */
/* ------------------------------------ Glow ------------------------------------ */
/* ----------------------------------- Shadow ----------------------------------- */
/* ------------------------------------ Main ------------------------------------ */
/* ---------------------------------- Overlay ----------------------------------- */
.bg--repeat-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

.bg--repeat-canvas canvas {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
}

.site-main > :not(.bg-layers) {
  position: relative;
  z-index: 1;
}

@media (orientation: landscape) and (min-width: 768px) {
  .bg--mask-hero {
    background-image: var(--mask-hero-landscape);
  }
  .bg--mask-hero, .bg--mask-project {
    background-size: 3840px 2160px;
  }
}
.topbar {
  height: var(--gutter-h);
  margin-top: var(--margin-h);
  margin-inline: var(--margin);
}
.topbar--main {
  height: var(--topbar-height);
}
.topbar__inner {
  height: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: nowrap;
}
.topbar__avatar-link {
  display: inline-block;
  text-decoration: none;
  cursor: pointer;
}
.topbar__avatar-wrap {
  position: relative;
  display: inline-block;
  height: 96px;
  width: 72px;
  overflow: visible;
}
.topbar__avatar-wrap:hover .topbar__avatar, .topbar__avatar-wrap.hover .topbar__avatar {
  transform: rotate(-5deg);
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.25));
}
.topbar__avatar-wrap:hover .topbar__avatar-surprise, .topbar__avatar-wrap.hover .topbar__avatar-surprise {
  opacity: 1;
  transform: translateX(40px) rotate(35deg) scale(1);
}
.topbar__avatar, .topbar__avatar-surprise {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.4s ease, filter 0.4s ease, opacity 0.4s ease;
  transform-origin: center;
  aspect-ratio: 3/4;
  border-radius: 10%;
  filter: grayscale(10%);
}
.topbar__avatar {
  z-index: 2;
}
.topbar__avatar-surprise {
  z-index: 1;
  opacity: 0;
  transform: translateX(0) rotate(0deg);
}

@media (orientation: landscape) and (min-width: 768px) {
  .topbar {
    position: relative;
  }
}
.panel {
  height: auto;
  padding-inline: var(--margin);
}
.panel--hero {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}

.featured {
  height: auto;
  display: flex;
  justify-content: center;
  margin-inline: var(--margin);
  margin-block: var(--margin-h);
}
.featured__inner {
  display: flex;
  flex-direction: column;
  width: 100%;
  justify-content: center;
  align-items: center;
}
.featured__card {
  max-width: 100%;
  margin-block: var(--margin-h);
  overflow: hidden;
  border-radius: 2rem;
  position: relative;
  container-type: inline-size;
}
.featured__card--landscape {
  width: min(var(--container), 748.8px);
  height: min(var(--container), 499.2px);
}
.featured__card--square {
  width: min(var(--container), 748.8px);
  height: min(var(--container), 748.8px);
}
.featured__card--portrait {
  width: min(var(--container), 499.2px);
  height: min(var(--container), 748.8px);
}
.featured__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
  border-radius: 0;
}
.featured__text {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.featured__text--right {
  text-align: right;
  right: var(--margin);
}
.featured__text--left {
  text-align: left;
  left: var(--margin);
}
.featured__mask {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.featured__mask--right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 33%, rgba(30, 30, 30, 0.8) 50%, rgba(20, 20, 20, 0.85) 75%, rgba(15, 15, 15, 0.9) 100%);
  right: 0;
  top: 0;
}
.featured__mask--left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0) 33%, rgba(30, 30, 30, 0.8) 50%, rgba(20, 20, 20, 0.85) 75%, rgba(15, 15, 15, 0.9) 100%);
  left: 0;
  top: 0;
}
.featured__label {
  font-size: 0.875rem;
}
@container (min-width: 28rem) {
  .featured__label {
    font-size: clamp(0.875rem, 0.875rem + (0.875rem) * (100cqw - 28rem) / 19rem, 1.75rem);
  }
}
@container (min-width: 47rem) {
  .featured__label {
    font-size: clamp(1.75rem, 1.75rem + (0.25rem) * (100cqw - 47rem) / 33rem, 2rem);
  }
}
@container (min-width: 80rem) {
  .featured__label {
    font-size: clamp(2rem, 2rem + (0.625rem) * (100cqw - 80rem) / 40rem, 2.625rem);
  }
}
@container (min-width: 120rem) {
  .featured__label {
    font-size: 2.625rem;
  }
}
@media (max-height: 480px) {
  .featured__label {
    font-size: clamp(0.6875rem, 0.6875rem + (0.6875rem) * (100cqw - 28rem) / 19rem, 1.375rem);
  }
}
.featured__label {
  font-family: var(--font-display);
  font-weight: 600;
  display: block;
  color: var(--featured-label);
}
.featured__title {
  font-size: 0.875rem;
}
@container (min-width: 28rem) {
  .featured__title {
    font-size: clamp(0.875rem, 0.875rem + (0.875rem) * (100cqw - 28rem) / 19rem, 1.75rem);
  }
}
@container (min-width: 47rem) {
  .featured__title {
    font-size: clamp(1.75rem, 1.75rem + (0.25rem) * (100cqw - 47rem) / 33rem, 2rem);
  }
}
@container (min-width: 80rem) {
  .featured__title {
    font-size: clamp(2rem, 2rem + (0.625rem) * (100cqw - 80rem) / 40rem, 2.625rem);
  }
}
@container (min-width: 120rem) {
  .featured__title {
    font-size: 2.625rem;
  }
}
@media (max-height: 480px) {
  .featured__title {
    font-size: clamp(0.6875rem, 0.6875rem + (0.6875rem) * (100cqw - 28rem) / 19rem, 1.375rem);
  }
}
.featured__title {
  font-weight: 450;
}
.featured__button {
  font-size: 0.8125rem;
}
@container (min-width: 28rem) {
  .featured__button {
    font-size: clamp(0.8125rem, 0.8125rem + (0.3125rem) * (100cqw - 28rem) / 19rem, 1.125rem);
  }
}
@container (min-width: 47rem) {
  .featured__button {
    font-size: clamp(1.125rem, 1.125rem + (0.375rem) * (100cqw - 47rem) / 33rem, 1.5rem);
  }
}
@container (min-width: 80rem) {
  .featured__button {
    font-size: clamp(1.5rem, 1.5rem + (0.25rem) * (100cqw - 80rem) / 40rem, 1.75rem);
  }
}
@container (min-width: 120rem) {
  .featured__button {
    font-size: 1.75rem;
  }
}
@media (max-height: 480px) {
  .featured__button {
    font-size: clamp(0.625rem, 0.625rem + (0.25rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
.featured__button {
  background-color: var(--button);
  color: var(--text);
  align-self: center;
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75em 1.5em;
  border-radius: 9999px;
  font-weight: 500;
  text-align: center;
  text-decoration: none;
  border: none;
  white-space: nowrap;
  transition: background-color 0.2s ease, transform 0.1s ease;
  margin-top: calc(var(--gutter-h) * 0.25);
}
.featured__button:hover, .featured__button:focus-visible {
  background-color: var(--button-hover);
  color: var(--text);
  outline: none;
}

@media (orientation: landscape) and (min-width: 768px) {
  .featured__card {
    width: 100%;
    height: auto;
    max-height: var(--container-h);
  }
  .featured__card--landscape {
    width: min(var(--container), 1872px);
    height: min(var(--container), 1248px);
  }
  .featured__card--square {
    width: min(var(--container), 1872px);
    height: min(var(--container), 1872px);
  }
  .featured__card--portrait {
    width: min(var(--container), 499.2px);
    height: min(var(--container), 748.8px);
  }
  .featured__mask--right {
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 33%, rgba(30, 30, 30, 0.8) 60%, rgba(20, 20, 20, 0.85) 75%, rgba(15, 15, 15, 0.9) 100%);
  }
  .featured__mask--left {
    background-image: linear-gradient(to left, rgba(0, 0, 0, 0) 33%, rgba(30, 30, 30, 0.8) 55%, rgba(20, 20, 20, 0.85) 75%, rgba(15, 15, 15, 0.9) 100%);
  }
  .featured__other {
    display: flex;
    justify-content: space-between;
    width: min(var(--container), 1872px);
  }
  .featured__other > * {
    width: min(var(--col-half), 1872px);
  }
  .featured__button {
    padding: 0.75em 2em;
  }
}
@media (max-height: 480px) {
  .featured__card {
    max-width: 100%;
    max-height: calc(100svh - (var(--margin-h)));
  }
  .featured__card--landscape {
    width: min(var(--container), 1872px);
    height: min(var(--container), 1248px);
  }
  .featured__card--square {
    width: min(var(--container), 1872px);
    height: min(var(--container), 1872px);
  }
  .featured__card--portrait {
    width: min(var(--container), 1248px);
    height: min(var(--container), 1872px);
  }
  .featured__other {
    display: flex;
    flex-direction: column;
  }
  .featured__other > * {
    width: min(var(--container), 1872px);
  }
}
.about {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-self: center;
  margin-bottom: var(--gutter-2h);
}
.about__hero {
  width: var(--container);
  display: flex;
  justify-content: center;
  margin-block: var(--gutter-2h);
  padding-inline: var(--margin);
}
.about__hero-inner {
  inline-size: var(--project-section);
  margin-inline: auto;
  container-type: inline-size;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.about__section {
  width: var(--container);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.about__frame {
  margin-block: var(--margin-h);
  overflow: hidden;
  border-radius: 2rem;
  position: relative;
}
.about__frame--landscape {
  width: min(var(--container), 748.8px);
  height: min(var(--container), 499.2px);
}
.about__frame--square {
  width: min(var(--container), 748.8px);
  height: min(var(--container), 748.8px);
}
.about__frame--portrait {
  width: min(var(--container), 499.2px);
  height: min(var(--container), 748.8px);
}

@media (orientation: landscape) and (min-width: 768px) {
  .about__hero-inner {
    inline-size: var(--project-section);
  }
  .about__section {
    flex-direction: row;
  }
  .about__frame--landscape {
    width: min(var(--container), 1872px);
    aspect-ratio: 3/2;
  }
  .about__frame--square {
    width: min(var(--col-half), 1872px);
    aspect-ratio: 1/1;
  }
  .about__frame--portrait {
    width: min(var(--col-half), 499.2px);
    aspect-ratio: 4/5;
  }
}
.creative {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-self: center;
  margin-bottom: var(--gutter-2h);
}
.creative__hero {
  width: var(--container);
  display: flex;
  justify-content: center;
  margin-block: var(--gutter-2h);
  padding-inline: var(--margin);
}
.creative__hero-inner {
  inline-size: var(--container);
  margin-inline: auto;
  container-type: inline-size;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.creative__gallery {
  width: var(--container);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.creative__item {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-block: 1em;
}
.creative__frame {
  margin-block: var(--margin-h);
}
.creative__frame--key {
  width: min(var(--container), 480px);
  aspect-ratio: 0.6666666667;
}
.creative__frame--1x1 {
  width: min(var(--container), 480px);
  aspect-ratio: 1;
}
.creative__frame--2x3 {
  width: min(var(--container), 480px);
  aspect-ratio: 0.6666666667;
}
.creative__frame--3x4 {
  width: min(var(--container), 480px);
  aspect-ratio: 0.75;
}
.creative__frame--3x2 {
  width: min(var(--container), 740px);
  aspect-ratio: 1.5;
}
.creative__frame--4x3 {
  width: min(var(--container), 740px);
  aspect-ratio: 1.3333333333;
}
.creative__frame--5x4 {
  width: min(var(--container), 740px);
  aspect-ratio: 1.25;
}
.creative__frame--16x9 {
  width: min(var(--container), 740px);
  aspect-ratio: 1.5;
}
.creative__card {
  background-color: color-mix(in srgb, var(--creative-card) 75%, transparent);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 15px;
  width: 165px;
  aspect-ratio: 1/1;
}
.creative__card--start {
  align-self: flex-start;
}
.creative__card--end {
  align-self: flex-end;
}
.creative__info {
  display: flex;
  flex-direction: column;
  gap: 1em;
  width: 100%;
}

@media (orientation: landscape) and (min-width: 768px) {
  .creative__hero-inner {
    inline-size: var(--project-section);
  }
  .creative__item {
    flex-direction: row;
    gap: 1em;
  }
  .creative__frame--key {
    width: min(var(--container), 832px);
    aspect-ratio: 0.6666666667;
  }
  .creative__frame--1x1 {
    width: min(var(--container), 560px);
    aspect-ratio: 1;
  }
  .creative__frame--2x3 {
    width: min(var(--container), 560px);
    aspect-ratio: 0.6666666667;
  }
  .creative__frame--3x4 {
    width: min(var(--container), 560px);
    aspect-ratio: 0.75;
  }
  .creative__frame--3x2 {
    width: min(var(--container), 1120px);
    aspect-ratio: 1.5;
  }
  .creative__frame--4x3 {
    width: min(var(--container), 1120px);
    aspect-ratio: 1.3333333333;
  }
  .creative__frame--5x4 {
    width: min(var(--container), 1120px);
    aspect-ratio: 1.25;
  }
  .creative__frame--16x9 {
    width: min(var(--container), 1120px);
    aspect-ratio: 1.7777777778;
  }
  .creative__card {
    padding: 24px;
    width: 200px;
  }
  .creative__card--start, .creative__card--end {
    align-self: center;
  }
}
.project {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-self: center;
}
.project__hero {
  width: var(--container);
  display: flex;
  justify-content: center;
  margin-top: var(--gutter-h);
  padding-inline: var(--margin);
}
.project__hero-inner {
  inline-size: var(--container);
  margin-inline: auto;
  container-type: inline-size;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.project__section {
  inline-size: 100%;
  display: flex;
  flex-direction: column;
  container-type: inline-size;
  padding-block: var(--gutter-h);
  align-items: center;
}
.project__section--challenge {
  margin-inline: 0;
  padding-inline: 0;
  background: var(--project-panel);
  padding-block: var(--gutter-h);
}
.project__section--light {
  inline-size: var(--project-light);
  background-color: color-mix(in srgb, var(--project-mask) 90%, transparent);
}
.project__section--dark {
  margin-inline: 0;
  padding-inline: 0;
  background: var(--project-panel);
}
.project__details {
  inline-size: var(--project-panel);
  display: flex;
  flex-direction: column;
  margin-top: calc(var(--gutter-h) * 0.5);
  gap: 1em;
  align-items: flex-start;
}
.project__details-item {
  width: 100%;
  display: flex;
  gap: 1em;
}
.project__list {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.project__list-item {
  display: flex;
  gap: 1em;
  margin: 1em;
}
.project__list2 {
  margin-inline: calc(var(--margin) * 1.5);
  display: flex;
  flex-direction: column;
  margin-block: 0;
  gap: 0.5em;
}
.project__list2 li {
  margin: 0;
}
.project__grid {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}
.project__grid-item {
  background-color: var(--project-panel);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  border-radius: 2rem;
  padding-block: calc(var(--gutter-h) * 0.25);
}
.project__grid-item p {
  margin-block: calc(var(--gutter-h) * 0.25);
  margin-inline: var(--gutter);
}
.project__inner {
  padding-inline: var(--margin);
}
.project__hero-image {
  margin-inline: 0;
  padding-inline: 0;
  width: 100%;
  display: flex;
  justify-content: center;
  background-image: linear-gradient(to bottom, transparent 0%, var(--project-panel) 100%);
}

@media (orientation: landscape) and (min-width: 768px) {
  .project__hero-inner {
    inline-size: var(--project-section);
  }
  .project__inner {
    width: var(--project-section);
  }
  .project__list2 {
    margin-inline: var(--margin);
    gap: 1em;
  }
  .project__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1em;
  }
}
@container (min-width: 768px) {
  .project__details {
    display: grid;
    grid-template-areas: "item1 item2" "item3 item4";
    inline-size: var(--project-section);
    justify-self: center;
    justify-items: start;
  }
}
.footer {
  margin-inline: 0;
  padding-inline: 0;
  max-width: 100svw;
  container-type: inline-size;
}
.footer__inner {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  background-color: color-mix(in srgb, var(--bg-footer) 75%, transparent);
  padding-inline: calc(var(--margin) * 2);
  padding-block: calc(var(--gutter-h) * 0.5);
  gap: 1em;
}
.footer__endbar {
  display: flex;
}
.footer__info {
  display: flex;
  gap: 1em;
}
.footer__contact {
  display: none;
}
.footer__links {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: center;
}
.footer__link {
  font-size: 0.6875rem;
}
@container (min-width: 28rem) {
  .footer__link {
    font-size: clamp(0.6875rem, 0.6875rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .footer__link {
    font-size: clamp(0.875rem, 0.875rem + (0.125rem) * (100cqw - 47rem) / 33rem, 1rem);
  }
}
@container (min-width: 80rem) {
  .footer__link {
    font-size: clamp(1rem, 1rem + (0rem) * (100cqw - 80rem) / 40rem, 1rem);
  }
}
@container (min-width: 120rem) {
  .footer__link {
    font-size: 1rem;
  }
}
@media (max-height: 480px) {
  .footer__link {
    font-size: clamp(0.5625rem, 0.5625rem + (0.125rem) * (100cqw - 28rem) / 19rem, 0.6875rem);
  }
}
.footer__link {
  color: var(--text);
  text-decoration: none;
  margin: 0.5em 1.5em;
}
.footer__link--none {
  display: none;
}
.footer__link:hover, .footer__link:focus-visible {
  color: var(--text-2);
  outline: none;
}
.footer p {
  margin: 0;
}

@media (orientation: landscape) {
  .footer__inner {
    gap: 2em;
  }
  .footer__endbar {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    width: calc(var(--container) - 36px);
    margin-block: calc(var(--gutter-h) * 0.25);
  }
  .footer__contact {
    display: flex;
    flex-direction: column;
  }
  .footer__links {
    width: var(--col-half);
    gap: 1em;
  }
  .footer__link--none {
    display: inline;
  }
}
.nav {
  display: none;
  height: 100svh;
  flex-direction: column;
}
.nav__inner {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  align-items: center;
  gap: var(--gutter-h);
}
.nav__link {
  font-size: 2.25rem;
}
@container (min-width: 28rem) {
  .nav__link {
    font-size: clamp(2.25rem, 2.25rem + (2.25rem) * (100cqw - 28rem) / 19rem, 4.5rem);
  }
}
@container (min-width: 47rem) {
  .nav__link {
    font-size: clamp(4.5rem, 4.5rem + (0.1875rem) * (100cqw - 47rem) / 33rem, 4.6875rem);
  }
}
@container (min-width: 80rem) {
  .nav__link {
    font-size: clamp(4.6875rem, 4.6875rem + (0.5625rem) * (100cqw - 80rem) / 40rem, 5.25rem);
  }
}
@container (min-width: 120rem) {
  .nav__link {
    font-size: 5.25rem;
  }
}
@media (max-height: 480px) {
  .nav__link {
    font-size: clamp(1.8125rem, 1.8125rem + (1.8125rem) * (100cqw - 28rem) / 19rem, 3.625rem);
  }
}
.nav__link {
  color: var(--nav);
  font-family: var(--font-serif);
  text-decoration: none;
  background: none;
  border: none;
}
.nav__link:hover, .nav__link:focus-visible {
  color: var(--nav-hover);
  outline: none;
}

@media (orientation: landscape) and (min-width: 768px) {
  .nav {
    width: calc(1280px / 2);
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    min-width: 0;
    gap: var(--gutter);
    height: var(--gutter-h);
  }
  .nav__inner {
    width: 100%;
    flex-direction: row;
    align-items: center;
    justify-content: space-evenly;
    gap: var(--gutter);
    flex: 1 1 100%;
  }
  .nav__link {
    font-size: 1.125rem;
  }
  @container (min-width: map.get($cq, c3)) {
    .nav__link {
      font-size: 1.1875rem;
    }
  }
  .nav__link--contact {
    margin-top: 0;
  }
}
.is-nav-open {
  overflow: hidden;
}
.is-nav-open .nav {
  display: flex;
  position: fixed;
  inset: 0;
  background: var(--bg-nav);
  flex-direction: column;
  gap: 0;
  z-index: 1000;
  justify-content: center;
  align-items: center;
}

.is-nav-open .panel,
.is-nav-open .panel--hero {
  padding-inline: 0 !important;
  padding-block: 0 !important;
}

.is-nav-open .hamburger {
  position: absolute;
  top: 24px;
  right: var(--margin);
}

.is-nav-open .topbar {
  margin: 0;
  height: 100svh !important;
}

.is-nav-open .hero__title,
.is-nav-open .hero__subtitle,
.is-nav-open .hero__explore,
.is-nav-open .hero__arrow,
.is-nav-open .featured {
  opacity: 0 !important;
  transform: translateY(10px);
  transition: none !important;
}

@media (max-height: 480px) {
  .hamburger {
    display: block;
  }
  .nav {
    display: none;
    width: 100%;
    height: var(--gutter-h);
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: var(--gutter);
  }
  .is-nav-open .nav {
    display: flex;
    position: fixed;
    inset: 0;
    background: var(--bg-nav);
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: var(--gutter);
    z-index: 2000;
    margin: 0;
  }
  .is-nav-open .nav__inner {
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: var(--gutter);
  }
}
@media (max-height: 480px) and (max-width: 750px) {
  .nav__link {
    font-size: 1.6875rem;
  }
  @container (min-width: 28rem) {
    .nav__link {
      font-size: clamp(1.6875rem, 1.6875rem + (0.5625rem) * (100cqw - 28rem) / 19rem, 2.25rem);
    }
  }
  @container (min-width: 47rem) {
    .nav__link {
      font-size: clamp(2.25rem, 2.25rem + (0rem) * (100cqw - 47rem) / 33rem, 2.25rem);
    }
  }
  @container (min-width: 80rem) {
    .nav__link {
      font-size: clamp(2.25rem, 2.25rem + (0rem) * (100cqw - 80rem) / 40rem, 2.25rem);
    }
  }
  @container (min-width: 120rem) {
    .nav__link {
      font-size: 2.25rem;
    }
  }
}
@media (max-height: 480px) and (max-width: 750px) and (max-height: 480px) {
  .nav__link {
    font-size: clamp(1.375rem, 1.375rem + (0.4375rem) * (100cqw - 28rem) / 19rem, 1.8125rem);
  }
}
@media (max-height: 480px) and (min-width: 751px) {
  .nav__link {
    font-size: 2.25rem;
  }
  @container (min-width: 28rem) {
    .nav__link {
      font-size: clamp(2.25rem, 2.25rem + (0rem) * (100cqw - 28rem) / 19rem, 2.25rem);
    }
  }
  @container (min-width: 47rem) {
    .nav__link {
      font-size: clamp(2.25rem, 2.25rem + (0rem) * (100cqw - 47rem) / 33rem, 2.25rem);
    }
  }
  @container (min-width: 80rem) {
    .nav__link {
      font-size: clamp(2.25rem, 2.25rem + (0rem) * (100cqw - 80rem) / 40rem, 2.25rem);
    }
  }
  @container (min-width: 120rem) {
    .nav__link {
      font-size: 2.25rem;
    }
  }
}
@media (max-height: 480px) and (min-width: 751px) and (max-height: 480px) {
  .nav__link {
    font-size: clamp(1.8125rem, 1.8125rem + (0rem) * (100cqw - 28rem) / 19rem, 1.8125rem);
  }
}
.hamburger {
  background: var(--hamburger);
  border: 0;
  width: 48px;
  height: 48px;
  padding: 8px;
  border-radius: 10%;
  cursor: pointer;
  z-index: 2100;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.hamburger__bar {
  display: block;
  width: 32px;
  height: 3px;
  background: var(--text);
  margin: 3px 0;
  transition: transform 180ms ease, opacity 150ms ease;
  transform-origin: center;
}
.hamburger[aria-expanded=true] .hamburger__bar:nth-child(1) {
  transform: translateY(9px) rotate(45deg);
}
.hamburger[aria-expanded=true] .hamburger__bar:nth-child(2) {
  opacity: 0;
}
.hamburger[aria-expanded=true] .hamburger__bar:nth-child(3) {
  transform: translateY(-9px) rotate(-45deg);
}

@media (orientation: landscape) and (min-width: 768px) {
  .hamburger {
    display: none;
  }
}
@media (max-height: 480px) {
  .hamburger {
    display: block;
  }
}
@media (hover: none) and (pointer: coarse) and (min-width: 820px) and (min-height: 820px) {
  .hamburger {
    width: 96px;
    height: 96px;
    padding: 16px;
  }
  .hamburger__bar {
    width: 64px;
    height: 6px;
    margin: 6px 0;
  }
  .hamburger[aria-expanded=true] .hamburger__bar:nth-child(1) {
    transform: translateY(18px) rotate(45deg);
  }
  .hamburger[aria-expanded=true] .hamburger__bar:nth-child(2) {
    opacity: 0;
  }
  .hamburger[aria-expanded=true] .hamburger__bar:nth-child(3) {
    transform: translateY(-18px) rotate(-45deg);
  }
}
.hero {
  height: auto;
  width: 100%;
  display: flex;
  flex: 1 1 100%;
  flex-direction: column;
  align-self: center;
  align-items: stretch;
  justify-items: center;
  container-type: inline-size;
}
.hero__inner {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
}
.hero__text {
  width: 100%;
  align-self: start;
  margin-bottom: var(--gutter-h);
}
.hero__title {
  font-size: 2.5rem;
}
@container (min-width: 28rem) {
  .hero__title {
    font-size: clamp(2.5rem, 2.5rem + (2rem) * (100cqw - 28rem) / 19rem, 4.5rem);
  }
}
@container (min-width: 47rem) {
  .hero__title {
    font-size: clamp(4.5rem, 4.5rem + (0.5rem) * (100cqw - 47rem) / 33rem, 5rem);
  }
}
@container (min-width: 80rem) {
  .hero__title {
    font-size: clamp(5rem, 5rem + (1.75rem) * (100cqw - 80rem) / 40rem, 6.75rem);
  }
}
@container (min-width: 120rem) {
  .hero__title {
    font-size: 6.75rem;
  }
}
@media (max-height: 480px) {
  .hero__title {
    font-size: clamp(2rem, 2rem + (1.625rem) * (100cqw - 28rem) / 19rem, 3.625rem);
  }
}
.hero__title {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--text);
  margin-top: calc(var(--gutter-h) * 0.5);
}
.hero__subtitle {
  font-size: 1.5rem;
}
@container (min-width: 28rem) {
  .hero__subtitle {
    font-size: clamp(1.5rem, 1.5rem + (0.5rem) * (100cqw - 28rem) / 19rem, 2rem);
  }
}
@container (min-width: 47rem) {
  .hero__subtitle {
    font-size: clamp(2rem, 2rem + (0.25rem) * (100cqw - 47rem) / 33rem, 2.25rem);
  }
}
@container (min-width: 80rem) {
  .hero__subtitle {
    font-size: clamp(2.25rem, 2.25rem + (0.75rem) * (100cqw - 80rem) / 40rem, 3rem);
  }
}
@container (min-width: 120rem) {
  .hero__subtitle {
    font-size: 3rem;
  }
}
@media (max-height: 480px) {
  .hero__subtitle {
    font-size: clamp(1.1875rem, 1.1875rem + (0.4375rem) * (100cqw - 28rem) / 19rem, 1.625rem);
  }
}
.hero__subtitle {
  font-family: var(--font-display);
  font-weight: 400;
  display: block;
  color: var(--text-2);
}
.hero__break {
  display: block;
}
.hero__break2 {
  display: inline;
}
.hero__pointer {
  display: flex;
  justify-self: flex-end;
  align-self: end;
  align-items: flex-end;
  gap: 0.5em;
}
.hero__arrow {
  font-size: 1rem;
}
@container (min-width: 28rem) {
  .hero__arrow {
    font-size: clamp(1rem, 1rem + (0.3125rem) * (100cqw - 28rem) / 19rem, 1.3125rem);
  }
}
@container (min-width: 47rem) {
  .hero__arrow {
    font-size: clamp(1.3125rem, 1.3125rem + (0.4375rem) * (100cqw - 47rem) / 33rem, 1.75rem);
  }
}
@container (min-width: 80rem) {
  .hero__arrow {
    font-size: clamp(1.75rem, 1.75rem + (0.25rem) * (100cqw - 80rem) / 40rem, 2rem);
  }
}
@container (min-width: 120rem) {
  .hero__arrow {
    font-size: 2rem;
  }
}
@media (max-height: 480px) {
  .hero__arrow {
    font-size: clamp(0.8125rem, 0.8125rem + (0.25rem) * (100cqw - 28rem) / 19rem, 1.0625rem);
  }
}
.hero__arrow {
  color: var(--hero-arrow);
  font-family: var(--font-arrow);
  display: inline-flex;
  align-items: flex-start;
}
.hero__explore {
  font-size: 1rem;
}
@container (min-width: 28rem) {
  .hero__explore {
    font-size: clamp(1rem, 1rem + (0.3125rem) * (100cqw - 28rem) / 19rem, 1.3125rem);
  }
}
@container (min-width: 47rem) {
  .hero__explore {
    font-size: clamp(1.3125rem, 1.3125rem + (0.4375rem) * (100cqw - 47rem) / 33rem, 1.75rem);
  }
}
@container (min-width: 80rem) {
  .hero__explore {
    font-size: clamp(1.75rem, 1.75rem + (0.25rem) * (100cqw - 80rem) / 40rem, 2rem);
  }
}
@container (min-width: 120rem) {
  .hero__explore {
    font-size: 2rem;
  }
}
@media (max-height: 480px) {
  .hero__explore {
    font-size: clamp(0.8125rem, 0.8125rem + (0.25rem) * (100cqw - 28rem) / 19rem, 1.0625rem);
  }
}
.hero__explore {
  align-self: center;
  font-family: var(--font-display);
  font-weight: 400;
}
.hero p {
  margin: 0;
}

@media (orientation: landscape) and (min-width: 768px) {
  .hero {
    align-items: center;
  }
  .hero__inner {
    grid-template-columns: 1fr;
    justify-items: start;
    text-align: left;
  }
  .hero__text {
    justify-self: flex-start;
    margin-bottom: calc(var(--gutter-h) * 0.5);
  }
  .hero__title {
    margin-bottom: calc(var(--gutter-h) * 0.5);
  }
  .hero__subtitle {
    margin: 0;
  }
  .hero__break {
    display: inline;
  }
  .hero__break2 {
    display: block;
  }
}
@media (max-height: 480px) {
  .hero__pointer {
    min-width: auto;
    position: absolute;
    bottom: clamp(8px, 2vh, 24px);
  }
  .hero__inner {
    position: relative;
  }
}
.image__wrapper {
  width: var(--project-section);
  overflow: hidden;
  border-radius: 2rem;
  position: relative;
  aspect-ratio: 1/1;
}
.image__wrapper--hero {
  margin-top: var(--gutter-h);
}
.image__wrapper--content {
  justify-self: center;
}
.image__content {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.image__logo {
  height: 48px;
  width: 48px;
  display: inline-block;
}
.image__logo--footer {
  height: 24px;
  width: 24px;
}
.image__icon {
  inline-size: 1em;
  block-size: 1em;
  display: inline-block;
  vertical-align: text-bottom;
}
.image__icon-big {
  inline-size: 1.5em;
  block-size: 1.5em;
  display: inline-block;
  vertical-align: text-bottom;
}

@media (orientation: landscape) and (min-width: 768px) {
  .image__wrapper {
    height: auto;
    aspect-ratio: 21/9;
  }
  .image__wrapper--hero {
    width: var(--project-section);
    max-width: var(--project-section);
  }
  .image__wrapper--content {
    width: var(--project-image);
    max-width: var(--project-image);
  }
  .image__content {
    display: block;
    inline-size: 100%;
    block-size: 100%;
    object-position: center 0%;
  }
  .image__logo--footer {
    height: 36px;
    width: 36px;
  }
}
.text__title {
  font-size: 2.25rem;
}
@container (min-width: 28rem) {
  .text__title {
    font-size: clamp(2.25rem, 2.25rem + (2.25rem) * (100cqw - 28rem) / 19rem, 4.5rem);
  }
}
@container (min-width: 47rem) {
  .text__title {
    font-size: clamp(4.5rem, 4.5rem + (0.1875rem) * (100cqw - 47rem) / 33rem, 4.6875rem);
  }
}
@container (min-width: 80rem) {
  .text__title {
    font-size: clamp(4.6875rem, 4.6875rem + (0.5625rem) * (100cqw - 80rem) / 40rem, 5.25rem);
  }
}
@container (min-width: 120rem) {
  .text__title {
    font-size: 5.25rem;
  }
}
@media (max-height: 480px) {
  .text__title {
    font-size: clamp(1.8125rem, 1.8125rem + (1.8125rem) * (100cqw - 28rem) / 19rem, 3.625rem);
  }
}
.text__title {
  inline-size: fit-content;
  max-inline-size: var(--project-section);
  text-wrap: balance;
  margin-inline: 0;
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--text);
}
.text__title--about {
  font-size: 1.5rem;
}
@container (min-width: 28rem) {
  .text__title--about {
    font-size: clamp(1.5rem, 1.5rem + (1.625rem) * (100cqw - 28rem) / 19rem, 3.125rem);
  }
}
@container (min-width: 47rem) {
  .text__title--about {
    font-size: clamp(3.125rem, 3.125rem + (0.875rem) * (100cqw - 47rem) / 33rem, 4rem);
  }
}
@container (min-width: 80rem) {
  .text__title--about {
    font-size: clamp(4rem, 4rem + (1.25rem) * (100cqw - 80rem) / 40rem, 5.25rem);
  }
}
@container (min-width: 120rem) {
  .text__title--about {
    font-size: 5.25rem;
  }
}
@media (max-height: 480px) {
  .text__title--about {
    font-size: clamp(1.1875rem, 1.1875rem + (1.3125rem) * (100cqw - 28rem) / 19rem, 2.5rem);
  }
}
.text__title--about {
  text-align: left;
}
.text__subtitle {
  font-size: 1.25rem;
}
@container (min-width: 28rem) {
  .text__subtitle {
    font-size: clamp(1.25rem, 1.25rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.375rem);
  }
}
@container (min-width: 47rem) {
  .text__subtitle {
    font-size: clamp(1.375rem, 1.375rem + (0.25rem) * (100cqw - 47rem) / 33rem, 1.625rem);
  }
}
@container (min-width: 80rem) {
  .text__subtitle {
    font-size: clamp(1.625rem, 1.625rem + (0.375rem) * (100cqw - 80rem) / 40rem, 2rem);
  }
}
@container (min-width: 120rem) {
  .text__subtitle {
    font-size: 2rem;
  }
}
@media (max-height: 480px) {
  .text__subtitle {
    font-size: clamp(1rem, 1rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.125rem);
  }
}
.text__subtitle {
  inline-size: var(--project-section);
  max-inline-size: 100%;
  font-family: var(--font-display);
  font-weight: 400;
  display: block;
  color: var(--text-mint-1);
  margin-block: 0;
  margin-inline: 0;
  text-align: justify;
}
.text__small {
  font-size: 0.6875rem;
}
@container (min-width: 28rem) {
  .text__small {
    font-size: clamp(0.6875rem, 0.6875rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .text__small {
    font-size: clamp(0.875rem, 0.875rem + (0.125rem) * (100cqw - 47rem) / 33rem, 1rem);
  }
}
@container (min-width: 80rem) {
  .text__small {
    font-size: clamp(1rem, 1rem + (0rem) * (100cqw - 80rem) / 40rem, 1rem);
  }
}
@container (min-width: 120rem) {
  .text__small {
    font-size: 1rem;
  }
}
@media (max-height: 480px) {
  .text__small {
    font-size: clamp(0.5625rem, 0.5625rem + (0.125rem) * (100cqw - 28rem) / 19rem, 0.6875rem);
  }
}
.text__small {
  color: var(--text-2);
  margin: 0;
}
.text__h2 {
  font-size: 1.25rem;
}
@container (min-width: 28rem) {
  .text__h2 {
    font-size: clamp(1.25rem, 1.25rem + (1rem) * (100cqw - 28rem) / 19rem, 2.25rem);
  }
}
@container (min-width: 47rem) {
  .text__h2 {
    font-size: clamp(2.25rem, 2.25rem + (0.75rem) * (100cqw - 47rem) / 33rem, 3rem);
  }
}
@container (min-width: 80rem) {
  .text__h2 {
    font-size: clamp(3rem, 3rem + (0.375rem) * (100cqw - 80rem) / 40rem, 3.375rem);
  }
}
@container (min-width: 120rem) {
  .text__h2 {
    font-size: 3.375rem;
  }
}
@media (max-height: 480px) {
  .text__h2 {
    font-size: clamp(1rem, 1rem + (0.8125rem) * (100cqw - 28rem) / 19rem, 1.8125rem);
  }
}
.text__h2 {
  inline-size: var(--project-section);
  max-inline-size: 100%;
  font-family: var(--font-display);
  font-weight: 400;
  display: block;
  color: var(--text-mint-1);
  margin-block: 0;
  margin-inline: 0;
  text-align: center;
}
.text__h3 {
  font-size: 1.5rem;
}
@container (min-width: 28rem) {
  .text__h3 {
    font-size: clamp(1.5rem, 1.5rem + (0.25rem) * (100cqw - 28rem) / 19rem, 1.75rem);
  }
}
@container (min-width: 47rem) {
  .text__h3 {
    font-size: clamp(1.75rem, 1.75rem + (0.4375rem) * (100cqw - 47rem) / 33rem, 2.1875rem);
  }
}
@container (min-width: 80rem) {
  .text__h3 {
    font-size: clamp(2.1875rem, 2.1875rem + (0.4375rem) * (100cqw - 80rem) / 40rem, 2.625rem);
  }
}
@container (min-width: 120rem) {
  .text__h3 {
    font-size: 2.625rem;
  }
}
@media (max-height: 480px) {
  .text__h3 {
    font-size: clamp(1.1875rem, 1.1875rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 1.375rem);
  }
}
.text__h3 {
  color: var(--project-h3);
  font-weight: 600;
  margin-top: 0;
}
.text__h4 {
  font-size: 1.25rem;
}
@container (min-width: 28rem) {
  .text__h4 {
    font-size: clamp(1.25rem, 1.25rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.375rem);
  }
}
@container (min-width: 47rem) {
  .text__h4 {
    font-size: clamp(1.375rem, 1.375rem + (0.25rem) * (100cqw - 47rem) / 33rem, 1.625rem);
  }
}
@container (min-width: 80rem) {
  .text__h4 {
    font-size: clamp(1.625rem, 1.625rem + (0.375rem) * (100cqw - 80rem) / 40rem, 2rem);
  }
}
@container (min-width: 120rem) {
  .text__h4 {
    font-size: 2rem;
  }
}
@media (max-height: 480px) {
  .text__h4 {
    font-size: clamp(1rem, 1rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.125rem);
  }
}
.text__h4 {
  color: var(--project-h4);
  font-weight: 500;
  margin-top: var(--gutter-h);
}
.text__s4 {
  font-size: 1.25rem;
}
@container (min-width: 28rem) {
  .text__s4 {
    font-size: clamp(1.25rem, 1.25rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.375rem);
  }
}
@container (min-width: 47rem) {
  .text__s4 {
    font-size: clamp(1.375rem, 1.375rem + (0.25rem) * (100cqw - 47rem) / 33rem, 1.625rem);
  }
}
@container (min-width: 80rem) {
  .text__s4 {
    font-size: clamp(1.625rem, 1.625rem + (0.375rem) * (100cqw - 80rem) / 40rem, 2rem);
  }
}
@container (min-width: 120rem) {
  .text__s4 {
    font-size: 2rem;
  }
}
@media (max-height: 480px) {
  .text__s4 {
    font-size: clamp(1rem, 1rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.125rem);
  }
}
.text__s4 {
  color: var(--text-2);
  font-weight: 200;
}
.text__body {
  font-size: 1rem;
}
@container (min-width: 28rem) {
  .text__body {
    font-size: clamp(1rem, 1rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.125rem);
  }
}
@container (min-width: 47rem) {
  .text__body {
    font-size: clamp(1.125rem, 1.125rem + (0.0625rem) * (100cqw - 47rem) / 33rem, 1.1875rem);
  }
}
@container (min-width: 80rem) {
  .text__body {
    font-size: clamp(1.1875rem, 1.1875rem + (0.0625rem) * (100cqw - 80rem) / 40rem, 1.25rem);
  }
}
@container (min-width: 120rem) {
  .text__body {
    font-size: 1.25rem;
  }
}
@media (max-height: 480px) {
  .text__body {
    font-size: clamp(0.8125rem, 0.8125rem + (0.0625rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
.text__body {
  margin-inline: 0;
  margin-block: 1em;
}
.text__big {
  font-size: 1.125rem;
}
@container (min-width: 28rem) {
  .text__big {
    font-size: clamp(1.125rem, 1.125rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.25rem);
  }
}
@container (min-width: 47rem) {
  .text__big {
    font-size: clamp(1.25rem, 1.25rem + (0.0625rem) * (100cqw - 47rem) / 33rem, 1.3125rem);
  }
}
@container (min-width: 80rem) {
  .text__big {
    font-size: clamp(1.3125rem, 1.3125rem + (0.0625rem) * (100cqw - 80rem) / 40rem, 1.375rem);
  }
}
@container (min-width: 120rem) {
  .text__big {
    font-size: 1.375rem;
  }
}
@media (max-height: 480px) {
  .text__big {
    font-size: clamp(0.875rem, 0.875rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1rem);
  }
}
.text__big {
  margin-inline: 0;
}
.text__footer {
  font-size: 0.6875rem;
}
@container (min-width: 28rem) {
  .text__footer {
    font-size: clamp(0.6875rem, 0.6875rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .text__footer {
    font-size: clamp(0.875rem, 0.875rem + (0.125rem) * (100cqw - 47rem) / 33rem, 1rem);
  }
}
@container (min-width: 80rem) {
  .text__footer {
    font-size: clamp(1rem, 1rem + (0rem) * (100cqw - 80rem) / 40rem, 1rem);
  }
}
@container (min-width: 120rem) {
  .text__footer {
    font-size: 1rem;
  }
}
@media (max-height: 480px) {
  .text__footer {
    font-size: clamp(0.5625rem, 0.5625rem + (0.125rem) * (100cqw - 28rem) / 19rem, 0.6875rem);
  }
}
.text__footer {
  color: var(--text-2);
}
.text__copyright {
  font-size: 0.6875rem;
}
@container (min-width: 28rem) {
  .text__copyright {
    font-size: clamp(0.6875rem, 0.6875rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .text__copyright {
    font-size: clamp(0.875rem, 0.875rem + (0.125rem) * (100cqw - 47rem) / 33rem, 1rem);
  }
}
@container (min-width: 80rem) {
  .text__copyright {
    font-size: clamp(1rem, 1rem + (0rem) * (100cqw - 80rem) / 40rem, 1rem);
  }
}
@container (min-width: 120rem) {
  .text__copyright {
    font-size: 1rem;
  }
}
@media (max-height: 480px) {
  .text__copyright {
    font-size: clamp(0.5625rem, 0.5625rem + (0.125rem) * (100cqw - 28rem) / 19rem, 0.6875rem);
  }
}
.text__copyright {
  color: var(--text-3);
  padding-top: 1em;
}
.text__break {
  display: block;
}
.text__bold {
  color: var(--text);
  font-weight: bold;
}
.text__highlight {
  color: var(--project-highlight);
  font-weight: 600;
}
.text__card {
  font-size: 0.625rem;
}
@container (min-width: 28rem) {
  .text__card {
    font-size: clamp(0.625rem, 0.625rem + (0.25rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .text__card {
    font-size: clamp(0.875rem, 0.875rem + (0.25rem) * (100cqw - 47rem) / 33rem, 1.125rem);
  }
}
@container (min-width: 80rem) {
  .text__card {
    font-size: clamp(1.125rem, 1.125rem + (0.125rem) * (100cqw - 80rem) / 40rem, 1.25rem);
  }
}
@container (min-width: 120rem) {
  .text__card {
    font-size: 1.25rem;
  }
}
@media (max-height: 480px) {
  .text__card {
    font-size: clamp(0.5rem, 0.5rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 0.6875rem);
  }
}
.text__card {
  color: var(--text-2);
  margin: 0;
}
.text__role {
  font-size: 0.625rem;
}
@container (min-width: 28rem) {
  .text__role {
    font-size: clamp(0.625rem, 0.625rem + (0.25rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .text__role {
    font-size: clamp(0.875rem, 0.875rem + (0.25rem) * (100cqw - 47rem) / 33rem, 1.125rem);
  }
}
@container (min-width: 80rem) {
  .text__role {
    font-size: clamp(1.125rem, 1.125rem + (0.125rem) * (100cqw - 80rem) / 40rem, 1.25rem);
  }
}
@container (min-width: 120rem) {
  .text__role {
    font-size: 1.25rem;
  }
}
@media (max-height: 480px) {
  .text__role {
    font-size: clamp(0.5rem, 0.5rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 0.6875rem);
  }
}
.text__role {
  font-weight: 600;
  color: var(--creative-role);
  margin: 0;
}

@media (orientation: landscape) and (min-width: 768px) {
  .text__title {
    max-inline-size: 100%;
    inline-size: var(--project-section);
  }
  .text__text {
    margin-block: calc(var(--gutter-h) * 0.5);
  }
  .text__break {
    display: inline;
  }
}
.button {
  font-size: 1rem;
}
@container (min-width: 28rem) {
  .button {
    font-size: clamp(1rem, 1rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.125rem);
  }
}
@container (min-width: 47rem) {
  .button {
    font-size: clamp(1.125rem, 1.125rem + (0.0625rem) * (100cqw - 47rem) / 33rem, 1.1875rem);
  }
}
@container (min-width: 80rem) {
  .button {
    font-size: clamp(1.1875rem, 1.1875rem + (0.0625rem) * (100cqw - 80rem) / 40rem, 1.25rem);
  }
}
@container (min-width: 120rem) {
  .button {
    font-size: 1.25rem;
  }
}
@media (max-height: 480px) {
  .button {
    font-size: clamp(0.8125rem, 0.8125rem + (0.0625rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
.button {
  background-color: var(--button);
  color: var(--text);
  align-self: center;
  margin-top: auto;
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  padding: 0.75em 2em;
  border-radius: 9999px;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  border: none;
  white-space: nowrap;
  transition: background-color 0.2s ease, transform 0.1s ease;
  margin-top: calc(var(--gutter-h) * 0.25);
}
.button:hover, .button:focus-visible {
  background-color: var(--button-hover);
  color: var(--text);
  outline: none;
}
.button--topbar {
  font-size: 2.25rem;
}
@container (min-width: 28rem) {
  .button--topbar {
    font-size: clamp(2.25rem, 2.25rem + (2.25rem) * (100cqw - 28rem) / 19rem, 4.5rem);
  }
}
@container (min-width: 47rem) {
  .button--topbar {
    font-size: clamp(4.5rem, 4.5rem + (0.1875rem) * (100cqw - 47rem) / 33rem, 4.6875rem);
  }
}
@container (min-width: 80rem) {
  .button--topbar {
    font-size: clamp(4.6875rem, 4.6875rem + (0.5625rem) * (100cqw - 80rem) / 40rem, 5.25rem);
  }
}
@container (min-width: 120rem) {
  .button--topbar {
    font-size: 5.25rem;
  }
}
@media (max-height: 480px) {
  .button--topbar {
    font-size: clamp(1.8125rem, 1.8125rem + (1.8125rem) * (100cqw - 28rem) / 19rem, 3.625rem);
  }
}
.button--topbar {
  font-family: var(--font-serif);
  background-color: var(--button-contact);
  color: var(--text);
  margin-top: auto;
  gap: 0.5em;
  align-items: center;
  padding: 0.5em 1em;
}
.button--topbar:hover, .button--topbar:focus-visible {
  background-color: var(--button-contact-hover);
}
.button--footer {
  font-size: 0.6875rem;
}
@container (min-width: 28rem) {
  .button--footer {
    font-size: clamp(0.6875rem, 0.6875rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .button--footer {
    font-size: clamp(0.875rem, 0.875rem + (0.125rem) * (100cqw - 47rem) / 33rem, 1rem);
  }
}
@container (min-width: 80rem) {
  .button--footer {
    font-size: clamp(1rem, 1rem + (0rem) * (100cqw - 80rem) / 40rem, 1rem);
  }
}
@container (min-width: 120rem) {
  .button--footer {
    font-size: 1rem;
  }
}
@media (max-height: 480px) {
  .button--footer {
    font-size: clamp(0.5625rem, 0.5625rem + (0.125rem) * (100cqw - 28rem) / 19rem, 0.6875rem);
  }
}
.button--footer {
  gap: 0.5em;
  align-items: center;
  margin-top: 0;
  padding: 0.5em 1.5em;
}
.button--footer:hover, .button--footer:focus-visible {
  background-color: var(--button-footer-hover);
}
.button--creative {
  font-size: 0.625rem;
}
@container (min-width: 28rem) {
  .button--creative {
    font-size: clamp(0.625rem, 0.625rem + (0.25rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .button--creative {
    font-size: clamp(0.875rem, 0.875rem + (0.25rem) * (100cqw - 47rem) / 33rem, 1.125rem);
  }
}
@container (min-width: 80rem) {
  .button--creative {
    font-size: clamp(1.125rem, 1.125rem + (0.125rem) * (100cqw - 80rem) / 40rem, 1.25rem);
  }
}
@container (min-width: 120rem) {
  .button--creative {
    font-size: 1.25rem;
  }
}
@media (max-height: 480px) {
  .button--creative {
    font-size: clamp(0.5rem, 0.5rem + (0.1875rem) * (100cqw - 28rem) / 19rem, 0.6875rem);
  }
}
.button--creative {
  background-color: var(--button-creative);
  align-self: flex-start;
}
.button--creative:hover, .button--creative:focus-visible {
  background-color: var(--button-creative-hover);
}

@media (orientation: landscape) and (min-width: 768px) {
  .button--topbar {
    font-size: 1.125rem;
  }
  @container (min-width: map.get($cq, c3)) {
    .button--topbar {
      font-size: 1.1875rem;
    }
  }
  .button--topbar {
    padding: 0.75em 2em;
    margin-top: 0;
  }
}
.butterfly {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: var(--project-section);
  height: var(--project-section);
}
.butterfly div {
  position: absolute;
  box-sizing: border-box;
}

.animations-init .featured,
.animations-init .project__hero,
.animations-init .project__hero-image,
.animiations-init .image__wrapper,
.animiations-init .image__content {
  opacity: 0;
}

.animations-init .bg-layers,
.animations-init .topbar,
.animations-init .hero__title,
.animations-init .hero__subtitle,
.animations-init .hero__explore,
.animations-init .hero__arrow,
.animations-init .featured__card {
  opacity: 0;
  transform: translateY(10px);
}

.animations-init .bg,
.animations-init .bg--base {
  opacity: 1;
  transform: none;
}

/* Motion reduction */
@media (prefers-reduced-motion: reduce) {
  .hamburger__bar {
    transition: none !important;
  }
  .featured .featured__img {
    transition: none !important;
  }
  .featured.is-in .project-card {
    transition: none !important;
  }
  .project-card {
    transform: none;
    opacity: 1;
  }
}

/*# sourceMappingURL=styles.css.map */
