.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: none;
  font: inherit;
  padding: 5px;
  border-radius: 6px;
  outline: 1px rgba(255, 255, 255, 0.50) solid;
  outline-offset: -1px;
  backdrop-filter: blur(12.50px);
  -webkit-backdrop-filter: blur(12.50px);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-out);
  max-width: 100%;
  box-sizing: border-box;
}

/* Primary style: glassmorphic outer wrapper background */
.button-primary,
.button--primary {
  background: rgba(255, 255, 255, 0.30);
}

/* Secondary style: dark transparent outer wrapper background */
.button-secondary,
.button--secondary {
  background: rgba(0, 0, 0, 0.20);
}

/* Fallback button text fallback */
.button-text,
.button--text {
  background: transparent;
  outline: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  padding: 0;
}

/* Inner container style */
.button__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 32px;
  border-radius: 6px;
  width: 100%;
  height: 100%;
  font-family: var(--font-secondary);
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.3;
  letter-spacing: 2.80px;
  white-space: nowrap;
  box-sizing: border-box;
  transition: all var(--duration-normal) var(--ease-out);
}

/* Primary inner background & text color */
.button-primary .button__inner,
.button--primary .button__inner {
  background: var(--color-brand-primary); /* #91C83E */
  color: #22341A;
}

.button-primary:hover .button__inner,
.button--primary:hover .button__inner {
  background: var(--color-brand-primary-hover); /* #9FD94A */
}

/* Secondary inner background & text color */
.button-secondary .button__inner,
.button--secondary .button__inner {
  background: transparent;
  color: #ffffff;
}

.button-secondary:hover,
.button--secondary:hover {
  background: rgba(0, 0, 0, 0.30);
}

.button-secondary:hover .button__inner,
.button--secondary:hover .button__inner {
  background: rgba(255, 255, 255, 0.08);
}

/* Fallback text button inner */
.button-text .button__inner,
.button--text .button__inner {
  padding: 0;
  color: var(--color-brand-primary);
}

.button-text:hover .button__inner,
.button--text:hover .button__inner {
  color: var(--color-brand-primary-hover);
  text-decoration: underline;
}

@media (hover: none), (pointer: coarse) {
  .button-primary:hover .button__inner,
  .button--primary:hover .button__inner {
    background: var(--color-brand-primary);
  }

  .button-secondary:hover,
  .button--secondary:hover {
    background: transparent;
  }

  .button-secondary:hover .button__inner,
  .button--secondary:hover .button__inner {
    background: transparent;
  }

  .button-text:hover .button__inner,
  .button--text:hover .button__inner {
    color: var(--color-brand-primary);
    text-decoration: none;
  }
}

/* Button Icon wrapper */
.button__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.button__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .button {
    width: 100%;
  }

  .button__inner {
    padding: 14px 24px;
    font-size: 16px;
    letter-spacing: 2.0px;
  }
}
