/* –––––––––––––––––––––––––––––– BUTTONS –––––––––––––––––––––––––––––––––*/
button,
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7em 1.4em;
  border-radius: var(--border-radius-m);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-normal);
  border: none;
  font-size: var(--fs-s);
  font-family: var(--font-primary);
  letter-spacing: 0.01em;
}

.button-primary {
  background-color: var(--c-primary-1);
  color: var(--c-white);
}

.button-primary:hover {
  background-color: #5b21b6;
  color: var(--c-white);
}

.button-secondary {
  background-color: transparent;
  color: var(--c-primary-1);
  border: 1px solid var(--c-primary-1);
}

.button-secondary:hover {
  background-color: var(--bg-bright-2);
  color: var(--c-primary-1);
}

.dark-bg .button-secondary {
  background-color: transparent;
  color: var(--c-white);
  border: 1px solid var(--c-white);
}

.dark-bg .button-secondary:hover {
  background-color: var(--bg-dark-2);
  color: var(--c-white);
}


.button-inverse {
  background-color: var(--c-white);
  color: var(--c-primary-1);
}

.button-inverse:hover {
  background-color: #f3f4f6;
}

.button-large {
  padding: var(--spacing-s) var(--spacing-m);
  font-size: var(--fs-s);
}

/* –––––––––––––––––––––––––––––– UNDERLINE –––––––––––––––––––––––––––––––––*/
h1 u, h2 u, h3 u, h4 u, h5 u, h6 u {
  text-decoration-thickness: 0.12em;
  text-underline-offset: 0.1em;
  text-decoration-color: var(--c-primary-1);
}


/* –––––––––––––––––––––––––––––– IMAGE a-fade MASK –––––––––––––––––––––––––––––––––*/
.img-fade-r-to-l {
    mask-image: linear-gradient(to right, black 50%, transparent 100%);
    mask-size: 100% 100%;
    mask-repeat: no-repeat;
    -webkit-mask-image: linear-gradient(to right, black 50%, transparent 100%);
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
  }
  
  .img-fade-l-to-r {
    mask-image: linear-gradient(to left, black 50%, transparent 100%);
    mask-size: 100% 100%;
    mask-repeat: no-repeat;
    -webkit-mask-image: linear-gradient(to left, black 50%, transparent 100%);
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
  }
  
  /* –––––––––––––––––––––––––––––– UNORDERED AND ORDERED LISTS –––––––––––––––––––––––––––––––––*/

  ul.checklist,
  ul.icons {
    list-style: none;
    padding-left: 0;
  }
  
  ul.checklist li,
  ul.icons li {
    position: relative;
  }

  ul.checklist li {
    margin-bottom: var(--spacing-m);
    padding-left: 2.5em;
  }

  ul.icons li {
    display: grid;
    align-items: flex-start;
    align-content: flex-start;
    gap: 0.25em;
    padding: var(--spacing-m) var(--spacing-l) var(--spacing-m) calc(var(--spacing-m) * 2 + 0.8em);
    background-color: rgba(255, 255, 255, 0.75);
    border: 1px solid rgba(100, 100, 100, 0.15);
    border-radius: var(--border-radius-m);
  }
  
  ul.checklist li::before,
  ul.icons li i {
    font-family: "hgi-stroke-rounded";
    position: absolute;
    width: 0.8em;
    height: 0.8em;
    font-size: 0.8em;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--c-primary-1);
    transform: scale(1.8);
  }
  
  ul.checklist li::before {
    left: 0;
    top: 0.5em;
    content: "䤈";
  }
  
  ul.icons li i {
    left: var(--spacing-m);
    top: calc(var(--spacing-m) + 0.5em);
  }

  ul.icons li span {
    font-size: var(--fs-s);
    font-weight: 400;
    letter-spacing: 0;
  }
  /* –––––––––––––––––––––––––––––– BLOBS FRAMEWORK –––––––––––––––––––––––––––––––––*/

  .c-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(5vmax);
    opacity: 0.3;
    pointer-events: none;
    z-index: -1;
  }
  
  /* --- Sizing --- */
  .c-size-xs { width: 8vmin; height: 8vmin; }
  .c-size-s { width: 12vmin; height: 12vmin; }
  .c-size-m { width: 20vmin; height: 20vmin; }
  .c-size-l { width: 30vmin; height: 30vmin; }
  .c-size-xl { width: 40vmin; height: 40vmin; }
  .c-size-2xl { width: 50vmin; height: 50vmin; }
  .c-size-3xl { width: 60vmin; height: 60vmin; }
  
  /* --- Colors --- */
  /* Primary */
  .c-color-p1 { background-color: var(--c-primary-1); }
  .c-color-p2 { background-color: var(--c-primary-2); }
  .c-color-p3 { background-color: var(--c-primary-3); }
  .c-color-p4 { background-color: var(--c-primary-4); }
  .c-color-p5 { background-color: var(--c-primary-5); }
  .c-color-p6 { background-color: var(--c-primary-6); }
  /* Secondary */
  .c-color-s1 { background-color: var(--c-secondary-1); }
  .c-color-s2 { background-color: var(--c-secondary-2); }
  .c-color-s3 { background-color: var(--c-secondary-3); }
  .c-color-s4 { background-color: var(--c-secondary-4); }
  .c-color-s5 { background-color: var(--c-secondary-5); }
  .c-color-s6 { background-color: var(--c-secondary-6); }
  /* Accent */
  .c-color-a1 { background-color: var(--c-accent-1); }
  .c-color-a2 { background-color: var(--c-accent-2); }
  
  /* --- Positioning (12-Point Grid: 4 Columns x 3 Rows) --- */
  .c-position-1 { top: 5%; left: 5%; }
  .c-position-2 { top: 5%; left: 35%; }
  .c-position-3 { top: 5%; left: 55%; }
  .c-position-4 { top: 5%; left: 80%; }
  .c-position-5 { top: 35%; left: 5%; }
  .c-position-6 { top: 35%; left: 35%; }
  .c-position-7 { top: 35%; left: 55%; }
  .c-position-8 { top: 35%; left: 80%; }
  .c-position-9 { top: 75%; left: 5%; }
  .c-position-10 { top: 75%; left: 35%; }
  .c-position-11 { top: 75%; left: 55%; }
  .c-position-12 { top: 75%; left: 80%; }
  
  /* --- Movement Routes --- */
  @keyframes route1 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(2vw, 1vh); }
    50% { transform: translate(0, 2vh); }
    75% { transform: translate(-1vw, 1vh); }
  }
  .c-route-1 { animation: route1 8s infinite alternate; }
  
  @keyframes route2 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(-1vw, 2vh); }
    50% { transform: translate(-2vw, 0); }
    75% { transform: translate(-1vw, -1vh); }
  }
  .c-route-2 { animation: route2 10s infinite alternate; }
  
  @keyframes route3 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(3vw, 0); }
    50% { transform: translate(2vw, 2vh); }
    75% { transform: translate(0, 1vh); }
  }
  .c-route-3 { animation: route3 12s infinite alternate; }
  
  @keyframes route4 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(0, 2vh); }
    50% { transform: translate(-2vw, 1vh); }
    75% { transform: translate(-2vw, -1vh); }
  }
  .c-route-4 { animation: route4 9s infinite alternate; }
  
  @keyframes route5 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(1vw, -1vh); }
    50% { transform: translate(2vw, 0); }
    75% { transform: translate(1vw, 1vh); }
  }
  .c-route-5 { animation: route5 11s infinite alternate; }
  
  @keyframes route6 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(-1vw, 1vh); }
    50% { transform: translate(0, 2vh); }
    75% { transform: translate(1vw, 1vh); }
  }
  .c-route-6 { animation: route6 8.5s infinite alternate; }
  
  @keyframes route7 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(1.6vw, 0.4vh); }
    50% { transform: translate(0.8vw, 1.6vh); }
    75% { transform: translate(0.4vw, 0.8vh); }
  }
  .c-route-7 { animation: route7 10.5s infinite alternate; }
  
  @keyframes route8 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(-0.4vw, 1.6vh); }
    50% { transform: translate(-1.6vw, 0.8vh); }
    75% { transform: translate(-0.8vw, 0.4vh); }
  }
  .c-route-8 { animation: route8 9.5s infinite alternate; }
  
  @keyframes route9 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(1.2vw, -0.6vh); }
    50% { transform: translate(2.4vw, 0); }
    75% { transform: translate(1.2vw, 0.6vh); }
  }
  .c-route-9 { animation: route9 11.5s infinite alternate; }
  
  @keyframes route10 {
    0%, 100% { transform: translate(0, 0); }
    25% { transform: translate(-0.6vw, 1.2vh); }
    50% { transform: translate(0, 2.4vh); }
    75% { transform: translate(0.6vw, 1.2vh); }
  }
  .c-route-10 { animation: route10 8.8s infinite alternate; }
  
  /* –––––––––––––––––––––––––––––– TILES ––––––––––––––––––––––––––––––––– */
  .tile {
    --tile-bg: var(--bg-bright-1);
    --tile-border-color: var(--c-border-light);
    --tile-border-width: 1px;
    --tile-text: inherit;
    --tile-opacity: 0.8;
  
    display: grid;
    gap: var(--spacing-2xs);
    align-items: center;
    position: relative;
    border-radius: var(--border-radius-m);
    padding: var(--spacing-s);
    color: var(--tile-text);
    z-index: 2;
  }

  .dark-bg .tile {
    --tile-bg: var(--bg-dark-1);
    --tile-border-color: var(--c-border-dark);
  }
  
  .tile::before {
    content: '';
    position: absolute;
    opacity: var(--tile-opacity);
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--tile-bg);
    border: var(--tile-border-width) solid var(--tile-border-color);
    border-radius: inherit;
    z-index: -1;
  }
  
  .tile-primary,
  .dark-bg .tile-primary {
    --tile-bg: var(--c-primary-3);
    --tile-border-color: var(--c-primary-4);
    --tile-text: var(--c-white);
  }
  
  .tile-secondary,
  .dark-bg .tile-secondary {
    --tile-bg: var(--c-primary-2);
    --tile-border-color: var(--c-primary-4);
    --tile-text: var(--c-white);
    --tile-opacity: 0.7;
  }
  
  .tile-accent,
  .dark-bg .tile-accent {
    --tile-bg: var(--c-accent-1);
    --tile-border-color: var(--c-accent-2);
    --tile-text: var(--c-white);
  }
  
  .tile.wide {
    padding: var(--spacing-s);
    padding-right: var(--spacing-l);
  }
  
  .tile .tile-title-xs {
    font-size: var(--fs-xs);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.01em;
  }
  
  .tile .tile-title-s {
    font-size: var(--fs-s);
    font-weight: 500;
    letter-spacing: 0.01em;
  }
  
  .tile .tile-title-m {
    font-size: var(--fs-l);
    font-weight: 700;
    letter-spacing: 0.02em;
  }
  
  .tile .suffix {
    font-size: var(--fs-s);
    font-weight: 400;
    letter-spacing: 0;
  }
  
  .tile > .icon {
    margin-bottom: 5px
  }

  .tile strong {
    font-weight: 800;
  }
  
  /* –––––––––––––––––––––––––––––– CTA BANNER –––––––––––––––––––––––––––––––––*/
  .cta-banner {
    background-color: var(--bg-bright-5);
    padding: var(--spacing-m) 0;
    text-align: center;
    overflow: hidden;
    z-index: 1;
  }
  
  @media screen and (max-width: 749px) {
    .cta-banner > .container {
      flex-direction: column;
      gap: 20px;
    }
  }

/* –––––––––––––––––––––––––––––– STEPS –––––––––––––––––––––––––––––– */
.steps {
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  position: relative;
}

.step {
  display: flex;
  gap: var(--spacing-m);
  margin-bottom: var(--spacing-l);
  position: relative;
  z-index: 1;
}

.step:not(:last-child)::before {
    content: '';
    position: absolute;
    left: 24px;
    top: 0;
    bottom: calc(var(--spacing-l) * -1);
    width: 2px;
    background-color: var(--c-secondary-1);
    z-index: -1;
    transform: translateY(calc(var(--spacing-m) - 0.75em));
}

.step-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  background-color: var(--c-primary-1);
  color: var(--c-white);
  border-radius: 50%;
  font-weight: 700;
  flex-shrink: 0;
  transform: translateY(calc(var(--spacing-m) - 0.75em));
}

.step-content {
  text-align: left;
  padding: var(--spacing-m);
  background-color: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(100, 100, 100, 0.15);
  border-radius: var(--border-radius-m);
  flex-grow: 1;
}

.step-content h4 {
  margin-bottom: var(--spacing-xs);
}

@media (max-width: 640px) {
  .steps::before {
    left: 20px;
  }
  
  .step {
    padding-left: 0;
  }
  
  .step-number {
    width: 40px;
    height: 40px;
    font-size: var(--fs-medium);
  }
}

/* –––––––––––––––––––––––––––––– BETA TAG –––––––––––––––––––––––––––––– */
.beta-tag {
  display: inline-block;
  position: relative;
}

.beta-tag::after {
  content: "BETA";
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-m);
  position: absolute;
  left: calc(100% + 0.5em);
  top: 0;
  padding: 0.25em 0.9em;
  box-sizing: border-box;
  background: linear-gradient(155deg, var(--c-primary-1),var(--c-secondary-5), var(--c-secondary-3), var(--c-accent-1));
  color: var(--c-white);
  border-radius: 100px;
}

.button.beta-tag::after {
  top: -0.75em;
  left: calc(100% - 1.5em);
}

@media screen and (max-width: 749px) {
  .beta-tag::after {
    left: -5px;
    top: 5px;
    padding: 0.15em 0.8em;
  }

  .button.beta-tag::after {
    top: -0.45em;
  }
}

/* –––––––––––––––––––––––––––––– PRICING CARDS –––––––––––––––––––––––––––––– */
.price-card {
  background-color: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(100, 100, 100, 0.15);
  border-radius: var(--border-radius-m);
  padding: var(--spacing-l) var(--spacing-xl);

  display: flex;
  flex-direction: column;
  position: relative;
  gap: var(--spacing-s);
}

.price-card.card-inactive {
  background-color: rgba(255, 255, 255, 0.45);
  opacity: 0.75;
  pointer-events: none;
  filter: saturate(0);
}

.price-card .checklist li {
  margin-bottom: var(--spacing-xs);
}

.price-card .button {
  margin-top: auto;
}

.price-card.card-focused {
  background-color: rgba(255, 255, 255, 0.95);
  border-color: var(--c-primary-1);
  border-width: 2px;
}

@media screen and (max-width: 749px) {
  .price-col {
    display: flex;
    overflow-x: auto;
    padding: 0 var(--spacing-m);
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  .price-col::-webkit-scrollbar {
    display: none;
  }

  .price-card {
    padding: var(--spacing-m) var(--spacing-l);
    width: calc(100vw - var(--spacing-m) * 3);
    gap: 10px;
    scroll-snap-align: center;
  }
}