html, body {
    height: auto;
}

:is(a, button, input):focus-visible {
  outline: 2px solid var(--focus-color, #000);
  outline-offset: 2px;
}

.redesign .button {
    font-size: 15px;
    font-weight: 500;
    background-color: var(--color-primary);
    border: 1px solid var(--color-primary);
    color: var(--color-light);
    border-radius: 4px;
    margin: 0;
    padding: 11px 16px;
    width: auto;
}

.redesign .button.arrow {
    padding: 11px 30px 11px 16px;
}
.redesign .button.arrow.link {
    padding-right: 20px;
}

.redesign .button.arrow::after {
    content: '\e6f7';
    font-family: 'icons';
    font-size: 1.5em;
    font-weight: 700;
    position: absolute;
    right: 10px;
    top: 2px;
    line-height: 40px;
}
.redesign .button.arrow.link::after {
    line-height: 1;
    top: 0;
    right: 0;
}

.redesign .button.large.arrow::after{
    top: 16px;
}

.redesign .button.primary {
    background-color: var(--color-primary);
    text-decoration: none;
}

.redesign .button.secondary {
    background-color: var(--color-secondary);
    border: 1px solid var(--color-secondary);
    color: var(--color-primary);
    text-decoration: none;
}

.redesign .button.transparent {
    background-color: transparent;
    color: var(--color-primary);
    text-decoration: none;
}

.redesign .button.link {
    background-color: transparent;
    border: none;
    color: var(--color-primary);
    font-weight: 300;
    font-size: 14px;
    padding: 0;
    text-decoration: none;
}

.redesign .button.full-width {
    width: 100%;
}

.redesign a {
    color: var(--color-primary);
    font-weight: 400;
    text-decoration: underline;
}

.ss-main:focus {
  box-shadow: none;
}

.ss-main:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}

/* Utility classes */

.no-scroll {
    overflow: hidden;
}

.mb-1 {
    margin-bottom: 1rem;
}

.flex {
    display: flex;
}

.flex-direction-row {
    flex-direction: row;
}
.flex-direction-column {
    flex-direction: column;
}

.justify-start {
    justify-content: flex-start;
}
.justify-center {
    justify-content: center;
}
.justify-end {
    justify-content: flex-end;
}

.align-start {
    align-items: flex-start;
}
.align-center {
    align-items: center;
}
.align-end {
    align-items: flex-end;
}

.wrap {
    flex-wrap: wrap;
}
.nowrap {
    flex-wrap: nowrap;
}

.variable-gap {
    gap: var(--flex-variable-gap);
}
