/* ============================================================================== */
/* =                                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;
  --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-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;
  /* ================================ SITE ALIASES ================================ */
  /* ----------------------------------- COLORS ----------------------------------- */
  --bg: var(--bg-400);
  --bg-alt: var(--bg-600);
  --bg-nav: var(--bg-700);
  --bg-footer: var(--surface-900);
  --text: var(--text-1);
  --featured-label: var(--secondary-200);
  --button: var(--secondary-500);
  --button-hover: var(--secondary-400);
  --button-contact: var(--accent-orange-600);
  --button-contact-hover: var(--accent-orange-700);
  --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(--margin) * 2));
  --col-half: calc((var(--container) * 0.5) - (var(--gutter) * 0.5));
  --margin-h: 24px;
  --gutter-h: 48px;
  --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 {
  /* ================================= VARIABLES ================================== */
  --pattern-green: var(--primary-900);
  --pattern-dark-green: var(--secondary-900);
  --pattern-mint-1: var(--secondary-300);
  --pattern-mint-2: var(--secondary-200);
  --pattern-bright-orange: var(--accent-orange-500);
  --pattern-muted-orange: var(--accent-orange-700);
  --pattern-yellow: var(--accent-yellow-200);
  --pattern-brown: var(--accent-brown-800);
  --pattern-blue: var(--accent-seaglass-900);
  --pattern-dark-blue: var(--accent-blue-900);
  --pattern-seaglass-1: var(--accent-seaglass-500);
  --pattern-seaglass-2: var(--accent-seaglass-400);
  --pattern-bright-blue: var(--accent-blue-400);
  --pattern-muted-blue: var(--accent-blue-600);
  --pattern-light: var(--accent-seaglass-100);
  --pattern-bluegreen: var(--surface-800);
  --pattern-orange: var(--accent-peach-900);
  --pattern-dark-orange: var(--accent-orange-900);
  --pattern-peach-1: var(--accent-peach-500);
  --pattern-peach-2: var(--accent-peach-400);
  --pattern-bright-green: var(--secondary-400);
  --pattern-muted-green: var(--primary-700);
  --pattern-sun: var(--accent-yellow-100);
  --pattern-cloud: var(--accent-blue-400);
  --sheen-angle: 150deg;
  --sheen-start: 24.55%;
  --sheen-end: 79.09%;
  /* ================================== PATTERNS ================================== */
  --hero-main:
      linear-gradient(180.17deg,
          var(--bg-600) 32.8%,
          var(--bg-400) 99.85%);
  --hero-sheen:
      linear-gradient(180deg,
          color-mix(in srgb, color-mix(in srgb, var(--secondary-400) 21%, transparent) 40%, transparent) 0%,
          transparent 50%),
      linear-gradient(var(--sheen-angle),
          color-mix(in srgb, var(--text-1) 33%, transparent) var(--sheen-start),
          var(--secondary-400-21) var(--sheen-end));
  --hero-green:
      radial-gradient(ellipse 1100px 1000px at 40% 15%,
          color-mix(in srgb,
              var(--pattern-green) 60%,
              transparent 40%),
          transparent 100%),
      radial-gradient(ellipse 600px 400px at 66% 40%,
          color-mix(in srgb,
              var(--pattern-green) 50%,
              transparent 50%),
          transparent 100%);
  --hero-dark-green:
      radial-gradient(ellipse 1200px 700px at 30% 15%,
          color-mix(in srgb,
              var(--pattern-dark-green) 95%,
              transparent 5%),
          transparent 100%),
      radial-gradient(ellipse 1000px 400px at 70% 40%,
          color-mix(in srgb,
              var(--pattern-dark-green) 95%,
              transparent 5%),
          transparent 100%);
}

/* ============================== HELPER FUNCTIONS ============================== */
/* ============================================================================== */
/* =                                   MIXINS                                   = */
/* ============================================================================== */
/* ============================== SITE BACKGROUND =============================== */
/* ================================ FONT SIZING ================================= */
/* =============================== COLUMN SIZING ================================ */
/* ============================================================================== */
/* =                                    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: var(--gutter);
}

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;
  width: 100%;
  pointer-events: none;
  z-index: 0;
}

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

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

.bg--hero-sheen {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--hero-sheen);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 3840px 2160px;
  mix-blend-mode: lighten;
  opacity: 0.12;
  z-index: 2;
}

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

.bg--hero-green {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--hero-green);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 3840px 2160px;
  mix-blend-mode: normal;
  opacity: 1;
  z-index: 4;
}

.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 (max-height: 480px) {
  .bg--hero-sheen {
    opacity: 0.11;
    background-size: 932px 430px;
  }
  .bg--hero-dark-green {
    opacity: 0.2;
    background-size: 932px 430px;
  }
}
.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__logo {
  height: 48px;
  width: 48px;
  display: block;
}
.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) 45%, rgba(50, 50, 50, 0.5) 55%, rgba(25, 25, 25, 0.7) 75%, rgba(0, 0, 0, 0.9) 100%);
  right: 0;
  top: 0;
}
.featured__mask--left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0) 45%, rgba(50, 50, 50, 0.5) 55%, rgba(25, 25, 25, 0.7) 75%, rgba(0, 0, 0, 0.9) 100%);
  left: 0;
  top: 0;
}
.featured__label {
  font-size: 1rem;
}
@container (min-width: 28rem) {
  .featured__label {
    font-size: clamp(1rem, 1rem + (0.5rem) * (100cqw - 28rem) / 19rem, 1.5rem);
  }
}
@container (min-width: 47rem) {
  .featured__label {
    font-size: clamp(1.5rem, 1.5rem + (0.375rem) * (100cqw - 47rem) / 33rem, 1.875rem);
  }
}
@container (min-width: 80rem) {
  .featured__label {
    font-size: clamp(1.875rem, 1.875rem + (0.8125rem) * (100cqw - 80rem) / 40rem, 2.6875rem);
  }
}
@container (min-width: 120rem) {
  .featured__label {
    font-size: 2.6875rem;
  }
}
.featured__label {
  font-family: var(--font-display);
  font-weight: 400;
  display: block;
  color: var(--featured-label);
}
.featured__title {
  font-size: 1rem;
}
@container (min-width: 28rem) {
  .featured__title {
    font-size: clamp(1rem, 1rem + (0.5rem) * (100cqw - 28rem) / 19rem, 1.5rem);
  }
}
@container (min-width: 47rem) {
  .featured__title {
    font-size: clamp(1.5rem, 1.5rem + (0.375rem) * (100cqw - 47rem) / 33rem, 1.875rem);
  }
}
@container (min-width: 80rem) {
  .featured__title {
    font-size: clamp(1.875rem, 1.875rem + (0.8125rem) * (100cqw - 80rem) / 40rem, 2.6875rem);
  }
}
@container (min-width: 120rem) {
  .featured__title {
    font-size: 2.6875rem;
  }
}
.featured__button {
  font-size: 1rem;
}
@container (min-width: 28rem) {
  .featured__button {
    font-size: clamp(1rem, 1rem + (0.125rem) * (100cqw - 28rem) / 19rem, 1.125rem);
  }
}
@container (min-width: 47rem) {
  .featured__button {
    font-size: clamp(1.125rem, 1.125rem + (0.0625rem) * (100cqw - 47rem) / 33rem, 1.1875rem);
  }
}
@container (min-width: 80rem) {
  .featured__button {
    font-size: clamp(1.1875rem, 1.1875rem + (0.0625rem) * (100cqw - 80rem) / 40rem, 1.25rem);
  }
}
@container (min-width: 120rem) {
  .featured__button {
    font-size: 1.25rem;
  }
}
.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 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);
}
.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 {
    height: min(var(--container), 1872px);
    width: auto;
  }
  .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) 0%, rgba(50, 50, 50, 0.5) 66%, rgba(25, 25, 25, 0.7) 75%, rgba(0, 0, 0, 0.9) 100%);
  }
  .featured__mask--left {
    background-image: linear-gradient(to left, rgba(0, 0, 0, 0) 45%, rgba(50, 50, 50, 0.5) 55%, rgba(25, 25, 25, 0.7) 75%, rgba(0, 0, 0, 0.9) 100%);
  }
  .featured__other {
    display: flex;
    justify-content: space-between;
    width: min(var(--container), 1872px);
  }
  .featured__other > * {
    width: min(var(--col-half), 1872px);
  }
}
@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);
  }
}
.footer {
  margin-inline: 0;
  padding-inline: 0;
  max-width: 100svw;
  container-type: inline-size;
  margin-bottom: 0;
}
.footer__inner {
  display: flex;
  flex-direction: column;
}
.footer__connect {
  display: flex;
  flex-direction: column;
  --width: calc(var(--cols) * var(--col) + (var(--cols) - 1) * var(--gutter));
}
.footer__connect > * {
  width: 100%;
  max-width: var(--width);
  flex: 0 0 auto;
  display: flex;
  align-self: center;
  justify-content: center;
  align-items: center;
  text-align: center;
}
@media (orientation: landscape) {
  .footer__connect {
    flex-direction: row;
    justify-content: space-around;
    --width: calc(((var(--cols) / 2) * var(--col)) + (((var(--cols) / 2) - 1) * var(--gutter)));
  }
  .footer__connect > * {
    flex: 0 0 var(--width);
    max-width: var(--width);
  }
}
.footer__connect {
  width: 100svw;
  align-self: center;
  background-color: var(--button-contact);
  padding-inline: var(--margin);
  margin-bottom: calc(var(--gutter-h) * 0.5);
  cursor: pointer;
  transition: color 0.3s ease;
}
.footer__connect:hover .footer__arrow,
.footer__connect .footer__arrow.nudge {
  transform: translateX(50%) rotate(0deg);
}
.footer__connect:hover .footer__connect {
  background-color: var(--button-contact-hover);
}
.footer__header {
  font-size: 1.1875rem;
}
@container (min-width: 28rem) {
  .footer__header {
    font-size: clamp(1.1875rem, 1.1875rem + (1rem) * (100cqw - 28rem) / 19rem, 2.1875rem);
  }
}
@container (min-width: 47rem) {
  .footer__header {
    font-size: clamp(2.1875rem, 2.1875rem + (0.6875rem) * (100cqw - 47rem) / 33rem, 2.875rem);
  }
}
@container (min-width: 80rem) {
  .footer__header {
    font-size: clamp(2.875rem, 2.875rem + (0.375rem) * (100cqw - 80rem) / 40rem, 3.25rem);
  }
}
@container (min-width: 120rem) {
  .footer__header {
    font-size: 3.25rem;
  }
}
.footer__header {
  margin: 0.5em 0;
  display: flex;
  align-items: center;
}
.footer__arrow {
  font-size: 1.5rem;
}
@container (min-width: 28rem) {
  .footer__arrow {
    font-size: clamp(1.5rem, 1.5rem + (1.1875rem) * (100cqw - 28rem) / 19rem, 2.6875rem);
  }
}
@container (min-width: 47rem) {
  .footer__arrow {
    font-size: clamp(2.6875rem, 2.6875rem + (0.9375rem) * (100cqw - 47rem) / 33rem, 3.625rem);
  }
}
@container (min-width: 80rem) {
  .footer__arrow {
    font-size: clamp(3.625rem, 3.625rem + (0.4375rem) * (100cqw - 80rem) / 40rem, 4.0625rem);
  }
}
@container (min-width: 120rem) {
  .footer__arrow {
    font-size: 4.0625rem;
  }
}
.footer__arrow {
  display: inline-block;
  font-family: var(--font-arrow);
  transform: translateX(0);
  transition: transform 0.3s ease;
  transform: rotate(-90deg);
}
.footer__email {
  font-size: 1.1875rem;
}
@container (min-width: 28rem) {
  .footer__email {
    font-size: clamp(1.1875rem, 1.1875rem + (1rem) * (100cqw - 28rem) / 19rem, 2.1875rem);
  }
}
@container (min-width: 47rem) {
  .footer__email {
    font-size: clamp(2.1875rem, 2.1875rem + (0.6875rem) * (100cqw - 47rem) / 33rem, 2.875rem);
  }
}
@container (min-width: 80rem) {
  .footer__email {
    font-size: clamp(2.875rem, 2.875rem + (0.375rem) * (100cqw - 80rem) / 40rem, 3.25rem);
  }
}
@container (min-width: 120rem) {
  .footer__email {
    font-size: 3.25rem;
  }
}
.footer__email {
  color: var(--text);
  transition: color 0.3s ease;
  display: flex;
  align-items: center;
  margin-inline: 0;
}
.footer__email.copied {
  color: var(--text);
}
.footer__endbar {
  background-color: color-mix(in srgb, var(--bg-footer) 50%, transparent);
  display: flex;
  flex-direction: column;
  --width: calc(var(--cols) * var(--col) + (var(--cols) - 1) * var(--gutter));
}
.footer__endbar > * {
  width: 100%;
  max-width: var(--width);
  flex: 0 0 auto;
  display: flex;
  align-self: center;
  justify-content: center;
  align-items: center;
  text-align: center;
}
@media (orientation: landscape) {
  .footer__endbar {
    flex-direction: row;
    justify-content: space-around;
    --width: calc(((var(--cols) / 2) * var(--col)) + (((var(--cols) / 2) - 1) * var(--gutter)));
  }
  .footer__endbar > * {
    flex: 0 0 var(--width);
    max-width: var(--width);
  }
}
.footer__endbar {
  display: flex;
  margin-top: 1em;
  margin-bottom: 0;
}
.footer__copyright {
  font-size: 0.75rem;
}
@container (min-width: 28rem) {
  .footer__copyright {
    font-size: clamp(0.75rem, 0.75rem + (0.125rem) * (100cqw - 28rem) / 19rem, 0.875rem);
  }
}
@container (min-width: 47rem) {
  .footer__copyright {
    font-size: clamp(0.875rem, 0.875rem + (0.125rem) * (100cqw - 47rem) / 33rem, 1rem);
  }
}
@container (min-width: 80rem) {
  .footer__copyright {
    font-size: clamp(1rem, 1rem + (0rem) * (100cqw - 80rem) / 40rem, 1rem);
  }
}
@container (min-width: 120rem) {
  .footer__copyright {
    font-size: 1rem;
  }
}
.footer__copyright {
  color: var(--text-2);
}
.footer__links {
  display: flex;
  justify-content: space-evenly;
}
.footer__link {
  font-size: 0.75rem;
}
@container (min-width: 28rem) {
  .footer__link {
    font-size: clamp(0.75rem, 0.75rem + (0.125rem) * (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;
  }
}
.footer__link {
  color: var(--text);
  text-decoration: none;
}
.footer__link:hover, .footer__link:focus-visible {
  color: var(--text-2);
  outline: none;
}
.footer p {
  margin: 0.5em;
  margin-block: 1em;
}

@media (orientation: landscape) {
  .footer__connect {
    width: var(--container);
    border-radius: 2rem;
  }
  .footer__connect:hover .footer__arrow,
  .footer .footer__arrow.nudge {
    transform: rotate(-90deg) translateY(50%);
  }
  .footer__copyright {
    justify-self: flex-start;
  }
  .footer__email {
    align-self: center;
  }
  .footer__endbar {
    flex-direction: row;
    margin: 0.5em 0;
    max-height: var(margin-h);
    margin-bottom: 0;
  }
  .footer p {
    margin: 1em;
  }
}
.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: 1.5rem;
}
@container (min-width: 28rem) {
  .nav__link {
    font-size: clamp(1.5rem, 1.5rem + (1.1875rem) * (100cqw - 28rem) / 19rem, 2.6875rem);
  }
}
@container (min-width: 47rem) {
  .nav__link {
    font-size: clamp(2.6875rem, 2.6875rem + (0.9375rem) * (100cqw - 47rem) / 33rem, 3.625rem);
  }
}
@container (min-width: 80rem) {
  .nav__link {
    font-size: clamp(3.625rem, 3.625rem + (0.4375rem) * (100cqw - 80rem) / 40rem, 4.0625rem);
  }
}
@container (min-width: 120rem) {
  .nav__link {
    font-size: 4.0625rem;
  }
}
.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;
}
.nav__link--contact {
  background-color: var(--button-contact);
  color: var(--text);
  align-self: center;
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5em 1.25em;
  border-radius: 9999px;
  font-weight: 600;
  text-align: center;
  white-space: nowrap;
  transition: background-color 0.2s ease, transform 0.1s ease;
}
.nav__link--contact:hover, .nav__link--contact:focus-visible {
  background-color: var(--button-contact-hover);
  color: var(--text);
  outline: none;
}

@media (orientation: landscape) and (min-width: 768px) {
  .nav {
    width: calc(1280px / 2.5);
    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-between;
    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 (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;
    }
  }
}
.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;
  }
}
.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.125rem;
}
@container (min-width: 28rem) {
  .hero__subtitle {
    font-size: clamp(1.125rem, 1.125rem + (0.875rem) * (100cqw - 28rem) / 19rem, 2rem);
  }
}
@container (min-width: 47rem) {
  .hero__subtitle {
    font-size: clamp(2rem, 2rem + (0.5rem) * (100cqw - 47rem) / 33rem, 2.5rem);
  }
}
@container (min-width: 80rem) {
  .hero__subtitle {
    font-size: clamp(2.5rem, 2.5rem + (0.875rem) * (100cqw - 80rem) / 40rem, 3.375rem);
  }
}
@container (min-width: 120rem) {
  .hero__subtitle {
    font-size: 3.375rem;
  }
}
.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;
  flex-direction: column;
  justify-self: flex-end;
  align-self: end;
}
.hero__arrow {
  color: var(--hero-arrow);
  font-family: var(--font-arrow);
  font-size: calc(var(--gutter-h));
  display: inline-flex;
  align-items: flex-start;
}
.hero__explore {
  font-size: 1rem;
}
@container (min-width: 28rem) {
  .hero__explore {
    font-size: clamp(1rem, 1rem + (0.5rem) * (100cqw - 28rem) / 19rem, 1.5rem);
  }
}
@container (min-width: 47rem) {
  .hero__explore {
    font-size: clamp(1.5rem, 1.5rem + (0.375rem) * (100cqw - 47rem) / 33rem, 1.875rem);
  }
}
@container (min-width: 80rem) {
  .hero__explore {
    font-size: clamp(1.875rem, 1.875rem + (0.8125rem) * (100cqw - 80rem) / 40rem, 2.6875rem);
  }
}
@container (min-width: 120rem) {
  .hero__explore {
    font-size: 2.6875rem;
  }
}
.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: 5px;
  }
  .hero__subtitle {
    margin: 0;
  }
  .hero__break {
    display: inline;
  }
  .hero__break2 {
    display: block;
  }
  .hero__pointer {
    min-width: calc(1280px / 2.5);
  }
}
@media (max-height: 480px) {
  .hero__pointer {
    min-width: auto;
    position: absolute;
    bottom: clamp(8px, 2vh, 24px);
  }
  .hero__inner {
    position: relative;
  }
}
.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 {
  opacity: 0;
  transform: translateY(10px);
}

/* 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 */
