@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--sidebar-w:268px;--topbar-h:60px;--r:14px;--r-sm:9px;--ease:.2s ease;--theme-transition:background-color .3s ease, color .3s ease, border-color .3s ease, box-shadow .3s ease;--bg-base:#060b14;--bg-surface:#0d1525;--bg-card:#0f182ae6;--bg-input:#ffffff0d;--bg-input-h:#ffffff14;--bg-tooltip:#0a101ef7;--bg-topbar:#060b14e0;--bg-table-th:#ffffff06;--bg-row-hover:#ffffff05;--border:#ffffff12;--border-h:#ffffff24;--border-row:#ffffff0a;--shadow-card:0 4px 24px #00000040;--shadow-modal:0 24px 60px #00000080;--shadow-panel:0 20px 50px #0006;--txt-1:#f1f5f9;--txt-2:#94a3b8;--txt-3:#475569;--chip-income-bg:#22c55e1f;--chip-income-txt:#86efac;--chip-income-bdr:#22c55e40;--chip-expense-bg:#ef44441f;--chip-expense-txt:#fca5a5;--chip-expense-bdr:#ef444440;--chip-done-bg:#22c55e1a;--chip-done-txt:#86efac;--chip-pending-bg:#f59e0b1f;--chip-pending-txt:#fde68a;--chip-surplus-bg:#22c55e1a;--chip-surplus-txt:#86efac;--chip-deficit-bg:#ef44441a;--chip-deficit-txt:#fca5a5;--blue:#3b82f6;--green:#22c55e;--red:#ef4444;--orange:#f97316;--purple:#a855f7;--cyan:#06b6d4;--amber:#f59e0b;--pink:#ec4899}.light{--bg-base:#f1f5fb;--bg-surface:#e8eef7;--bg-card:#fffffff2;--bg-input:#0f172a0d;--bg-input-h:#0f172a14;--bg-tooltip:#fffffffc;--bg-topbar:#f8fafdeb;--bg-table-th:#0f172a08;--bg-row-hover:#0f172a06;--border:#0f172a14;--border-h:#0f172a29;--border-row:#0f172a0d;--shadow-card:0 2px 16px #0f172a12;--shadow-modal:0 16px 48px #0f172a26;--shadow-panel:0 10px 40px #0f172a1f;--txt-1:#0f172a;--txt-2:#475569;--txt-3:#94a3b8;--chip-income-bg:#15803d1a;--chip-income-txt:#15803d;--chip-income-bdr:#15803d40;--chip-expense-bg:#b91c1c14;--chip-expense-txt:#b91c1c;--chip-expense-bdr:#b91c1c33;--chip-done-bg:#15803d14;--chip-done-txt:#15803d;--chip-pending-bg:#b4530914;--chip-pending-txt:#b45309;--chip-surplus-bg:#15803d14;--chip-surplus-txt:#15803d;--chip-deficit-bg:#b91c1c14;--chip-deficit-txt:#b91c1c}.role-viewer-theme{--accent:var(--purple);--accent-l:#c084fc}.role-admin-theme{--accent:var(--blue);--accent-l:#93c5fd}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}*{transition:var(--theme-transition)}.loading-screen,.ls-orbit-dot,.ls-progress-bar-fill,.onboarding-pulse{transition:none!important}body{color:var(--txt-1);-webkit-font-smoothing:antialiased;background:#060b14;font-family:Inter,sans-serif;line-height:1.5;overflow-x:hidden}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select{font-family:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:99px}.light ::-webkit-scrollbar-thumb{background:#0000001f}.loading-screen{z-index:9999;background:#050a12;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ls-grid{pointer-events:none;background-image:linear-gradient(#3b82f60a 1px,#0000 1px),linear-gradient(90deg,#3b82f60a 1px,#0000 1px);background-size:50px 50px;position:absolute;inset:0}.ls-glow{filter:blur(80px);pointer-events:none;border-radius:50%;position:absolute}.ls-glow-1{background:#3b82f61f;width:400px;height:400px;top:-100px;right:-80px}.ls-glow-2{background:#a855f71a;width:300px;height:300px;bottom:-60px;left:-60px}.ls-content{z-index:1;flex-direction:column;align-items:center;gap:24px;display:flex;position:relative}.ls-logo-wrap{justify-content:center;align-items:center;width:90px;height:90px;display:flex;position:relative}.ls-logo-ring{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;display:flex;box-shadow:0 0 40px #3b82f666}.ls-logo-inner{background:#050a12;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;display:flex}.ls-logo-symbol{color:#fff;font-family:Space Grotesk,sans-serif;font-size:26px;font-weight:700}.ls-orbit-dot{transform-origin:6px 51px;background:#3b82f6;border-radius:50%;width:12px;height:12px;margin-top:-6px;margin-left:-6px;position:absolute;top:0;left:50%;box-shadow:0 0 12px #3b82f6cc}.ls-brand{text-align:center}.ls-brand-name{color:#f1f5f9;letter-spacing:-.5px;font-family:Space Grotesk,sans-serif;font-size:28px;font-weight:700;display:block}.ls-brand-tagline{color:#475569;margin-top:4px;font-size:13px;display:block}.ls-progress-wrap{width:280px}.ls-progress-bar-track{background:#ffffff12;border-radius:99px;height:3px;margin-bottom:10px;position:relative;overflow:visible}.ls-progress-bar-fill{background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:99px;height:100%;transition:width .1s linear}.ls-progress-glow{pointer-events:none;background:#60a5fa;border-radius:50%;width:10px;height:10px;position:absolute;top:-4px;transform:translate(-50%);box-shadow:0 0 14px #3b82f6}.ls-progress-info{color:#475569;justify-content:space-between;font-size:11px;display:flex}.ls-pct{color:#64748b;font-weight:600}.ls-version{color:#334155;font-size:11px}.onboarding-overlay{z-index:800;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000bf;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.onboarding-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:500px;padding:30px;position:relative;overflow:hidden;box-shadow:0 30px 80px #00000080}.light .onboarding-modal{background:#fff}.onboarding-skip{color:var(--txt-3);background:var(--bg-input);border:1px solid var(--border);cursor:pointer;border-radius:99px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;transition:all .2s;display:flex;position:absolute;top:18px;right:18px}.onboarding-skip:hover{color:var(--txt-2)}.onboarding-dots{gap:6px;margin-bottom:24px;display:flex}.onboarding-dot{background:var(--border-h);cursor:pointer;border:none;border-radius:99px;width:24px;height:4px;transition:all .25s}.onboarding-dot.active{width:36px}.onboarding-dot.done{background:#3b82f666}.onboarding-step{flex-direction:column;align-items:flex-start;gap:14px;min-height:320px;display:flex}.onboarding-icon-wrap{border-radius:18px;justify-content:center;align-items:center;width:70px;height:70px;display:flex;position:relative}.onboarding-icon-inner{justify-content:center;align-items:center;display:flex}.onboarding-pulse{pointer-events:none;border:1.5px solid;border-radius:24px;position:absolute;inset:-8px}.onboarding-text{width:100%}.onboarding-step-num{letter-spacing:1px;font-size:11px;font-weight:600}.onboarding-title{color:var(--txt-1);letter-spacing:-.3px;margin:6px 0 4px;font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700}.onboarding-subtitle{color:var(--txt-2);font-size:13px;font-weight:500}.onboarding-desc{color:var(--txt-2);margin-top:10px;font-size:14px;line-height:1.65}.onboarding-highlights{flex-direction:column;gap:8px;margin-top:14px;list-style:none;display:flex}.onboarding-highlights li{color:var(--txt-2);align-items:center;gap:8px;font-size:13px;display:flex}.onboarding-nav{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:24px;padding-top:18px;display:flex}.onboarding-btn-primary{border-radius:var(--r-sm);color:#fff;cursor:pointer;border:none;align-items:center;gap:5px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .2s;display:inline-flex}.onboarding-btn-primary:hover{opacity:.9}.onboarding-btn-secondary{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--txt-2);cursor:pointer;padding:10px 16px;font-size:14px;transition:all .2s}.onboarding-btn-secondary:hover{border-color:var(--border-h);color:var(--txt-1)}.onboarding-btn-secondary:disabled{opacity:.3;pointer-events:none}.notif-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);width:340px;box-shadow:var(--shadow-panel);z-index:200;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.light .notif-panel{background:#fff}.notif-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-title-row{color:var(--txt-1);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.notif-unread-badge{color:#93c5fd;background:#3b82f626;border:1px solid #3b82f633;border-radius:99px;padding:2px 7px;font-size:10px}.notif-actions{gap:4px;display:flex}.notif-action-btn{background:var(--bg-input);border:1px solid var(--border);width:28px;height:28px;color:var(--txt-2);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;transition:all .2s;display:flex}.notif-action-btn:hover{border-color:var(--border-h);color:var(--txt-1)}.notif-list{max-height:360px;overflow-y:auto}.notif-empty{text-align:center;color:var(--txt-3);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:40px 20px;display:flex}.notif-empty p{color:var(--txt-2);font-size:14px}.notif-empty span{font-size:12px}.notif-item{border-bottom:1px solid var(--border);border-left:3px solid #0000;align-items:flex-start;gap:10px;padding:12px 16px;transition:background .2s;display:flex;position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-input)}.notif-item.unread{background:#3b82f608}.notif-item-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.notif-item-body{flex:1;min-width:0}.notif-item-title{color:var(--txt-1);font-size:13px;font-weight:600}.notif-item-msg{color:var(--txt-2);margin-top:2px;font-size:12px;line-height:1.5}.notif-item-time{color:var(--txt-3);margin-top:4px;font-size:11px}.notif-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.app-root{background:var(--bg-base);min-height:100vh;color:var(--txt-1);display:flex;position:relative}.dark.app-root:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(55% 45% at 8% 18%,#3b82f612 0,#0000 60%),radial-gradient(45% 35% at 88% 8%,#a855f70f 0,#0000 55%),radial-gradient(40% 55% at 50% 92%,#22c55e0a 0,#0000 65%);position:fixed;inset:0}.dark.role-viewer-theme.app-root:before{background:radial-gradient(55% 45% at 8% 18%,#a855f714 0,#0000 60%),radial-gradient(45% 35% at 88% 8%,#ec48990f 0,#0000 55%)}.light.app-root:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(60% 45% at 10% 15%,#3b82f60d 0,#0000 60%),radial-gradient(50% 40% at 90% 10%,#a855f70a 0,#0000 55%),radial-gradient(45% 50% at 50% 95%,#22c55e08 0,#0000 65%);position:fixed;inset:0}.sidebar{width:var(--sidebar-w);background:var(--bg-card);border-right:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;height:100vh;padding:20px 14px;transition:transform .2s,background-color .3s,border-color .3s;display:flex;position:fixed;top:0;left:0;overflow-y:auto;box-shadow:4px 0 24px #00000026}.light .sidebar{background:#fffffff7;box-shadow:4px 0 16px #0f172a0f}.sidebar-viewer{border-right-color:#a855f733}.sidebar-overlay{z-index:99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;display:none;position:fixed;inset:0}.sidebar-logo{border-bottom:1px solid var(--border);flex-direction:column;margin-bottom:16px;padding:6px 8px 22px;display:flex}.logo-title{letter-spacing:-.5px;background:linear-gradient(135deg,#f8fafc 0%,#cbd5e1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:27px;font-weight:800}.light .logo-title{background:linear-gradient(135deg,#0f172a 0%,#475569 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.logo-sub{color:var(--txt-3);letter-spacing:1px;margin-top:2px;font-size:10px;font-weight:600}.role-banner{border-radius:var(--r-sm);letter-spacing:1.2px;align-items:center;gap:6px;margin-bottom:14px;padding:6px 12px;font-size:10px;font-weight:700;display:flex}.role-banner-admin{color:#93c5fd;background:#3b82f61a;border:1px solid #3b82f633}.role-banner-viewer{color:#c084fc;background:#a855f71f;border:1px solid #a855f738}.sidebar-nav{flex-direction:column;flex:1;gap:3px;display:flex}.nav-section-label{letter-spacing:1.4px;color:var(--txt-3);margin-top:4px;margin-bottom:5px;padding:0 10px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--r-sm);width:100%;color:var(--txt-2);cursor:pointer;text-align:left;border:1px solid #0000;align-items:center;gap:9px;padding:10px 12px;font-size:13.5px;font-weight:500;display:flex;position:relative}.nav-item:hover{background:var(--bg-input);color:var(--txt-1)}.nav-active{color:#1d72f3;background:#3b82f61a;border-color:#3b82f633}.light .nav-active{color:#1d4ed8;background:#3b82f614;border-color:#3b82f62e}.sidebar-viewer .nav-active{color:#a855f7;background:#a855f71a;border-color:#a855f733}.light .sidebar-viewer .nav-active{color:#7c3aed}.nav-indicator{border-radius:99px;width:3px;height:18px;position:absolute;top:50%;right:0;transform:translateY(-50%)}.nav-arrow{opacity:.35;margin-left:auto}.role-section{border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:12px 0;padding:14px 0}.role-toggle-wrap{flex-direction:column;gap:6px;margin-top:10px;display:flex}.role-option{border-radius:var(--r-sm);background:var(--bg-input);border:1px solid var(--border);cursor:pointer;transition:all var(--ease);text-align:left;align-items:center;gap:10px;width:100%;padding:10px 12px;display:flex;position:relative}.role-option:hover{border-color:var(--border-h)}.role-option-icon{background:var(--bg-input);width:28px;height:28px;color:var(--txt-2);border-radius:7px;justify-content:center;align-items:center;display:flex}.role-option-label{color:var(--txt-1);font-size:13px;font-weight:600;display:block}.role-option-sub{color:var(--txt-3);font-size:11px;display:block}.role-option-active-admin{background:#3b82f61a;border-color:#3b82f64d}.role-option-active-admin .role-option-icon{color:#93c5fd;background:#3b82f626}.role-option-active-viewer{background:#a855f71a;border-color:#a855f74d}.role-option-active-viewer .role-option-icon{color:#c084fc;background:#a855f726}.role-check-dot{border-radius:50%;width:8px;height:8px;position:absolute;right:12px}.admin-dot{background:var(--blue);box-shadow:0 0 8px #3b82f699}.viewer-dot{background:var(--purple);box-shadow:0 0 8px #a855f799}.sidebar-help{padding:10px 0}.help-btn{border-radius:var(--r-sm);background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--txt-2);cursor:pointer;transition:all var(--ease);align-items:center;gap:8px;padding:9px 12px;font-size:13px;display:flex}.help-btn:hover{border-color:var(--border-h);color:var(--txt-1)}.sidebar-bottom{flex-direction:column;gap:8px;padding-top:10px;display:flex}.sidebar-credit{text-align:center;color:var(--txt-3);letter-spacing:.3px;opacity:.7;padding:6px 0 2px;font-size:11px;text-decoration:none;transition:opacity .2s,color .2s;display:block}.sidebar-credit:hover{opacity:1;color:var(--txt-2)}.sidebar-credit-name{color:var(--blue);background:linear-gradient(90deg,#3b82f6,#a855f7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:600}.light .sidebar-credit-name{background:linear-gradient(90deg,#1d4ed8,#7c3aed);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.theme-toggle{border-radius:var(--r-sm);width:100%;color:var(--txt-2);background:var(--bg-input);border:1px solid var(--border);cursor:pointer;transition:all var(--ease);align-items:center;gap:8px;padding:9px 12px;font-size:13px;display:flex}.theme-toggle:hover{border-color:var(--border-h);color:var(--txt-1)}.theme-pill{border-radius:99px;width:26px;height:14px;margin-left:auto;transition:background .3s;position:relative}.dark-pill{background:#1e3a5f}.light-pill{background:#fbbf24}.theme-pill:after{content:"";background:#fff;border-radius:50%;width:10px;height:10px;transition:left .3s;position:absolute;top:2px}.dark-pill:after{left:14px}.light-pill:after{left:2px}.sidebar-user{border-radius:var(--r-sm);background:var(--bg-input);border:1px solid var(--border);align-items:center;gap:10px;padding:10px 12px;display:flex}.user-avatar-box{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.avatar-admin{color:#93c5fd;background:#3b82f626;border:1px solid #3b82f633}.avatar-viewer{color:#c084fc;background:#a855f726;border:1px solid #a855f733}.user-name{color:var(--txt-1);font-size:13px;font-weight:600}.user-role-badge{letter-spacing:1px;border-radius:99px;margin-top:2px;padding:2px 6px;font-size:9px;font-weight:700;display:inline-block}.badge-admin{color:#93c5fd;background:#3b82f626}.badge-viewer{color:#c084fc;background:#a855f726}.main-content{margin-left:var(--sidebar-w);z-index:1;background:var(--bg-base);flex-direction:column;flex:1;min-height:100vh;display:flex;position:relative}.viewer-content{--accent:var(--purple)}.topbar{height:var(--topbar-h);background:var(--bg-topbar);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);z-index:50;box-shadow:var(--shadow-card);align-items:center;gap:14px;padding:0 22px;display:flex;position:sticky;top:0}.topbar-viewer{border-bottom-color:#a855f733}.hamburger{border-radius:var(--r-sm);background:var(--bg-input);border:1px solid var(--border);width:34px;height:34px;color:var(--txt-1);transition:all var(--ease);justify-content:center;align-items:center;display:none}.hamburger:hover{background:var(--border)}.topbar-title{flex:1;align-items:center;gap:7px;display:flex}.breadcrumb,.breadcrumb-sep{color:var(--txt-3);font-size:13px}.breadcrumb-active{color:var(--txt-1);font-size:14px;font-weight:600}.topbar-role-badge{letter-spacing:1.2px;border-radius:99px;padding:3px 9px;font-size:9.5px;font-weight:700}.topbar-admin-badge{color:#93c5fd;background:#3b82f61f;border:1px solid #3b82f633}.topbar-viewer-badge{color:#c084fc;background:#a855f71f;border:1px solid #a855f733}.topbar-right{align-items:center;gap:8px;display:flex;position:relative}.icon-btn{border-radius:var(--r-sm);background:var(--bg-input);border:1px solid var(--border);width:34px;height:34px;color:var(--txt-2);cursor:pointer;transition:all var(--ease);justify-content:center;align-items:center;display:flex;position:relative}.icon-btn:hover,.icon-btn-active{border-color:var(--border-h);color:var(--txt-1)}.notif-count{background:var(--red);color:#fff;border-radius:99px;justify-content:center;align-items:center;min-width:17px;height:17px;padding:0 3px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-5px;right:-5px}.viewer-top-bar{background:linear-gradient(90deg,#a855f71f,#ec489914);border-bottom:1px solid #a855f733}.viewer-top-inner{color:#c084fc;text-align:center;max-width:900px;margin:0 auto;padding:9px 22px;font-size:12.5px}.page-content{background:var(--bg-base);flex:1;padding:22px;overflow:hidden auto}.dark .page-content:before{content:"";z-index:-1;pointer-events:none;background-image:linear-gradient(#ffffff03 1px,#0000 1px),linear-gradient(90deg,#ffffff03 1px,#0000 1px);background-size:60px 60px;position:fixed;inset:0}.btn-primary{color:#fff;letter-spacing:.3px;cursor:pointer;background:linear-gradient(135deg,#2563eb,#6366f1,#8b5cf6) 0 0/200% 200%;border:1px solid #ffffff26;border-radius:8px;align-items:center;gap:8px;padding:10px 22px;font-size:13.5px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden;box-shadow:0 4px 14px #6366f159,inset 0 1px #fff3}.btn-primary:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);transition:transform .6s;position:absolute;inset:0;transform:translate(-100%)skew(-15deg)}.btn-primary:hover{background-position:100%;border-color:#ffffff4d;transform:translateY(-1.5px);box-shadow:0 8px 24px #6366f180,inset 0 1px #fff6}.btn-primary:hover:before{transform:translate(100%)skew(-15deg)}.btn-primary:active{transform:translateY(0);box-shadow:0 2px 8px #6366f166}.light .btn-primary{box-shadow:0 4px 14px #6366f140,inset 0 1px #fff6}.btn-secondary{background:var(--bg-input);color:var(--txt-1);border-radius:var(--r-sm);cursor:pointer;transition:all var(--ease);border:1px solid var(--border);align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:600;display:inline-flex}.btn-secondary:hover{border-color:var(--border-h)}.btn-sm{padding:6px 11px;font-size:12px}.link-btn{color:var(--blue);cursor:pointer;transition:opacity var(--ease);background:0 0;border:none;font-size:13px;font-weight:500}.link-btn:hover{opacity:.75}.req{color:var(--red);margin-left:2px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:22px;display:flex}.page-title{color:var(--txt-1);letter-spacing:-.4px;font-family:Space Grotesk,sans-serif;font-size:24px;font-weight:700}.page-sub{color:var(--txt-2);align-items:center;gap:6px;margin-top:4px;font-size:13px;display:flex}.page-actions{flex-wrap:wrap;gap:8px;display:flex}.viewer-readonly-label{color:var(--purple);background:#a855f71a;border:1px solid #a855f733;border-radius:99px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:inline-flex}.viewer-mode-banner{border-radius:var(--r-sm);color:#c084fc;background:#a855f714;border:1px solid #a855f733;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.summary-cards{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}.summary-card{border-radius:var(--r);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:default;border:1px solid;padding:20px;position:relative;overflow:hidden}.card-header{align-items:center;gap:9px;margin-bottom:12px;display:flex}.card-icon-wrap{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.card-label{color:var(--txt-2);font-size:12.5px;font-weight:500}.card-value{letter-spacing:-.4px;margin-bottom:5px;font-family:Space Grotesk,sans-serif;font-size:24px;font-weight:700}.card-sub{color:var(--txt-3);font-size:12px}.card-accent-line{transform-origin:0;border-radius:0 3px 0 0;width:100%;height:3px;position:absolute;bottom:0;left:0}.dashboard-page{max-width:1440px}.dashboard-hero{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-card);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:20px;padding:20px 24px;display:flex}.dark .dashboard-hero{background:linear-gradient(135deg,#3b82f612 0%,#a855f70d 100%);border-color:#3b82f61f}.hero-title{color:var(--txt-1);letter-spacing:-.4px;font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700}.hero-sub{color:var(--txt-2);margin-top:4px;font-size:13px}.hero-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.live-clock{color:var(--txt-2);background:var(--bg-card);border:1px solid var(--border);border-radius:99px;align-items:center;gap:5px;padding:5px 11px;font-size:13px;font-weight:600;display:flex}.hero-badge{background:var(--bg-card);border:1px solid var(--border);color:var(--txt-2);border-radius:99px;padding:5px 12px;font-size:12px}.hero-badge.pulse{color:#86efac;background:#22c55e12;border-color:#22c55e4d;animation:2.2s ease-in-out infinite pulse-badge}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.55}}.charts-grid{grid-template-columns:1.55fr 1fr;gap:14px;margin-bottom:14px;display:grid}.charts-grid-2{grid-template-columns:1.2fr 1fr;gap:14px;margin-bottom:14px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-card);padding:18px}.chart-card:hover{border-color:var(--border-h)}.light .chart-card{background:#fff}.chart-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.chart-header h3{color:var(--txt-1);font-size:14px;font-weight:600}.chart-badge{color:#93c5fd;background:#3b82f61a;border:1px solid #3b82f62e;border-radius:99px;padding:3px 9px;font-size:11px}.light .chart-badge{color:#1d4ed8;background:#3b82f61a;border-color:#3b82f633}.chart-tooltip{background:var(--bg-tooltip);border:1px solid var(--border);color:var(--txt-1);border-radius:10px;padding:10px 14px;font-size:13px;box-shadow:0 10px 30px #0000004d}.tooltip-label{color:var(--txt-2);margin-bottom:6px;font-weight:600}.tooltip-row{align-items:center;gap:6px;margin-top:3px;display:flex}.tooltip-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.top-cats{flex-direction:column;gap:11px;display:flex}.top-cat-item{align-items:center;gap:9px;display:flex}.top-cat-left{flex-shrink:0;align-items:center;gap:6px;width:145px;display:flex}.top-cat-rank{color:var(--txt-3);width:20px;font-size:11px}.top-cat-name{color:var(--txt-2);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;overflow:hidden}.top-cat-right{flex:1;align-items:center;gap:9px;display:flex}.top-cat-bar-wrap{background:var(--bg-input);border-radius:99px;flex:1;height:5px;overflow:hidden}.top-cat-bar{border-radius:99px;max-width:100%;height:100%}.top-cat-val{color:var(--txt-1);text-align:right;flex-shrink:0;width:50px;font-size:12px;font-weight:600}.recent-list{flex-direction:column;gap:1px;display:flex}.recent-item{border-radius:var(--r-sm);transition:background var(--ease);align-items:center;gap:11px;padding:11px 8px;display:flex}.recent-item:hover{background:var(--bg-input)}.recent-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.recent-category-abbr{letter-spacing:.5px;font-size:11px;font-weight:700}.recent-info{flex:1;min-width:0}.recent-desc{color:var(--txt-1);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:500;overflow:hidden}.recent-meta{color:var(--txt-3);margin-top:2px;font-size:11.5px}.recent-amount{flex-shrink:0;align-items:center;gap:3px;font-size:13.5px;font-weight:700;display:flex}.recent-amount.income{color:var(--green)}.recent-amount.expense{color:var(--red)}.transactions-page{max-width:1440px}.filters-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:18px;display:flex}.search-wrap{flex:1;min-width:200px;position:relative}.search-icon{color:var(--txt-3);pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.search-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--txt-1);transition:all var(--ease);padding:9px 34px 9px 36px;font-size:13.5px}.search-input:focus{border-color:#3b82f673;outline:none;box-shadow:0 0 0 3px #3b82f614}.search-input::placeholder{color:var(--txt-3)}.clear-search{color:var(--txt-3);cursor:pointer;background:0 0;border:none;align-items:center;display:flex;position:absolute;top:50%;right:9px;transform:translateY(-50%)}.filter-select{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--txt-1);cursor:pointer;transition:all var(--ease);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding:9px 30px 9px 12px;font-size:13px}.filter-select:focus{border-color:#3b82f673;outline:none}.filter-select option{background:var(--bg-surface);color:var(--txt-1)}.sort-wrap{align-items:center;gap:4px;display:flex}.sort-dir-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--txt-2);cursor:pointer;transition:all var(--ease);align-items:center;padding:9px;display:flex}.sort-dir-btn:hover{border-color:var(--border-h);color:var(--txt-1)}.reset-btn{border-radius:var(--r-sm);color:#fca5a5;cursor:pointer;transition:all var(--ease);white-space:nowrap;background:#ef444414;border:1px solid #ef444433;align-items:center;gap:5px;padding:9px 13px;font-size:13px;display:flex}.reset-btn:hover{background:#ef444424}.table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-card);overflow:auto hidden}.txn-table{border-collapse:collapse;width:100%;min-width:680px}.txn-table th{text-align:left;letter-spacing:.8px;color:var(--txt-3);text-transform:uppercase;background:var(--bg-table-th);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 15px;font-size:10.5px;font-weight:600}.txn-table td{border-bottom:1px solid var(--border-row);vertical-align:middle;padding:12px 15px;font-size:13px}.txn-row:hover td{background:var(--bg-row-hover)}.txn-row:last-child td{border-bottom:none}.txn-date{color:var(--txt-3);white-space:nowrap}.txn-desc{color:var(--txt-1);font-weight:500}.txn-category{color:var(--txt-2);white-space:nowrap;background:#ffffff0a;border:1px solid;border-radius:99px;align-items:center;gap:6px;padding:4px 9px;font-size:12px;display:inline-flex}.light .txn-category{background:#0000000a}.txn-type{border-radius:99px;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-block}.txn-type.income{background:var(--chip-income-bg);color:var(--chip-income-txt);border:1px solid var(--chip-income-bdr)}.txn-type.expense{background:var(--chip-expense-bg);color:var(--chip-expense-txt);border:1px solid var(--chip-expense-bdr)}.txn-amount{white-space:nowrap;font-size:13.5px;font-weight:700}.txn-amount.income{color:var(--chip-income-txt)}.txn-amount.expense{color:var(--chip-expense-txt)}.txn-status{text-transform:capitalize;border-radius:99px;padding:3px 9px;font-size:11px;font-weight:500;display:inline-block}.txn-status.completed{background:var(--chip-done-bg);color:var(--chip-done-txt)}.txn-status.pending{background:var(--chip-pending-bg);color:var(--chip-pending-txt)}.txn-actions{gap:5px;display:flex}.action-btn{cursor:pointer;border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.action-btn.edit{color:var(--blue);background:#3b82f614;border-color:#3b82f626}.action-btn.edit:hover{background:#3b82f62e}.action-btn.delete{color:var(--red);background:#ef444414;border-color:#ef444426}.action-btn.delete:hover{background:#ef44442e}.pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:5px;margin-top:18px;display:flex}.page-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);min-width:32px;height:32px;color:var(--txt-2);cursor:pointer;transition:all var(--ease);justify-content:center;align-items:center;padding:0 7px;font-size:13px;display:flex}.page-btn:hover:not(:disabled){border-color:var(--border-h);color:var(--txt-1)}.page-btn.active{background:linear-gradient(135deg,var(--blue),#6366f1);color:#fff;border-color:#0000}.page-btn:disabled{opacity:.3;cursor:not-allowed}.page-info{color:var(--txt-3);margin-left:7px;font-size:12px}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:70px 20px;display:flex}.empty-icon{color:var(--txt-3)}.empty-state p{color:var(--txt-2);margin-bottom:6px;font-size:15px}.insights-page{max-width:1440px}.ai-badge{color:#c4b5fd;background:linear-gradient(135deg,#a855f71f,#3b82f61f);border:1px solid #a855f738;border-radius:99px;align-self:center;align-items:center;gap:6px;padding:6px 13px;font-size:11.5px;font-weight:600;display:flex}.insight-cards{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px;display:grid}.insight-card{background:var(--bg-card);border-radius:var(--r);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:default;box-shadow:var(--shadow-card);border:1px solid;padding:18px}.light .insight-card{background:#fff}.insight-card-top{margin-bottom:12px}.insight-icon-wrap{border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.insight-value{letter-spacing:-.3px;margin-bottom:4px;font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700}.insight-title{color:var(--txt-1);margin-bottom:3px;font-size:13px;font-weight:600}.insight-sub{color:var(--txt-3);font-size:12px}.insights-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.insight-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-card);padding:18px}.light .insight-section{background:#fff}.insight-section h3{color:var(--txt-1);margin-bottom:16px;font-size:14px;font-weight:600}.span-full{grid-column:1/-1}.breakdown-list{flex-direction:column;gap:9px;display:flex}.breakdown-item{align-items:center;gap:9px;display:flex}.breakdown-label{width:130px;color:var(--txt-2);flex-shrink:0;align-items:center;gap:7px;font-size:12.5px;display:flex}.breakdown-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.breakdown-bar-wrap{background:var(--bg-input);border-radius:99px;flex:1;height:6px;overflow:hidden}.breakdown-bar{border-radius:99px;min-width:2px;height:100%}.breakdown-pct{color:var(--txt-3);text-align:right;flex-shrink:0;width:36px;font-size:11.5px}.breakdown-val{color:var(--txt-1);text-align:right;flex-shrink:0;width:52px;font-size:12px;font-weight:600}.monthly-table{border-collapse:collapse;width:100%;font-size:13px}.monthly-table th{text-align:left;letter-spacing:.8px;color:var(--txt-3);text-transform:uppercase;background:var(--bg-table-th);border-bottom:1px solid var(--border);padding:10px 14px;font-size:10.5px;font-weight:600}.monthly-table td{border-bottom:1px solid var(--border-row);color:var(--txt-1);padding:11px 14px}.monthly-table tr:last-child td{border-bottom:none}.monthly-table tr:hover td{background:var(--bg-row-hover)}.income-text{font-weight:600;color:var(--chip-income-txt)!important}.expense-text{font-weight:600;color:var(--chip-expense-txt)!important}.insight-pill{border-radius:99px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}.insight-pill.good{background:var(--chip-surplus-bg);color:var(--chip-surplus-txt)}.insight-pill.bad{background:var(--chip-deficit-bg);color:var(--chip-deficit-txt)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;background:#000000a6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.light .modal-overlay{background:#0f172a73}.modal-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);width:100%;max-width:470px;box-shadow:var(--shadow-modal);padding:24px}.modal-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.modal-header h3{color:var(--txt-1);font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700}.modal-sub{color:var(--txt-3);margin-top:3px;font-size:12.5px}.modal-close{border-radius:var(--r-sm);background:var(--bg-input);border:1px solid var(--border);width:30px;height:30px;color:var(--txt-2);cursor:pointer;transition:all var(--ease);flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-close:hover{color:#fca5a5;background:#ef44441a;border-color:#ef444433}.modal-form{flex-direction:column;gap:14px;display:flex}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--txt-2);letter-spacing:.4px;text-transform:uppercase;font-size:12px;font-weight:600}.form-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--txt-1);width:100%;transition:all var(--ease);padding:9px 12px;font-size:13.5px}.form-input:focus{border-color:#3b82f673;outline:none;box-shadow:0 0 0 3px #3b82f614}.form-input::placeholder{color:var(--txt-3)}.form-input option{background:var(--bg-surface);color:var(--txt-1)}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.type-toggle{gap:5px;display:flex}.type-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--txt-2);cursor:pointer;text-align:center;flex:1;padding:9px;font-size:13px;font-weight:500}.active-income{background:var(--chip-income-bg);border-color:var(--chip-income-bdr);color:var(--chip-income-txt)}.active-expense{background:var(--chip-expense-bg);border-color:var(--chip-expense-bdr);color:var(--chip-expense-txt)}.modal-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:9px;margin-top:4px;padding-top:6px;display:flex}@media (width<=1200px){.summary-cards,.insight-cards{grid-template-columns:repeat(2,1fr)}.charts-grid,.charts-grid-2{grid-template-columns:1fr}}@media (width<=900px){:root{--sidebar-w:0px}.sidebar{width:268px;transform:translate(-268px);box-shadow:0 0 40px #0006}.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block}.main-content{margin-left:0}.hamburger{display:flex}.page-content{padding:14px}.insights-grid{grid-template-columns:1fr}.span-full{grid-column:auto}}@media (width<=640px){.summary-cards,.insight-cards{grid-template-columns:1fr 1fr;gap:10px}.card-value,.page-title{font-size:20px}.form-row{grid-template-columns:1fr}.hero-title{font-size:18px}.topbar-role-badge{display:none}}@media (width<=420px){.summary-cards,.insight-cards{grid-template-columns:1fr}.page-content{padding:10px}.topbar{padding:0 14px}}
