@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-card: #1e2130;--bg-hover: #252839;--border-color: #2a2d3a;--text-primary: #e4e6ef;--text-secondary: #8b8fa3;--text-muted: #5e6278;--accent-blue: #3b82f6;--accent-blue-hover: #2563eb;--accent-green: #22c55e;--accent-red: #ef4444;--accent-orange: #f59e0b;--accent-purple: #a855f7;--accent-cyan: #06b6d4;--sidebar-width: 260px;--sidebar-collapsed: 0px;--topbar-height: 64px;--radius: 12px;--radius-sm: 8px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.layout-wrapper{display:flex;min-height:100vh}.layout-main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease}.layout-content{flex:1;padding:28px;overflow-y:auto}.sidebar{width:var(--sidebar-width);height:100vh;background-color:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:200;transition:transform .3s ease;overflow:hidden}.sidebar-overlay{display:none}.topbar{height:var(--topbar-height);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50;gap:12px}.topbar-hamburger{display:none;width:40px;height:40px;border-radius:var(--radius-sm);align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.topbar-search{display:flex;align-items:center;gap:10px;background-color:var(--bg-card);border-radius:var(--radius-sm);padding:8px 16px;border:1px solid var(--border-color);width:380px;max-width:100%;flex-shrink:1}.topbar-profile-info{display:flex;flex-direction:column}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.charts-row{display:grid;gap:16px}.charts-row-top{grid-template-columns:2fr 1fr}.charts-row-bottom{grid-template-columns:1fr 1fr 1fr}.summary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.controls-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.page-header-actions{display:flex;gap:10px;flex-shrink:0}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.analytics-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.budgets-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.settings-grid{display:grid;grid-template-columns:240px 1fr;gap:24px}@media(max-width:768px){.layout-main{margin-left:0}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:150;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.topbar{padding:0 16px}.topbar-hamburger{display:flex}.topbar-search{width:auto;flex:1;min-width:0}.topbar-profile-info{display:none}.layout-content{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-row-top,.charts-row-bottom,.summary-row{grid-template-columns:1fr}.controls-row{flex-direction:column;align-items:stretch}.page-header{flex-direction:column}.page-header-actions{width:100%}.page-header-actions button{flex:1}.analytics-grid-2,.budgets-grid,.settings-grid{grid-template-columns:1fr}}@media(min-width:769px)and (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-row-top{grid-template-columns:1fr}.charts-row-bottom{grid-template-columns:1fr 1fr}.budgets-grid{grid-template-columns:repeat(2,1fr)}.settings-grid{grid-template-columns:200px 1fr}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.page-header-actions{flex-direction:column}}@media(max-width:768px){.sidebar .sidebar-close-btn{display:flex!important}}
