/**
 * Expense Manager — shared UI components
 * Color values come from config.yaml via partials/theme_vars.html
 */

/* Page layout */
.em-page-title {
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--em-color-text);
}

.em-page-subtitle {
    font-size: 0.95rem;
}

.em-page-header-actions .em-page-actions {
    flex-shrink: 0;
}

/* Cards */
.em-card {
    border: none;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    border-radius: var(--em-radius);
    background-color: var(--em-color-surface);
}

.em-card-header {
    background: var(--em-header-bg);
    color: var(--em-color-on-color);
    border-radius: var(--em-radius) var(--em-radius) 0 0 !important;
}

.em-card-title {
    font-weight: 600;
}

.em-card-subtitle {
    opacity: 0.9;
    color: rgba(255, 255, 255, 0.85);
}

/* Buttons */
.em-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    border-radius: var(--em-radius);
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.em-btn > i {
    flex-shrink: 0;
    line-height: 1;
}

.em-btn > i.me-1,
.em-btn > i.me-2 {
    margin-right: 0.25rem !important;
}

.em-btn > i.me-2 {
    margin-right: 0.5rem !important;
}

.em-btn-money-in,
.em-btn.em-btn-money-in,
.em-btn-income,
.em-btn.em-btn-income {
    background-color: var(--em-color-money-in);
    border-color: var(--em-color-money-in);
    color: var(--em-color-on-color);
}

.em-btn-money-in:hover,
.em-btn.em-btn-money-in:hover,
.em-btn-income:hover,
.em-btn.em-btn-income:hover {
    background-color: var(--em-color-money-in-hover);
    border-color: var(--em-color-money-in-hover);
    color: var(--em-color-on-color);
}

.em-btn-money-out,
.em-btn.em-btn-money-out,
.em-btn-expense,
.em-btn.em-btn-expense {
    background-color: var(--em-color-money-out);
    border-color: var(--em-color-money-out);
    color: var(--em-color-on-color);
}

.em-btn-money-out:hover,
.em-btn.em-btn-money-out:hover,
.em-btn-expense:hover,
.em-btn.em-btn-expense:hover {
    background-color: var(--em-color-money-out-hover);
    border-color: var(--em-color-money-out-hover);
    color: var(--em-color-on-color);
}

.em-btn-money-move,
.em-btn.em-btn-money-move,
.em-btn-transfer,
.em-btn.em-btn-transfer {
    background-color: var(--em-color-money-move);
    border-color: var(--em-color-money-move);
    color: var(--em-color-on-color);
}

.em-btn-money-move:hover,
.em-btn.em-btn-money-move:hover,
.em-btn-transfer:hover,
.em-btn.em-btn-transfer:hover {
    background-color: var(--em-color-money-move-hover);
    border-color: var(--em-color-money-move-hover);
    color: var(--em-color-on-color);
}

.em-btn-group-transaction .em-btn {
    min-width: 6rem;
}

.em-btn-primary {
    background-color: var(--em-color-primary);
    border-color: var(--em-color-primary);
    color: var(--em-color-on-color);
}

.em-btn-primary:hover {
    background-color: var(--em-color-primary-hover);
    border-color: var(--em-color-primary-hover);
    color: var(--em-color-on-color);
}

.em-btn-secondary {
    background-color: var(--em-color-muted);
    border-color: var(--em-color-muted);
    color: var(--em-color-on-color);
}

.em-btn-danger {
    background-color: var(--em-color-money-out);
    border-color: var(--em-color-money-out);
    color: var(--em-color-on-color);
}

.em-btn-success {
    background-color: var(--em-color-money-in);
    border-color: var(--em-color-money-in);
    color: var(--em-color-on-color);
}

.em-btn-group-transaction .btn-success {
    background-color: var(--em-color-money-in) !important;
    border-color: var(--em-color-money-in) !important;
}

.em-btn-group-transaction .btn-danger {
    background-color: var(--em-color-money-out) !important;
    border-color: var(--em-color-money-out) !important;
}

.em-btn-group-transaction .btn-primary:not(.btn-outline-primary) {
    background-color: var(--em-color-money-move) !important;
    border-color: var(--em-color-money-move) !important;
}

/* Modals */
.em-modal-header {
    background: var(--em-header-bg);
    color: var(--em-color-on-color);
}

.em-modal-title {
    font-weight: 600;
}

.em-modal-footer {
    border-top: 1px solid var(--em-color-border);
}

/* Forms */
.em-form-label {
    font-weight: 500;
    color: var(--em-color-text-muted);
}

.em-input:focus,
.em-select:focus {
    border-color: var(--em-color-accent);
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--em-color-accent) 25%, transparent);
}

/* Auth */
.em-auth-card {
    margin-top: 2rem;
}

.em-auth-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--em-color-text);
}

/* Loading */
.em-spinner {
    color: var(--em-color-accent);
}

.em-loading .spinner-border {
    width: 2.5rem;
    height: 2.5rem;
}

/* Bank account summary cards (Add + Dashboard) */
.em-account-card {
    background-color: var(--em-color-background);
    border-color: var(--em-color-border) !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.em-account-card:hover {
    border-color: var(--em-color-primary) !important;
    box-shadow: 0 4px 15px color-mix(in srgb, var(--em-color-primary) 15%, transparent);
}

.em-account-card-selected {
    border-color: var(--em-color-primary) !important;
    background-color: color-mix(in srgb, var(--em-color-primary) 12%, var(--em-color-surface));
    box-shadow: 0 4px 15px color-mix(in srgb, var(--em-color-primary) 15%, transparent);
}

.em-account-card-name {
    font-size: 12px;
}

.em-account-card-type {
    font-size: 10px;
    letter-spacing: 0.5px;
    color: var(--em-color-muted) !important;
}

.em-account-card-balance {
    font-size: 12px;
    color: var(--em-color-text);
}

.em-account-card .form-check {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    margin: 0;
    min-height: 0;
}

.em-account-checkbox,
.em-account-card .form-check-input {
    width: 1.1rem;
    height: 1.1rem;
    margin: 0 !important;
    flex-shrink: 0;
    float: none;
    vertical-align: middle;
}

.em-account-checkbox:checked,
.em-account-card .form-check-input:checked {
    background-color: var(--em-color-primary);
    border-color: var(--em-color-primary);
}

.em-account-card label {
    cursor: pointer;
}

.em-alert-container:empty {
    display: none;
}

.em-toast-container {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1080;
    max-width: 360px;
}

.em-toast {
    min-width: 280px;
}

/* Icon-only action buttons */
.em-icon-actions,
.em-txn-actions {
    flex-wrap: nowrap;
    align-items: center;
}

.em-btn-icon-only,
.em-icon-actions .em-btn-icon-only,
.em-txn-actions .em-btn-icon-only,
.btn.em-btn-icon-only {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 2rem !important;
    height: 2rem !important;
    min-width: 2rem !important;
    max-width: 2rem !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 0 !important;
    border-radius: 6px !important;
    flex: 0 0 auto !important;
    box-sizing: border-box !important;
}

.em-icon-actions.btn-group-xs .em-btn-icon-only,
.btn-group-xs.em-icon-actions .em-btn-icon-only {
    width: 1.625rem !important;
    height: 1.625rem !important;
    min-width: 1.625rem !important;
    max-width: 1.625rem !important;
    border-radius: 4px !important;
}

.em-btn-icon-only > i,
.em-icon-actions .em-btn-icon-only > i,
.em-txn-actions .em-btn-icon-only > i {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 1em !important;
    height: 1em !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 0.875rem !important;
    line-height: 1 !important;
    vertical-align: 0 !important;
}

.em-icon-actions.btn-group-xs .em-btn-icon-only > i,
.btn-group-xs.em-icon-actions .em-btn-icon-only > i {
    font-size: 0.7rem !important;
}

.em-btn-icon-only > i::before {
    line-height: 1 !important;
}

.em-icon-actions .em-btn-icon-only + .em-btn-icon-only,
.em-txn-actions .em-btn-icon-only + .em-btn-icon-only {
    margin-left: 0.25rem !important;
}

/* Compact icon buttons — Bank Accounts + Category Management (after general .em-btn-icon-only rules) */
.em-icon-actions-compact.em-icon-actions,
.em-icon-actions-compact:not(.em-icon-actions) {
    flex-wrap: nowrap;
    gap: 0;
    display: inline-flex;
    align-items: center;
}

.em-icon-actions-compact .em-btn-icon-only,
.em-icon-actions-compact.em-btn-icon-only,
.em-icon-actions-compact > .em-btn-icon-only {
    width: 1.25rem !important;
    height: 1.25rem !important;
    min-width: 1.25rem !important;
    max-width: 1.25rem !important;
    border-radius: 3px !important;
}

.em-icon-actions-compact .em-btn-icon-only > i,
.em-icon-actions-compact.em-btn-icon-only > i,
.em-icon-actions-compact > .em-btn-icon-only > i {
    font-size: 0.6rem !important;
    width: 0.85em !important;
    height: 0.85em !important;
}

.em-icon-actions-compact .em-btn-icon-only + .em-btn-icon-only {
    margin-left: 0.12rem !important;
}

.em-account-card .em-account-card-actions {
    margin-left: 0.2rem;
    flex-shrink: 0;
}

.em-category-card-header .em-icon-actions-compact {
    flex-shrink: 0;
}

.em-btn-add {
    background-color: var(--em-color-money-in);
    border-color: var(--em-color-money-in);
    color: var(--em-color-on-color);
}

.em-btn-add:hover,
.em-btn-add:focus {
    background-color: var(--em-color-money-in-hover);
    border-color: var(--em-color-money-in-hover);
    color: var(--em-color-on-color);
}

.em-btn-edit {
    background-color: var(--em-color-money-move);
    border-color: var(--em-color-money-move);
    color: var(--em-color-on-color);
}

.em-btn-edit:hover,
.em-btn-edit:focus {
    background-color: var(--em-color-money-move-hover);
    border-color: var(--em-color-money-move-hover);
    color: var(--em-color-on-color);
}

.em-btn-delete {
    background-color: var(--em-color-money-out);
    border-color: var(--em-color-money-out);
    color: var(--em-color-on-color);
}

.em-btn-delete:hover,
.em-btn-delete:focus {
    background-color: var(--em-color-money-out-hover);
    border-color: var(--em-color-money-out-hover);
    color: var(--em-color-on-color);
}

@media (max-width: 576px) {
    .em-icon-actions,
    .em-txn-actions {
        flex-direction: row !important;
        width: auto !important;
    }

    .em-icon-actions .em-btn-icon-only,
    .em-txn-actions .em-btn-icon-only {
        width: 2rem !important;
        flex: 0 0 auto !important;
    }
}
