/*---------------------------------------/*
 # SETTINGS
/*---------------------------------------*/
@import url('https://fonts.googleapis.com/css2?family=Bitcount+Grid+Single:wght@100..900&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

:root {
  /* primary color palette */
  --color-primary-600: #c2b63c;
  --color-primary-500: #faea50;
  --color-primary-300: #fef3a5;
  --color-primary-100: #fefae0;
  --color-primary-50: #fffdf0;
  --color-background: #fff;

  /* grayscale palette */
  --grayscale-900: #242420;
  --grayscale-800: #43423d;
  --grayscale-700: #64645c;
  --grayscale-600: #88877c;
  --grayscale-500: #acab9e;
  --grayscale-200: #dfdecd;
  --grayscale-50: #f8f7ed;

  /* system colors */
  --color-red: #f27143;
  --color-orange: #ebc443;
  --color-green: #00a231;

  /* fonts */
  --font-base: 'Inter', sans-serif;
  --font-display: 'Bitcount Grid Single', monospace;

  /* typography scales */
  --font-weight-400: 400;
  --font-weight-500: 500;
  --font-weight-600: 600;
  --font-weight-700: 700;

  --font-size-48: 3rem;
  --font-size-24: 1.5rem;
  --font-size-20: 1.25rem;
  --font-size-16: 1rem;
  --font-size-14: 0.875rem;
  --font-size-12: 0.75rem;

  /* shadows */
  --box-shadow:
    0 1.586px 3.172px 0 rgba(49, 45, 8, 0.11),
    0 4px 8px 0 rgba(49, 45, 8, 0.07),
    0 6.414px 12.828px 0 rgba(49, 45, 8, 0.03);

  /* spacing */
  --space-5: 0.3125rem;
  --space-10: 0.625rem;
  --space-15: 0.9375rem;
  --space-20: 1.25rem;
  --space-30: 1.875rem;
  --space-40: 2.5rem;
  --space-50: 3.125rem;
  --space-60: 3.75rem;

  /* border radius */
  --radius-6: 0.375rem;
  --radius-16: 1rem;
  --radius-24: 1.5rem;
  --radius-32: 2rem;
  --radius-full: 9999rem;
}

/*---------------------------------------/*
 # GENERIC
/*---------------------------------------*/

*,
*::before,
*::after {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
}
/*---------------------------------------/*
 # ELEMENTS
/*---------------------------------------*/

html {
  font-family: var(--font-base);
  color: var(--grayscale-900);
  background-color: var(--color-background);
  -webkit-font-smoothing: antialiased;
}

img,
svg {
  max-width: 100%;
  height: auto;
  display: block;
}

/*---------------------------------------/*
 # OBJECTS
/*---------------------------------------*/
.o-container {
  max-width: 75rem;
  margin: 0 auto;
  width: 100%;
  padding-left: var(--space-20);
  padding-right: var(--space-20);
}
/*---------------------------------------/*
 # COMPONENTS
/*---------------------------------------*/

.c-header {
  background: var(--color-primary-500);
  padding: var(--space-20) 0;
  margin-bottom: var(--space-20);
}

.c-nav__hamburger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--grayscale-900);
  box-shadow: none;
  cursor: pointer;
  position: relative;
  z-index: 1;
  -webkit-tap-highlight-color: transparent;
}

.c-nav__hamburger svg {
  flex-shrink: 0;
}

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

.c-menu-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}

.c-menu-drawer {
  position: fixed;
  top: 0;
  left: 0;
  width: min(20rem, 86vw);
  height: 100dvh;
  padding: var(--space-20);
  background: var(--color-background);
  box-shadow: 0 16px 40px rgba(36, 36, 32, 0.18);
  transform: translateX(-102%);
  transition: transform 0.25s ease;
  z-index: 30;
  overflow-y: auto;
}

.c-menu-drawer.is-open {
  transform: translateX(0);
}

.has-menu-open {
  overflow: hidden;
}

.c-menu-drawer__header {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  margin-bottom: var(--space-20);
}

.c-menu-drawer__header #menuClose {
  cursor: pointer;
}

.c-menu-drawer__title {
  font-size: var(--font-size-20);
  font-weight: var(--font-weight-700);
}

.c-menu-drawer__nav {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.c-menu-drawer__item {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  padding: 0.875rem 1rem;
  border-radius: var(--radius-16);
  color: var(--grayscale-900);
  text-decoration: none;
  font-weight: var(--font-weight-600);
}

.c-menu-drawer__item--active,
.c-menu-drawer__item:hover {
  background: var(--color-primary-100);
}

.c-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-20);
  padding: 0 10px;
}

.c-nav__sub {
  display: flex;
  align-items: center;
  gap: var(--space-10);
}

.c-nav__title {
  font-size: var(--font-size-20);
  font-weight: var(--font-weight-700);
  color: var(--grayscale-900);
}

.c-nav__connection {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  padding: 0.5rem var(--space-20);
  background: var(--color-green);
  border-radius: var(--radius-full);
  color: var(--grayscale-50);
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-500);
  box-shadow: var(--box-shadow);
}

.c-heading-2 {
  font-size: var(--font-size-20);
  font-weight: var(--font-weight-700);
  display: flex;
  align-items: center;
  gap: var(--space-10);
  margin-bottom: var(--space-20);
}

.c-heading-3 {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-600);
  color: var(--grayscale-700);
  display: flex;
  align-items: center;
  gap: var(--space-10);
  margin-top: var(--space-20);
  margin-bottom: var(--space-10);
}

.c-grid-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-20);
}

.c-stat-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-end;
  padding: var(--space-20);
  background: var(--color-primary-100);
  border: 1px solid var(--grayscale-200);
  border-radius: var(--radius-16);
  box-shadow: var(--box-shadow);
}

.c-stat-card__top {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-700);
  width: 100%;
  text-align: left;
}

.c-stat-card__notlive {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-700);
  width: 100%;
}

.c-stat-card__display {
  font-family: var(--font-display);
  font-size: var(--font-size-48);
  font-weight: 300;
  line-height: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.c-stat-card__sub {
  font-family: var(--font-base);
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-400);
  color: var(--grayscale-600);
  margin-right: 5px;
}

.c-map {
  width: 100%;
  aspect-ratio: 16/9;
  min-height: 250px;
  max-height: 450px;
  background: var(--color-background);
  border: 1px solid var(--grayscale-200);
  border-radius: var(--radius-32);
  box-shadow: var(--box-shadow);
  padding: var(--space-20);
}

.c-map__inner {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 12px;
  overflow: hidden;
}

.c-height-profile {
  width: 100%;
  min-height: 250px;
  background: var(--color-background);
  border: 1px solid var(--grayscale-200);
  border-radius: var(--radius-24);
  box-shadow: var(--box-shadow);
  padding: var(--space-20);
}

.c-progress-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-20);
  background: var(--color-background);
  border: 1px solid var(--grayscale-200);
  border-radius: var(--radius-24);
  box-shadow: var(--box-shadow);
  text-align: center;
}

.c-progress-card__title {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-600);
  color: var(--grayscale-800);
  margin-bottom: var(--space-10); 
}

.c-progress-card__subtext {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-700);
  line-height: 1.5;
  color: var(--color-orange);
  margin: 1rem;
}

.c-progress-ring {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 75%;
  margin: auto 0;
}

.c-shoe-visual {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  width: 100%;
  margin: auto 0;
}

.c-shoe-visual__image {
  width: 45%;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 4px 8px rgba(49, 45, 8, 0.07));
}

.c-shoe-visual__ring {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 45%;
  align-self: center;
  justify-self: center;
}

.c-progress-card__pagination {
  display: flex;
  gap: 0.375rem;
  align-items: center;
  margin-top: auto;
}

.c-nav__hamburger {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: inherit;
  line-height: 0;
}

.c-nav__hamburger:focus-visible {
  outline: 2px solid var(--grayscale-900);
  outline-offset: 3px;
  border-radius: var(--radius-6);
}

.c-menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(36, 36, 32, 0.35);
  backdrop-filter: blur(2px);
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.c-menu-overlay.is-open {
  opacity: 1;
  pointer-events: all;
}

.c-menu-drawer {
  position: fixed;
  top: 0;
  left: 0;
  width: 300px;
  height: 100dvh;
  background: var(--color-background);
  z-index: 101;
  display: flex;
  flex-direction: column;
  gap: var(--space-40);
  padding: var(--space-20) var(--space-10);
  box-shadow: 4px 0 24px 0 rgba(49, 45, 8, 0.1);
  transform: translateX(-100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}

.c-menu-drawer.is-open {
  transform: translateX(0);
}

.c-menu-drawer__header {
  display: flex;
  align-items: center;
  gap: var(--space-15);
  margin: 10px;
}

.c-menu-drawer__title {
  font-family: var(--font-base);
  font-size: var(--font-size-20);
  font-weight: var(--font-weight-700);
  color: var(--grayscale-900);
  line-height: 1.5;
}

.c-menu-drawer__nav {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.c-menu-drawer__item {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  padding: 5px var(--space-10);
  height: 35px;
  text-decoration: none;
  color: var(--grayscale-900);
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-500);
  line-height: 1.5;
  border-radius: var(--radius-full);
  transition:
    background 0.15s ease,
    color 0.15s ease;
  width: 160px;
}

.c-menu-drawer__item:hover {
  background: var(--color-primary-100);
}

.c-menu-drawer__item--active {
  background: var(--color-primary-500);
  font-weight: var(--font-weight-700);
  /* justify-content: space-between; */
}

.c-menu-drawer__item--active:hover {
  background: var(--color-primary-600);
}

.c-main__change {
  margin-bottom: 20px;
}

.c-accordion {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
  margin-top: var(--space-10);
}

.c-accordion__header {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 24px;
  padding: var(--space-15) var(--space-20);
  background-color: var(--color-primary-300);
  border-radius: var(--radius-full);
  border: 1px solid var(--grayscale-200);
  font-weight: var(--font-weight-700);
  font-size: var(--font-size-14);
  color: var(--grayscale-900);
  margin-bottom: var(--space-5);
}

.c-accordion__item {
  background-color: var(--color-primary-50);
  border: 1px solid var(--grayscale-200);
  border-radius: var(--radius-24);
  overflow: hidden;
  transition:
    background-color 0.3s ease,
    border-radius 0.3s ease;
}

.c-accordion__trigger {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 24px;
  align-items: center;
  width: 100%;
  padding: var(--space-15) var(--space-20);
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: var(--font-size-14);
  color: var(--grayscale-800);
  text-align: left;
  outline: none;
}

.c-accordion__trigger:focus-visible {
  box-shadow: 0 0 0 2px var(--grayscale-900);
  border-radius: var(--radius-24);
}

.c-accordion__icon {
  transition: transform 0.3s ease;
  justify-self: end;
}

.c-accordion__item.is-active .c-accordion__icon {
  transform: rotate(180deg);
}

.c-accordion__item.is-active {
  background-color: var(--color-primary-50);
}

.c-accordion__content {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.c-accordion__item.is-active .c-accordion__content {
  grid-template-rows: 1fr;
}

.c-accordion__inner {
  overflow: hidden;
  padding: 0 var(--space-20);
}

.c-accordion__item.is-active .c-accordion__inner {
  padding-bottom: var(--space-20);
}

.c-accordion__section-title {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-600);
  color: var(--grayscale-700);
  margin: var(--space-20) 0 var(--space-10) 0;
}

.c-stat-card--highlight {
  background-color: var(--color-primary-300);
  border: none;
}

.c-shoe-cards-layout {
  display: flex;
  flex-direction: column;
  gap: var(--space-15);
  margin-bottom: var(--space-30);
}

.c-shoe-card {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-15);
  background: var(--color-background);
  border: 1px solid var(--grayscale-200);
  border-radius: var(--radius-16);
  box-shadow: var(--box-shadow);
  cursor: pointer;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.c-shoe-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(49, 45, 8, 0.08);
}

.c-shoe-card__content {
  flex: 1;
}

.c-shoe-card__title {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-700);
  margin-bottom: var(--space-5);
  font-family: var(--font-base);
}

.c-shoe-card__stats {
  font-size: var(--font-size-12);
  color: var(--grayscale-600);
  font-family: var(--font-base);
}

.c-shoe-card__image-wrap {
  background: var(--color-primary-100);
  border: 1px solid var(--grayscale-200);
  border-radius: var(--radius-16);
  width: 80px;
  height: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: var(--space-5);
  flex-shrink: 0;
}

.c-progress-track {
  background: var(--color-primary-100);
  border-radius: var(--radius-full);
  height: 12px;
  width: 80%;
  display: flex;
  overflow: hidden;
  margin-bottom: 4px;
}

.c-progress-track--small {
  height: 10px;
  width: 100%;
}

.c-progress-fill {
  height: 100%;
  border-radius: var(--radius-full);
  transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  /* Controlled via HTML/JS */
  width: var(--progress, 0%);
  background-color: var(--color, var(--grayscale-200));
}

.c-comparison-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-15);
  width: 100%;
  padding: var(--space-20);
  margin-bottom: var(--space-30);
}

.c-comparison-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  gap: var(--space-15);
}

.c-comparison-item__title {
  font-family: var(--font-base);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-700);
  width: 45%;
}

.c-comparison-item__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.c-comparison-item__stats {
  color: var(--grayscale-600);
  font-family: var(--font-base);
  font-weight: var(--font-weight-400);
  font-size: var(--font-size-12);
}

.c-button {
  background: var(--color-primary-600);
  color: var(--color-background);
  border: none;
  border-radius: var(--radius-full);
  padding: 0.75rem 1.5rem;
  display: flex;
  align-items: center;
  gap: var(--space-10);
  font-family: var(--font-base);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-600);
  width: 100%;
  justify-content: center;
  margin-bottom: var(--space-30);
  cursor: pointer;
  box-shadow: var(--box-shadow);
  transition: opacity 0.2s ease;
}

.c-button:hover {
  opacity: 0.9;
}

.c-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-5) var(--space-15);
  border-radius: var(--radius-full);
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-600);
  margin-bottom: var(--space-20);
}

.c-badge--yellow {
  background-color: var(--color-primary-300);
  color: var(--grayscale-900);
}

.c-control-card {
  background-color: var(--color-primary-100);
  border-radius: var(--radius-24);
  padding: var(--space-20);
  margin-bottom: var(--space-20);
  box-shadow: var(--box-shadow);
}

.c-control-card__label {
  display: block;
  font-size: var(--font-size-12);
  font-weight: var(--font-weight-700);
  color: var(--grayscale-800);
  margin-bottom: var(--space-10);
}

.c-control-card__input {
  width: 100%;
  height: 120px;
  padding: var(--space-15);
  border: 1px solid var(--grayscale-200);
  border-radius: var(--radius-16);
  font-family: var(--font-base);
  font-size: var(--font-size-14);
  resize: none;
  background-color: var(--color-background);
  color: var(--grayscale-900);
}

.c-control-card__input::placeholder {
  color: var(--grayscale-500);
}

.c-control-card__input:focus {
  outline: 2px solid var(--color-primary-500);
  border-color: transparent;
}

.c-button--auto {
  width: auto;
  display: inline-flex;
  background-color: var(--color-primary-300);
  color: var(--grayscale-900);
  margin-bottom: var(--space-40);
  padding: var(--space-10) var(--space-20);
  font-size: var(--font-size-12);
}

.c-button--red {
  background-color: var(--color-red);
  color: var(--color-background);
  box-shadow: 0 4px 12px rgba(242, 113, 67, 0.3);
}

.c-button--green {
  background-color: var(--color-green);
  color: var(--color-background);
  box-shadow: 0 4px 12px rgba(242, 113, 67, 0.3);
}

.c-button--red:hover {
  opacity: 0.85;
}

.c-system-group {
  margin-bottom: var(--space-40);
}

.c-device-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-10) var(--space-20);
  margin-bottom: var(--space-20);
}

.c-device-info__label {
  font-weight: var(--font-weight-600);
  font-size: var(--font-size-14);
  color: var(--grayscale-800);
}

.c-device-info .c-badge {
  margin-bottom: 0;
}

.c-button-group {
  display: flex;
  gap: var(--space-10);
  margin-top: var(--space-15);
}

.c-button-group .c-button {
  margin-bottom: 0;
  flex: 1;
}

.c-matrix-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
  padding-top: var(--space-5);
}

.c-matrix-list .c-button {
  margin-bottom: 0;
  width: 100%;
  justify-content: flex-start;
  background-color: var(--color-background);
  color: var(--grayscale-900);
  border: 1px solid var(--grayscale-200);
  box-shadow: none;
}

.c-matrix-list .c-button:hover {
  background-color: var(--color-primary-100);
}

/* Modal (Popover) styling */
.c-modal {
  border: none;
  border-radius: var(--radius-24);
  padding: var(--space-30) var(--space-20);
  background: var(--color-background);
  box-shadow: 0 16px 40px rgba(36, 36, 32, 0.18);
  max-width: 360px;
  width: 90%;
  margin: auto;
  color: var(--grayscale-900);
}

.c-modal::backdrop {
  background: rgba(36, 36, 32, 0.45);
  backdrop-filter: blur(2px);
}

.c-modal__text {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-600);
  text-align: center;
  line-height: 1.5;
  margin-bottom: var(--space-20);
}


/* --- Goal Card Specifieke Styling --- */
.c-progress-card--goal {
  justify-content: center;
  padding-bottom: 2.5rem;
}

.c-progress-card__title--goal {
  margin-bottom: var(--space-20);
}

.c-button-circular {
  background-color: var(--color-primary-100);
  width: 80px;
  height: 80px;
  border-radius: 50%;
  border: none;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  box-shadow: var(--box-shadow);
  transition: transform 0.2s ease;
}

.c-button-circular:hover {
  transform: scale(1.05);
}

.c-modal__title {
  justify-content: center;
  margin-top: 0;
}

.c-modal__form-group {
  margin-bottom: var(--space-20);
  text-align: left;
}

.c-control-card__input--auto {
  height: auto;
  padding: 10px var(--space-15);
}

.c-button-circular {
  background-color: var(--color-primary-100);
  width: 80px;
  height: 80px;
  border-radius: 50%;
  border: none;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  box-shadow: var(--box-shadow);
  transition: transform 0.2s ease;
}

.c-button-circular:hover {
  transform: scale(1.05);
}

.c-progress-ring--button {
  min-height: 250px;
}
/*---------------------------------------/*
 # UTILITIES
/*---------------------------------------*/

.u-link__unset {
  all: unset;
}

.u-mb-15 {
  margin-bottom: var(--space-15);
}
