:root{--font-sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bg-main:#0b0f19;--bg-card:#161c2da6;--bg-sidebar:#111827f2;--bg-input:#111827cc;--bg-modal:#111827;--border-color:#ffffff0f;--text-primary:#f8fafc;--text-secondary:#94a3b8;--color-primary:#6366f1;--color-primary-hover:#4f46e5;--color-success:#10b981;--color-danger:#f43f5e;--color-warning:#f59e0b;--color-info:#06b6d4;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-glow:0 0 20px #6366f126;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s ease}body.light-theme{--bg-main:#f8fafc;--bg-card:#ffffffd9;--bg-sidebar:#fffffff2;--bg-input:#fff;--bg-modal:#fff;--border-color:#0f172a14;--text-primary:#0f172a;--text-secondary:#475569;--shadow-md:0 4px 6px -1px #00000008, 0 2px 4px -1px #00000005;--shadow-lg:0 10px 15px -3px #0000000a, 0 4px 6px -2px #00000005;--shadow-glow:0 0 20px #6366f114}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-main);color:var(--text-primary);min-height:100vh;transition:background-color var(--transition-normal), color var(--transition-normal);background-image:radial-gradient(at 0 0,#6366f114 0,#0000 50%),radial-gradient(at 100% 100%,#10b9810d 0,#0000 50%);background-attachment:fixed;line-height:1.5;overflow-x:hidden}body.light-theme{background-image:radial-gradient(at 0 0,#6366f10a 0,#0000 50%),radial-gradient(at 100% 100%,#10b98108 0,#0000 50%)}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}.app-frame{justify-content:flex-start;align-items:stretch;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.desktop-sidebar{display:none}.app-container{background-color:var(--bg-main);flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.mobile-header{background-color:var(--bg-sidebar);border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;height:64px;padding:0 1.25rem;display:flex}@media (width>=501px){.mobile-header{height:75px;padding-top:15px}}.mobile-header .brand{align-items:center;gap:.5rem;margin-bottom:0;font-size:1.2rem;font-weight:700;display:flex}.mobile-header .brand span{background:linear-gradient(135deg, var(--color-primary), var(--color-success));-webkit-text-fill-color:transparent;-webkit-background-clip:text}.mobile-header .header-actions{align-items:center;gap:.75rem;display:flex}.user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary), var(--color-info));color:#fff;border:none;justify-content:center;align-items:center;width:32px;height:32px;font-size:.95rem;font-weight:700;display:flex}.logout-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;display:inline-flex}.logout-btn:hover{color:var(--color-danger);background-color:#f43f5e1a}#theme-toggle:hover{color:var(--color-warning);background-color:#f59e0b1a}.main-content{-webkit-overflow-scrolling:touch;flex:1;width:100%;max-width:100%;padding:1.25rem 1rem 5.5rem;overflow-y:auto}.header-row{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.header-title h1{letter-spacing:-.025em;margin-bottom:.25rem;font-size:2rem;font-weight:700}.header-title p{color:var(--text-secondary);font-size:.95rem}.card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-md);transition:transform var(--transition-normal), box-shadow var(--transition-normal), background-color var(--transition-normal), border-color var(--transition-normal);padding:1.5rem}.card:hover{box-shadow:var(--shadow-lg)}.card-title{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:1rem;font-weight:600;display:flex}.summary-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem;display:grid}.summary-card{position:relative;overflow:hidden}.summary-value{letter-spacing:-.03em;margin-bottom:.5rem;font-size:1.85rem;font-weight:700}.summary-indicator{align-items:center;gap:.25rem;font-size:.85rem;font-weight:600;display:flex}.indicator-up{color:var(--color-success)}.indicator-down{color:var(--color-danger)}.indicator-neutral{color:var(--text-secondary)}.summary-icon{opacity:.15;font-size:3rem;position:absolute;bottom:1.5rem;right:1.5rem}.charts-grid{grid-template-columns:1fr;gap:1.25rem;margin-bottom:1.5rem;display:grid}.table-container{margin-top:1rem;overflow-x:auto}.app-table{border-collapse:collapse;text-align:left;width:100%}.app-table th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.05em;padding:1rem;font-size:.85rem;font-weight:600}.app-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:1rem;font-size:.95rem}.app-table tr{transition:var(--transition-fast)}.app-table tr:hover td{background-color:#ffffff05}body.light-theme .app-table tr:hover td{background-color:#00000003}.badge{border-radius:var(--radius-full);text-transform:capitalize;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-income{color:var(--color-success);background-color:#10b98126}.badge-expense{color:var(--color-danger);background-color:#f43f5e26}.badge-transfer{color:var(--color-primary);background-color:#6366f126}.category-tag{border-radius:var(--radius-sm);align-items:center;gap:.35rem;padding:.25rem .5rem;font-size:.8rem;font-weight:500;display:inline-flex}.budget-list{flex-direction:column;gap:1.25rem;display:flex}.budget-item{flex-direction:column;gap:.5rem;display:flex}.budget-info{justify-content:space-between;font-size:.9rem;display:flex}.budget-name{font-weight:600}.budget-limit{color:var(--text-secondary)}.progress-bar-bg{border-radius:var(--radius-full);background-color:#ffffff0d;height:8px;overflow:hidden}body.light-theme .progress-bar-bg{background-color:#0f172a14}.progress-bar-fill{border-radius:var(--radius-full);height:100%;transition:width .5s ease-out}.form-group{margin-bottom:1.25rem}.form-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.form-control{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:var(--transition-fast);padding:.75rem 1rem}.form-control:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #6366f126}.form-row{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.form-check{cursor:pointer;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.form-check input{width:1.1rem;height:1.1rem;accent-color:var(--color-primary)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover);box-shadow:var(--shadow-glow)}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);background-color:#ffffff0d}body.light-theme .btn-secondary{background-color:#fff}.btn-secondary:hover{background-color:#ffffff1a}body.light-theme .btn-secondary:hover{background-color:#0f172a0a}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-sm{border-radius:var(--radius-sm);padding:.4rem .8rem;font-size:.8rem}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#000000b3;justify-content:center;align-items:center;width:100vw;height:100vh;display:none;position:fixed;top:0;left:0}.modal-content{background-color:var(--bg-modal);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:550px;box-shadow:var(--shadow-lg);transition:background-color var(--transition-normal);padding:2rem;animation:.3s ease-out modalSlideUp;position:relative}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-header h3{font-size:1.3rem;font-weight:700}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:1.5rem}.modal-close:hover{color:var(--text-primary)}.alert{border-radius:var(--radius-md);border-left:4px solid #0000;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem;font-size:.9rem;font-weight:500;display:flex}.alert-danger{color:#fda4af;border-color:var(--color-danger);background-color:#f43f5e1a}body.light-theme .alert-danger{color:#991b1b;background-color:#f43f5e14}.alert-success{color:#6ee7b7;border-color:var(--color-success);background-color:#10b9811a}body.light-theme .alert-success{color:#065f46;background-color:#10b98114}.auth-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative}.auth-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);width:100%;max-width:440px;box-shadow:var(--shadow-lg);padding:2.5rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h2{margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.auth-header p{color:var(--text-secondary);font-size:.9rem}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:1.5rem;font-size:.85rem}.auth-footer a{color:var(--color-primary);font-weight:600}.auth-footer a:hover{text-decoration:underline}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.filters{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.scanner-dropzone{border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:var(--transition-normal);background-color:#ffffff03;border:2px dashed #ffffff26;flex-direction:column;align-items:center;gap:1rem;padding:3rem 2rem;display:flex}body.light-theme .scanner-dropzone{border-color:#0f172a26}.scanner-dropzone:hover{border-color:var(--color-primary);background-color:#6366f105}.scanner-icon{color:var(--text-secondary);transition:var(--transition-fast);font-size:3rem}.scanner-dropzone:hover .scanner-icon{color:var(--color-primary);transform:translateY(-2px)}.spinner{border:3px solid #ffffff1a;border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:1s ease-in-out infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.scanner-loading{flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 0;display:flex}.preview-receipt{object-fit:contain;border-radius:var(--radius-md);border:1px solid var(--border-color);max-width:100%;max-height:250px;margin-bottom:1rem}.color-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.icon-svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;vertical-align:-.15em;width:1.1em;height:1.1em}.csv-mapper-table select{width:100%;padding:.4rem}.mobile-nav{background-color:var(--bg-sidebar);border-top:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:99;flex-shrink:0;justify-content:space-around;align-items:center;width:100%;height:64px;display:flex;position:absolute;bottom:0;left:0}@media (width>=501px){.mobile-nav{height:76px;padding-bottom:12px}}.nav-item-mobile{color:var(--text-secondary);height:100%;transition:color var(--transition-fast);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.25rem;font-size:.65rem;font-weight:600;display:flex}.nav-item-mobile:hover,.nav-item-mobile.active{color:var(--color-primary)}.nav-item-mobile .icon-svg{stroke-width:2.2px;width:20px;height:20px;transition:transform var(--transition-fast)}.nav-item-mobile:active .icon-svg{transform:scale(.9)}.nav-fab-container{justify-content:center;align-items:flex-start;width:68px;height:100%;display:flex;position:relative}.nav-fab-btn{background:linear-gradient(135deg, var(--color-primary), var(--color-success));border:4px solid var(--bg-sidebar);color:#fff;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s,box-shadow .2s;display:flex;position:absolute;top:-24px;box-shadow:0 8px 16px #6366f159}.nav-fab-btn:hover{transform:translateY(-2px)scale(1.05);box-shadow:0 10px 20px #6366f180}.nav-fab-btn:active{transform:translateY(1px)scale(.95)}.nav-fab-btn .icon-svg{stroke-width:3px;width:24px;height:24px}.drawer-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;visibility:hidden;background-color:#00000080;width:100%;height:100%;transition:opacity .3s,visibility .3s;position:absolute;top:0;left:0}.drawer-overlay.open{opacity:1;visibility:visible}.drawer-content{background-color:var(--bg-modal);border-left:1px solid var(--border-color);z-index:1001;flex-direction:column;width:280px;height:100%;padding:1.5rem;transition:right .3s cubic-bezier(.16,1,.3,1);display:flex;position:absolute;top:0;right:-280px;box-shadow:-5px 0 25px #0000004d}.drawer-overlay.open .drawer-content{right:0}.drawer-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;display:flex}.drawer-header h3{font-size:1.1rem;font-weight:700}.drawer-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:1.75rem;line-height:1}.drawer-close:hover{color:var(--text-primary)}.drawer-profile{border-bottom:1px solid var(--border-color);align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1.25rem;display:flex}.drawer-menu{flex-direction:column;flex:1;gap:.5rem;display:flex}.drawer-item{border-radius:var(--radius-md);color:var(--text-secondary);align-items:center;gap:.75rem;padding:.85rem 1rem;font-weight:500;transition:all .2s;display:flex}.drawer-item:hover{color:var(--text-primary);background-color:#6366f114}.drawer-item .icon-svg{stroke-width:2px;width:20px;height:20px}.drawer-footer{border-top:1px solid var(--border-color);margin-top:auto;padding-top:1rem}.header-row{flex-direction:row;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem}.header-title h1{font-size:1.5rem}.header-title p{font-size:.85rem}.btn,.form-control,.nav-item-mobile{min-height:44px}@media (width<=480px){.app-table th:nth-child(3),.app-table td:nth-child(3),.app-table th:nth-child(4),.app-table td:nth-child(4){display:none}.header-row{flex-direction:column;align-items:flex-start;gap:.75rem}.header-row>div,.header-row .btn{width:100%}}@media (width>=1025px){.mobile-header,.mobile-nav,.drawer-overlay{display:none!important}.desktop-sidebar{background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box;z-index:100;width:280px;min-width:280px;height:100vh;transition:background-color var(--transition-normal), border-color var(--transition-normal);flex-direction:column;flex-shrink:0;justify-content:space-between;padding:2.25rem 1.5rem;display:flex}.sidebar-brand{color:var(--text-primary);align-items:center;gap:.75rem;margin-bottom:2.5rem;font-size:1.5rem;font-weight:800;display:flex}.sidebar-brand span{background:linear-gradient(135deg, var(--color-primary), var(--color-success));-webkit-text-fill-color:transparent;-webkit-background-clip:text}.sidebar-menu{flex-direction:column;flex:1;gap:.5rem;display:flex}.sidebar-item{color:var(--text-secondary);border-radius:var(--radius-md);transition:var(--transition-normal);align-items:center;gap:.85rem;padding:.85rem 1rem;font-size:.95rem;font-weight:600;display:flex}.sidebar-item .icon-svg{width:1.25rem;height:1.25rem;transition:transform var(--transition-fast)}.sidebar-item:hover{color:var(--text-primary);background-color:#ffffff08}body.light-theme .sidebar-item:hover{background-color:#0f172a0a}.sidebar-item:hover .icon-svg{transform:translate(3px)}.sidebar-item.active{color:#fff;background:linear-gradient(135deg, var(--color-primary), #6366f1cc);box-shadow:var(--shadow-glow)}body.light-theme .sidebar-item.active{color:#fff;background:var(--color-primary)}.sidebar-footer{border-top:1px solid var(--border-color);flex-direction:column;gap:1.25rem;padding-top:1.5rem;display:flex}.user-profile-summary{align-items:center;gap:.75rem;display:flex}.user-profile-summary .user-info{flex-direction:column;display:flex}.user-profile-summary .user-name{color:var(--text-primary);font-size:.95rem;font-weight:700}.user-profile-summary .user-role{color:var(--text-secondary);font-size:.75rem}.footer-actions{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.footer-actions .logout-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;display:inline-flex}.footer-actions .logout-btn:hover{color:var(--color-danger);background-color:#f43f5e1a}.footer-actions .sidebar-theme-toggle:hover{color:var(--color-warning);background-color:#f59e0b1a}.app-container{flex:1;height:100vh;overflow:hidden}.main-content{box-sizing:border-box;height:100vh;padding:2.5rem 3rem;overflow-y:auto}.summary-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2rem}.charts-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.charts-grid>div{height:100%}.header-row{margin-bottom:2.5rem}.header-title h1{font-size:2.25rem}}.member-chip{cursor:pointer;display:inline-flex}.member-chip .chip-inner{border-radius:var(--radius-full);transition:all var(--transition-fast);cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:2px solid;align-items:center;gap:.3rem;padding:.3rem .7rem;font-size:.82rem;font-weight:600;display:inline-flex}.member-chip input[type=radio]:checked+.chip-inner{filter:brightness();opacity:1;background-color:currentColor;box-shadow:0 0 0 3px}.member-chip .chip-inner:hover{opacity:.85}.member-badge{border-radius:var(--radius-full);border:1px solid;align-items:center;gap:.25rem;padding:.15rem .55rem;font-size:.75rem;font-weight:600;display:inline-flex}
