.App{min-height:100vh}:root{--theme-name:dark;--app-max-width:1700px;--content-width:1600px;--gap-section:1.75rem;--gap-section-mobile:1.25rem;--color-bg:#0f1218;--color-surface:#181d25;--color-surface-alt:#202733;--color-surface-soft:#2a3342;--color-border:#2d3642;--color-border-soft:#3a4654;--color-primary:#3d8bfd;--color-primary-accent:#61dafb;--color-success:#3fb950;--color-warning:#e3b341;--color-danger:#f85149;--color-text:#f0f3f6;--color-text-muted:#b3bcc6;--color-text-muted-strong:#c9d2dc;--gradient-accent:linear-gradient(135deg,#3d8bfd,#9353d3 55%,#ff6e6e);--radius-sm:4px;--radius-md:8px;--radius-lg:14px;--shadow-sm:0 1px 2px #0006,0 0 0 1px #ffffff08 inset;--shadow-md:0 4px 12px -2px #0000008c,0 0 0 1px #ffffff0a inset;--shadow-glow:0 0 0 1px #ffffff0d,0 0 0 4px #3d8bfd26,0 4px 18px -2px #0009;--transition:.16s cubic-bezier(.4,.2,.2,1)}@media (width<=1750px){:root{--content-width:1540px}}@media (width<=1680px){:root{--content-width:1480px}}@media (width<=1600px){:root{--content-width:1420px}}@media (width<=1520px){:root{--content-width:1360px}}@media (width<=1440px){:root{--content-width:1300px}}@media (width<=1360px){:root{--content-width:1220px}}@media (width<=1280px){:root{--content-width:1160px}}@media (width<=1200px){:root{--content-width:1100px}}@media (width<=1120px){:root{--content-width:1040px}}@media (width<=1040px){:root{--content-width:980px}}@media (width<=980px){:root{--content-width:920px}}@media (width<=920px){:root{--content-width:860px}}@media (width<=860px){:root{--content-width:800px}}@media (width<=800px){:root{--content-width:92%}}body.light-theme{--theme-name:light;--color-bg:#f5f7fb;--color-surface:#fff;--color-surface-alt:#fff;--color-surface-soft:#f1f4f9;--color-border:#d9e1ec;--color-border-soft:#c9d4e2;--color-primary:#2563eb;--color-primary-accent:#0ea5e9;--color-success:#059669;--color-warning:#d97706;--color-danger:#dc2626;--color-text:#1e293b;--color-text-muted:#64748b;--gradient-accent:linear-gradient(135deg,#2563eb,#7c3aed 55%,#db2777);--shadow-sm:0 1px 2px #00000012,0 0 0 1px #00000008 inset;--shadow-md:0 6px 16px -4px #0000001f,0 0 0 1px #0000000a inset;--shadow-glow:0 0 0 1px #0000000a,0 0 0 4px #2563eb40,0 6px 22px -4px #0000002e}body.dark,body:not(.light-theme){color:var(--color-text);background:radial-gradient(circle at 20% 20%,#131721,#0b0d12 70%)}body.light-theme{background:linear-gradient(#eef2f8,#e2e8f0 300px,#edf2f7)}h1,h2,h3,h4,h5,h6{letter-spacing:.5px}.text-muted{color:var(--color-text-muted)!important}.text-muted-strong{color:var(--color-text-muted-strong)!important}.page-shell{min-height:calc(100vh - 76px);padding-bottom:2rem}.content-width{width:100%;max-width:var(--content-width);box-sizing:border-box;margin:0 auto;padding:0 1rem}.MuiFormControl-root+.MuiFormControl-root{margin-top:18px}.MuiFormControl-root.MuiFormControl-fullWidth+.MuiFormControl-root.MuiFormControl-fullWidth{margin-top:20px}@media (width<=768px){.page-shell{min-height:calc(100vh - 64px)}}body.dark:before,body:not(.light-theme):before,body.light-theme:before{content:"";z-index:-1;pointer-events:none;background:radial-gradient(circle at 20% 20%,#131721,#0b0d12 70%) 0 0/cover no-repeat fixed;position:fixed;inset:0}body.light-theme:before{background:linear-gradient(#eef2f8,#e2e8f0 300px,#edf2f7)}.navbar.main-nav{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px)saturate(140%);background:var(--color-surface-alt)!important}body.light-theme .navbar.main-nav{background:var(--color-surface)!important}.navbar.main-nav .app-brand{letter-spacing:.6px;font-weight:700;color:var(--color-text)!important}.navbar.main-nav .app-brand:hover{text-decoration:none;color:var(--color-primary-accent)!important}body:not(.light-theme) .navbar.main-nav .app-brand.gradient{background:var(--gradient-accent);-webkit-background-clip:text;background-clip:text;color:#0000!important}.navbar .navbar-brand,.navbar .nav-link{position:relative}.navbar .nav-link{font-weight:500;color:var(--color-text-muted)!important}.navbar .nav-link.active,.navbar .nav-link:hover{color:var(--color-primary-accent)!important}.navbar .nav-link.active:after{content:"";background:var(--gradient-accent);border-radius:2px;height:2px;position:absolute;bottom:4px;left:8px;right:8px;box-shadow:0 0 6px -1px #61dafb}.mobile-active-label{letter-spacing:.5px;color:var(--color-text-muted);background:var(--color-surface-soft);border:1px solid var(--color-border-soft);border-radius:999px;margin-left:.75rem;padding:.2rem .55rem;font-size:.8rem;font-weight:600;line-height:1}body.light-theme .mobile-active-label{background:var(--color-surface-soft);color:var(--color-text-muted)}.surface,.card-like{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition);padding:1.25rem 1.4rem}.surface:hover,.card-like:hover{border-color:var(--color-border-soft);box-shadow:var(--shadow-md)}.list-group-item{background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text);transition:var(--transition)}.list-group-item:hover{background:var(--color-surface-soft);border-color:var(--color-border-soft)}.btn-primary,.btn-outline-primary:hover,.action-pill{box-shadow:var(--shadow-sm);background:var(--gradient-accent)!important;color:#fff!important;border:none!important}.btn-primary:hover,.action-pill:hover{box-shadow:var(--shadow-glow)}.action-pill{border-radius:var(--radius-md);cursor:pointer;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.85rem 1rem;font-weight:600;display:inline-flex}.list-group-item.action-add{border:1px dashed var(--color-border-soft);color:var(--color-text-muted);background:linear-gradient(135deg,#1f2632,#242e3d);border-radius:var(--radius-md)!important}.d-flex .list-group-item.action-add+.list-group-item.action-add{margin-left:.5rem}.add-actions{gap:.5rem}.add-actions.no-wrap{flex-wrap:nowrap!important}.add-actions .list-group-item.action-add{letter-spacing:.4px;justify-content:center;align-items:center;min-height:52px;font-size:.9rem;font-weight:600;display:flex}.add-actions .list-group-item.action-add svg{margin-right:.55rem}.add-actions{gap:.5rem;padding:.35rem .5rem!important}.add-actions .list-group-item.action-add{letter-spacing:.4px;flex:1 1 0;justify-content:center;align-items:center;gap:.55rem;min-height:46px;font-weight:600;display:flex}@media (width<=640px){.add-actions{flex-direction:column!important}.d-flex .list-group-item.action-add+.list-group-item.action-add{margin-left:0}}.budget-item-grid{padding-top:.75rem}.budget-item-tile{background:linear-gradient(145deg,#ffffff05,#fff0);flex-direction:column;gap:.25rem;min-height:110px;margin-bottom:1rem;transition:background .25s,border-color .25s,transform .2s;display:flex;position:relative;border:1px solid var(--color-border-soft)!important;border-radius:8px!important;padding:.55rem .65rem!important}.budget-item-tile.layout-v2{min-height:130px}.budget-item-tile.layout-v2 .bi-head{margin-top:.15rem}.budget-item-tile.layout-v2 .big-center{text-align:center;letter-spacing:.5px;margin-top:.65rem;margin-bottom:.65rem;font-size:1.12rem;font-weight:650}.budget-item-tile.layout-v2 .bottom-center{text-align:center;letter-spacing:1px;margin-top:auto;padding-bottom:.25rem;font-size:.68rem;font-weight:600}.budget-item-tile:hover{background:linear-gradient(145deg,#ffffff0f,#fff0);text-decoration:none;transform:translateY(-2px);border-color:var(--color-border)!important}.budget-item-tile:active{transform:translateY(0)}.budget-item-tile .bi-head{color:var(--color-text);letter-spacing:.3px;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.budget-item-tile .bi-desc{color:var(--color-text-muted-strong);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;max-height:2.2em;font-size:.7rem;line-height:1.2;display:-webkit-box;overflow:hidden}.budget-item-tile .bi-meta{display:none}.budget-item-tile .bi-amount{color:var(--color-accent,#3d8bfd);font-size:.95rem;font-weight:600;line-height:1}.budget-item-tile .bi-frequency{color:var(--color-text-muted-strong);letter-spacing:.8px;font-size:.72rem;font-weight:500}.bi-frequency.freq-yearly{color:#9353d3}.bi-frequency.freq-quarterly{color:#ff6e6e}.bi-frequency.freq-monthly{color:#0ea5e9}.bi-frequency.freq-fortnightly{color:#e3b341}.bi-frequency.freq-weekly{color:#3fb950}.freq-chips{flex-wrap:wrap;gap:.5rem;display:flex}.freq-chip{background:var(--color-surface-alt);border:1px solid var(--color-border-soft);color:var(--color-text);letter-spacing:.5px;cursor:pointer;border-radius:999px;align-items:center;gap:.25rem;padding:.25rem .55rem;font-size:.65rem;font-weight:500;line-height:1.1;display:inline-flex}.freq-chip:hover{border-color:var(--color-border)}.freq-chip .x{opacity:.6;font-weight:600}.freq-chip.reset{background:linear-gradient(90deg,#3d8bfd22,#9353d322)}.freq-chip.freq-yearly{background:#9353d322}.freq-chip.freq-quarterly{background:#ff6e6e22}.freq-chip.freq-monthly{background:#0ea5e922}.freq-chip.freq-fortnightly{background:#e3b34122}.freq-chip.freq-weekly{background:#3fb95022}.freq-filter-btn .dropdown-menu{background:var(--color-surface-alt);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-md)}.freq-filter-btn .dropdown-item.active,.freq-filter-btn .dropdown-item:active{background:var(--color-primary-accent);color:#fff}body.light-theme .freq-filter-btn .dropdown-menu{background:#fff}@media (width<=640px){.budget-item-tile{min-height:100px;padding:.5rem .55rem!important}.budget-item-tile .bi-head{font-size:.9rem}.budget-item-tile .bi-desc{font-size:.66rem}.budget-item-tile .bi-amount{font-size:.9rem}.budget-item-tile .bi-meta,.budget-item-tile .bi-frequency{font-size:.68rem}}.list-group-item.action-add:hover{background:var(--color-surface-soft);color:var(--color-primary-accent);border-color:var(--color-primary-accent)}body.light-theme .list-group-item.action-add{background:linear-gradient(135deg,#f1f5f9,#fff)}input,select,textarea{background:var(--color-surface-alt)!important;border:1px solid var(--color-border)!important;color:var(--color-text)!important}input:focus,select:focus,textarea:focus{border-color:var(--color-primary-accent)!important;outline:none!important;box-shadow:0 0 0 2px #61dafb40!important}body.light-theme input,body.light-theme select,body.light-theme textarea{box-shadow:none}.stack-md>*+*{margin-top:1rem}.stack-lg>*+*{margin-top:var(--gap-section)}@media (width<=680px){.stack-lg>*+*{margin-top:var(--gap-section-mobile)}}.inline-gap-sm>*+*{margin-left:.5rem}.stack-xs>*+*{margin-top:.35rem}.stack-sm>*+*{margin-top:.65rem}.stack-xl>*+*{margin-top:2.25rem}.pad-sm{padding:.5rem!important}.pad-md{padding:1rem!important}.pad-lg{padding:1.5rem!important}.gap-row-sm{row-gap:.75rem}.gap-row-md{row-gap:1.25rem}.gap-row-lg{row-gap:2rem}.mw-tight{max-width:640px}.mw-wide{max-width:1280px}.centered{margin-left:auto;margin-right:auto}.container{min-height:auto}.fill-vh,.page-shell>.container:first-of-type{min-height:80vh}.chart-surface{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:.75rem 1rem}.chart-surface h3{margin-top:0}.chart-wrapper{position:relative}.chart-wrapper svg{background:0 0!important}body.light-theme .recharts-default-tooltip{border:1px solid var(--color-border-soft)!important;background:#fff!important}body:not(.light-theme) .recharts-default-tooltip{background:var(--color-surface-alt)!important;border:1px solid var(--color-border)!important}.recharts-default-tooltip,.recharts-default-tooltip *{font-size:.8rem;color:var(--color-text)!important}.recharts-default-tooltip{box-shadow:var(--shadow-md);border-radius:6px!important;padding:.5rem .65rem!important}.recharts-cartesian-axis-tick-value{fill:var(--color-text-muted)!important}.recharts-legend-item-text{color:var(--color-text-muted)!important}.portfolio-dates.row{margin-top:6px}.portfolio-dates .date-box{text-align:center;letter-spacing:.4px;font-size:.78rem}.portfolio-dates .date-box strong{font-weight:600;display:block}.portfolio-dates .date-left{border-right:1px dashed var(--color-border)}body.light-theme .portfolio-dates .date-left{border-right-color:var(--color-border-soft)}.section-heading{border:1px solid var(--color-border);border-left:4px solid var(--color-primary-accent);border-radius:var(--radius-md);letter-spacing:.5px;box-shadow:var(--shadow-sm);background:linear-gradient(90deg,#ffffff0a,#fff0);align-items:center;gap:.75rem;margin:2rem 0 1rem;padding:.6rem 1.1rem .65rem;font-size:1.05rem;font-weight:600;display:flex}body.light-theme .section-heading{border-left-color:var(--color-primary);background:linear-gradient(90deg,#0000000a,#0000)}.section-heading small{color:var(--color-text-muted);font-weight:400}.update-bar+.stack-lg .section-heading{margin-top:.35rem}.table-shell{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:.75rem 1rem 1rem;overflow:hidden}body.light-theme .table-shell{background:var(--color-surface)}.table-shell table{color:var(--color-text);background:0 0!important}.table-shell thead th{border-bottom:1px solid var(--color-border);font-weight:600;background:var(--color-surface-alt)!important}.table-shell tbody tr{transition:var(--transition)}.table-shell tbody tr:hover{background:var(--color-surface-soft)!important}.ag-theme-alpine.table-shell{padding:0}.lander{text-align:center;padding:4rem 1rem}.lander h1{background:var(--gradient-accent);color:#0000;-webkit-background-clip:text;background-clip:text;font-weight:600}.lander .tagline{letter-spacing:.3px;max-width:640px;margin:0 auto;font-size:.95rem}.ag-theme-alpine{--ag-grid-size:4px;--ag-list-item-height:16px;--ag-background-color:var(--color-surface-alt);--ag-foreground-color:var(--color-text);--ag-header-background-color:var(--color-surface);--ag-odd-row-background-color:var(--color-surface);--ag-row-hover-color:#61dafb14;--ag-border-color:var(--color-border);--ag-input-focus-border-color:var(--color-primary-accent)}.ag-theme-alpine .ag-header,.ag-theme-alpine .ag-root-wrapper{border-radius:var(--radius-md)}.table-responsive-wrapper{width:100%;overflow-x:auto}.table-responsive-wrapper .ag-root-wrapper{min-width:720px}@media (width<=640px){.table-responsive-wrapper .ag-root-wrapper{min-width:680px}}.table-responsive-wrapper:not(.narrow) .ag-root-wrapper-body .ag-center-cols-container .ag-row .ag-cell:first-child,.sticky-col{background:inherit;z-index:2;box-shadow:1px 0 0 0 var(--color-border);position:sticky;left:0}.table-responsive-wrapper.narrow{overflow-x:hidden}.table-responsive-wrapper.narrow .ag-root-wrapper{min-width:0!important}.table-responsive-wrapper.narrow .ag-cell,.table-responsive-wrapper.narrow .ag-header-cell{padding-left:6px!important;padding-right:6px!important}.table-zebra .ag-row-even .ag-cell{background:#ffffff0e!important}.table-zebra .ag-row-odd .ag-cell{background:#ffffff05!important}.table-zebra .ag-row:hover .ag-cell{background:#ffffff17!important}body.light-theme .table-zebra .ag-row-even .ag-cell{background:#0000000d!important}body.light-theme .table-zebra .ag-row-odd .ag-cell{background:#00000005!important}body.light-theme .table-zebra .ag-row:hover .ag-cell{background:#00000014!important}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}[data-animate=fadeIn]{animation:fadeInUp .45s var(--transition)}@media (width<=768px){.navbar .navbar-brand{font-size:1rem}.surface,.card-like{padding:1rem 1.1rem}}.app-container{width:100%;max-width:var(--app-max-width);margin:0 auto;padding:0 1rem}.nav-bar-inner{max-width:var(--content-width);margin:0 auto}.nav-surface{width:100%;max-width:var(--content-width);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);align-items:center;gap:.75rem;margin:0 auto;padding:.4rem 1rem;display:flex}body.light-theme .nav-surface{background:var(--color-surface)}.app-container.flex{align-items:center;gap:2rem;display:flex}@media (width<=1024px){.app-container.flex{gap:1.25rem}}@media (width<=640px){.app-container.flex{flex-wrap:wrap;gap:.75rem}}.nav-bar-inner{align-items:center;gap:1.25rem;width:100%;display:flex}.nav-bar-inner>.brand{flex-shrink:0}.nav-bar-inner>.main-links{flex-grow:1;display:flex}.nav-bar-inner>.actions{gap:.65rem;display:flex}@media (width<=640px){.nav-bar-inner{flex-wrap:wrap}.nav-bar-inner>.main-links{order:3;width:100%}.nav-bar-inner>.actions{order:2;margin-left:auto}}.subMenu .sub-nav-wrapper.constrained-surface{max-width:var(--content-width);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:0 auto}body.light-theme .subMenu .sub-nav-wrapper.constrained-surface{background:var(--color-surface)}.subMenu .sub-nav-wrapper.constrained-surface>.sub-nav-inner{max-width:100%;margin:0;padding:0 .75rem}.subMenu+.content-width>:first-child,.subMenu+.content-width .overview-block:first-child{margin-top:.75rem}@media (width<=800px){.subMenu+.content-width>:first-child,.subMenu+.content-width .overview-block:first-child{margin-top:.6rem}}.app-hr{max-width:var(--app-max-width);border:0;border-top:1px solid var(--color-border);margin:0 auto}.app-divider{width:100%}.overview-actions{flex-wrap:wrap;display:flex}.overview-actions .MuiButton-root{letter-spacing:.5px;font-weight:600}@media (width<=680px){.overview-actions{flex-direction:column;align-items:stretch}.overview-actions .MuiButton-root{justify-content:center;width:100%}}.settings-modal-backdrop{z-index:9997;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;position:fixed;inset:0}.settings-modal{z-index:9999;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:520px;box-shadow:var(--shadow-glow);color:var(--color-text);padding:1.25rem 1.5rem;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}body.light-theme .settings-modal{background:var(--color-surface)}.settings-modal h5{letter-spacing:.5px;font-weight:600}.settings-modal .text-muted{color:var(--color-text-muted)!important}.settings-modal button{position:relative}.settings-modal button:focus{outline:2px solid var(--color-primary-accent);outline-offset:2px}.settings-modal button:disabled{opacity:.45}.settings-modal .inline-gap-sm>*+*{margin-left:.4rem}.settings-modal .inline-gap-sm{flex-wrap:wrap}@media (width<=800px){:root{--content-width:100%}.content-width{padding-left:12px;padding-right:12px}.nav-surface{border-radius:0;max-width:100%;margin:0;padding:.55rem .75rem}.subMenu .sub-nav-wrapper.constrained-surface{border-radius:0;max-width:100%;margin:0}.subMenu .sub-nav-wrapper.constrained-surface>.sub-nav-inner{padding-left:12px;padding-right:12px}.surface,.card-like{padding:1rem .9rem}.table-shell{padding:.65rem .7rem .85rem}}body{color:#333;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin:0;padding:0;font-family:Open Sans,sans-serif;font-size:16px}h1,h2,h3,h4,h5,h6{font-family:PT Serif,serif}select.form-control,textarea.form-control,input.form-control{font-size:1rem}input[type=file]{width:100%}
