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

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

  /* Spagcing */
  --space-3xs: clamp(0.25rem, 0.2244rem + 0.1136vw, 0.3125rem);
  --space-2xs: clamp(0.5rem, 0.4744rem + 0.1136vw, 0.5625rem);
  --space-xs: clamp(0.75rem, 0.6989rem + 0.2273vw, 0.875rem);
  --space-s: clamp(1rem, 0.9489rem + 0.2273vw, 1.125rem);
  --space-m: clamp(1.5rem, 1.4233rem + 0.3409vw, 1.6875rem);
  --space-l: clamp(2rem, 1.8977rem + 0.4545vw, 2.25rem);
  --space-xl: clamp(3rem, 2.8466rem + 0.6818vw, 3.375rem);
  --space-2xl: clamp(4rem, 3.7955rem + 0.9091vw, 4.5rem);
  --space-3xl: clamp(6rem, 5.6932rem + 1.3636vw, 6.75rem);

  /* One-up pairs */
  --space-3xs-2xs: clamp(0.25rem, 0.1222rem + 0.5682vw, 0.5625rem);
  --space-2xs-xs: clamp(0.5rem, 0.3466rem + 0.6818vw, 0.875rem);
  --space-xs-s: clamp(0.75rem, 0.5966rem + 0.6818vw, 1.125rem);
  --space-s-m: clamp(1rem, 0.7188rem + 1.25vw, 1.6875rem);
  --space-m-l: clamp(1.5rem, 1.1932rem + 1.3636vw, 2.25rem);
  --space-l-xl: clamp(2rem, 1.4375rem + 2.5vw, 3.375rem);
  --space-xl-2xl: clamp(3rem, 2.3864rem + 2.7273vw, 4.5rem);
  --space-2xl-3xl: clamp(4rem, 2.875rem + 5vw, 6.75rem);

  /* Font sizes */
  --step--2: clamp(0.6944rem, 0.684rem + 0.0465vw, 0.72rem);
  --step--1: clamp(0.8333rem, 0.8061rem + 0.1212vw, 0.9rem);
  --step-0: clamp(1rem, 0.9489rem + 0.2273vw, 1.125rem);
  --step-1: clamp(1.2rem, 1.1156rem + 0.375vw, 1.4063rem);
  --step-2: clamp(1.44rem, 1.31rem + 0.5778vw, 1.7578rem);
  --step-3: clamp(1.728rem, 1.536rem + 0.8532vw, 2.1973rem);
  --step-4: clamp(2.0736rem, 1.7983rem + 1.2236vw, 2.7466rem);
  --step-5: clamp(2.4883rem, 2.1018rem + 1.718vw, 3.4332rem);

  /* Colors */ 
  --color-red: #DA0530;
  --color-purple: #5B056A;
  --color-white: #FFFFFF;
  --color-medium-gray: #666666;
}

/* =========================
   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;
}

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

body {
  font-family: gotham;
  margin: 0;
  font-size: var(--step-0);
  line-height: 120%;
}

/* =========================
   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;
}

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

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

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

.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;  
      }
    }
  }
}

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

.menu-toggle img {
  display: block;
}

.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 {
  --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 .stamp {
  position: absolute;
  width: 120px;
  height: 120px;
  z-index: 0;
}
.mobile-menu .stamp1 {
  top: 135px;
  left: -20px;
  transform: rotate(35deg);
}
.mobile-menu .stamp2 {
  top: 300px;
  right: -10px;
  transform: rotate(-40deg);
}
.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-family: "gotham-xnarrow";
  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: inherit;
  text-decoration: none;
  font-size: var(--step-1);
  font-family: "gotham";
  font-weight: 400;
  &.fs-0 {
    font-size: var(--step-0) !important;
  }
}

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

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

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

.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-title {
  margin: 10px 0 var(--space-xs);
  font-size: var(--step-2);
  line-height: 1.2;
}

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

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

.modal-sub-header {
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 8px;
}
.modal-info {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 16px;
}

@media (min-width: 768px) {
  .menu-bar {
    height: 120px;
  }
}

.wave-bg {
  background-image:
    linear-gradient(to bottom, var(--color-red) 0 calc(100% - 34vw), transparent calc(100% - 34vw) 100%),
    url('/images/wave-bg-narrow.svg');
  background-position: top, bottom;
  background-repeat: no-repeat, no-repeat;
  background-size: 100% 100%, 100% auto;
  color: white;
  padding-bottom: 33vw;
  flex-grow: 0;
  z-index:1;
}
@media (min-width: 768px) {
  .wave-bg {
    background-image:
    linear-gradient(to bottom, var(--color-red) 0 calc(100% - 390px), transparent calc(100% - 390px) 100%),
    url('/images/wave-bg-wide.svg');
    padding-bottom: 15vw;
  }
}

.red-bg-before-wave {
  background-color: var(--color-red);
  flex-grow: 0;
  color: var(--color-white);
  padding-bottom: 15vw;
  margin-bottom: -15vw;
}

.white-wave-bg {
  background-image:
    linear-gradient(to bottom, transparent 0 20vw, var(--color-white) 20vw 100%),
    url('/images/wave-white.svg');
  background-position: top;
  background-repeat: no-repeat;
  background-size: 100% auto;
  /* margin-top: -20vw; */
  flex-grow: 1;
  z-index: 1;
  .in-wave-content {
    height: 15vw;
    width: 50%;
    display: flex;
    align-items: center;
  }
}

.photo-bg {
  flex-grow: 1;
  background-image: url('/images/backgrounds/london1.png');
  background-size: cover;
  background-position: center center;
  &.under-wave {
    margin-top: -33vw;
  }
  &.background-1 {
    background-image: url('/images/backgrounds/background-1.jpg');
  }
  &.background-2 {
    background-image: url('/images/backgrounds/background-2.jpg');
  }
  @media (min-width: 768px) {
    &.under-wave {
      margin-top: -15vw;
      background-position: bottom;
    }
    &.background-1 {
      background-image: url('/images/backgrounds/background-1-desktop.jpg');
    }
    &.background-2 {
      background-image: url('/images/backgrounds/background-2-desktop.jpg');
    }
  }
}
/* =========================
   Start page
   ========================= */
.start-image {
  width: 50%;
  max-width: 250px;
  margin-bottom: var(--space-l);
}
.title {
  margin-bottom: var(--space-m);
}
.start-page-header {
  position: relative;
  overflow: hidden;
  .stamp {
      z-index: -1;
    img {
      height: 100%;
      z-index: -1;
    }
    position: absolute;
    top: 92px;
    right: -33px;
    width: 110px;
    height: 110px;
    transform: rotate(-6deg);
  }
  @media (min-width: 768px) {
    overflow: visible;
    .stamp {
      width: 140px;
      height: 140px;
    }
  }
}


/* =========================
   Register
   ========================= */
.reg-profile-image {
  border-radius: 999px;
  height: 60px;
  width: 60px;
}

form {
  margin: 0 auto;
  max-width: 300px;
  label {
    display: block;
    font-family: 'gotham-xnarrow';
    font-size: var(--step--1);
    text-transform: uppercase;
    text-align: start;
    line-height: 120%;
    margin-bottom: var(--space-3xs);
  }
  input {
    display: block;
    width: calc(100% - 2 * var(--space-xs));
    color: var(--color-purple);
    font-size: var(--step-0);
    padding-top: var(--space-2xs);
    padding-left:  var(--space-xs);
    padding-bottom: var(--space-2xs);
    padding-right:  var(--space-xs);
    border-radius: 4px;
    border: none;
  }
  span.field-validation-error {
    width: 100%;
    display: block;
    text-align: start;
    font-size: var(--step--2);
  }
}

.register-checkbox {
  margin-top: var(--space-m);
  text-align: center;
  .field-validation-error {
    text-align: center;
  }
}

.register-checkbox-label {
  display: flex;
  align-items: center;
  justify-content: center;
  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;
  font-family: 'gotham';
}

.register-checkbox-label input[type="checkbox"] {
  margin-top: 0.15rem;
  flex: 0 0 auto;
  width: auto;
}

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

/* =========================
   My page
   ========================= */
.button {
  display: inline-flex;
  padding: 8px 16px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  color: var(--color-white);
  border-radius: 4px;
  border: 1px solid #FFF;
  font-size: var(--step--1);
  font-family: 'gotham-xnarrow';
  text-transform: uppercase;
  text-decoration: none;
  font-weight: 500;
  line-height: 120%;
  &.button-white {
    background-color: var(--color-white);
    color: var(--color-purple);
  }
  &.button-red {
    background-color: var(--color-red);
    color: var(--color-white);
  }
}

/* =========================
   My page
   ========================= */

.challenges {
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
  .separator {
    height: 1px;
    background-color: var(--color-light-grey, #EEE);
    margin: 0 var(--space-xs);
    border: none;
  }
  .challenge {
    cursor: pointer;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    .info {
      display: flex;
      flex-direction: column;
      gap: var(--space-2xs);
      .challenge-link {
        display: flex;
        align-items: center;
        gap: 8px;
      }
      .name {
        color: var(--color-purple);
        font-size: var(--step-2);
        .city {
          display: block;
        }
      }
    }
    img.stamp {
      height: 80px;
      opacity: 0.2;
      &.completed {
        opacity: 1.0;
      }
    }
  }
}

.share {
  cursor: pointer;
  display: flex;
  flex-direction: row;
  gap: var(--space-3xs);
  align-items: center;
  font-size: var(--step--1);
  font-family: 'gotham-xnarrow';
  text-transform: uppercase;
  color: var(--color-red);
}

/* =========================
   Challenge page
   ========================= */
.challenge-page-header {
  position: relative;
  overflow: hidden;
  .stamp {
    img {
      height: 100%;
    }
    position: absolute;
    top: 43px;
    right: -10px;
    width: 90px;
    height: 90px;
    transform: rotate(20deg);
  }
  @media (min-width: 768px) {
    overflow: visible;
    .stamp {
      width: 110px;
      height: 100px;
    }
  }
}

.challenge-metadata {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.challenge-strava-data {
  border-radius: var(--Border-radius-S, 4px);
  background: #C00228;
  padding: 14px 16px;
  margin-bottom: 27px;
  .caption {
    font-family: 'gotham-xnarrow';
    text-transform: uppercase;
  }
  .challenge-stats-card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 7px 40px;
  }
  .stats-head {
    font-family: 'gotham-xnarrow';
  }
  .stats-divider {
    grid-column: 1 / -1;
    height: 1px;
    background: rgba(255, 255, 255, 0.45);
  }
  .stats-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: var(--step--1);
  }
}
.challenge-info {
  .title {
    font-size: var(--step-5);
    color: var(--color-purple);
    max-width: 80%;
    font-weight: 300;
  }
  .images {
    display: flex;
    gap: var(--space-2xs);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    margin: var(--space-s) 0;
    padding-bottom: var(--space-2xs);
  }
  .image-slide {
    flex: 0 0 72%;
    /* height: 220px; */
    aspect-ratio: 1.5;
    border-radius: 12px;
    scroll-snap-align: start;
    background-size: cover;
    background-position: center;
  }
  .image-slide._1 {
    background: linear-gradient(135deg, #fdd743 0%, #f59e0b 100%);
  }
  .image-slide._2 {
    background: linear-gradient(135deg, #0ea5e9 0%, #1d4ed8 100%);
  }
  .image-slide._3 {
    background: linear-gradient(135deg, #10b981 0%, #047857 100%);
  }
  .image-slide._4 {
    background: linear-gradient(135deg, #fb7185 0%, #be123c 100%);
  }
  .challenge-text p {
    color: var(--color-purple);
  }
}

/* =========================
   Leaderboards
   ========================= */
.segment-leaderboard-title {
  font-family: "gotham";
  font-weight: 300;
  margin-bottom: var(--space-l);
  line-height: 110%;
  .city {
    display: block;
  }
  .segment-name {
    display: block;
    font-weight: 500;
  }
}

.leaderboard {
  display: flex;
  flex-direction: column;
}
.leaderboard .leaderboard-entry {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-s);
  display: flex;
  padding: var(--space-3xs) 0 var(--space-2xs) 0;
  justify-content: space-between;
  align-items: flex-start;
  align-self: stretch;
  border-bottom: 1px solid var(--color-light-grey, #EEE);
  .position {
    font-weight: 400;
    font-size: var(--step-0);
    color: var(--color-medium-gray);
    width: 50px;
    text-align: center;
  }
  .name {
    font-weight: 400;
    font-size: var(--step-0);
    color: var(--color-purple);
  }
  .score {
    margin-left: auto;
    font-weight: 400;
    font-size: var(--step-0);
    color: var(--color-purple);
  }
  &.user {
    
    .name, .score, .position {
      color: var(--color-red);
    }
    .name {
      font-weight: 500;
      &::after {
        content: "";
        position: absolute;
        top: -7px;
        left: 40px;
        width: 103px;
        height: 44px;
        background: url('/images/icons/leaderboard-you.svg') no-repeat 0 0;
        background-size: 103px 44px;
        pointer-events: none;
      }
    }
  }
  &._1, &._2, &._3 {
    .name {
      font-weight: 500;
    }
  }
  &._1 {
    .position {
      color: #FDD743;
    }
  }
  &._2 {
    .position {
      color: #B4B4B4;
    }
  }
  &._3 {
    .position {
      color: #C97A4F;
    }
  }
}
#mid-expander, #end-expander {
  cursor: pointer;
  .leaderboard-entry {
    .name {
      text-decoration: underline;
    }
  }
}

/* =========================
   Tags
   ========================= */

.tag {
  display: flex;
  flex-direction: row;
  align-items: center;
  align-self: flex-start;
  gap: var(--space-3xs);
  padding: 0 var(--space-2xs);
  border-radius: 99px;
  font-family: "gotham-xnarrow";
  text-transform: uppercase;
  &.red-tag {
    background-color: var(--color-red);
    color: var(--color-white);
  }
  &.green-tag {
    background-color: #4C9E3C;
    color: white;
  }
  &.grey-tag {
    background-color: #EEEEEE;
    color: #333333;
  }
  &.white-tag {
    background-color: #FFFFFF;
    color: #4c9e3c;
  }
}
.in-wave-content .tag {
  align-self: center !important;
}
@keyframes spin-image {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

.spin-image {
  animation: spin-image 2s linear infinite;
}
