:root{--teal-dark: #005d62;--teal-main: #017a73;--teal-light: #e6f4f4;--bg-light: #fffdf8;--text-dark: #053342;--text-light: #5a7d8a;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .12);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: all .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%;height:auto;font-family:Manrope,sans-serif;background:var(--bg-light);color:var(--text-dark);line-height:1.5;overflow-x:hidden}.container{display:flex;min-height:100vh}.blurred{filter:blur(12px);-webkit-user-select:none;user-select:none;cursor:default}.blurred:hover{filter:none;-webkit-user-select:text;user-select:text;cursor:default}:root{--sidebar-w: 280px;--drawer-w: 240px;--topbar-h: 68px}.sidebar{width:var(--sidebar-w);position:sticky;top:0;height:100vh;background:var(--teal-dark);color:#fff;display:flex;flex-direction:column;align-items:center;padding:2.5rem 1.5rem;flex-shrink:0;z-index:200;transition:transform .3s ease;overflow:hidden;overscroll-behavior:contain}.topbar{display:none}.burger,.eye-btn-sm{background:none;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.logo{margin:0 0 2.5rem;font-size:1.8rem;font-weight:700;letter-spacing:-.5px}.logo .light{font-weight:400}.avatar{width:100px;height:100px;border-radius:50%;margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:700;color:var(--teal-dark);background:var(--bg-light);border:3px solid var(--teal-main);box-shadow:0 2px 10px #00000026}.name{margin:0 0 2.5rem;font-size:1.35rem;font-weight:600}.name-row{display:flex;align-items:flex-start;justify-content:center;gap:.5rem;margin-bottom:2.5rem;position:relative}.eye-btn,.eye-btn-sm{display:flex;align-items:center;justify-content:center;height:28px;width:28px;padding:0;background:#ffffff26;border:none;border-radius:6px;color:#fff;cursor:pointer;transition:background .2s,transform .2s}.eye-btn:hover,.eye-btn-sm:hover{background:#fff;color:var(--teal-dark);transform:scale(1.05)}.eye-btn svg,.eye-btn-sm svg{width:18px;height:18px}.nav-wrapper{display:flex;flex-direction:column;width:100%;flex:1}.nav{list-style:none;margin:0;padding:0;width:100%}.nav li{display:flex;align-items:center;gap:.8rem;padding:.9rem 1.5rem;font-size:1.05rem;font-weight:500;color:#fff;border-radius:10px;cursor:pointer;transition:background .18s}.nav li a{display:flex;align-items:center;gap:.8rem;color:inherit;text-decoration:none;width:100%}.nav li:hover,.nav li.active{background:#ffffff26}.nav svg{flex-shrink:0}.logout-separator{margin:1.5rem 0 1rem;width:100%;height:1px;background:#ffffff26}.logout-btn{width:100%;padding:.9rem 1.5rem;background:transparent;border:none;border-radius:10px;display:flex;align-items:center;gap:.8rem;font-size:1.05rem;font-weight:400;color:#fff;cursor:pointer;transition:background .18s}.logout-btn:hover{background:#ffffff26}.main{flex:1;overflow-y:auto;padding:4rem 4rem 6rem;max-width:1400px;margin:0 auto}@media (max-width: 1250px){.topbar{display:flex;position:fixed;top:0;left:0;width:100vw;height:var(--topbar-h);background:var(--teal-dark);color:#fff;align-items:center;justify-content:space-between;padding:0 1rem;z-index:300}.logo-sm{font-size:1.4rem;margin:0}.logo-sm .light{font-weight:400}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--drawer-w);height:100vh;padding:2rem 1.2rem;transform:translate(-100%);z-index:350;background:var(--teal-dark)}.sidebar.open{transform:translate(0)}.drawer-overlay{content:"";position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .3s;z-index:340}.sidebar.open+.drawer-overlay{opacity:1;pointer-events:auto}.close-drawer{display:block;background:none;border:none;color:#fff;cursor:pointer;margin-left:auto;margin-bottom:1rem}.burger,.eye-btn-sm{display:flex}.close-drawer{display:block}}@media (min-width: 1200px){.burger,.eye-btn-sm,.close-drawer{display:none}.main{padding:4rem 4rem 4rem calc(var(--sidebar-w) + 40px)}}@media (min-width: 1250px){.sidebar{position:fixed;top:0;left:0;height:100vh}.main{margin-left:var(--sidebar-w)}}.main{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:4rem 4rem 6rem;overflow-y:auto}.dashboard{width:100%;max-width:1200px;margin:auto;display:grid;grid-template-columns:minmax(0,1fr) 320px;grid-template-areas:"summary  trans" "chart    trans" "chart    summary2";grid-template-rows:auto auto 1fr;gap:2rem}.summary-card{grid-area:summary}.chart-card{grid-area:chart}.transactions-card{grid-area:trans}.month-summary-card{grid-area:summary2}@media (max-width: 1250px){.dashboard{max-width:1100px;display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"summary summary" "chart chart" "trans summary2";gap:2rem}}@media (max-width:670px){.main{padding:2rem 1.2rem 4rem}.dashboard{max-width:100%;gap:1.4rem;grid-template-areas:"summary" "chart" "summary2" "trans"}.transactions-card{max-width:none}}.summary-card{display:flex;align-items:center;justify-content:space-between;background:#fff;padding:2rem 2.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);min-height:140px}.summary-left,.summary-right{display:flex;flex-direction:column;justify-content:center}.balance{font-size:3.5rem;font-weight:700;letter-spacing:-1px;color:#c0392b;margin:0}.spent-summary{font-size:1.15rem;color:var(--text-light);margin:0;line-height:1.6;text-align:right}.spent-summary strong{color:var(--text-dark);font-weight:600}.trend{color:#0f8c76;font-weight:500}.fab{position:fixed;right:4rem;bottom:4rem;z-index:30;width:64px;height:64px;border:none;border-radius:50%;background:var(--teal-main);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);cursor:pointer;transition:var(--transition)}.fab:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #017a734d}.summary2-content-vertical{display:flex;flex-direction:column;gap:1.2rem}.summary2-text{text-align:center}.summary2-text p{font-size:.95rem;color:var(--text-light)}.bars-comparison{display:flex;flex-direction:column;gap:.8rem}.bar-row{display:flex;align-items:center;gap:.8rem;font-size:.95rem}.bar-label{flex-shrink:0;width:80px;white-space:nowrap}.bar-track{flex:1;height:14px;background:#eef1f2;border-radius:10px;max-width:150px;min-width:80px;margin-inline:auto}.bar-fill{height:100%;transition:width .4s ease;border-radius:10px}.bar-fill.red{background:#c0392b}.bar-fill.green{background:#0f8c76}.bar-number{flex-shrink:0;width:68px;text-align:right;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.chart-heading{font-size:1.1rem;font-weight:600;margin-bottom:1rem;text-align:center}.mini-quarter-chart{margin-top:1.2rem}.blurred-line{filter:blur(6px);transition:filter .2s}.blurred-line:hover{filter:none}@media (max-width: 1250px){.main{padding:calc(var(--topbar-h) + 2rem) 1.2rem 4rem}}.chart-card{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.chart-visuals{display:flex;align-items:center;gap:2.5rem;flex-wrap:wrap;justify-content:center}.legend-row{display:grid;grid-template-columns:16px 1fr auto;align-items:center;gap:.8rem}.legend-label{white-space:nowrap}.legend-numbers{display:flex;flex-direction:column;align-items:flex-end;font-variant-numeric:tabular-nums;gap:.1rem}.legend-value{font-weight:600;text-align:right;min-width:70px}.legend-percent{color:var(--text-light);font-size:.9rem;text-align:right}.legend-color{width:14px;height:14px;border-radius:50%;flex-shrink:0;background-color:#ccc;display:inline-block}.chart-toggle{display:flex;gap:.4rem;margin-bottom:1.4rem}.chart-toggle button{padding:.35rem .9rem;font:500 .9rem/1 Manrope,sans-serif;color:#46606c;background:#f4f6f7;border:1px solid #e1e5e8;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.chart-toggle button.active{background:var(--teal-main);color:#fff;border-color:var(--teal-main)}.chart-toggle button:hover:not(.active){background:#e9eef0}.chart-slider{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}.chart-slider::-webkit-scrollbar{display:none}.chart-slide{flex:0 0 100%;scroll-snap-align:start;display:flex;justify-content:center;gap:2.5rem;padding-bottom:1rem;flex-wrap:nowrap}.chart-slide-inner{width:100%;max-width:100%}.chart-heading{font-size:1.4rem;font-weight:600;margin-bottom:1.2rem;text-align:center}.chart-dots{display:flex;justify-content:center;gap:.5rem}.chart-dots .dot{width:10px;height:10px;border-radius:50%;background:#cfd4d8;border:none;cursor:pointer;transition:background .2s}.chart-dots .dot.active{background:var(--teal-main)}.chart-dots .dot:hover:not(.active){background:#aeb5bb}.tooltip-box{background:#fff;border:1px solid rgba(0,0,0,.05);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:.6rem 1rem;font-size:.95rem;font-weight:500;pointer-events:none}.spent-label{cursor:default;-webkit-user-select:none;user-select:none}.spent-label{fill:var(--text-light)}.spent-label:hover{filter:none!important;-webkit-filter:none!important}.pie-faded{opacity:.3;transition:opacity .2s ease}.legend-row{position:relative;display:grid;grid-template-columns:16px 1fr auto;align-items:center;gap:.8rem;padding:.4rem .6rem;border-radius:8px;cursor:pointer;transition:background .15s ease}.legend-row:before{content:"";position:absolute;inset:0;border-radius:8px;background:transparent;transition:background .15s ease;z-index:0}.legend-row:hover:before,.legend-row.legend-active:before{background:#0000000d}.legend-row>*{position:relative;z-index:1}.bar-faded{opacity:.25;transition:opacity .18s ease}.legend{display:flex;flex-direction:column;gap:1rem;max-width:240px;justify-content:center;height:420px}@media (max-width:1485px){.legend{flex-direction:row;flex-wrap:wrap;max-width:none;height:auto;justify-content:center;row-gap:1.2rem;column-gap:2rem}.legend-row{width:calc(50% - 1rem)}}@media (max-width:1250px){.legend{flex-direction:row;flex-wrap:wrap;max-width:none;height:auto;justify-content:center;row-gap:1.2rem;column-gap:2rem}.legend-row{width:calc(30% - 1rem)}}@media (max-width:800px){.legend{column-gap:1rem}.legend-row{width:calc(50% - 1rem)}}.transactions-card{background:#fff;padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);width:100%;max-height:380px;overflow-y:auto}.transactions-card h3{margin-bottom:1.2rem;font-size:1.3rem;font-weight:600}.transaction{display:flex;align-items:center;gap:.9rem;padding:.7rem 0;border-bottom:1px solid rgba(0,0,0,.06)}.transaction:last-child{border-bottom:none}.amount{font-weight:600;white-space:nowrap}.amount.out{color:#c0392b}.amount.in{color:#0f8c76}.see-more-wrapper{margin-top:1rem;padding-left:2.4rem}.see-more-link{color:#a5b3bb;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s ease}.see-more-link:hover{color:var(--teal-main)}.monthly-summary-card{grid-area:summary2;background:#fff;padding:1.2rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);font-size:1rem;font-weight:500;color:var(--text-dark);text-align:center;line-height:1.6;margin-top:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.monthly-summary-card strong{color:var(--teal-dark)}.modal-backdrop{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:2rem;border-radius:12px;width:100%;max-width:440px;box-shadow:0 12px 28px #0003;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}.close-btn{background:transparent;border:none;cursor:pointer}.form{display:flex;flex-direction:column;gap:1rem}input,textarea,select{width:100%;padding:.6rem .75rem;font-size:1rem;border-radius:8px;border:1px solid #ddd}.submit-btn{padding:.75rem;background:#e66795;color:#fff;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.submit-btn:hover{background:#01635e}.icon-dropdown{position:relative}.icon-toggle{padding:.4rem .6rem;border-radius:8px;border:1px solid #ccc;background:#f9f9f9;display:flex;align-items:center;gap:.25rem;box-shadow:inset 0 0 0 1px #e0e0e0}.icon-toggle:hover{background:#eee}.icon-toggle .arrow{font-size:.8rem}.icon-panel{position:absolute;top:110%;left:0;width:270px;max-height:260px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:.6rem;z-index:10}.icon-group{margin-bottom:.9rem}.icon-group:last-child{margin-bottom:.4rem}.icon-group-label{font-size:.75rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.4px;margin:.25rem 0 .35rem}.icon-grid{display:flex;flex-wrap:wrap;gap:.4rem}.icon-btn{width:38px;height:38px;border-radius:8px;border:none;background:#f3f3f3;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,background .15s}.icon-btn:hover{transform:scale(1.1);background:#eaeaea}.icon-btn.selected{background:#d0ebff;box-shadow:inset 0 0 0 2px #339af0}.amount-field{display:flex;align-items:center;gap:.6rem}.sign-toggle{width:40px;height:40px;font-size:1.3rem;font-weight:600;border:none;background:transparent;padding:.6rem 0;outline:none;appearance:none;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.sign-toggle.expense{color:#c0392b}.sign-toggle.income{color:#0f8c76}.sign-toggle:hover{transform:scale(1.05)}.category-row{display:flex;align-items:center;gap:.6rem}.category-pill{border:1px solid #ccc;border-radius:8px;background:#fff;padding:0 .6rem 0 .4rem;display:flex;align-items:center;flex:1;transition:border-color .2s,box-shadow .2s}.category-pill:focus-within{border-color:var(--pill-color, #017a73);box-shadow:0 0 0 2px color-mix(in srgb,var(--pill-color) 50%,transparent)}.category-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-right:.4rem}.category-select{flex:1;font-size:1rem;border:none;background:transparent;padding:.6rem 0;outline:none;appearance:none}.category-select::-ms-expand{display:none}.category-select:focus{outline:none}.amount-field.inside{position:relative}.sign-inside{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:1.2rem;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none}.sign-inside.income{color:#0f8c76}.sign-inside.expense{color:#c0392b}.amount-field.inside input{padding-left:2rem}.sign-toggle,.sign-inside{-webkit-user-select:none;user-select:none}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-light)}.login-card{width:100%;max-width:420px;background:#fff;padding:3rem 3.2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:1.8rem;animation:fade-in .4s ease}@keyframes fade-in{0%{opacity:0;translate:0 1rem}}.auth-logo{margin:0 auto .5rem;font-size:2rem;font-weight:700;letter-spacing:-.5px;color:var(--teal-dark)}.auth-logo .light{font-weight:400}.auth-heading{text-align:center;font-size:1.45rem;font-weight:600;color:var(--text-dark);margin:0 0 .2rem}.auth-field{display:flex;flex-direction:column;gap:.4rem}.auth-label{font-size:.95rem;color:var(--text-dark);font-weight:500}.auth-field input{font:500 1rem/1.4 Manrope,sans-serif;color:var(--text-dark);background:#f7f9fa;border:1px solid #e1e6ea;border-radius:var(--radius-sm);padding:.75rem 1rem;transition:border .18s,box-shadow .18s}.auth-field input:focus{outline:none;border-color:var(--teal-main);box-shadow:0 0 0 3px #017a7326}.auth-pass-wrapper{position:relative;display:flex;align-items:center}.auth-pass-wrapper input{padding-right:2.5rem;width:100%}.auth-eye{position:absolute;right:.6rem;background:none;border:none;padding:4px;cursor:pointer;color:var(--text-light);transition:color .18s}.auth-eye:hover{color:var(--teal-main)}.auth-btn{margin-top:.2rem;padding:.85rem 1rem;border:none;border-radius:var(--radius-md);font:600 1.05rem/1 Manrope,sans-serif;background:var(--teal-main);color:#fff;cursor:pointer;transition:background .2s,transform .15s}.auth-btn:hover{background:#019388}.auth-btn:active{transform:scale(.98)}.auth-note{text-align:center;font-size:.9rem;color:var(--text-light)}.auth-note a{color:var(--teal-main);text-decoration:none}.auth-note a:hover{text-decoration:underline}.google-btn{display:flex;align-items:center;justify-content:center;gap:.55rem;background:#fff;color:#3c4043;border:1px solid #dadce0;box-shadow:0 1px 2px #0000000d}.google-btn:hover{background:#f7f8f8}.google-btn:active{transform:scale(.97)}.google-icon{flex-shrink:0}
