a,
.btn-link {
    color: var(--club-primary);
    text-decoration-color: rgba(0, 91, 187, 0.35);
}

button,
a,
input,
select,
textarea,
summary {
    touch-action: manipulation;
}

.card-elevated {
    background: var(--ui-surface);
    border: 1px solid var(--ui-border);
    border-radius: var(--ui-radius-lg);
    box-shadow: var(--ui-shadow-sm);
}

.btn {
    border-radius: 3px !important;
    font-weight: 600;
    letter-spacing: 0.01em;
    min-height: 2.5rem;
    padding-inline: 0.9rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
}

.btn:not(.btn-icon-only):not(.btn-close):not(.btn-link):not(.btn-month):not(.reset-btn-compact) {
    min-width: 8.5rem;
}

.btn-sm:not(.btn-icon-only):not(.btn-close):not(.btn-link):not(.btn-month):not(.reset-btn-compact) {
    min-height: 2.2rem;
    min-width: 6.75rem;
    padding-inline: 0.7rem;
}

.btn.btn-lg {
    min-height: 2.85rem;
    padding-inline: 1rem;
}

.btn.w-100 {
    min-width: 0;
}

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--club-primary);
    --bs-btn-border-color: var(--club-primary);
    --bs-btn-hover-bg: var(--club-primary-dark);
    --bs-btn-hover-border-color: var(--club-primary-dark);
    --bs-btn-active-bg: var(--club-primary-dark);
    --bs-btn-active-border-color: var(--club-primary-dark);
    --bs-btn-focus-shadow-rgb: 0, 91, 187;
}

.btn-success {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--ui-success);
    --bs-btn-border-color: var(--ui-success);
    --bs-btn-hover-bg: #186b46;
    --bs-btn-hover-border-color: #186b46;
    --bs-btn-active-bg: #13573a;
    --bs-btn-active-border-color: #13573a;
    --bs-btn-focus-shadow-rgb: 31, 138, 91;
}

.btn-danger {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--ui-danger);
    --bs-btn-border-color: var(--ui-danger);
    --bs-btn-hover-bg: #af2d2d;
    --bs-btn-hover-border-color: #af2d2d;
    --bs-btn-active-bg: #972525;
    --bs-btn-active-border-color: #972525;
    --bs-btn-focus-shadow-rgb: 204, 60, 60;
}

.btn-secondary,
.btn-light {
    --bs-btn-color: #1f4682;
    --bs-btn-bg: #edf4ff;
    --bs-btn-border-color: #c7d8f1;
    --bs-btn-hover-bg: #e3eeff;
    --bs-btn-hover-border-color: #b5cceb;
    --bs-btn-active-bg: #d9e7ff;
    --bs-btn-active-border-color: #a6bfe3;
    --bs-btn-focus-shadow-rgb: 36, 84, 149;
}

.btn-outline-primary {
    --bs-btn-color: var(--club-primary);
    --bs-btn-border-color: var(--club-primary);
    --bs-btn-hover-bg: var(--club-primary);
    --bs-btn-hover-border-color: var(--club-primary);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: var(--club-primary-dark);
    --bs-btn-active-border-color: var(--club-primary-dark);
    --bs-btn-active-color: #fff;
}

.btn-outline-success {
    --bs-btn-color: var(--ui-success);
    --bs-btn-border-color: var(--ui-success);
    --bs-btn-hover-bg: var(--ui-success);
    --bs-btn-hover-border-color: var(--ui-success);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: #186b46;
    --bs-btn-active-border-color: #186b46;
    --bs-btn-active-color: #fff;
}

.btn-outline-danger {
    --bs-btn-color: var(--ui-danger);
    --bs-btn-border-color: var(--ui-danger);
    --bs-btn-hover-bg: var(--ui-danger);
    --bs-btn-hover-border-color: var(--ui-danger);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: #af2d2d;
    --bs-btn-active-border-color: #af2d2d;
    --bs-btn-active-color: #fff;
}

.btn-export {
    background: var(--ui-success);
    border-color: var(--ui-success);
    color: #ffffff;
}

.btn-export:hover,
.btn-export:focus {
    background: #18724c;
    border-color: #18724c;
    color: #ffffff;
}

.btn-icon {
    margin-right: 0.45rem;
    font-size: 0.9em;
}

.btn-icon-end {
    margin-right: 0;
    margin-left: 0.45rem;
}

.btn + .btn {
    margin-left: 5px;
}

.btn-group {
    gap: 5px;
}

.btn-group > .btn,
.btn-group > .btn-group {
    margin-left: 0 !important;
}

.btn-icon-only {
    width: 2.5rem;
    min-width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn-sm.btn-icon-only {
    width: 2.2rem;
    min-width: 2.2rem;
    height: 2.2rem;
    border-radius: 3px !important;
}

.btn.btn-month,
.btn.reset-btn-compact {
    min-width: 0;
}

.nav-pills .nav-link {
    min-height: 2.5rem;
    display: inline-flex;
    align-items: center;
}

.form-control,
.form-select,
.form-check-input,
.input-group-text {
    border-color: var(--ui-border-strong);
}

.form-control,
.form-select {
    border-radius: 3px !important;
    box-shadow: none;
}

.form-control:focus,
.form-select:focus {
    border-color: rgba(0, 91, 187, 0.5);
    box-shadow: 0 0 0 0.2rem rgba(0, 91, 187, 0.16);
}

.table {
    --bs-table-bg: transparent;
    --bs-table-border-color: #d8e1f0;
}

.table thead th {
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #6b7997;
    font-size: 0.78rem;
    font-weight: 700;
    border-bottom-width: 1px;
}

.table tbody td {
    font-size: 0.92rem;
}

.table-hover > tbody > tr:hover > * {
    background-color: rgba(11, 72, 149, 0.05);
}

.table-responsive {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}

.badge-role {
    background: rgba(242, 193, 0, 0.22);
    color: #6b4f00;
    border: 1px solid rgba(216, 170, 0, 0.5);
    border-radius: var(--ui-radius-pill);
    font-weight: 700;
    padding: 0.35rem 0.7rem;
}

.alert {
    border-radius: var(--ui-radius-sm);
    border-width: 1px;
}

.alert-info {
    --bs-alert-bg: #edf4ff;
    --bs-alert-color: #214a84;
    --bs-alert-border-color: #c3d9fb;
}

.alert-warning {
    --bs-alert-bg: #fff7e8;
    --bs-alert-color: #835a16;
    --bs-alert-border-color: #f0d59a;
}

.alert-success {
    --bs-alert-bg: #effcf5;
    --bs-alert-color: #175d3f;
    --bs-alert-border-color: #bce6cf;
}

.alert-danger {
    --bs-alert-bg: #fff1f1;
    --bs-alert-color: #8f2b2b;
    --bs-alert-border-color: #f2c2c2;
}

.nav-pills .nav-link {
    border-radius: 3px;
    color: #2a4b7f;
    font-weight: 600;
}

.input-group > .form-control,
.input-group > .form-select,
.input-group > .input-group-text,
.input-group > .btn {
    border-radius: 3px !important;
    min-width: 0;
}

.btn-group > .btn {
    border-radius: 3px !important;
    min-width: 0;
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background: var(--club-primary);
}

.currency-input {
    position: relative;
}

.currency-input::after {
    content: "EUR";
    position: absolute;
    right: 0.6rem;
    top: 50%;
    transform: translateY(-50%);
    color: #1a3e87;
    font-weight: 700;
    font-size: 0.7rem;
    letter-spacing: 0.05em;
    pointer-events: none;
}

.currency-input .form-control {
    padding-right: 2.2rem;
    text-align: right;
}

input[type="number"],
.form-control[type="number"] {
    text-align: right;
}

.blazor-error-boundary {
    background: #7f1d1d;
    padding: 1rem;
    color: white;
    border-radius: var(--ui-radius-sm);
}

.blazor-error-boundary::after {
    content: "Ein Fehler ist aufgetreten.";
}

@media (pointer: coarse) {
    .btn {
        min-height: var(--ui-touch-target-min);
        padding-top: 0.55rem;
        padding-bottom: 0.55rem;
    }

    .btn-sm {
        min-height: var(--ui-touch-target-min);
        padding-top: 0.45rem;
        padding-bottom: 0.45rem;
    }

    .btn-icon-only {
        width: 2.75rem;
        min-width: 2.75rem;
        height: 2.75rem;
    }

    .btn-sm.btn-icon-only {
        width: 2.5rem;
        min-width: 2.5rem;
        height: 2.5rem;
    }

    .form-control,
    .form-select {
        min-height: var(--ui-touch-target-min);
        font-size: 1rem;
    }

    textarea.form-control {
        min-height: 6rem;
    }

    .form-check-input {
        width: 1.35rem;
        height: 1.35rem;
    }

    .table th,
    .table td {
        padding-top: 0.72rem;
        padding-bottom: 0.72rem;
    }

    .nav-pills .nav-link {
        min-height: var(--ui-touch-target-min);
        padding-top: 0.55rem;
        padding-bottom: 0.55rem;
    }
}
