/* 
    Created on : 30 mars 2026, 09:59:40
    Author     : Morgan Vivier - https://github.com/rsquatre
*/

/*
    Global
*/

.budget-base {
    padding: 10px;
}

/*
    Dashboard
*/

.budget-charts {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.budget-accounts-list {
    background-color: var(--color-bg-elevated);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.budget-account-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-2) var(--space-3);
}

.budget-account-row:not(:last-child) {
    border-bottom: 1px solid var(--color-bg-surface);
}

.budget-account-total {
    border-bottom: 2px solid var(--color-bg-surface) !important;
    font-weight: var(--font-semibold);
}

.budget-account-type-header {
    padding: var(--space-1) var(--space-3);
    font-size: var(--fs-6);
    color: var(--color-text-muted);
    background-color: var(--color-bg-surface);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.budget-account-name {
    color: var(--color-text-secondary);
    font-size: var(--fs-5);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.budget-account-balance {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
    font-size: var(--fs-5);
    font-weight: var(--font-semibold);
    margin-left: var(--space-3);
}

.budget-transactions {
    max-height: 30vh;
    overflow-y: auto;
}

.budget-transaction {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    background-color: var(--color-bg-elevated);
    padding: var(--space-2) var(--space-3);
    border-left: 3px solid transparent;
    transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.budget-transaction:hover {
    background-color: var(--color-bg-hover);
}

.budget-transaction--revenue {
    border-left-color: var(--color-success);
}

.budget-transaction--expense {
    border-left-color: var(--color-danger);
}

.budget-transaction:not(:first-of-type) {
    margin-top: 1px;
}

.budget-transaction:first-of-type {
    border-top-left-radius: var(--radius-sm);
    border-top-right-radius: var(--radius-sm);
}

.budget-transaction:last-of-type {
    border-bottom-left-radius: var(--radius-sm);
    border-bottom-right-radius: var(--radius-sm);
}

.budget-transaction-label {
    font-weight: var(--font-medium);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex: 1;
}

.budget-transaction-flag {
    font-size: var(--fs-6);
    opacity: 0.75;
}

.budget-transaction-flag--pending {
    color: var(--color-warning);
}

.budget-transaction-flag--recurring {
    color: var(--color-text-secondary);
}

.budget-transaction-category {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-secondary);
    font-size: var(--fs-6);
}

.budget-transaction-date {
    color: var(--color-text-muted);
    font-size: var(--fs-6);
}

.budget-transaction-amount {
    font-weight: var(--font-semibold);
    text-align: right;
}

.budget-transaction-actions {
    flex: 0 0 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.budget-transaction-edit {
    opacity: 0;
    color: var(--color-text-muted);
    transition: opacity 0.15s;
    line-height: 1;
}

.budget-transaction:hover .budget-transaction-edit {
    opacity: 1;
}

.budget-chart {
    flex: 1 1 450px;
    padding: var(--space-4);
    min-width: 0;
    background-color: var(--color-bg-elevated);
    border-radius: var(--radius-sm);
}

.budget-chart--full {
    flex: 1 1 100%;
}

.budget-chart h3 {
    margin: 0 0 var(--space-3) 0;
    text-align: center;
}

.budget-chart .chart-container {
    width: 100%;
    height: 500px;
    position: relative;
}

.budget-chart .chart-container canvas {
    max-width: 100%;
    max-height: 100%;
}

.chart-details {
    padding: var(--space-4);
    background-color: var(--color-bg-elevated);
    border-radius: var(--radius-sm);
    margin-top: var(--space-4);
}

.budget-highlight-group {
    padding: var(--space-4);
    margin: var(--space-4) 0;
    background-color: var(--color-bg-elevated);
    border-radius: var(--radius-sm);
}
.budget-highlight-group div:last-of-type {
    color: var(--color-primary);
}

.budget-highlights-grid {
    display: flex;
    gap: var(--space-5);
    margin: var(--space-3) 0;
    align-items: flex-start;
}

.budget-highlight-section {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.budget-highlight-cards {
    display: flex;
    gap: var(--space-3);
}

.budget-highlight-cards .budget-highlight-group {
    margin: 0;
}

.budget-highlight-separator {
    color: var(--color-text-muted);
    font-size: var(--fs-7);
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

/* Responsive pour les petits écrans */
@media (max-width: 1024px) {
    .budget-charts {
        flex-direction: column;
    }

    .budget-chart {
        flex: 1 1 100%;
    }

    .budget-chart .chart-container {
        height: 400px;
    }
}


/*
    Graphs
*/
.graphs-accounts-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-6);
}

.graphs-accounts-grid > * {
    flex: 1 1 calc(50% - var(--space-6) / 2);
    min-width: 400px;
}

.graphs-chart-container {
    height: 300px;
    position: relative;
}

/*
    Pending transactions grid
*/

.budget-pending-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    margin-top: var(--space-3);
}

.budget-pending-card {
    flex: 1 1 calc(33.33% - var(--space-4));
    min-width: 260px;
    max-width: calc(33.33% - var(--space-4));
    background: var(--color-bg-elevated);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    border: 1px solid transparent;
    transition: border-color 0.2s, opacity 0.3s, transform 0.3s;
}

.budget-pending-card:hover {
    border-color: var(--color-primary);
}

.budget-pending-card--validating {
    opacity: 0.5;
    pointer-events: none;
}

.budget-pending-card--done {
    opacity: 0;
    transform: scale(0.95);
}

.budget-pending-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-2);
}

.budget-pending-card-label {
    font-weight: 600;
    color: var(--color-text-primary);
    font-size: var(--fs-5);
    flex: 1;
}

.budget-pending-card-badges {
    display: flex;
    gap: var(--space-1);
    flex-shrink: 0;
}

.budget-pending-card-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.budget-pending-card-date {
    color: var(--color-text-muted);
}

.budget-pending-card-footer {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-top: auto;
}

.budget-pending-card-amount-wrapper {
    position: relative;
    flex: 1;
}

.budget-pending-card-input {
    width: 100%;
    background: var(--color-bg-surface);
    border: 1px solid var(--color-bg-elevated);
    border-radius: var(--radius-md);
    color: var(--color-text-primary);
    padding: var(--space-2) var(--space-5) var(--space-2) var(--space-3);
    font-size: var(--fs-5);
    font-weight: 600;
    transition: border-color 0.2s;
    box-sizing: border-box;
}

.budget-pending-card-input:focus {
    outline: none;
    border-color: var(--color-primary);
}

.budget-pending-card-currency {
    position: absolute;
    right: var(--space-2);
    top: 50%;
    transform: translateY(-50%);
    font-weight: 600;
    pointer-events: none;
}

.budget-pending-card-btn {
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-4);
    font-size: var(--fs-6);
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s, transform 0.1s;
    white-space: nowrap;
}

.budget-pending-card-btn:hover {
    background: #2563eb;
}

.budget-pending-card-btn:active {
    transform: scale(0.97);
}

.budget-pending-card-feedback {
    font-size: var(--fs-6);
    min-height: 1em;
    text-align: center;
}

/*
    Categories
*/

.budget-category-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    margin-top: var(--space-3);
}

.budget-category-card {
    flex: 1 1 calc(33.33% - var(--space-4));
    min-width: 240px;
    background: var(--color-bg-elevated);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.budget-category-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.budget-category-name {
    flex: 1;
    font-weight: 600;
}

.budget-category-color {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
}

.budget-category-color--sm {
    width: 10px;
    height: 10px;
}

.budget-category-children {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    padding-left: var(--space-3);
    border-left: 2px solid var(--color-bg-surface);
}

.budget-category-child {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-bg-surface);
    border-radius: var(--radius-sm);
    padding: var(--space-2) var(--space-3);
}

/*
    Accounts
*/

.budget-account-cards {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    margin-top: var(--space-3);
}

.budget-account-card {
    flex: 1 1 calc(25% - var(--space-4));
    min-width: 200px;
    background: var(--color-bg-elevated);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.budget-account-card-name {
    font-weight: var(--font-semibold);
    font-size: var(--fs-5);
    color: var(--color-text-primary);
}

.budget-account-card-balance {
    font-size: var(--fs-2);
    font-weight: var(--font-bold);
}

.budget-account-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-2);
}

.budget-account-card-date {
    font-size: var(--fs-6);
    margin-top: auto;
    padding-top: var(--space-2);
}

.budget-accounts-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.budget-account-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    max-width: 480px;
    margin-top: var(--space-4);
}

.budget-account-form-fields {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.budget-account-form-actions {
    display: flex;
    gap: var(--space-3);
}

.budget-category-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    max-width: 480px;
    margin-top: var(--space-4);
}

.budget-category-form-fields {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/*
    Recurring
*/

.budget-recurring-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    margin-top: var(--space-3);
}

.budget-recurring-card {
    flex: 1 1 calc(33.33% - var(--space-4));
    min-width: 280px;
    background: var(--color-bg-elevated);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.budget-recurring-card--ended {
    opacity: 0.6;
}

.budget-recurring-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.budget-recurring-label {
    flex: 1;
    font-weight: 600;
}

.budget-recurring-header-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.budget-recurring-meta {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.budget-recurring-amount {
    font-size: 1.1em;
    font-weight: 700;
}

.budget-recurring-stats {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    background: var(--color-bg-surface);
    border-radius: var(--radius-sm);
    padding: var(--space-2) var(--space-3);
}

.budget-recurring-stat {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-2);
}

/*
    Quick actions
*/

.budget-quick-actions {
    display: flex;
    gap: var(--space-3);
    flex-wrap: wrap;
    align-items: center;
}

/*
    Modals
*/

.budget-modal {
    background: var(--color-bg-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 0;
    max-width: 520px;
    width: 90vw;
    color: var(--color-text-primary);
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5);
}

.budget-modal::backdrop {
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(3px);
}

.budget-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4) var(--space-5);
    border-bottom: 1px solid var(--color-border);
}

.budget-modal-title {
    font-size: var(--fs-4);
    font-weight: var(--font-semibold);
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.budget-modal-close {
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: var(--space-1) var(--space-2);
    line-height: 1;
    border-radius: var(--radius-sm);
    transition: color var(--transition-fast), background var(--transition-fast);
}

.budget-modal-close:hover {
    color: var(--color-text-primary);
    background: var(--color-bg-elevated);
}

.budget-modal-body {
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.budget-modal-footer {
    padding: var(--space-4) var(--space-5);
    border-top: 1px solid var(--color-border);
    display: flex;
    gap: var(--space-3);
    justify-content: flex-end;
}

/*
    Category details modal
*/

.budget-modal--lg {
    max-width: 680px;
}

.budget-modal-body--scroll {
    max-height: 70vh;
    overflow-y: auto;
    gap: 0;
    padding: 0;
}

.budget-category-details-total {
    margin-left: auto;
    font-size: var(--fs-4);
    font-weight: var(--font-bold);
}

.budget-category-details-section {
    padding: var(--space-3) var(--space-5);
    border-bottom: 1px solid var(--color-border);
}

.budget-category-details-section:last-child {
    border-bottom: none;
}

.budget-category-details-subcat-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-2);
}

.budget-category-details-subcat-info {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.budget-category-details-subcat-stats {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.budget-category-details-txlist {
    display: flex;
    flex-direction: column;
    gap: 1px;
    padding-left: var(--space-4);
}

.budget-category-details-txlist .budget-transaction {
    border-radius: var(--radius-sm);
}

.budget-transaction--upcoming {
    border-left-color: var(--color-primary) !important;
    opacity: 0.85;
}

.budget-category-details-separator {
    height: 1px;
    background: var(--color-border);
    margin: var(--space-2) 0;
}

.budget-category-details-section-label {
    padding: var(--space-2) var(--space-5);
    font-size: var(--fs-7);
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-primary);
}

/*
    Courses modal
*/

.groceries-shared-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
}

.groceries-payment-section-title {
    font-size: var(--fs-7);
    font-weight: var(--font-semibold);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.groceries-payment-card {
    background: var(--color-bg-elevated);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    border: 1px solid transparent;
    transition: border-color var(--transition-fast);
}

.groceries-payment-card:focus-within {
    border-color: var(--color-primary);
}

.groceries-payment-card-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-weight: var(--font-medium);
    color: var(--color-text-secondary);
    font-size: var(--fs-5);
}

.groceries-amount-wrapper {
    position: relative;
}

.groceries-amount-wrapper .form-control {
    padding-right: var(--space-6);
    text-align: right;
    font-size: var(--fs-4);
    font-weight: var(--font-semibold);
}

.groceries-amount-currency {
    position: absolute;
    right: var(--space-3);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    pointer-events: none;
    font-weight: var(--font-semibold);
}

/*
    Transaction search
*/

.budget-search-row {
    margin-bottom: var(--space-3);
}

.budget-search-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.budget-search-icon {
    position: absolute;
    left: var(--space-3);
    color: var(--color-text-muted);
    pointer-events: none;
    font-size: var(--fs-5);
}

.budget-search-input {
    padding-left: calc(var(--space-3) * 2 + 1em);
    padding-right: calc(var(--space-3) * 2 + 1em);
}

.budget-search-clear {
    position: absolute;
    right: var(--space-3);
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 0;
    line-height: 1;
    font-size: var(--fs-6);
    transition: color var(--transition-fast);
}

.budget-search-clear:hover {
    color: var(--color-text-primary);
}

.budget-transactions-empty {
    padding: var(--space-5) var(--space-3);
    text-align: center;
    color: var(--color-text-muted);
    font-size: var(--fs-5);
    background-color: var(--color-bg-elevated);
    border-radius: var(--radius-sm);
}