.button {
    display: inline-flex;
    text-decoration: none;
    vertical-align: middle;
}

.button > * {
    height: 100%;
}

.button[aria-disabled="true"] {
    cursor: not-allowed;
    pointer-events: none;
}

.button__body {
    display: inline-flex;
    align-items: center;
    height: auto;
    box-sizing: border-box;
    padding: 0 1.25rem;
    text-align: left;
}

.button.button--small .button__body {
    padding: 0 1rem;
}

.button__body .icon {
    flex-shrink: 0;
    height: 1em;
}

.button .icon--pre {
    margin-right: 0.125rem;
    min-height: var(--height);
    height: var(--height);
    flex-grow: 1;
    flex-shrink: 0;
}

.button .icon--before {
    margin-right: 1rem;
}

.button .icon--after {
    margin-left: 1rem;
}

.button.button--small .icon--before {
    margin-right: 0.5rem;
}

.button.button--small .icon--after {
    margin-left: 0.5rem;
}

.button .icon--municipality-set {
    height: 1.75em;
    pointer-events: none;
}

.button__label {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.button__label .file-info {
    overflow: auto;
    white-space: nowrap;
}

/* CTA Button */
.button.button--cta {
    display: inline-grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr 1fr;
    margin-top: 2rem;
}

.button.button--cta .button__body {
    flex: 1;
}

.button__cta {
    display: inline-flex;
    justify-items: center;
    align-items: center;
    padding: 0 1rem;
    gap: 1rem;
    white-space: nowrap;
}

.button__cta .icon--cta {
    fill: currentColor;
}

.button__cta-text {
    text-align: left;
}

.icon--cta {
    height: 2.25em;
}

@media (min-width: 30rem) {
    .button.button--cta {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 1fr;
    }

    .button.button--cta .button__body {
        flex: 1;
    }

    .button__cta {
        height: 100%;
    }

    .button__cta-text {
        text-align: center;
    }
}

