/* @link https://utopia.fyi/type/calculator?c=360,16,1.2,800,18,1.25,5,2,&s=0.75|0.5|0.25,1.5|2|3|4|6,s-l&g=s,l,xl,12 */

:root {
  /* Font sizes */
  --step--2: clamp(0.6944rem, 0.6735rem + 0.0929vw, 0.72rem);
  --step--1: clamp(0.8333rem, 0.7788rem + 0.2424vw, 0.9rem);
  --step-0: clamp(1rem, 0.8977rem + 0.4545vw, 1.125rem);
  --step-1: clamp(1.2rem, 1.0313rem + 0.75vw, 1.4063rem);
  --step-2: clamp(1.44rem, 1.18rem + 1.1557vw, 1.7578rem);
  --step-3: clamp(1.728rem, 1.3441rem + 1.7064vw, 2.1973rem);
  --step-4: clamp(2.0736rem, 1.523rem + 2.4472vw, 2.7466rem);
  --step-5: clamp(2.4883rem, 1.7152rem + 3.436vw, 3.4332rem);

  /* Spacing */
  --space-3xs: clamp(0.25rem, 0.1989rem + 0.2273vw, 0.3125rem);
  --space-2xs: clamp(0.5rem, 0.4489rem + 0.2273vw, 0.5625rem);
  --space-xs: clamp(0.75rem, 0.6477rem + 0.4545vw, 0.875rem);
  --space-s: clamp(1rem, 0.8977rem + 0.4545vw, 1.125rem);
  --space-m: clamp(1.5rem, 1.3466rem + 0.6818vw, 1.6875rem);
  --space-l: clamp(2rem, 1.7955rem + 0.9091vw, 2.25rem);
  --space-xl: clamp(3rem, 2.6932rem + 1.3636vw, 3.375rem);
  --space-2xl: clamp(4rem, 3.5909rem + 1.8182vw, 4.5rem);
  --space-3xl: clamp(6rem, 5.3864rem + 2.7273vw, 6.75rem);

  /* One-up pairs */
  --space-3xs-2xs: clamp(0.25rem, -0.0057rem + 1.1364vw, 0.5625rem);
  --space-2xs-xs: clamp(0.5rem, 0.1932rem + 1.3636vw, 0.875rem);
  --space-xs-s: clamp(0.75rem, 0.4432rem + 1.3636vw, 1.125rem);
  --space-s-m: clamp(1rem, 0.4375rem + 2.5vw, 1.6875rem);
  --space-m-l: clamp(1.5rem, 0.8864rem + 2.7273vw, 2.25rem);
  --space-l-xl: clamp(2rem, 0.875rem + 5vw, 3.375rem);
  --space-xl-2xl: clamp(3rem, 1.7727rem + 5.4545vw, 4.5rem);
  --space-2xl-3xl: clamp(4rem, 1.75rem + 10vw, 6.75rem);

  /* Grid */
  --grid-max-width: 69.75rem;
  --grid-gutter: var(--space-s-l, clamp(1rem, 0.4048rem + 2.6455vw, 2.25rem));
  --grid-columns: 12;

  /* Clamp */
  --fluid-16-48: clamp(1rem, -0.6364rem + 7.2727vw, 3rem);

  --color-red: #E30027;
  --color-white: #FFFFFF;
  --color-black: #000000;
  --color-orange: #f59300;
  --color-blue: #0050a5;
  --color-green: #009800;
  --focus-ring-color: #ffffff;
  --focus-ring-shadow: #000000;
}

/* =========================
   Typography utilities
   ========================= */

.fs--2 { font-size: var(--step--2); }
.fs--1 { font-size: var(--step--1); }
.fs-0  { font-size: var(--step-0); }
.fs-1  { font-size: var(--step-1); }
.fs-2  { font-size: var(--step-2); }
.fs-3  { font-size: var(--step-3); }
.fs-4  { font-size: var(--step-4); }
.fs-5  { font-size: var(--step-5); }
.fw-300 { font-weight: 300; }
.fw-400 { font-weight: 400; }
.fw-500 { font-weight: 500; }

/* Optional semantic aliases */
.text-xs   { font-size: var(--step--1); }
.text-sm   { font-size: var(--step-0); }
.text-base { font-size: var(--step-1); }
.text-lg   { font-size: var(--step-2); }
.text-xl   { font-size: var(--step-3); }
.text-2xl  { font-size: var(--step-4); }
.text-3xl  { font-size: var(--step-5); }

.lh-110 { line-height: 110%; }
.lh-120 { line-height: 120%; }


/* =========================
   Margin utilities
   ========================= */

/* 3xs */
.m-3xs  { margin: var(--space-3xs); }
.mt-3xs { margin-top: var(--space-3xs); }
.mr-3xs { margin-right: var(--space-3xs); }
.mb-3xs { margin-bottom: var(--space-3xs); }
.ml-3xs { margin-left: var(--space-3xs); }
.mx-3xs { margin-left: var(--space-3xs); margin-right: var(--space-3xs); }
.my-3xs { margin-top: var(--space-3xs); margin-bottom: var(--space-3xs); }

/* 2xs */
.m-2xs  { margin: var(--space-2xs); }
.mt-2xs { margin-top: var(--space-2xs); }
.mr-2xs { margin-right: var(--space-2xs); }
.mb-2xs { margin-bottom: var(--space-2xs); }
.ml-2xs { margin-left: var(--space-2xs); }
.mx-2xs { margin-left: var(--space-2xs); margin-right: var(--space-2xs); }
.my-2xs { margin-top: var(--space-2xs); margin-bottom: var(--space-2xs); }

/* xs */
.m-xs  { margin: var(--space-xs); }
.mt-xs { margin-top: var(--space-xs); }
.mr-xs { margin-right: var(--space-xs); }
.mb-xs { margin-bottom: var(--space-xs); }
.ml-xs { margin-left: var(--space-xs); }
.mx-xs { margin-left: var(--space-xs); margin-right: var(--space-xs); }
.my-xs { margin-top: var(--space-xs); margin-bottom: var(--space-xs); }

/* s */
.m-s  { margin: var(--space-s); }
.mt-s { margin-top: var(--space-s); }
.mr-s { margin-right: var(--space-s); }
.mb-s { margin-bottom: var(--space-s); }
.ml-s { margin-left: var(--space-s); }
.mx-s { margin-left: var(--space-s); margin-right: var(--space-s); }
.my-s { margin-top: var(--space-s); margin-bottom: var(--space-s); }

/* m */
.m-m  { margin: var(--space-m); }
.mt-m { margin-top: var(--space-m); }
.mr-m { margin-right: var(--space-m); }
.mb-m { margin-bottom: var(--space-m); }
.ml-m { margin-left: var(--space-m); }
.mx-m { margin-left: var(--space-m); margin-right: var(--space-m); }
.my-m { margin-top: var(--space-m); margin-bottom: var(--space-m); }

/* l */
.m-l  { margin: var(--space-l); }
.mt-l { margin-top: var(--space-l); }
.mr-l { margin-right: var(--space-l); }
.mb-l { margin-bottom: var(--space-l); }
.ml-l { margin-left: var(--space-l); }
.mx-l { margin-left: var(--space-l); margin-right: var(--space-l); }
.my-l { margin-top: var(--space-l); margin-bottom: var(--space-l); }

/* xl */
.m-xl  { margin: var(--space-xl); }
.mt-xl { margin-top: var(--space-xl); }
.mr-xl { margin-right: var(--space-xl); }
.mb-xl { margin-bottom: var(--space-xl); }
.ml-xl { margin-left: var(--space-xl); }
.mx-xl { margin-left: var(--space-xl); margin-right: var(--space-xl); }
.my-xl { margin-top: var(--space-xl); margin-bottom: var(--space-xl); }

/* 2xl */
.m-2xl  { margin: var(--space-2xl); }
.mt-2xl { margin-top: var(--space-2xl); }
.mr-2xl { margin-right: var(--space-2xl); }
.mb-2xl { margin-bottom: var(--space-2xl); }
.ml-2xl { margin-left: var(--space-2xl); }
.mx-2xl { margin-left: var(--space-2xl); margin-right: var(--space-2xl); }
.my-2xl { margin-top: var(--space-2xl); margin-bottom: var(--space-2xl); }

/* 3xl */
.m-3xl  { margin: var(--space-3xl); }
.mt-3xl { margin-top: var(--space-3xl); }
.mr-3xl { margin-right: var(--space-3xl); }
.mb-3xl { margin-bottom: var(--space-3xl); }
.ml-3xl { margin-left: var(--space-3xl); }
.mx-3xl { margin-left: var(--space-3xl); margin-right: var(--space-3xl); }
.my-3xl { margin-top: var(--space-3xl); margin-bottom: var(--space-3xl); }



/* =========================
   Padding utilities
   ========================= */

/* 3xs */
.p-3xs  { padding: var(--space-3xs); }
.pt-3xs { padding-top: var(--space-3xs); }
.pr-3xs { padding-right: var(--space-3xs); }
.pb-3xs { padding-bottom: var(--space-3xs); }
.pl-3xs { padding-left: var(--space-3xs); }
.px-3xs { padding-left: var(--space-3xs); padding-right: var(--space-3xs); }
.py-3xs { padding-top: var(--space-3xs); padding-bottom: var(--space-3xs); }

/* 2xs */
.p-2xs  { padding: var(--space-2xs); }
.pt-2xs { padding-top: var(--space-2xs); }
.pr-2xs { padding-right: var(--space-2xs); }
.pb-2xs { padding-bottom: var(--space-2xs); }
.pl-2xs { padding-left: var(--space-2xs); }
.px-2xs { padding-left: var(--space-2xs); padding-right: var(--space-2xs); }
.py-2xs { padding-top: var(--space-2xs); padding-bottom: var(--space-2xs); }

/* xs */
.p-xs  { padding: var(--space-xs); }
.pt-xs { padding-top: var(--space-xs); }
.pr-xs { padding-right: var(--space-xs); }
.pb-xs { padding-bottom: var(--space-xs); }
.pl-xs { padding-left: var(--space-xs); }
.px-xs { padding-left: var(--space-xs); padding-right: var(--space-xs); }
.py-xs { padding-top: var(--space-xs); padding-bottom: var(--space-xs); }

/* s */
.p-s  { padding: var(--space-s); }
.pt-s { padding-top: var(--space-s); }
.pr-s { padding-right: var(--space-s); }
.pb-s { padding-bottom: var(--space-s); }
.pl-s { padding-left: var(--space-s); }
.px-s { padding-left: var(--space-s); padding-right: var(--space-s); }
.py-s { padding-top: var(--space-s); padding-bottom: var(--space-s); }

/* m */
.p-m  { padding: var(--space-m); }
.pt-m { padding-top: var(--space-m); }
.pr-m { padding-right: var(--space-m); }
.pb-m { padding-bottom: var(--space-m); }
.pl-m { padding-left: var(--space-m); }
.px-m { padding-left: var(--space-m); padding-right: var(--space-m); }
.py-m { padding-top: var(--space-m); padding-bottom: var(--space-m); }

/* l */
.p-l  { padding: var(--space-l); }
.pt-l { padding-top: var(--space-l); }
.pr-l { padding-right: var(--space-l); }
.pb-l { padding-bottom: var(--space-l); }
.pl-l { padding-left: var(--space-l); }
.px-l { padding-left: var(--space-l); padding-right: var(--space-l); }
.py-l { padding-top: var(--space-l); padding-bottom: var(--space-l); }

/* xl */
.p-xl  { padding: var(--space-xl); }
.pt-xl { padding-top: var(--space-xl); }
.pr-xl { padding-right: var(--space-xl); }
.pb-xl { padding-bottom: var(--space-xl); }
.pl-xl { padding-left: var(--space-xl); }
.px-xl { padding-left: var(--space-xl); padding-right: var(--space-xl); }
.py-xl { padding-top: var(--space-xl); padding-bottom: var(--space-xl); }

/* 2xl */
.p-2xl  { padding: var(--space-2xl); }
.pt-2xl { padding-top: var(--space-2xl); }
.pr-2xl { padding-right: var(--space-2xl); }
.pb-2xl { padding-bottom: var(--space-2xl); }
.pl-2xl { padding-left: var(--space-2xl); }
.px-2xl { padding-left: var(--space-2xl); padding-right: var(--space-2xl); }
.py-2xl { padding-top: var(--space-2xl); padding-bottom: var(--space-2xl); }

/* 3xl */
.p-3xl  { padding: var(--space-3xl); }
.pt-3xl { padding-top: var(--space-3xl); }
.pr-3xl { padding-right: var(--space-3xl); }
.pb-3xl { padding-bottom: var(--space-3xl); }
.pl-3xl { padding-left: var(--space-3xl); }
.px-3xl { padding-left: var(--space-3xl); padding-right: var(--space-3xl); }
.py-3xl { padding-top: var(--space-3xl); padding-bottom: var(--space-3xl); }


/* =========================
   Gap utilities
   ========================= */

.gap-3xs { gap: var(--space-3xs); }
.gap-2xs { gap: var(--space-2xs); }
.gap-xs  { gap: var(--space-xs); }
.gap-s   { gap: var(--space-s); }
.gap-m   { gap: var(--space-m); }
.gap-l   { gap: var(--space-l); }
.gap-xl  { gap: var(--space-xl); }
.gap-2xl { gap: var(--space-2xl); }
.gap-3xl { gap: var(--space-3xl); }

.row-gap-3xs { row-gap: var(--space-3xs); }
.row-gap-2xs { row-gap: var(--space-2xs); }
.row-gap-xs  { row-gap: var(--space-xs); }
.row-gap-s   { row-gap: var(--space-s); }
.row-gap-m   { row-gap: var(--space-m); }
.row-gap-l   { row-gap: var(--space-l); }
.row-gap-xl  { row-gap: var(--space-xl); }
.row-gap-2xl { row-gap: var(--space-2xl); }
.row-gap-3xl { row-gap: var(--space-3xl); }

.col-gap-3xs { column-gap: var(--space-3xs); }
.col-gap-2xs { column-gap: var(--space-2xs); }
.col-gap-xs  { column-gap: var(--space-xs); }
.col-gap-s   { column-gap: var(--space-s); }
.col-gap-m   { column-gap: var(--space-m); }
.col-gap-l   { column-gap: var(--space-l); }
.col-gap-xl  { column-gap: var(--space-xl); }
.col-gap-2xl { column-gap: var(--space-2xl); }
.col-gap-3xl { column-gap: var(--space-3xl); }

.u-container {
  max-width: var(--grid-max-width);
  padding-inline: var(--grid-gutter);
  margin-inline: auto;
}

.skip-link {
  position: absolute;
  left: var(--space-s);
  top: var(--space-s);
  z-index: 1000;
  background-color: var(--color-white);
  color: var(--color-black);
  padding: var(--space-2xs) var(--space-s);
  border-radius: 8px;
  text-decoration: none;
  transform: translateY(-200%);
}

.skip-link:focus {
  transform: translateY(0);
}

.u-grid {
  display: grid;
  gap: var(--grid-gutter);
}

/* =========================
   Fonts
   ========================= */

@font-face {
  font-family: "PostcodeLottery";
  src: url("/fonts/PostcodeLottery-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "PostcodeLottery";
  src: url("/fonts/PostcodeLottery-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "PostcodeLottery";
  src: url("/fonts/PostcodeLottery-SemiBold.otf") format("opentype");
  font-weight: 600;
  font-style: normal;
}


/* =========================
   input reset
   ========================= */

button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
}

button,
input[type="button"],
input[type="submit"],
input[type="reset"] {
  all: unset;
  box-sizing: border-box;
  display: inline-block;
  cursor: pointer;
}

button:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible,
label:has(input:focus-visible) {
  outline: 3px solid var(--focus-ring-color);
  outline-offset: 3px;
  box-shadow: 0 0 0 6px var(--focus-ring-shadow);
}

.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

input:not([type="checkbox"]) {
  border: none;
  border-radius: 4px;
  padding: var(--space-xs) var(--space-s);
  font-size: var(--step-0);
  color: black;
}

.button {
  border-radius: 8px;
  padding: var(--space-xs) var(--space-m);
  line-height: 1;
  font-size: var(--step-0);
  font-weight: 600;
  &.button-white {
    background-color: var(--color-white);
    color: var(--color-black);
  }
  &.button-flex {
    display: flex;
    align-items: center;
    gap: 8px;
  }
  &.button-transparent {
    background-color: transparent;
    color: var(--color-white);
    border: 1px white solid;
  }
}

/* =========================
   Common custom styles
   ========================= */

.text-center {
  text-align: center;
}
.text-right, .text-end {
  text-align: end;
}

/* =========================
   Layout
   ========================= */

.main {
  display: flex;
  flex-direction: column;
  min-height: calc(100dvh - 64px);
  /* @media (min-width: 768px) {
    min-height: calc(100dvh - 120px);
  } */
}

body {
  background-color: var(--color-red);
  color: white;
  font-family: "PostcodeLottery", serif;
  &.start {
    background-image: url("/images/backgrounds/landing-page-bg-lines.svg");
    background-size: cover;
    background-position: center;
  }
  &.red {
    background-image: url("/images/backgrounds/page-red-bg.svg");
    background-size: cover;
    background-position: center;
  }
  &.blue {
    background-image: url("/images/backgrounds/challenge-page-blue-bg.svg");
    background-size: cover;
    background-position: center;
  }
  &.green {
    background-image: url("/images/backgrounds/challenge-page-green-bg.svg");
    background-size: cover;
    background-position: center;
  }
  &.yellow {
    background-image: url("/images/backgrounds/challenge-page-yellow-bg.svg");
    background-size: cover;
    background-position: center;
  }
  &.leaderboard {
    background-image: url("/images/backgrounds/leaderboard-page-bg.svg");
    background-size: cover;
    background-position: center;
  }
}

.bold {
  font-weight: 700;
}

/* =========================
   Menu 
   ========================= */
.menu-bar {
  /* background-color: var(--color-red); */
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 64px;
  padding-left: var(--grid-gutter);
  padding-right: var(--grid-gutter);
  .menu-user {
    display: flex;
    align-items: center;
    gap: var(--space-s);
    color: var(--color-white);
    .user-info {
      display: flex;
      flex-direction: row;
      justify-content: flex-start;
      align-items: center;
      font-weight: 500;
      font-family: "gotham-xnarrow";
      line-height: 120%;
        font-size: var(--step--1);
      gap: var(--space-2xs);
      .user-image {
        border-radius: 100px;
        width: 26px;
        height: 26px;
        border: 1px solid var(--color-white);
      }
      .user-name {
        text-transform: uppercase;
      }
      .user-score {
        background-color: rgba(255, 255, 255, 0.4);      
        padding: 0 6px;
        border-radius: 100px;  
      }
    }
  }
}

/* =========================
   Mobile menu
   ========================= */

.menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.menu-toggle img,
.menu-home-link img {
  display: block;
}

.menu-home-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.mobile-menu-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.3);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 20;
}

.mobile-menu-overlay[hidden] {
  display: none;
}

.mobile-menu {
  --mobile-menu-width: min(80dvw, 400px);
  position: fixed;
  top: 0;
  left: 0;
  width: var(--mobile-menu-width);
  height: 100dvh;
  background-color: var(--color-red);
  color: var(--color-white);
  box-sizing: border-box;
  padding: calc(64px + var(--space-m)) calc(var(--mobile-menu-width) * 0.20) var(--space-m);
  transform: translateX(-100%);
  transition: transform 0.2s ease;
  z-index: 30;
  overflow: hidden;
}
.mobile-menu-header {
  font-family: 'gotham-xnarrow';
  font-size: var(--step--1);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.60);
  text-transform: uppercase;
}
.mobile-menu-separator {
  height: 1px;
  width:100%;
  background-color: var(--color-white);
}

.mobile-menu-close {
  position: absolute;
  top: var(--space-m);
  left: var(--space-m);
  font-size: var(--step-2);
  line-height: 1;
  z-index: 1;
}

.mobile-menu-nav {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
}

.mobile-menu-nav a {
  color: var(--color-white);
  text-decoration: none;
  font-size: var(--step-1);
  font-weight: 400;
  &.fs-0 {
    font-size: var(--step-0) !important;
    color: white;
  }
}

body.menu-open .mobile-menu-overlay {
  opacity: 1;
  pointer-events: auto;
}

body.menu-open .mobile-menu {
  transform: translateX(0);
}

/* =========================
   Modal
   ========================= */
.site-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--space-m);
  z-index: 40;
  color: var(--color-black)
}

.site-modal.is-visible {
  display: flex;
}

.site-modal-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.3);
}

.site-modal-panel {
  position: relative;
  width: min(100%, 32rem);
  background-color: var(--color-white);
  border-radius: 3px;
  padding: var(--space-l);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
  z-index: 1;
}

.site-modal-close {
  position: absolute;
  top: var(--space-s);
  right: var(--space-s);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
}

.site-modal-close img {
  display: block;
  width: 24px;
  height: 24px;
}

.site-modal-header {
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: var(--space-2xs);
  margin-bottom: var(--space-m);
  .label {
    font-size: var(--step-0);
    line-height: 120%;
    font-weight: 700;
  }
  .header {
    font-size: var(--step-2);
    line-height: 120%;
    font-weight: 700;
  }
}

.site-modal-title {
  margin: 10px 0 var(--space-xs);
  font-size: var(--step-2);
  line-height: 1.2;
}

.site-modal-message {
  margin: 0;
  color: var(--color-black);
}

.site-modal-footer {
  margin-top: var(--space-l);
  display: flex;
  justify-content: flex-end;
}

/* =========================
   Start page
   ========================= */

.start-text {
  margin-top: var(--space-xl);
  margin-left: var(--space-m);
  margin-right: var(--space-m);
  font-size: var(--step-2);
  line-height: 120%;
}
.start-more {
  font-size: var(--step-0);
  line-height: 120%;
  font-weight: 700;
  button {
    color: var(--color-white);
    text-decoration: underline;
    background: none;
  }
}
.startlogo {
  width: 90%;
  max-width: 300px;
}

/* =========================
   Register
   ========================= */

.register-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-m);
  margin-bottom: var(--space-xl);
}

.register-avatar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}

.register-back {
  display: flex;
  flex-direction: row;
  gap: var(--space-2xs);
  justify-self: start;
  color: var(--color-white);
  text-decoration: none;
  font-size: var(--step-0);
  line-height: 120%;
  font-weight: 600;
}

.register-avatar-image {
  display: block;
  width: 94px;
  height: 94px;
  object-fit: cover;
  border-radius: 999px;
  border: 4px solid var(--color-white);
}

.register-name {
  font-size: var(--step-3);
  line-height: 120%;
  font-weight: 400;;
  text-align: center;
  .q {
    font-size: var(--step-1);
    font-weight: 400;
    margin: 0;
  }
  .name {
    font-weight: 700;
  }
}

.register-sep {
  height: 1px;
  background-color: rgba(255, 255, 255, 0.4);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
  label {
    font-size: var(--step--1);
    line-height: 120%;
    font-weight: 700;
  }
}

.validation-summary:empty {
  display: none;
}

.register-checkbox {
  text-align: start;
  .field-validation-error {
    text-align: center;
  }
}

.register-checkbox-label {
  display: flex;
  align-items: center;
  justify-content: start;
  gap: var(--space-2xs);
  color: var(--color-white);
  font-size: var(--step--1);
  font-weight: 400;
  line-height: 1.4;
  text-transform: none;
  cursor: pointer;
}

.register-checkbox-label input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  height: 16px;
  width: 16px;
  flex: 0 0 auto;
  border: 1px solid var(--color-white);
  border-radius: 2px;
  background-color: var(--color-white);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 12px 12px;
  cursor: pointer;
}

.register-checkbox-label input[type="checkbox"]:checked {
  background-color: var(--color-white);
  border-color: var(--color-white);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23009045' stroke-linecap='round' stroke-linejoin='round' stroke-width='2.25' d='M3 8.5l3.1 3.1L13 4.8'/%3E%3C/svg%3E");
}

.register-checkbox-label input[type="checkbox"]:focus-visible {
  outline: 2px solid var(--color-white);
  outline-offset: 2px;
}

.citypostcode {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 10px;
}

.citypostcode > * {
  flex: 1 1 0;
}

.register-checkbox-label a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.register-submit {
  display: flex;
  justify-content: center;
}

.register-submit button[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
}

.charity-info, .challenge-info {
  padding: var(--space-s);
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
}
.charity-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
  margin-top: var(--space-xs);
  border: 0;
  padding: 0;
}

.charity-card {
  border-radius: 8px;
  padding: 2px;
  background-color: var(--color-white);
  display: flex;
  flex-direction: column;
  .charity-inner {
    border-radius: 6px;
    border: 4px solid var(--color-red);
    padding: 12px 16px;
    display: flex;
    flex-direction: row;
    gap: var(--space-xs);
    align-items: center;
    color: var(--color-red);
    cursor: pointer;
    .charity-name {
      flex: 1 1 auto;
      min-width: 0;
    }
  }
  .learn-more-link {
    color: var(--color-red);
    font-weight: 400;
    align-self: flex-end;
    margin: 0 16px 12px auto;
  }
  .charity-radio-checked {
    display: none;
  }
  .charity-option-input:checked + .charity-inner {
    background-color: rgba(0, 0, 0, 0.04);
  }
  .charity-option-input:focus-visible + .charity-inner {
    outline: 3px solid var(--focus-ring-color);
    outline-offset: 3px;
    box-shadow: 0 0 0 6px var(--focus-ring-shadow);
  }
  .charity-option-input:checked + .charity-inner .charity-radio-unchecked {
    display: none;
  }
  .charity-option-input:checked + .charity-inner .charity-radio-checked {
    display: block;
  }
    &:nth-child(1) .charity-inner {
      border-color: var(--color-orange);
    }
    &:nth-child(2) .charity-inner {
      border-color: var(--color-blue);
    }
    &:nth-child(3) .charity-inner {
      border-color: var(--color-green);
    }
    &:nth-child(4) .charity-inner {
      border-color: var(--color-red);
    }
    &:nth-child(5) .charity-inner {
      border-color: var(--color-orange);
    }
}

/* =========================
   Charity detail page
   ========================= */
.charity-detail-logo {
  display: block;
  justify-content: center;
  border-radius: 8px;
  padding: 2px;
  background-color: var(--color-white);
}
.charity-detail-logo-inner {
  display: flex;
  padding: 20px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  border-radius: 6px;
  border: 4px solid var(--color-white);
  background-color: var(--color-white);
  img {
    height: 100px;
    width: 100px;
  }
  &._1, &._5 {
    border-color: var(--color-orange);
  }
  &._2 {
    border-color: var(--color-blue);
  }
  &._3 {
    border-color: var(--color-green);
  }
  &._4 {
    border-color: var(--color-red);
  }
}
.charity-info h1 {
  font-size: var(--step-3);
  font-weight: 700;
}
.charity-description{
  p:first-child {
    font-size: var(--step-1);
  }
}

/* =========================
   Dashboard
   ========================= */
.challenge-header {
  display: flex;
  flex-direction: column;
  gap: 24px;
  justify-content: center;
  margin-bottom: var(--space-m);
}
.challenge-image {
  display: flex;
  height: 118px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  img {
    height: 100%;
    border-radius: 999px;
    box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.25), 0 16px 12px 0 rgba(0, 0, 0, 0.20);
  }
}
.challenge-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-3xs);
  text-align: start;
  .challenge-label {
    font-size: var(--step-1);
    font-weight: 700;
    line-height: 120%;
  }
  h1 {
    font-size: var(--step-4);
    font-weight: 700;
    line-height: 120%;
  }
}
.challenge-info-header {
  text-align: center;
}
.challenge-completed-text {
  text-align: center;
  font-weight: 700;
  font-size: var(--step-1);
}
.challenge-tag {
  display: inline-flex;
  flex-direction: row;
  gap: var(--space-3xs);
  padding: 2px var(--space-xs);
  justify-content: center;
  align-items: center;
  width: fit-content;
  align-self: center;
  border-radius: 100px;
  background-color: var(--color-white);
  color: var(--color-black);
  font-size: var(--step--1);
}
.next-challenge {
  padding: var(--space-l) 0;
  font-size: var(--step-0);
  font-weight: 600;
  color: white;
  text-decoration: none;
  display: flex;
  flex-direction: row;
  gap: var(--space-xs);
  justify-content: center;
  align-items: center;
  a {
    color: white;
    text-decoration: none;
  }
  span {
    color: white;
    text-decoration: none;
  }
}
.challenge-info .bold {
  font-weight: 700;
}
.profile-page {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}
.profile-page > .challenge-info {
  flex: 1 1 auto;
}
.challenges-list {
  margin-bottom: var(--space-l);
  display: flex;
  flex-direction: column;
  .white-sep {
    height: 1px;
    width: 100%;
    background-color: var(--color-white);
  }
  .challenges-header {
    font-weight: 700;
    margin-top: 18px;
    margin-bottom: 12px;;
  }
  .challenge-card-link {
    text-decoration: none;
  }
  .the-challenges {
    display: flex;
    flex-direction: column;
    gap:12px;
  }
  .challenge-card {
    display: flex;
    flex-direction: row;
    gap: var(--space-2xs);
    align-items: center;
    background-color: var(--color-white);
    color: var(--challenge-card-color, var(--color-black));
    border-radius: 8px;
    padding: var(--space-xs) var(--space-s);
    .title {
      font-weight: 700;
      line-height: 120%;
    }
    .date-info {
      margin-left: auto;
      display: flex;
      flex-direction: row;
      gap: var(--space-3xs);
      font-size: var(--step--2);
      position: relative;
    }
    .date {
      position: absolute;
      top: 5px;
      left: 6px;
      font-size: 8px;
      font-weight: 600;
      line-height: 1;
    }
  }
}

.leaderboard-selector {
  display: flex;
  flex-direction: row;
  gap: var(--space-s);
  justify-content: start;
  padding: var(--space-s);
}

.leaderboard {
  display: flex;
  flex-direction: column;
  padding: var(--space-s);
  margin-bottom: var(--space-l);
  position: relative;
}

.leaderboard[hidden] {
  display: none;
}

.charity-leaderboard {
  gap: var(--space-m);
  .leaderboard-entry {
    display: flex;
    flex-direction: row;
    gap: 10px;
    align-items: center;
    justify-items: start;
    .logo {
      background-color: var(--color-white);
      border-radius: 8px;
      padding: var(--space-3xs);
      img {
        height: 40px;
        width: 40px;
      }  
    }
    .info {
      display: flex;
      flex-direction: column;
      gap: var(--space-3xs);
      .name {
        font-size: var(--step-1);
        font-weight: 700;
        line-height: 120%;
      }
      .amount {
        font-size: var(--step-0);
        font-weight: 400;
        line-height: 120%;
      }
    }
  }
}

.postcode-leaderboard {
  gap: var(--space-xs);
  padding-top: var(--space-l);
  .leaderboard-entry {
    position: relative;
    display: flex;
    flex-direction: row;
    gap: 10px;
    align-items: center;
    justify-items: start;
    img {
      position: absolute;
      top: -22px;
      left: 27px;
    }
    .rank {
      font-size: var(--step-0);
      font-weight: 400;
      line-height: 120%;
      color: var(--color-orange);
      width: 24px;
      text-align: center;
    }
    .postcode {
      font-size: var(--step-1);
      font-weight: 700;
      line-height: 120%;
      color: var(--color-white);
    }
    .amount {
      font-size: var(--step-0);
      font-weight: 400;
      line-height: 120%;
      color: var(--color-orange);
    }
    &:nth-child(1) .rank {
      color: var(--color-white);
      font-size: var(--step-4);
      font-weight: 700;
    }
    &:nth-child(1) .postcode {
      color: var(--color-white);
      font-size: var(--step-4);
      font-weight: 700;
    }
    &:nth-child(1) .amount {
      color: var(--color-white);
    }

    &:nth-child(2) .rank {
      font-size: var(--step-3);
      font-weight: 700;
    }
    &:nth-child(2) .postcode {
      color: var(--color-white);
      font-size: var(--step-3);
      font-weight: 700;
    }

    &:nth-child(3) .rank {
      font-size: var(--step-2);
      font-weight: 700;
    }
    &:nth-child(3) .postcode {
      color: var(--color-white);
      font-size: var(--step-2);
      font-weight: 700;
    }
  }
}
