:root {
    --bg-deep: #080a10;
    --bg-primary: #0c0f18;
    --bg-card: #121622;
    --bg-input: #0a0d15;
    --border: #1f2437;
    --text-primary: #e4e7f0;
    --text-secondary: #8890ab;
    --text-muted: #4e5573;
    --income: #10b981;
    --income-soft: rgba(16,185,129,0.10);
    --expense: #f43f5e;
    --expense-soft: rgba(244,63,94,0.10);
    --balance: #f59e0b;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body { 
    font-family: 'DM Sans', sans-serif; 
    background: var(--bg-deep); 
    color: var(--text-primary); 
    min-height: 100vh; 
}

h1,h2,h3,h4,h5,h6 { font-family: 'Space Grotesk', sans-serif; }

/* Standard Inputs */
.bs-input {
    background: var(--bg-input); border: 1px solid var(--border); color: var(--text-primary);
    padding: 8px 12px; border-radius: 6px; font-family: inherit; font-size: 13px; width: 100%;
    transition: border-color 0.2s;
}
.bs-input:focus { outline: none; border-color: var(--income); }

/* Transparent Inputs (for table rows) */
.bs-input-plain {
    background: transparent; border: 1px solid transparent; color: var(--text-primary);
    padding: 8px 10px; font-size: 13px; width: 100%; border-radius: 4px;
}
.bs-input-plain:hover { background: rgba(255,255,255,0.03); }
.bs-input-plain:focus { 
    outline: none; 
    background: var(--bg-input); 
    border-color: var(--income); 
}

/* TABLE VIEW STYLES */
.table-view-container {
    max-height: 600px;
    overflow-y: auto;
    border: 1px solid var(--border);
    border-top: none;
}

/* ----- INCOME TABLE (5 columns: Date, Description, Category, Amount, Delete) ----- */
#incomeEntries .table-header,
#incomeEntries .entry-row {
    display: grid;
    grid-template-columns: minmax(135px, auto) 2fr 1.5fr 120px 40px;
    align-items: center;
    padding: 10px 16px;
    border-bottom: 1px solid var(--border);
}
#incomeEntries .table-header {
    background: var(--bg-card);
    border-bottom: 2px solid var(--border);
    padding: 12px 16px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--text-secondary);
    letter-spacing: 0.5px;
    position: sticky;
    top: 0;
    z-index: 10;
}
#incomeEntries .entry-row:hover { background: rgba(255,255,255,0.02); }

/* ----- EXPENSE TABLE (4 columns: Date, Description, Amount, Delete) ----- */
#expenseEntries .table-header,
#expenseEntries .entry-row {
    display: grid;
    grid-template-columns: minmax(135px, auto) 3fr 120px 40px;
    align-items: center;
    padding: 10px 16px;
    border-bottom: 1px solid var(--border);
}
#expenseEntries .table-header {
    background: var(--bg-card);
    border-bottom: 2px solid var(--border);
    padding: 12px 16px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--text-secondary);
    letter-spacing: 0.5px;
    position: sticky;
    top: 0;
    z-index: 10;
}
#expenseEntries .entry-row:hover { background: rgba(255,255,255,0.02); }

/* --- LEFT ALIGN DATE COLUMN (first child) & PREVENT CLIPPING --- */
#incomeEntries .table-header > :first-child,
#incomeEntries .entry-row > :first-child,
#expenseEntries .table-header > :first-child,
#expenseEntries .entry-row > :first-child {
    text-align: left !important;
    overflow: visible !important;
    white-space: nowrap !important;
}

/* Date input styling */
.entry-row input[type="date"] {
    width: auto !important;
    min-width: 120px !important;
    background: transparent;
    border: 1px solid transparent;
    font-family: 'DM Sans', monospace;
    font-size: 13px;
    color: var(--text-primary);
    padding: 6px 4px;
    border-radius: 4px;
}
.entry-row input[type="date"]:focus {
    outline: none;
    border-color: var(--income);
    background: var(--bg-input);
}

/* Detail Pill */
.detail-pill {
    background: rgba(255,255,255,0.05); border: 1px solid var(--border);
    color: var(--text-secondary); font-size: 11px; padding: 2px 6px; border-radius: 4px;
    margin-right: 4px;
}

/* Utility */
.split-col { flex: 1; min-width: 0; overflow: hidden; }
.col-divider { width: 1px; background: var(--border); flex-shrink: 0; }

.summary-card {
    border: 1px solid var(--border); border-radius: 12px; padding: 20px 24px;
    background: var(--bg-card); position: relative; overflow: hidden;
}
.summary-card .accent-bar { position: absolute; top: 0; left: 0; right: 0; height: 2px; }

.panel { background: var(--bg-card); border: 1px solid var(--border); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; }
.panel-header { padding: 16px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }

.toast-container { position: fixed; bottom: 20px; right: 20px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; pointer-events: none; }
.toast { padding: 12px 20px; border-radius: 8px; font-size: 13px; font-weight: 500; display: flex; align-items: center; gap: 8px; transform: translateX(120%); transition: all 0.3s cubic-bezier(0.16,1,0.3,1); pointer-events: auto; backdrop-filter: blur(12px); }
.toast.show { transform: translateX(0); }
.toast.success { background: rgba(16,185,129,0.15); border: 1px solid rgba(16,185,129,0.25); color: #34d399; }
.toast.info { background: rgba(59,130,246,0.15); border: 1px solid rgba(59,130,246,0.25); color: #60a5fa; }

.save-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--text-muted); transition: background 0.3s; }
.save-dot.saving { background: var(--balance); animation: pulse 1s infinite; }
.save-dot.saved { background: var(--income); }
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:0.3; } }

/* Mobile responsiveness */
@media (max-width: 900px) {
    .summary-grid { grid-template-columns: 1fr !important; }
    .main-split { flex-direction: column !important; }
    .col-divider { width: 100% !important; height: 1px !important; }
    
    #incomeEntries .table-header,
    #incomeEntries .entry-row {
        grid-template-columns: minmax(100px, auto) 1.5fr 1fr 90px 35px;
        padding: 8px 12px;
        gap: 6px;
    }
    #expenseEntries .table-header,
    #expenseEntries .entry-row {
        grid-template-columns: minmax(100px, auto) 2fr 90px 35px;
        padding: 8px 12px;
        gap: 6px;
    }
    .entry-row input[type="date"] {
        min-width: 95px !important;
        font-size: 11px;
    }
}

/* ========== PRINT STYLES ========== */
@media print {
    @page {
        size: landscape;
        margin: 0.5cm;
    }

    body {
        background: white !important;
        color: black !important;
    }

    /* Hide non-essential UI */
    header > div:last-child,
    .panel-header button,
    .toast-container,
    .save-dot,
    #saveLabel {
        display: none !important;
    }

    /* Hide delete icons/buttons */
    .delete-icon,
    .delete-btn,
    [aria-label="Delete"],
    button.delete-entry,
    .entry-row .delete,
    .entry-row button:last-child,
    img[alt="delete"],
    .fa-trash,
    .fas.fa-trash {
        display: none !important;
    }

    header {
        border-bottom: 2px solid #000;
        padding-bottom: 20px;
        margin-bottom: 20px;
        display: flex !important;
    }

    .main-split {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        width: 100%;
        gap: 10px !important;
    }

    .panel {
        flex: 1 !important;
        width: 50% !important;
        box-shadow: none !important;
        border: 1px solid #ccc !important;
        background: white !important;
        margin-bottom: 0;
        break-inside: avoid;
    }

    /* INCOME TABLE – FIX: Added 5th column (0%) to hide delete button gracefully */
    #incomeEntries .table-header,
    #incomeEntries .entry-row {
        grid-template-columns: 20% 30% 20% 15% 0% !important;
    }

    /* EXPENSE TABLE – 4 columns */
    #expenseEntries .table-header,
    #expenseEntries .entry-row {
        grid-template-columns: 25% 50% 10% 15% !important;
    }

    .table-header {
        padding: 12px 16px !important;
        min-height: 42px !important;
        align-items: center !important;
        background: #f9f9f9 !important;
        border-bottom: 2px solid black !important;
        color: black !important;
    }
    .entry-row {
        padding: 10px 16px !important;
        min-height: 42px !important;
        align-items: center !important;
        border-bottom: 1px solid #ddd !important;
    }

    input, .bs-input-plain {
        border: none !important;
        background: transparent !important;
        color: black !important;
        padding: 0 !important;
        text-align: left !important;
        font-size: 12pt !important;
    }

    /* Force description column to max 2 lines (for "form & kg") */
    .entry-row .bs-input-plain,
    .entry-row input[type="text"] {
        white-space: normal !important;
        word-break: break-word !important;
        line-height: 1.3 !important;
        max-height: 2.6em !important;
        overflow: hidden !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
    }

    /* Date column left-aligned, fully visible */
    .table-header > :first-child,
    .entry-row > :first-child {
        text-align: left !important;
        overflow: visible !important;
        white-space: nowrap !important;
    }

    .entry-row input[type="date"] {
        width: 100% !important;
        min-width: 0 !important;
        font-size: 11pt !important;
        font-family: monospace !important;
        background: white !important;
        color: black !important;
        border: none !important;
        padding: 2px 0 !important;
        text-align: left !important;
    }

    .summary-card {
        box-shadow: none;
        border: 1px solid #ccc;
        color: black !important;
        break-inside: avoid;
        margin-bottom: 20px;
    }

    :root {
        --text-primary: #000000;
        --text-secondary: #444444;
        --income: #008000;
        --expense: #cc0000;
        --balance: #b8860b;
    }
}
