/* Modern App Styles for BillTracker */
:root {
    --bg: #0b0d10;
    --surface-0: #0b0d10;
    --surface-1: rgba(20, 22, 26, 0.98);
    --surface-2: rgba(255,255,255,0.03);
    --border: rgba(255,255,255,0.08);
    --border-subtle: rgba(255,255,255,0.06);
    --text: rgba(255,255,255,0.92);
    --text-muted: rgba(255,255,255,0.65);
    --text-faint: rgba(255,255,255,0.45);
    --accent: #14b8a6;
    --accent-2: #6366f1;
    --positive: #22c55e;
    --negative: #ef4444;
    --warning: #f59e0b;
    --info: #60a5fa;

    --bg-color: var(--bg);
    --card-bg: var(--surface-1);
    --card-border: var(--border-subtle);
    --text-primary: var(--text);
    --text-secondary: var(--text-muted);
    --primary-mint: var(--accent);
    --expense-red: var(--negative);
    --income-green: var(--positive);
    --income-blue: var(--info);
    --upcoming-orange: var(--warning);
    --nav-bg: rgba(15, 17, 21, 0.85);
    --nav-active: var(--accent);
    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --radius-card: 20px;
    --radius-pill: 999px;
    --shadow-card: 0 6px 24px rgba(0,0,0,0.25);
    --content-max: 1120px;
    --gutter: clamp(0.75rem, 1.6vw, 1.25rem);
    --card-pad: clamp(0.9rem, 1.2vw, 1.25rem);
    --title-size: clamp(1.1rem, 2vw, 1.5rem);
    --bottom-nav-height: calc(75px + env(safe-area-inset-bottom));
    --bottom-nav-content-pad: calc(var(--bottom-nav-height) + 18px);
}

:root[data-theme="light"]{
    --bg: #f6f7fb;
    --surface-0: #f6f7fb;
    --surface-1: rgba(255,255,255,0.92);
    --surface-2: rgba(0,0,0,0.04);
    --border: rgba(0,0,0,0.12);
    --border-subtle: rgba(0,0,0,0.08);
    --text: #000;
    --text-muted: rgba(0,0,0,0.72);
    --text-faint: rgba(0,0,0,0.55);
    --nav-bg: rgba(255,255,255,0.78);
    --shadow-card: 0 8px 28px rgba(0,0,0,0.10);
}

:root[data-style="glass"]{
    --glass-blur: 18px;
    --glass-sat: 165%;
    --bg: #070914;
    --surface-0: transparent;
    --surface-1: rgba(18, 22, 34, 0.52);
    --surface-2: rgba(255,255,255,0.08);
    --border: rgba(255,255,255,0.20);
    --border-subtle: rgba(255,255,255,0.12);
    --nav-bg: rgba(10, 12, 18, 0.42);
    --shadow-card: 0 18px 50px rgba(0,0,0,0.42);
    --card-bg: var(--surface-1);
    --card-border: var(--border-subtle);
}

:root[data-palette="violet"]{
    --accent: #7c3aed;
    --accent-2: #3b82f6;
    --primary-mint: var(--accent);
    --income-blue: #3b82f6;
    --nav-active: var(--accent);
}

:root[data-palette="teal"]{
    --accent: #14b8a6;
    --accent-2: #60a5fa;
    --primary-mint: var(--accent);
    --income-blue: #60a5fa;
    --nav-active: var(--accent);
}

:root[data-palette="sunset"]{
    --accent: #f97316;
    --accent-2: #ec4899;
    --primary-mint: var(--accent);
    --income-blue: #a78bfa;
    --nav-active: var(--accent);
}

:root[data-palette="mono"]{
    --accent: #94a3b8;
    --accent-2: #64748b;
    --primary-mint: #cbd5e1;
    --income-blue: #94a3b8;
    --nav-active: #cbd5e1;
}

:root[data-style="glass"][data-theme="light"]{
    --glass-blur: 18px;
    --glass-sat: 170%;
    --bg: #f6f7fb;
    --surface-0: transparent;
    --surface-1: rgba(255,255,255,0.58);
    --surface-2: rgba(0,0,0,0.05);
    --border: rgba(0,0,0,0.14);
    --border-subtle: rgba(0,0,0,0.10);
    --nav-bg: rgba(255,255,255,0.48);
    --shadow-card: 0 18px 50px rgba(0,0,0,0.14);
    --card-bg: var(--surface-1);
    --card-border: var(--border-subtle);
}

:root[data-style="glass"] body{
    background:
        radial-gradient(900px 600px at 15% -10%, rgba(99,102,241,0.35), rgba(99,102,241,0.00) 70%),
        radial-gradient(900px 600px at 110% 5%, rgba(20,184,166,0.26), rgba(20,184,166,0.00) 70%),
        radial-gradient(900px 700px at 50% 115%, rgba(96,165,250,0.18), rgba(96,165,250,0.00) 70%),
        linear-gradient(180deg, rgba(8,10,16,1), rgba(7,9,20,1));
}

:root[data-style="glass"][data-theme="light"] body{
    background:
        radial-gradient(900px 600px at 15% -10%, rgba(99,102,241,0.22), rgba(99,102,241,0.00) 70%),
        radial-gradient(900px 600px at 110% 5%, rgba(20,184,166,0.18), rgba(20,184,166,0.00) 70%),
        radial-gradient(900px 700px at 50% 115%, rgba(96,165,250,0.16), rgba(96,165,250,0.00) 70%),
        linear-gradient(180deg, rgba(246,247,251,1), rgba(240,244,252,1));
}

:root:not([data-style="glass"])[data-theme="light"] body{
    background: var(--bg-color) !important;
}

:root[data-theme="light"] .app-subtitle,
:root[data-theme="light"] .header-nav-item,
:root[data-theme="light"] .header-nav-item i{
    color: #000;
}

:root[data-theme="light"] .header-nav-item{
    background: rgba(0,0,0,0.03);
}

:root[data-theme="light"] .header-nav-item.active{
    color: #000;
    background: rgba(20,184,166,0.18);
    border-color: rgba(20,184,166,0.28);
}

:root[data-theme="light"] .header-nav-item.active i{
    color: #000;
}


* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html{
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

.app-container {
    min-height: 100vh;
    min-height: 100svh;
    min-height: 100dvh;
    width: 100%;
    overflow-x: hidden;
    background-color: var(--bg-color);
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

:root[data-style="glass"] .app-container{
    background-color: transparent;
}

.main-content {
    max-width: var(--content-max);
    margin: 0 auto;
    padding: var(--gutter);
}

body {
    background-color: var(--bg-color);
    color: var(--text-primary);
    font-family: var(--font-family);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding-bottom: var(--bottom-nav-content-pad);
    font-variant-numeric: tabular-nums;
}

.pie-row{
    display:flex;
    align-items:center;
    gap: clamp(0.75rem, 3vw, 2rem);
    flex-wrap: wrap;
}

.pie-row > div:first-child{
    width: clamp(96px, 28vw, 120px) !important;
    height: clamp(96px, 28vw, 120px) !important;
    flex: 0 0 auto;
}

.pie-row > div:last-child{
    flex: 1 1 220px;
    min-width: min(220px, 100%);
}

/* Header Styles */
.app-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: calc(0.7rem + env(safe-area-inset-top)) 1rem 0.7rem;
    background-color: var(--bg-color);
    position: sticky;
    top: 0;
    z-index: 100;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    background-color: var(--nav-bg);
    border-bottom: 1px solid var(--border-subtle);
    gap: 0.9rem;
}

:root[data-style="glass"] .app-header{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02)),
        var(--nav-bg);
    backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
    border-bottom: 1px solid var(--border-subtle);
}

.app-header-left {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.app-wordmark {
    display: none;
    flex-direction: column;
    min-width: 0;
}

.app-title {
    font-weight: 900;
    letter-spacing: -0.4px;
    line-height: 1.05;
}

.app-subtitle {
    font-size: 0.72rem;
    color: rgba(255,255,255,0.55);
    font-weight: 800;
    letter-spacing: 0.6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.header-nav {
    display: none;
    align-items: center;
    gap: 0.35rem;
    flex: 1;
    justify-content: center;
    min-width: 0;
}

.header-nav-item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.55rem 0.8rem;
    border-radius: 999px;
    text-decoration: none;
    color: rgba(255,255,255,0.7);
    font-weight: 800;
    font-size: 0.85rem;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border-subtle);
    position: relative;
    white-space: nowrap;
    --nav-accent: var(--accent, #7c3aed);
}

.header-nav-item i {
    font-size: 1rem;
    color: rgba(255,255,255,0.75);
    width: 30px;
    height: 30px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
}

.header-nav-item[data-page="dashboard"]{ --nav-accent: var(--income-blue); }
.header-nav-item[data-page="due"]{ --nav-accent: var(--upcoming-orange); }
.header-nav-item[data-page="bills"]{ --nav-accent: var(--expense-red); }
.header-nav-item[data-page="tasks"]{ --nav-accent: var(--accent); }
.header-nav-item[data-page="calendar"]{ --nav-accent: var(--accent-2); }
.header-nav-item[data-page="payments"]{ --nav-accent: #f59e0b; }
.header-nav-item[data-page="uitgaven"]{ --nav-accent: var(--primary-mint); }
.header-nav-item[data-page="insights"]{ --nav-accent: var(--accent-2); }

.header-nav-item.active {
    background: linear-gradient(180deg, color-mix(in oklab, var(--nav-accent) 22%, rgba(255,255,255,0.06)), rgba(255,255,255,0.04));
    border-color: color-mix(in oklab, var(--nav-accent) 45%, rgba(255,255,255,0.10));
    color: rgba(255,255,255,0.95);
}

.header-nav-item.active i {
    color: rgba(255,255,255,0.98);
    background: color-mix(in oklab, var(--nav-accent) 22%, rgba(255,255,255,0.06));
    border-color: color-mix(in oklab, var(--nav-accent) 48%, rgba(255,255,255,0.10));
}

.nav-badge.header-nav-badge {
    top: -6px;
    right: -6px;
}

@media (min-width: 900px) {
    .app-wordmark {
        display: flex;
    }
    .header-nav {
        display: flex;
    }
    body {
        padding-bottom: 0;
    }
    nav.modern-bottom-nav {
        display: none !important;
    }
    .page-content {
        padding-bottom: 1.25rem;
    }
}


.app-logo {
    display: inline-flex;
    align-items: center;
    line-height: 0;
}

.app-logo img {
    height: 34px;
    width: auto;
    display: block;
}

.app-header-actions {
    display: flex;
    gap: 1.5rem;
    font-size: 1.1rem;
    color: var(--text-secondary);
}

.app-header-actions i {
    cursor: pointer;
}

.notification-wrapper {
    position: relative;
    cursor: pointer;
    background: transparent;
    border: 0;
    padding: 0.35rem 0.45rem;
    border-radius: 12px;
    color: inherit;
    line-height: 1;
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.notification-wrapper.header-bank-btn.bank-state-connected {
    background: rgba(34, 197, 94, 0.16);
    color: rgba(220, 252, 231, 0.95);
}

.notification-wrapper.header-bank-btn.bank-state-disconnected {
    background: rgba(231, 76, 60, 0.14);
    color: rgba(254, 226, 226, 0.95);
}

.notification-wrapper.header-bank-btn.bank-state-needs-config {
    background: rgba(243, 156, 18, 0.16);
    color: rgba(255, 247, 237, 0.95);
}

.notification-wrapper.header-bank-btn.bank-state-unknown {
    background: rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.82);
}

.notification-wrapper.header-bank-btn:hover {
    filter: brightness(1.06);
}

.notification-badge-header {
    display: none;
}

/* Focus & accessibility */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 2px solid rgba(46, 204, 113, 0.75);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    * {
        scroll-behavior: auto !important;
        transition: none !important;
        animation: none !important;
    }
}

.ui-state {
    border: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.02);
    border-radius: 16px;
    padding: 1rem;
    text-align: center;
    color: rgba(255,255,255,0.75);
}

.ui-state.ui-loading {
    color: rgba(255,255,255,0.65);
}

/* Dashboard Content */
.dashboard-container {
    padding: 0;
}

.dashboard-title {
    font-size: 1.5rem;
    font-weight: 800;
    margin-bottom: 0.1rem;
    letter-spacing: -0.5px;
}

.dashboard-subtitle {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 1.25rem;
    opacity: 0.8;
}

/* Tab Controls */
.dashboard-tabs {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
    overflow-x: auto;
    padding-bottom: 0.25rem;
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.dashboard-tabs::-webkit-scrollbar {
    display: none;
}

:root[data-style="glass"] .dashboard-tabs{
    background: rgba(255,255,255,0.06);
    border: 1px solid var(--border-subtle);
    border-radius: 16px;
    padding: 0.25rem;
    backdrop-filter: blur(calc(var(--glass-blur) - 2px)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(calc(var(--glass-blur) - 2px)) saturate(var(--glass-sat));
}

.tab-btn {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 0.8rem;
    background-color: var(--surface-2);
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 600;
    white-space: nowrap;
    cursor: pointer;
    transition: all 0.2s ease;
}

:root[data-style="glass"] .tab-btn{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.04)),
        rgba(255,255,255,0.02);
    border: 1px solid var(--border-subtle);
    backdrop-filter: blur(calc(var(--glass-blur) - 6px)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(calc(var(--glass-blur) - 6px)) saturate(var(--glass-sat));
}

#dashboard-page .dashboard-tabs,
#due-page .dashboard-tabs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
    overflow-x: hidden;
    gap: 0.5rem;
}

#dashboard-page .dashboard-tabs .tab-btn,
#due-page .dashboard-tabs .tab-btn {
    width: 100%;
    justify-content: center;
    padding: 0.55rem 0.5rem;
    min-width: 0;
    font-size: 0.82rem;
    text-overflow: ellipsis;
    overflow: hidden;
}

.tab-btn i {
    font-size: 1rem;
}

.tab-btn.active {
    background-color: var(--primary-mint);
    color: #000000;
}

:root[data-style="glass"] .tab-btn.active{
    background:
        linear-gradient(135deg, rgba(20,184,166,0.40), rgba(99,102,241,0.18));
    border-color: rgba(255,255,255,0.18);
    color: rgba(255,255,255,0.95);
    box-shadow: 0 10px 26px rgba(20,184,166,0.22);
}

#dashboard-page .dashboard-tabs{
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border-subtle);
    border-radius: 16px;
    padding: 0.25rem;
    gap: 0.25rem;
}

#dashboard-page .dashboard-tabs .tab-btn{
    background: transparent;
    color: rgba(255,255,255,0.75);
    font-size: 0;
    border-radius: 14px;
    padding: 0.55rem 0.35rem;
    display:flex;
    flex-direction: column;
    align-items:center;
    justify-content:center;
    gap: 0.25rem;
    position: relative;
    --tab-accent: var(--primary-mint);
    line-height: 1.05;
}

#dashboard-page .dashboard-tabs .tab-btn i{
    font-size: 1.1rem;
    color: rgba(255,255,255,0.75);
}

#dashboard-page .dashboard-tabs .tab-btn .badge{
    font-size: 0.72rem;
    opacity: 0.85;
    position: absolute;
    top: 6px;
    right: 10px;
}

#dashboard-page .dashboard-tabs .tab-btn::after{
    display:block;
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: 0.2px;
    opacity: 0.8;
    line-height: 1.15;
}

#dashboard-page .dashboard-tabs .tab-btn[data-tab="chart"]::after{ content: "Home"; }
#dashboard-page .dashboard-tabs .tab-btn[data-tab="bills"]::after{ content: "Rekeningen"; }
#dashboard-page .dashboard-tabs .tab-btn[data-tab="tasks"]::after{ content: "Taken"; }
#dashboard-page .dashboard-tabs .tab-btn[data-tab="balance"]::after{ content: "Balans"; }

#dashboard-page .dashboard-tabs .tab-btn[data-tab="chart"]{ --tab-accent: var(--income-blue); }
#dashboard-page .dashboard-tabs .tab-btn[data-tab="bills"]{ --tab-accent: var(--expense-red); }
#dashboard-page .dashboard-tabs .tab-btn[data-tab="tasks"]{ --tab-accent: var(--upcoming-orange); }
#dashboard-page .dashboard-tabs .tab-btn[data-tab="balance"]{ --tab-accent: var(--primary-mint); }

#dashboard-page .dashboard-tabs .tab-btn.active{
    background: rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.92);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
}

#dashboard-page .dashboard-tabs .tab-btn.active i{
    color: var(--tab-accent);
}

#dashboard-page .dashboard-tabs .tab-btn:active{
    transform: scale(0.98);
}

.filter-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
    margin: 1.5rem 0;
}

.filter-tabs-compact {
    margin: 0 0 1.5rem 0;
}

.filter-tabs .tab-btn {
    width: 100%;
    justify-content: center;
    text-overflow: ellipsis;
    overflow: hidden;
}

.tab-btn .badge {
    font-size: 0.8rem;
    opacity: 0.8;
}

/* Summary Card */
.summary-card-modern {
    background: linear-gradient(145deg, #171b22, #12151b);
    border-radius: var(--radius-card);
    padding: var(--card-pad);
    margin-bottom: 1rem;
    border: 1px solid var(--card-border);
    box-shadow: var(--shadow-card);
}

.summary-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 800;
    font-size: 1rem;
    margin-bottom: 1.25rem;
}

.summary-header-row{
    justify-content: space-between;
}
.summary-header-left{
    display:flex;
    align-items:center;
    gap: 0.5rem;
    min-width: 0;
}

.dash-collapsible{
    margin-top: 0.85rem;
    padding-top: 0.85rem;
    border-top: 1px solid var(--border-subtle);
}
.dash-collapsible[aria-hidden="true"]{
    display:none;
}

.projection-header-row{
    display:flex;
    justify-content: space-between;
    align-items:center;
    gap: 0.75rem;
}
.projection-header-left{
    display:flex;
    align-items:center;
    gap: 0.5rem;
    min-width: 0;
}
.dash-collapsible-body.is-collapsed{
    display:none;
}

.summary-header i {
    color: var(--income-blue);
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.summary-item {
    background-color: rgba(255, 255, 255, 0.04);
    border-radius: 16px;
    padding: 1rem;
    border: 1px solid rgba(255,255,255,0.06);
}

:root[data-style="glass"] .content-card,
:root[data-style="glass"] .summary-card-modern,
:root[data-style="glass"] .projection-card,
:root[data-style="glass"] .summary-item,
:root[data-style="glass"] .arrangement-modern-card,
:root[data-style="glass"] .bill-card,
:root[data-style="glass"] .task-modern-card,
:root[data-style="glass"] .inout-split-card,
:root[data-style="glass"] table,
:root[data-style="glass"] th,
:root[data-style="glass"] td{
    border: 0 !important;
}

:root[data-style="glass"] table{
    border-collapse: collapse;
}
.summary-item.income {
    border-left: 4px solid var(--income-green);
}

.summary-item.expense {
    border-left: 4px solid var(--expense-red);
}

.summary-item.commitment {
    border-left: 4px solid rgba(168, 85, 247, 0.9);
}

.item-label {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.item-value {
    font-size: 1.25rem;
    font-weight: 800;
}

.item-subvalue{
    margin-top: 0.25rem;
    font-size: 0.85rem;
    font-weight: 800;
    color: rgba(255,255,255,0.68);
}

.summary-item.income .item-value {
    color: var(--income-green);
}

.summary-item.expense .item-value {
    color: var(--expense-red);
}

.net-balance-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

@media (max-width: 720px){
    .summary-grid{
        grid-template-columns: 1fr;
    }
}

.net-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
    font-size: 0.95rem;
}

.net-value {
    font-size: 1.5rem;
    font-weight: 800;
}

.summary-footer {
    text-align: center;
    margin-top: 1rem;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

/* Saldo Projectie Card */
.projection-card {
    background-color: #0d2a1c; /* Dark green background */
    border-radius: 20px;
    padding: 1.25rem;
    margin-bottom: 1rem;
    border: 1px solid rgba(46, 204, 113, 0.2);
}

.projection-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 1.25rem;
    color: var(--primary-mint);
}

.input-group {
    margin-bottom: 1.25rem;
}

.input-label {
    display: block;
    font-size: 0.75rem;
    text-transform: uppercase;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.5);
    margin-bottom: 0.5rem;
}

.modern-input {
    width: 100%;
    background-color: #1a1a1a;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 0.8rem 1rem;
    color: white;
    font-size: 1.1rem;
    font-weight: 600;
}

.projection-details {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.projection-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.projection-grid.projection-grid-simple{
    grid-template-columns: 1.15fr 0.85fr;
    gap: 0.85rem;
    align-items: start;
}

.projection-kpis {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.6rem;
    margin-bottom: 0.75rem;
}

.projection-kpi {
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
    border-radius: 14px;
    padding: 0.75rem 0.85rem;
}

.projection-kpi-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    font-weight: 900;
    color: rgba(255,255,255,0.6);
}

.projection-kpi-value {
    font-weight: 900;
    font-size: 1.35rem;
    margin-top: 0.15rem;
    color: rgba(255,255,255,0.92);
}

.projection-details-collapsible {
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.02);
    border-radius: 14px;
    padding: 0.6rem 0.75rem;
}

.projection-details-collapsible > summary {
    cursor: pointer;
    font-weight: 900;
    color: rgba(255,255,255,0.85);
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.projection-details-collapsible > summary::-webkit-details-marker {
    display: none;
}

@media (max-width: 900px) {
    .projection-grid {
        grid-template-columns: 1fr;
    }
    .projection-grid.projection-grid-simple{
        gap: 0.75rem;
    }
}

.detail-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.95rem;
}

.detail-label {
    color: rgba(255, 255, 255, 0.7);
}

.detail-value {
    font-weight: 700;
}

.detail-value.pos { color: var(--income-green); }
.detail-value.neg { color: var(--expense-red); }

/* Tab Content */
.tab-content {
    display: none;
    animation: fadeIn 0.3s ease;
}

.tab-content.active {
    display: block;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Month Selector */
.month-selector-modern {
    background-color: var(--card-bg);
    border-radius: 16px;
    padding: 0.5rem 1rem;
    border: 1px solid var(--card-border);
}

#dashboard-month-selector{
    display:flex !important;
    align-items:center !important;
    justify-content: space-between !important;
    gap: 0.6rem !important;
    padding: 0.65rem 0.75rem !important;
    margin: 0 0 1rem !important;
    position: sticky;
    top: var(--app-header-h, 72px);
    z-index: 99;
    background: rgba(20,22,26,0.98);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

:root[data-style="glass"] #dashboard-month-selector{
    background: var(--nav-bg);
    border: 1px solid var(--border-subtle);
    backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}
#dashboard-month-selector #dashboard-month-label{
    flex: 1 1 auto;
    text-align: center;
    font-weight: 950 !important;
    letter-spacing: -0.2px;
}
#dashboard-month-selector .action-btn-circle{
    width: 44px;
    height: 44px;
}
#dashboard-month-selector #dashboard-month-now{
    border: none;
    background: rgba(255,255,255,0.06);
    font-weight: 950;
}

.card-collapsible-body{
    overflow: hidden;
    transition: max-height 0.22s ease, opacity 0.22s ease;
    max-height: 5000px;
    opacity: 1;
}
.content-card.collapsed .card-collapsible-body,
.summary-card-modern.collapsed .card-collapsible-body{
    max-height: 0;
    opacity: 0;
    pointer-events: none;
}

#category-modal-overlay{
    z-index: 2100;
}

/* Filter Tabs */
.filter-tabs .tab-btn {
    flex: 1;
    justify-content: center;
}

/* Page Containers */
.page {
    display: none;
}

.page.active {
    display: block;
}

/* App Logo Fix */
.main-content {
    flex: 1;
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

.page-content {
    padding-bottom: var(--bottom-nav-content-pad);
}

@media (min-width: 1024px) {
    nav.modern-bottom-nav {
        display: flex !important;
    }
}

@media (max-width: 480px){
    :root{
        --gutter: 0.65rem;
        --card-pad: 0.85rem;
        --bottom-nav-height: calc(68px + env(safe-area-inset-bottom));
        --bottom-nav-content-pad: calc(var(--bottom-nav-height) + 16px);
    }
}

.notification-badge-header {
    position: absolute;
    top: -5px;
    right: -5px;
    background-color: var(--expense-red);
    color: white;
    font-size: 0.65rem;
    font-weight: 800;
    min-width: 16px;
    height: 16px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2px;
    border: 2px solid var(--bg-color);
}

/* Installment Cards */
.installment-card {
    background-color: var(--card-bg);
    border-radius: 24px;
    padding: 1.5rem;
    border: 1px solid var(--card-border);
}

.installment-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.installment-title {
    font-size: 1.25rem;
    font-weight: 800;
    color: white;
}

.installment-amount {
    text-align: right;
}

.amount-val {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--income-blue);
}

.amount-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.installment-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

.installment-progress-container {
    margin-bottom: 1.5rem;
}

.progress-labels {
    display: flex;
    justify-content: space-between;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.modern-progress-bar {
    height: 8px;
    background-color: rgba(255, 255, 255, 0.05);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 1rem;
}

.progress-fill {
    height: 100%;
    background-color: var(--income-blue);
    border-radius: 4px;
}

.installment-dots {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.1);
}

.dot.paid {
    background-color: var(--income-blue);
}

.btn-pay-installment {
    width: 100%;
    background-color: rgba(52, 152, 219, 0.1);
    color: var(--income-blue);
    border: 1px solid rgba(52, 152, 219, 0.2);
    border-radius: 12px;
    padding: 0.8rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-pay-installment:hover {
    background-color: var(--income-blue);
    color: white;
}

.period-section {
    margin-top: 1rem !important;
    padding: 1rem !important;
}

.period-section h3 {
    font-size: 1rem !important;
    margin-bottom: 0.75rem !important;
}

.due-section-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.1rem;
    margin-bottom: 1rem;
}

.due-tab-content {
    animation: fadeIn 0.3s ease;
}

/* Chart Legends */
.legend-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.85rem;
    margin-bottom: 0.5rem;
}

.legend-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
}

.legend-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.legend-value {
    font-weight: 700;
}


/* Bottom Navigation */
nav.modern-bottom-nav {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: var(--bottom-nav-height) !important;
    background-color: rgba(15, 17, 21, 0.88) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    display: flex !important;
    justify-content: space-around !important;
    align-items: center !important;
    padding: 8px 0.5rem env(safe-area-inset-bottom) !important;
    border-top: 1px solid rgba(255,255,255,0.08) !important;
    z-index: 1000 !important;
}

nav.modern-bottom-nav .bottom-nav-container {
    display: flex;
    width: 100%;
    justify-content: flex-start;
    align-items: flex-start;
    padding: 0 0.75rem;
    gap: 0.4rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.nav-item-modern {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.25rem !important;
    text-decoration: none !important;
    color: var(--text-secondary) !important;
    font-size: 0.7rem !important;
    font-weight: 600 !important;
    transition: all 0.2s ease !important;
    background: transparent !important;
    border: none !important;
    flex: 0 0 auto;
    min-width: 58px;
    padding: 0.25rem 0;
    text-align: center;
    position: relative;
    border: none !important;
}
.nav-item-modern::before,
.nav-item-modern::after{
    display:none !important;
    content: none !important;
}

.nav-item-modern i {
    font-size: 1.55rem;
    line-height: 1;
}

:root{
    --accent-orange: #ff7a1a;
    --surface-border: var(--border-subtle);
    --surface-border-2: var(--border);
}

@media (max-width: 900px){
    .app-header{
        padding: calc(0.65rem + env(safe-area-inset-top)) 0.9rem 0.65rem;
    }
    .app-logo img{ height: 28px; }
    .app-wordmark{
        display:flex !important;
        position:absolute;
        left:50%;
        transform:translateX(-50%);
        align-items:center;
        justify-content:center;
        text-align:center;
        pointer-events:none;
        width: min(62vw, 420px);
    }
    .app-title{
        font-size: 1.05rem;
        font-weight: 950;
        letter-spacing: -0.2px;
    }
    .app-subtitle{ display:none !important; }
}

.app-header-actions{
    gap: 0.75rem;
}
.app-header-actions i{
    color: rgba(255,255,255,0.78);
    background: transparent;
    border: none;
}
.app-header-actions i:hover{
    color: rgba(255,255,255,0.92);
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
}

:root[data-theme="light"] .app-header-actions i{
    color: rgba(12,14,20,0.72);
}
:root[data-theme="light"] .app-header-actions i:hover{
    color: rgba(12,14,20,0.90);
    background: rgba(0,0,0,0.04);
    border: 1px solid rgba(0,0,0,0.08);
}

:root:not([data-style="glass"]) .content-card,
:root:not([data-style="glass"]) .summary-card-modern,
:root:not([data-style="glass"]) .projection-card{
    background: rgba(20,22,26,0.98) !important;
    border: 1px solid var(--surface-border) !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

:root:not([data-style="glass"])[data-theme="light"] .content-card,
:root:not([data-style="glass"])[data-theme="light"] .summary-card-modern,
:root:not([data-style="glass"])[data-theme="light"] .projection-card{
    background: rgba(255,255,255,0.92) !important;
    border: 1px solid rgba(0,0,0,0.08) !important;
    box-shadow: var(--shadow-card) !important;
}

:root[data-style="glass"] .content-card,
:root[data-style="glass"] .summary-card-modern,
:root[data-style="glass"] .projection-card{
    background: var(--card-bg) !important;
    border: 1px solid var(--card-border) !important;
    box-shadow: var(--shadow-card) !important;
    backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}
.content-card,
.summary-card-modern,
.projection-card{
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}
.content-card:hover,
.summary-card-modern:hover,
.projection-card:hover{
    transform: translateY(-2px);
}
.content-card[data-anim="pop"]{
    animation: cardPop 240ms ease-out both;
}
@keyframes cardPop{
    from{opacity:0; transform: translateY(8px) scale(0.985);}
    to{opacity:1; transform: translateY(0) scale(1);}
}
@media (prefers-reduced-motion: reduce){
    .content-card,
    .summary-card-modern,
    .projection-card{
        transition: none;
    }
    .content-card:hover,
    .summary-card-modern:hover,
    .projection-card:hover{
        transform: none;
    }
    .content-card[data-anim="pop"]{
        animation: none;
    }
}

.budget-rings-grid{
    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.75rem;
}
.budget-ring-item{
    display:flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    padding: 0.2rem 0.15rem;
}
.budget-ring{
    width: 118px;
    height: 118px;
    border-radius: 999px;
    background: conic-gradient(var(--ring) calc(var(--p) * 1%), rgba(255,255,255,0.10) 0);
    display:flex;
    align-items:center;
    justify-content:center;
    transition: background 320ms ease;
}
.budget-ring-inner{
    width: 86px;
    height: 86px;
    border-radius: 999px;
    background: rgba(20,22,26,0.98);
    border: 1px solid rgba(255,255,255,0.10);
    display:flex;
    flex-direction: column;
    align-items:center;
    justify-content:center;
    gap: 0.15rem;
}

:root[data-style="glass"] .budget-ring-inner{
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}

:root[data-theme="light"] .budget-ring{
    background: conic-gradient(var(--ring) calc(var(--p) * 1%), rgba(0,0,0,0.08) 0);
}
:root[data-theme="light"] .budget-ring-inner{
    background: rgba(255,255,255,0.96);
    border: 1px solid rgba(0,0,0,0.08);
}

:root[data-theme="light"] #dashboard-month-selector{
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(0,0,0,0.08);
}
:root[data-theme="light"] #dashboard-month-selector #dashboard-month-now{
    background: rgba(0,0,0,0.04);
}
.budget-ring-pct{
    font-weight: 950;
    letter-spacing: -0.2px;
    font-size: 1.05rem;
}
.budget-ring-sub{
    opacity: 0.8;
    font-weight: 900;
    font-size: 0.85rem;
}
.budget-ring-label{
    font-weight: 950;
    text-align: center;
    margin-top: 0.15rem;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.budget-ring-meta{
    opacity: 0.72;
    font-weight: 850;
    font-size: 0.82rem;
    text-align: center;
}

.budget-members{
    margin-top: 0.55rem;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
    border-radius: 14px;
    padding: 0.55rem;
    max-height: 220px;
    overflow:auto;
    display:flex;
    flex-direction: column;
    gap: 0.4rem;
}
.budget-members.disabled{
    opacity: 0.55;
    pointer-events:none;
}
.budget-member{
    display:grid;
    grid-template-columns: auto 1fr auto;
    align-items:center;
    gap: 0.6rem;
    padding: 0.35rem 0.4rem;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.03);
}

.summary-header{
    color: rgba(255,255,255,0.90);
    font-weight: 950;
    letter-spacing: -0.2px;
}
.summary-header i{
    color: var(--accent-orange);
}

.btn{
    box-shadow: none;
    border: 1px solid var(--surface-border);
    background: rgba(255,255,255,0.04);
}
.btn:hover{
    box-shadow: none;
    background: rgba(255,255,255,0.06);
}
.btn.btn-primary{
    background: rgba(255,122,26,0.14);
    border-color: rgba(255,122,26,0.22);
    box-shadow: none;
}
.btn.btn-primary:hover{
    background: rgba(255,122,26,0.18);
    border-color: rgba(255,122,26,0.28);
    box-shadow: none;
}

.action-btn-circle,
.bill-icon-btn{
    box-shadow: none !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
}
.action-btn-circle:hover,
.bill-icon-btn:hover{
    box-shadow: none !important;
    background: rgba(255,255,255,0.08) !important;
    border-color: rgba(255,255,255,0.12) !important;
}

.search-box-modern{
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    padding: 0.65rem 0.75rem;
    display:flex;
    align-items:center;
    gap: 0.65rem;
}
.search-box-modern i{
    color: rgba(255,255,255,0.55);
}
.search-box-modern input,
.search-box-modern .modern-input{
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    color: rgba(255,255,255,0.92);
}
.search-box-modern input::placeholder,
.search-box-modern .modern-input::placeholder{
    color: rgba(255,255,255,0.45);
}

.quick-actions-wrap{
    display:flex !important;
    justify-content: space-between;
    gap: 0.6rem !important;
}
.quick-action{
    flex: 1 1 0;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0.35rem 0.15rem !important;
    display:flex !important;
    flex-direction: column !important;
    align-items:center !important;
    justify-content:center !important;
    gap: 0.45rem !important;
    font-weight: 900 !important;
    color: rgba(255,255,255,0.82) !important;
}
.quick-action i{
    width: 48px;
    height: 48px;
    border-radius: 999px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size: 1.35rem;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
    color: var(--accent-orange) !important;
}

.nav-item-modern span {
    font-size: 0.65rem;
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

.nav-item-modern.active {
    color: var(--income-blue);
}

.nav-item-modern.active i {
    color: var(--income-blue);
}

.nav-badge {
    position: absolute;
    top: -4px;
    right: 18px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    background: rgba(239, 68, 68, 0.95);
    color: rgba(255,255,255,0.95);
    font-size: 0.65rem;
    font-weight: 900;
    display: none;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 14px rgba(0,0,0,0.25);
    line-height: 1;
    white-space: nowrap;
}

/* FAB Menu */
.fab-container {
    position: fixed;
    bottom: calc(var(--bottom-nav-height) + 10px);
    right: 1.25rem;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 12px;
    z-index: 10000;
}

.fab-options {
    display: none;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    margin-bottom: 8px;
}

.fab-options.active {
    display: flex;
}

.fab-option {
    display: flex;
    align-items: center;
    gap: 12px;
    background-color: #1e1e1e;
    padding: 8px 16px;
    border-radius: 12px;
    color: white;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    transition: transform 0.2s ease;
}

.fab-option:hover {
    transform: scale(1.05);
}

.fab-option i {
    font-size: 1.2rem;
}

.fab-option.taak i { color: #3498db; }
.fab-option.bill i { color: #9b59b6; }
.fab-option.inkomst i { color: #2ecc71; }
.fab-option.uitgave i { color: #e74c3c; }

.fab-main {
    width: 60px;
    height: 60px;
    background-color: #3498db;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    font-size: 1.5rem;
    box-shadow: 0 4px 15px rgba(52, 152, 219, 0.4);
    cursor: pointer;
    border: none;
    transition: transform 0.3s ease;
}

.fab-main.active {
    transform: rotate(45deg);
    background-color: #e74c3c;
}

.modal-content-modern {
    width: 100%;
    max-width: 520px;
    background-color: #1e1e1e;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 20px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 32px);
}

.modal-header-modern {
    padding: 1rem 1rem 0.75rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.modal-header-modern h3 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 800;
}

.modal-body-modern {
    padding: 1rem;
    overflow-y: auto;
}

.modal-footer-modern {
    padding: 0.75rem 1rem 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
}

#bills-page .page-actions {
    display: none;
}

#bills-page .content-card.period-section {
    display: none;
}

#bills-modern-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

#tasks-modern-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.bill-pill.status.open {
    background: rgba(59, 130, 246, 0.18);
    border-color: rgba(59, 130, 246, 0.28);
    color: rgba(191, 219, 254, 0.95);
}

.bill-pill.status.pending {
    background: rgba(245, 158, 11, 0.18);
    border-color: rgba(245, 158, 11, 0.28);
    color: rgba(254, 215, 170, 0.95);
}

.bill-pill.status.completed {
    background: rgba(34, 197, 94, 0.18);
    border-color: rgba(34, 197, 94, 0.28);
    color: rgba(187, 247, 208, 0.95);
}

.bill-action-primary.complete {
    background: rgba(34, 197, 94, 0.18);
    color: rgba(187, 247, 208, 0.95);
}

.bill-action-primary.reopen {
    background: rgba(59, 130, 246, 0.18);
    color: rgba(191, 219, 254, 0.95);
}

.bill-modern-card {
    background: linear-gradient(145deg, #1c1c1e, #121214);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 18px;
    padding: 1.1rem 1.1rem 0.9rem;
}

.bill-modern-card.due-overdue {
    border-color: rgba(231, 76, 60, 0.55);
    box-shadow: 0 0 0 1px rgba(231, 76, 60, 0.20), 0 8px 24px rgba(231, 76, 60, 0.08);
}

.bill-modern-card.due-soon {
    border-color: rgba(245, 158, 11, 0.55);
    box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.18), 0 8px 24px rgba(245, 158, 11, 0.06);
}

.bill-modern-header {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.4rem;
}

.bill-modern-title {
    font-weight: 900;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    font-size: 1.05rem;
}

.bill-title-row {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    min-width: 0;
}

.bill-title-icon {
    width: 32px;
    height: 32px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.06);
    flex: 0 0 auto;
}

.bill-title-text {
    font-weight: 900;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    font-size: 1.05rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.bill-modern-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: center;
    color: rgba(255,255,255,0.7);
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}

.bill-meta-amount {
    color: var(--expense-red);
    font-weight: 800;
}

.bill-meta-date {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.bill-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.25rem 0.6rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.25px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    color: rgba(255,255,255,0.85);
}

.bill-pill.period {
    background: rgba(99, 102, 241, 0.18);
    border-color: rgba(99, 102, 241, 0.28);
    color: rgba(199, 210, 254, 0.95);
}

.bill-pill.period.monthly {
    background: rgba(59, 130, 246, 0.18);
    border-color: rgba(59, 130, 246, 0.28);
}

.bill-pill.period.quarterly {
    background: rgba(147, 51, 234, 0.18);
    border-color: rgba(147, 51, 234, 0.28);
}

.bill-pill.period.semiannual {
    background: rgba(245, 158, 11, 0.18);
    border-color: rgba(245, 158, 11, 0.28);
}

.bill-pill.period.yearly {
    background: rgba(16, 185, 129, 0.18);
    border-color: rgba(16, 185, 129, 0.28);
}

.bill-pill.due-badge {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.9);
}

.bill-pill.due-badge.overdue,
.bill-pill.due-badge.urgent {
    background: rgba(231, 76, 60, 0.18);
    border-color: rgba(231, 76, 60, 0.32);
    color: rgba(254, 202, 202, 0.95);
}

.bill-pill.due-badge.soon {
    background: rgba(245, 158, 11, 0.18);
    border-color: rgba(245, 158, 11, 0.32);
    color: rgba(254, 215, 170, 0.95);
}

.bill-pill.due-badge.upcoming {
    background: rgba(234, 179, 8, 0.16);
    border-color: rgba(234, 179, 8, 0.30);
    color: rgba(254, 240, 138, 0.95);
}

.bill-pill.due-badge.snoozed {
    background: rgba(245, 158, 11, 0.12);
    border-color: rgba(245, 158, 11, 0.22);
    color: rgba(254, 215, 170, 0.92);
}

.bill-snoozed-label {
    color: rgba(245, 158, 11, 0.95);
    font-weight: 800;
    font-size: 0.85rem;
    margin-left: 0.25rem;
}

.bill-modern-actions {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    padding-top: 0.9rem;
    border-top: 1px solid rgba(255,255,255,0.06);
    margin-top: 0.6rem;
}

.bill-action-primary {
    flex: 1;
    height: 44px;
    border: none;
    border-radius: 12px;
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    cursor: pointer;
}

.bill-action-primary.pay {
    background: rgba(34, 197, 94, 0.18);
    color: rgba(187, 247, 208, 0.95);
}

.bill-action-primary.unpay {
    background: rgba(239, 68, 68, 0.14);
    color: rgba(254, 202, 202, 0.95);
}

.bill-action-primary.snooze {
    background: rgba(245, 158, 11, 0.18);
    color: rgba(254, 215, 170, 0.95);
}

.bill-action-primary.unsnooze {
    background: rgba(59, 130, 246, 0.18);
    color: rgba(191, 219, 254, 0.95);
}

.bill-action-primary.paid {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.75);
    cursor: default;
}

.bill-action-iconbar {
    display: flex;
    gap: 0.6rem;
}

.bill-icon-btn {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    border: none;
    background: rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.85);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.bill-icon-btn.delete {
    color: rgba(248, 113, 113, 0.95);
}

.bill-icon-btn.undo {
    color: rgba(167, 139, 250, 0.95);
}

.arrangements-modern-section {
    margin-top: 1.25rem;
}

.arrangements-modern-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.05rem;
    font-weight: 900;
    margin-bottom: 0.75rem;
}

#arrangements-modern-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.arrangement-modern-card {
    background: linear-gradient(145deg, #1c1c1e, #121214);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 18px;
    padding: 1.1rem;
}

.arrangement-modern-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.arrangement-modern-title {
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.arrangement-modern-amount {
    color: var(--income-blue);
    font-weight: 900;
}

.arrangement-modern-sub {
    color: rgba(255,255,255,0.65);
    font-size: 0.8rem;
    margin-top: 0.2rem;
}

.arrangement-progress-bar {
    height: 8px;
    border-radius: 999px;
    background: rgba(255,255,255,0.06);
    overflow: hidden;
    margin: 0.75rem 0 0.75rem;
}

.arrangement-progress-fill {
    height: 100%;
    background: rgba(59, 130, 246, 0.9);
}

.arrangement-dots {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 0.85rem;
}

.arrangement-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.12);
    border: none;
}

.arrangement-dot.paid {
    background: rgba(34, 197, 94, 0.95);
}
.arrangement-dot.overdue {
    background: rgba(239, 68, 68, 0.95);
}
.arrangement-dot.due {
    background: rgba(245, 158, 11, 0.95);
}

.arrangement-dot.just-paid {
    box-shadow: 0 0 0 6px rgba(59, 130, 246, 0.20);
    transform: scale(1.15);
    transition: transform 160ms ease;
}

.filter-button-row .filter-btn{
    border: none !important;
    box-shadow: none !important;
    background: rgba(255,255,255,0.06);
}
.filter-button-row .filter-btn.active{
    background: linear-gradient(135deg, rgba(20,184,166,0.28), rgba(99,102,241,0.12));
}

:root[data-style="glass"] .filter-button-row .filter-btn{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.04)),
        rgba(255,255,255,0.02);
    border: 1px solid var(--border-subtle) !important;
    backdrop-filter: blur(calc(var(--glass-blur) - 6px)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(calc(var(--glass-blur) - 6px)) saturate(var(--glass-sat));
}
:root[data-style="glass"] .filter-button-row .filter-btn.active{
    background:
        linear-gradient(135deg, rgba(20,184,166,0.34), rgba(99,102,241,0.16));
    border-color: rgba(255,255,255,0.16) !important;
}

#dashboard-page .dashboard-tabs .tab-btn{
    border: none;
}
#dashboard-page .dashboard-tabs .tab-btn.active{
    background: linear-gradient(135deg, rgba(99,102,241,0.22), rgba(20,184,166,0.20));
    color: rgba(255,255,255,0.98);
}

:root[data-style="glass"] #dashboard-page .dashboard-tabs .tab-btn.active{
    background:
        linear-gradient(135deg, rgba(20,184,166,0.42), rgba(99,102,241,0.20));
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.14),
        0 12px 30px rgba(20,184,166,0.22);
    color: rgba(255,255,255,0.96);
}

:root[data-style="glass"] #dashboard-page .dashboard-tabs .tab-btn.active i{
    color: rgba(255,255,255,0.96);
}

.dashboard-tabs{
    border: none !important;
    box-shadow: none !important;
}
.dashboard-tabs .tab-btn{
    border: none !important;
    box-shadow: none !important;
}

:root[data-style="glass"] .dashboard-tabs{
    border: 1px solid var(--border-subtle) !important;
    box-shadow: var(--shadow-card) !important;
}

#dashboard-tabs-sidebar{
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
}
#dashboard-tabs-sidebar .tab-btn{
    border: none !important;
    box-shadow: none !important;
}

.arrangement-pay-btn {
    width: 100%;
    height: 44px;
    border: none;
    border-radius: 12px;
    background: rgba(59, 130, 246, 0.18);
    color: rgba(191, 219, 254, 0.95);
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    cursor: pointer;
}

.arrangement-pay-btn.loading {
    cursor: default;
    opacity: 0.85;
}

.snooze-options-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
}

.snooze-option-btn {
    height: 48px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(59, 130, 246, 0.12);
    color: rgba(255,255,255,0.9);
    font-weight: 900;
    cursor: pointer;
}

/* Modern Modal Redesign */
.modern-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.8);
    display: none;
    justify-content: center;
    align-items: flex-end;
    z-index: 2000;
}

.modern-modal-overlay.active {
    display: flex;
}

:root[data-style="glass"] .modern-modal-overlay{
    background-color: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

:root[data-style="glass"][data-theme="light"] .modern-modal-overlay{
    background-color: rgba(8, 10, 16, 0.25);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.modern-modal {
    width: 100%;
    max-width: 500px;
    background-color: #1e1e1e;
    border-radius: 24px 24px 0 0;
    padding: 2rem;
    animation: slideUp 0.3s ease-out;
}

:root[data-style="glass"] .modern-modal{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.03)),
        var(--card-bg);
    border: 1px solid var(--card-border);
    box-shadow: 0 24px 70px rgba(0,0,0,0.55);
    backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}
@keyframes slideUp {
    from { transform: translateY(100%); }
    to { transform: translateY(0); }
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
}

.modal-header h2 {
    font-size: 1.5rem;
    font-weight: 800;
}

.modal-close {
    background: none;
    border: none;
    color: var(--text-primary);
    font-size: 1.5rem;
    cursor: pointer;
}

.form-group {
    margin-bottom: 1.5rem;
}

.form-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    margin-bottom: 0.5rem;
}

.modern-input, .modern-select {
    width: 100%;
    background-color: var(--surface-2);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 0.8rem 1rem;
    color: var(--text-primary);
    font-size: 1rem;
    font-weight: 600;
}

:root[data-style="glass"] .modern-input,
:root[data-style="glass"] .modern-select{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.03)),
        rgba(255,255,255,0.02);
    border: 1px solid var(--border-subtle);
    color: var(--text-primary);
    backdrop-filter: blur(calc(var(--glass-blur) - 4px)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(calc(var(--glass-blur) - 4px)) saturate(var(--glass-sat));
}

.filter-button-row {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    align-items: center;
}

.filter-scroll-row{
    flex-wrap: nowrap !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.filter-scroll-row::-webkit-scrollbar{ display:none; }
.filter-scroll-row .filter-btn{
    flex: 0 0 auto;
}

.filter-btn {
    border: 1px solid rgba(255, 255, 255, 0.10);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.85);
    border-radius: 999px;
    padding: 0.45rem 0.8rem;
    font-weight: 800;
    cursor: pointer;
}

.filter-btn.icon-only {
    position: relative;
    width: 40px;
    height: 38px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0;
}

.filter-btn.icon-only .btn-label {
    display: none;
}

.filter-btn.icon-only::after {
    content: attr(data-label);
    position: absolute;
    left: 50%;
    top: calc(100% + 8px);
    transform: translateX(-50%) translateY(-2px);
    background: rgba(15, 23, 42, 0.95);
    border: 1px solid rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.92);
    font-size: 0.75rem;
    font-weight: 900;
    padding: 0.35rem 0.55rem;
    border-radius: 10px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 140ms ease, transform 140ms ease;
    z-index: 20;
}

.filter-btn.icon-only:hover::after {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

.filter-btn.active {
    background: rgba(46, 204, 113, 0.18);
    border-color: rgba(46, 204, 113, 0.35);
    color: rgba(220, 252, 231, 0.95);
}

@media (max-width: 720px){
    .filter-btn.icon-only{
        width: 38px;
        height: 36px;
    }
    .filter-button-row{
        gap: 0.4rem;
    }
}

#tasks-status-filter {
    display: none !important;
}

.type-toggle {
    display: flex;
    gap: 0.5rem;
}

.toggle-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.8rem;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background-color: transparent;
    color: var(--text-secondary);
    font-weight: 700;
    cursor: pointer;
}

.toggle-btn.active.expense {
    background-color: #e74c3c;
    color: white;
    border-color: #e74c3c;
}

.toggle-btn.active.income {
    background-color: #2ecc71;
    color: white;
    border-color: #2ecc71;
}

.btn-save {
    width: 100%;
    background-color: var(--primary-mint);
    color: #000;
    border: none;
    border-radius: 16px;
    padding: 1.2rem;
    font-size: 1.1rem;
    font-weight: 800;
    margin-top: 1rem;
    cursor: pointer;
}

/* Transactions List */
.transaction-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.transaction-item {
    background-color: var(--card-bg);
    border-radius: 12px;
    padding: 0.75rem 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid var(--card-border);
}

.transaction-info {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.transaction-icon {
    width: 36px;
    height: 36px;
    background-color: rgba(231, 76, 60, 0.1);
    border-radius: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--expense-red);
}

.transaction-icon.income {
    background-color: rgba(46, 204, 113, 0.1);
    color: var(--income-green);
}

.transaction-name {
    font-weight: 700;
    font-size: 1rem;
}

.transaction-date {
    font-size: 0.8rem;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.transaction-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    color: rgba(255,255,255,0.8);
    font-weight: 800;
    font-size: 0.72rem;
}

.heatmap-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.5rem;
}

.heatmap-cell {
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.03);
    min-height: 44px;
    padding: 0.35rem 0.45rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.heatmap-cell.active {
    border-color: rgba(96, 165, 250, 0.55);
    box-shadow: 0 0 0 2px rgba(96, 165, 250, 0.18);
}

.heatmap-day {
    font-weight: 900;
    font-size: 0.85rem;
    color: rgba(255,255,255,0.92);
}

.heatmap-amt {
    font-weight: 900;
    font-size: 0.75rem;
    color: rgba(255,255,255,0.7);
    text-align: right;
}

.heatmap-dow {
    font-size: 0.72rem;
    font-weight: 900;
    color: rgba(255,255,255,0.55);
    text-align: center;
}

.transaction-amount {
    font-weight: 800;
    font-size: 1.1rem;
    text-align: right;
}

.transaction-amount.neg { color: var(--expense-red); }
.transaction-amount.pos { color: var(--income-green); }

.transaction-actions {
    display: flex;
    gap: 0.5rem;
    margin-left: 1rem;
}

.action-btn-circle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: rgba(255, 255, 255, 0.05);
    color: var(--income-blue);
    border: none;
    cursor: pointer;
}

.action-btn-circle.delete {
    color: var(--expense-red);
}

:root{
    --2026-teal:#14B8A6;
    --2026-indigo:#6366F1;
    --2026-glass-bg:rgba(255,255,255,0.04);
    --2026-glass-bd:rgba(255,255,255,0.08);
    --2026-glow:0 18px 46px rgba(0,0,0,0.28), 0 0 26px rgba(20,184,166,0.16);
}

.btn{
    display:inline-flex;
    align-items:center;
    gap:0.5rem;
    padding:0.6rem 0.9rem;
    font-weight:900;
    border-radius:14px;
    border:1px solid var(--2026-glass-bd);
    background: var(--2026-glass-bg);
    color: rgba(255,255,255,0.92);
    box-shadow: 0 14px 28px rgba(0,0,0,0.22);
    transition: transform 240ms cubic-bezier(.2,.8,.2,1), background 240ms ease, border-color 240ms ease, box-shadow 240ms ease, color 240ms ease, opacity 240ms ease;
}
.btn:hover{ transform: translateY(-1px); border-color: rgba(255,255,255,0.14); background: rgba(255,255,255,0.06); box-shadow: 0 18px 42px rgba(0,0,0,0.26); }
.btn:active{ transform: translateY(0px) scale(0.98); }
.btn.btn-primary{
    border-color: rgba(20,184,166,0.35);
    background: linear-gradient(135deg, rgba(20,184,166,0.28), rgba(99,102,241,0.12));
    box-shadow: var(--2026-glow);
    color: rgba(255,255,255,0.96);
}
.btn.btn-primary:hover{ box-shadow: 0 22px 60px rgba(0,0,0,0.32), 0 0 34px rgba(20,184,166,0.20); }
.btn.btn-secondary{
    border-color: var(--2026-glass-bd);
    background: var(--2026-glass-bg);
    color: rgba(255,255,255,0.88);
}
.btn.btn-danger{
    border-color: rgba(239,68,68,0.28);
    background: rgba(239,68,68,0.10);
    color: rgba(254,226,226,0.96);
}

.modern-input, .modern-select{
    outline: none;
    transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}
.modern-input:focus, .modern-select:focus{
    border-color: rgba(20,184,166,0.40);
    box-shadow: 0 0 0 3px rgba(20,184,166,0.18);
    background-color: #22252d;
}

.tab-btn{
    border:1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    border-radius: 999px;
    font-weight: 900;
}
.tab-btn:hover{
    transform: translateY(-1px);
    border-color: rgba(255,255,255,0.14);
    color: rgba(255,255,255,0.88);
}
.tab-btn.active{
    background: linear-gradient(135deg, rgba(20,184,166,0.22), rgba(99,102,241,0.10));
    border-color: rgba(20,184,166,0.32);
    color: rgba(255,255,255,0.96);
    box-shadow: 0 16px 40px rgba(0,0,0,0.22), 0 0 0 1px rgba(20,184,166,0.10) inset, 0 0 22px rgba(20,184,166,0.18);
}

.filter-btn{
    border:1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    border-radius: 999px;
    font-weight: 900;
}
.filter-btn.active{
    border-color: rgba(20,184,166,0.35);
    background: linear-gradient(135deg, rgba(20,184,166,0.28), rgba(99,102,241,0.12));
    box-shadow: var(--2026-glow);
    color: rgba(255,255,255,0.96);
}

.action-btn-circle, .bill-icon-btn{
    border:1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    box-shadow: 0 14px 28px rgba(0,0,0,0.22);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.action-btn-circle:hover, .bill-icon-btn:hover{
    transform: translateY(-1px);
    border-color: rgba(255,255,255,0.14);
    background: rgba(255,255,255,0.06);
    box-shadow: 0 18px 42px rgba(0,0,0,0.26);
}
.action-btn-circle:active, .bill-icon-btn:active{ transform: translateY(0px) scale(0.98); }

.app-header{
    background-color: rgba(15,17,21,0.85);
    border-bottom: 1px solid rgba(255,255,255,0.06);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

*:focus-visible{
    outline: 3px solid rgba(20,184,166,0.55);
    outline-offset: 2px;
    border-radius: 14px;
}

#dashboard-page .dashboard-tabs .tab-btn{
    padding: 0.7rem 0.75rem !important;
    min-height: 48px;
}
#dashboard-page .dashboard-tabs .tab-btn i{
    font-size: 1.25rem;
}
#dashboard-page .dashboard-tabs .tab-btn.active i{
    color: rgba(255,255,255,0.96);
}

.task-modern-card{
    background: linear-gradient(145deg, rgba(20,184,166,0.08), rgba(18,18,20,0.98));
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 18px;
    padding: 1.1rem 1.1rem 0.9rem;
}
.task-modern-card.due-overdue{
    border-color: rgba(231, 76, 60, 0.55);
    box-shadow: 0 0 0 1px rgba(231, 76, 60, 0.20), 0 8px 24px rgba(231, 76, 60, 0.08);
}
.task-modern-card.due-soon{
    border-color: rgba(245, 158, 11, 0.55);
    box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.18), 0 8px 24px rgba(245, 158, 11, 0.06);
}

.task-status-segment{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0.5rem;
}
.task-status-segment .segment-btn{
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    color: rgba(255,255,255,0.86);
    border-radius: 14px;
    padding: 0.65rem 0.7rem;
    font-weight: 950;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    cursor: pointer;
    transition: transform 240ms cubic-bezier(.2,.8,.2,1), background 240ms ease, border-color 240ms ease, box-shadow 240ms ease, color 240ms ease, opacity 240ms ease;
}
.task-status-segment .segment-btn:hover{
    transform: translateY(-1px);
    border-color: rgba(255,255,255,0.14);
    background: rgba(255,255,255,0.06);
}
.task-status-segment .segment-btn.active{
    border-color: rgba(20,184,166,0.35);
    background: linear-gradient(135deg, rgba(20,184,166,0.22), rgba(99,102,241,0.10));
    box-shadow: 0 16px 40px rgba(0,0,0,0.22), 0 0 0 1px rgba(20,184,166,0.10) inset, 0 0 22px rgba(20,184,166,0.18);
    color: rgba(255,255,255,0.96);
}

.widget-toggle{
    border: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.03);
    border-radius: 14px;
    padding: 0.65rem 0.7rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-weight: 900;
    color: rgba(255,255,255,0.88);
}
.widget-toggle input{
    width: 18px;
    height: 18px;
    accent-color: var(--2026-teal);
}
.widget-switch{
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.03);
    border-radius: 999px;
    padding: 0.45rem 0.6rem;
    font-weight: 950;
}
.widget-switch input{
    width: 18px;
    height: 18px;
    accent-color: var(--2026-teal);
}

:root[data-style="glass"]{
    --accent: #7c3aed;
    --accent-2: #3b82f6;
    --nav-active: var(--accent);
}

:root[data-style="glass"][data-theme="light"]{
    --bg: #f7f8ff;
    --text: rgba(15,23,42,0.92);
    --text-muted: rgba(15,23,42,0.68);
    --text-faint: rgba(15,23,42,0.52);
    --surface-1: rgba(255,255,255,0.72);
    --surface-2: rgba(15,23,42,0.04);
    --border: rgba(15,23,42,0.14);
    --border-subtle: rgba(15,23,42,0.10);
    --nav-bg: rgba(255,255,255,0.62);
    --shadow-card: 0 16px 48px rgba(17,24,39,0.14);
    --radius-card: 22px;
}

:root[data-style="glass"][data-theme="light"] body{
    background:
        radial-gradient(900px 620px at 14% -12%, rgba(124,58,237,0.18), rgba(124,58,237,0.00) 70%),
        radial-gradient(900px 620px at 110% 5%, rgba(59,130,246,0.18), rgba(59,130,246,0.00) 70%),
        radial-gradient(900px 760px at 55% 120%, rgba(236,72,153,0.10), rgba(236,72,153,0.00) 70%),
        linear-gradient(180deg, rgba(247,248,255,1), rgba(240,244,252,1));
}

:root[data-style="glass"][data-theme="light"] .app-header{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.70), rgba(255,255,255,0.40));
    border-bottom: 1px solid var(--border-subtle);
    backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}

:root[data-style="glass"][data-theme="light"] .content-card,
:root[data-style="glass"][data-theme="light"] .summary-card-modern,
:root[data-style="glass"][data-theme="light"] .projection-card{
    box-shadow: 0 14px 46px rgba(17,24,39,0.10);
}

:root[data-style="glass"][data-theme="light"] .btn{
    border-color: rgba(15,23,42,0.10);
    background:
        linear-gradient(135deg, rgba(255,255,255,0.72), rgba(255,255,255,0.46));
    color: rgba(15,23,42,0.88);
    box-shadow: 0 14px 34px rgba(17,24,39,0.12);
}

:root[data-style="glass"][data-theme="light"] .btn:hover{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.82), rgba(255,255,255,0.52));
    border-color: rgba(15,23,42,0.14);
    box-shadow: 0 18px 44px rgba(17,24,39,0.14);
}

:root[data-style="glass"][data-theme="light"] .btn.btn-primary{
    border-color: rgba(124,58,237,0.26);
    background: linear-gradient(135deg, rgba(124,58,237,0.42), rgba(59,130,246,0.20));
    color: rgba(255,255,255,0.96);
    box-shadow: 0 18px 52px rgba(124,58,237,0.24);
}

:root[data-style="glass"][data-theme="light"] .btn.btn-secondary{
    border-color: rgba(15,23,42,0.10);
    background:
        linear-gradient(135deg, rgba(255,255,255,0.68), rgba(255,255,255,0.40));
    color: rgba(15,23,42,0.82);
}

:root[data-style="glass"][data-theme="light"] .dashboard-tabs{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.55), rgba(255,255,255,0.34));
    border: 1px solid rgba(15,23,42,0.08) !important;
    box-shadow: 0 16px 40px rgba(17,24,39,0.10) !important;
}

:root[data-style="glass"][data-theme="light"] .tab-btn{
    border-color: rgba(15,23,42,0.08);
    background:
        linear-gradient(135deg, rgba(255,255,255,0.68), rgba(255,255,255,0.42));
    color: rgba(15,23,42,0.76);
}

:root[data-style="glass"][data-theme="light"] .tab-btn.active{
    border-color: rgba(124,58,237,0.22);
    background: linear-gradient(135deg, rgba(124,58,237,0.28), rgba(59,130,246,0.12));
    color: rgba(15,23,42,0.90);
    box-shadow: 0 14px 34px rgba(124,58,237,0.16);
}

:root[data-style="glass"][data-theme="light"] #dashboard-page .dashboard-tabs .tab-btn.active{
    color: rgba(15,23,42,0.92);
}

:root[data-style="glass"][data-theme="light"] .filter-btn{
    border-color: rgba(15,23,42,0.08);
    background:
        linear-gradient(135deg, rgba(255,255,255,0.64), rgba(255,255,255,0.40));
    color: rgba(15,23,42,0.78);
}

:root[data-style="glass"][data-theme="light"] .filter-btn.active{
    border-color: rgba(124,58,237,0.22);
    background: linear-gradient(135deg, rgba(124,58,237,0.22), rgba(59,130,246,0.10));
    box-shadow: 0 14px 34px rgba(124,58,237,0.14);
    color: rgba(15,23,42,0.90);
}

:root[data-style="glass"][data-theme="light"] nav.modern-bottom-nav{
    background:
        linear-gradient(135deg, rgba(255,255,255,0.62), rgba(255,255,255,0.40)) !important;
    border-top: 1px solid rgba(15,23,42,0.10) !important;
    box-shadow: 0 -10px 38px rgba(17,24,39,0.10) !important;
    backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) !important;
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) !important;
}

:root[data-style="glass"][data-theme="light"] .nav-item-modern{
    color: rgba(15,23,42,0.64) !important;
}

:root[data-style="glass"][data-theme="light"] .nav-item-modern i{
    color: rgba(15,23,42,0.70) !important;
}

:root[data-style="glass"][data-theme="light"] .nav-item-modern.active,
:root[data-style="glass"][data-theme="light"] .nav-item-modern.active i{
    color: rgba(124,58,237,0.95) !important;
}

:root[data-style="glass"][data-theme="light"] .quick-action i{
    background: linear-gradient(135deg, rgba(124,58,237,0.16), rgba(59,130,246,0.10));
    border: 1px solid rgba(124,58,237,0.18);
    color: rgba(124,58,237,0.95) !important;
    box-shadow: 0 14px 34px rgba(124,58,237,0.14);
}

.budget-ring-slice{cursor:pointer}
.budget-ring-slice:hover{opacity:0.92}
