/* ══ ACCOUNTING MODULE CSS ══ */

/* Accounts tree */
.accounts-tree {
    font-size: 0.875rem;
}

.account-group {
    margin-bottom: var(--space-2);
}

.account-group-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: var(--cr-dark);
    color: #fff;
    border-radius: var(--radius);
    font-weight: 700;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    cursor: pointer;
}

.account-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px var(--space-4);
    border-bottom: 1px solid var(--cr-border);
    transition: background var(--tr-fast);
}

.account-item:hover {
    background: var(--cr-surface);
}

.account-code {
    font-family: var(--font-mono);
    font-size: 0.78rem;
    color: var(--cr-mid);
    width: 70px;
    flex-shrink: 0;
}

.account-name {
    flex: 1;
    font-weight: 500;
}

.account-type-badge {
    font-size: 0.65rem;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: var(--radius-full);
    text-transform: uppercase;
}

.account-type-A {
    background: var(--cr-blue-light);
    color: var(--cr-blue);
}

.account-type-P {
    background: var(--cr-red-light);
    color: var(--cr-red);
}

.account-type-Pat {
    background: var(--cr-purple-light);
    color: var(--cr-purple);
}

.account-type-I {
    background: var(--cr-green-light);
    color: var(--cr-green);
}

.account-type-E {
    background: var(--cr-orange-light);
    color: var(--cr-orange);
}

.account-balance {
    font-weight: 700;
    font-family: var(--font-mono);
    font-size: 0.875rem;
    width: 110px;
    text-align: right;
}

/* Journal entry */
.journal-entry-card {
    background: var(--cr-white);
    border: 1px solid var(--cr-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: var(--space-3);
    transition: box-shadow var(--tr-fast);
}

.journal-entry-card:hover {
    box-shadow: var(--shadow-md);
}

.journal-entry-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3) var(--space-4);
    background: var(--cr-surface);
    border-bottom: 1px solid var(--cr-border);
}

.journal-entry-id {
    font-family: var(--font-mono);
    font-size: 0.78rem;
    color: var(--cr-mid);
}

.journal-entry-desc {
    font-weight: 600;
    font-size: 0.875rem;
}

.journal-lines {
    padding: var(--space-2) 0;
}

.journal-line {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr;
    gap: var(--space-3);
    padding: 6px var(--space-4);
    font-size: 0.8125rem;
    border-bottom: 1px solid var(--cr-border);
}

.journal-line:last-child {
    border-bottom: none;
}

.journal-line-account {
    color: var(--cr-dark);
    font-weight: 500;
}

.journal-line-debit {
    text-align: right;
    color: var(--cr-blue);
    font-weight: 600;
    font-family: var(--font-mono);
}

.journal-line-credit {
    text-align: right;
    color: var(--cr-green);
    font-weight: 600;
    font-family: var(--font-mono);
}

.journal-totals {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-4);
    background: var(--cr-surface);
    border-top: 2px solid var(--cr-border);
    font-weight: 700;
    font-size: 0.875rem;
    font-family: var(--font-mono);
}

/* Financial statements */
.financial-statement {
    background: var(--cr-white);
    border: 1px solid var(--cr-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.fs-header {
    text-align: center;
    padding: var(--space-6);
    background: var(--cr-dark);
    color: #fff;
}

.fs-header h2 {
    color: #fff;
    margin-bottom: 4px;
}

.fs-header p {
    color: rgba(255, 255, 255, .6);
    font-size: 0.875rem;
}

.fs-section {
    padding: var(--space-4);
}

.fs-section-title {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--cr-mid);
    padding-bottom: var(--space-2);
    border-bottom: 2px solid var(--cr-border);
    margin-bottom: var(--space-3);
}

.fs-row {
    display: flex;
    justify-content: space-between;
    padding: 5px 0;
    font-size: 0.8125rem;
    border-bottom: 1px dotted var(--cr-border);
}

.fs-row:last-child {
    border-bottom: none;
}

.fs-row.indent {
    padding-left: var(--space-5);
    color: var(--cr-mid);
}

.fs-row.subtotal {
    font-weight: 700;
    background: var(--cr-surface);
    padding: 6px var(--space-3);
    border-radius: var(--radius-sm);
    border: none;
    margin: 4px 0;
}

.fs-row.grand-total {
    font-weight: 800;
    font-size: 1rem;
    background: var(--cr-dark);
    color: #fff;
    padding: 10px var(--space-4);
    border-radius: var(--radius);
    border: none;
    margin-top: var(--space-2);
}