/* ==========================================================================
   BUTTON COMPONENT — Base
   ========================================================================== */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--btn-gap);
    padding-block: var(--space-s);
    padding-inline: var(--btn-padding-x);
    font-weight: var(--btn-font-weight);
    font-size: calc(var(--paragraf-m) - 1px);
    border: none;
    border-radius: var(--btn-radius);
    transition: background-color 0.2s ease, transform 0.1s ease;
}

.btn:active {
    transform: scale(0.98);
}

.btn:focus {
    outline: none;
}

.btn:focus-visible {
    outline: 2px solid var(--btn-focus-ring);
    outline-offset: 2px;
}

.btn svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}


.btn--report {
    display: inline-flex;
    gap: var(--space-2xs);
    align-items: center;
    background: var(--c-surface);
    border: 1px solid var(--c-btn-outline-border);
    border-radius: var(--space-l);
    padding-inline: var(--space-s);
    padding-block: var(--space-3xs);
    font-size: var(--paragraf-s);
    color: var(--c-text);
}

.btn--report:hover {
    background: var(--c-surface-hover);
    border-color: var(--c-text-muted);
}

.btn--report:active {
    background: var(--c-surface-alt);
}


/* ==========================================================================
   BUTTON SIZES & LAYOUT
   ========================================================================== */

.btn--full {
    width: 100%;
}

.btn--lg {
    font-size: var(--paragraf-l);
    font-weight: var(--fw-regular);
    gap: var(--space-s);
    padding: var(--sp-4) var(--sp-6);
}

.btn--sm {
    font-size: var(--caption-m);
    padding-block: var(--space-2xs);
    padding-inline: var(--space-s);
}




/* ==========================================================================
   BUTTON VARIANTS
   ========================================================================== */

.btn--primary {
    background: var(--c-primary);
    border: 1px solid var(--c-primary);
    color: var(--c-text-inverse);
}

.btn--primary:hover {
    background: var(--c-primary-dark);
    border-color: var(--c-primary-dark);
    color: var(--c-text-inverse);
}

.btn--primary:active {
    opacity: 0.9;
}

.btn--outline {
    background: var(--c-surface);
    border: 1px solid var(--c-btn-outline-border);
    color: var(--c-text);
}

.btn--outline:hover {
    background: var(--c-surface-hover);
    border-color: var(--c-text-muted);
}

.btn--outline:active {
    background: var(--c-surface-alt);
}


/* ==========================================================================
   BUTTON SUBELEMENTS
   ========================================================================== */

.btn__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}




/* ==========================================================================
   BUTTON GROUP
   ========================================================================== */

.button-group {
    display: flex;
    flex-direction: row;
    gap: var(--sp-4);
    margin-top: var(--sp-4);
    padding: 0 var(--sp-4);
}

@media (min-width: 768px) {
    .button-group {
        max-width: var(--card-max-width);
        margin-left: auto;
        margin-right: auto;
        padding: 0;
    }
}




/* ==========================================================================
   BACK LINK
   ========================================================================== */
.back-link-wrapper {
    display: flex;
    justify-content: center;
    /* margin-block: var(--sp-6); */
}

.back-link {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    color: var(--c-text-muted);
    transition: color 0.2s ease;
}

.back-link:hover {
    color: var(--c-primary);
}

.back-link svg {
    width: 12px;
    height: 12px;
}