@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Space+Mono:wght@400;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{min-height:100dvh;font-size:15px}body{color:#f1f5f9;background:#0a0e17;min-height:100dvh;font-family:DM Sans,sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#111827}::-webkit-scrollbar-thumb{background:#1e2a42;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#475569}.mono{font-family:Space Mono,monospace}.fade-in{animation:.35s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.card{background:#111827;border:1px solid #1e2a42;border-radius:16px;padding:20px;transition:border-color .25s}.card:hover{border-color:#0e7490}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:8px;min-height:44px;padding:10px 20px;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{color:#0a0e17;background:#22d3ee}.btn-primary:hover{background:#67e8f9;transform:translateY(-1px);box-shadow:0 4px 20px #22d3ee26}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{color:#94a3b8;background:0 0;border:1px solid #1e2a42}.btn-ghost:hover{color:#22d3ee;border-color:#22d3ee}.btn-ghost.active{color:#22d3ee;background:#22d3ee26;border-color:#22d3ee}.btn-sm{border-radius:8px;min-height:36px;padding:6px 14px;font-size:.8rem}input,select,textarea{color:#f1f5f9;background:#1a2236;border:1px solid #1e2a42;border-radius:10px;width:100%;min-height:44px;padding:10px 14px;font-family:DM Sans,sans-serif;font-size:.9rem;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:#22d3ee;outline:none}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}label{color:#94a3b8;margin-bottom:4px;font-size:.8rem;font-weight:500;display:block}.table-wrap{-webkit-overflow-scrolling:touch;border:1px solid #1e2a42;border-radius:12px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.85rem}th{color:#475569;text-transform:uppercase;letter-spacing:.05em;text-align:left;white-space:nowrap;z-index:1;background:#1a2236;padding:12px 14px;font-size:.7rem;font-weight:600;position:sticky;top:0}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{color:#22d3ee}td{white-space:nowrap;border-top:1px solid #1e2a42;padding:10px 14px}tr:hover td{background:#22d3ee0d}.badge{letter-spacing:.03em;border-radius:20px;padding:3px 10px;font-size:.7rem;font-weight:600;display:inline-block}.sidebar{z-index:50;background:#111827;border-right:1px solid #1e2a42;flex-direction:column;width:220px;padding:24px 16px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-btn{color:#94a3b8;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-family:DM Sans;font-size:.9rem;font-weight:400;transition:all .2s;display:flex}.sidebar-btn:hover{color:#f1f5f9;background:#22d3ee0d}.sidebar-btn.active{color:#22d3ee;background:#22d3ee26;font-weight:600}.nav-bottom{padding:6px 0 calc(6px + env(safe-area-inset-bottom,8px));z-index:100;-webkit-backdrop-filter:blur(12px);background:#111827fa;border-top:1px solid #1e2a42;display:none;position:fixed;bottom:0;left:0;right:0}.nav-bottom-inner{justify-content:space-around;display:flex}.nav-item{cursor:pointer;color:#475569;background:0 0;border:none;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:56px;min-height:44px;padding:8px 12px;font-family:DM Sans;font-size:.65rem;transition:color .2s;display:flex}.nav-item.active{color:#22d3ee}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background:#111827;border:1px solid #1e2a42;border-radius:16px;width:100%;max-width:560px;max-height:90dvh;padding:24px;overflow:auto}.skeleton{background:linear-gradient(90deg,#1a2236 25%,#1e2a42 50%,#1a2236 75%) 0 0/200% 100%;border-radius:8px;animation:1.5s infinite shimmer}.toast-success{color:#f1f5f9!important;background:#111827!important;border:1px solid #1e2a42!important}@media (width<=768px){.hide-mobile{display:none!important}html{font-size:14px}.nav-bottom{display:block}.sidebar{display:none!important}.main-content{margin-left:0!important;padding:16px 16px 120px!important}.card{border-radius:12px;padding:14px}.stat-grid{grid-template-columns:1fr 1fr!important}.chart-grid,.form-grid{grid-template-columns:1fr!important}.header-row{flex-direction:row;align-items:center!important;gap:12px!important}.header-btn-label{display:none}.header-action-btn{justify-content:center;min-width:44px;border-radius:12px!important;gap:0!important;padding:10px!important}.expense-table-container{max-height:60dvh}.modal-content{border-radius:14px;max-height:95dvh;padding:16px}.modal-overlay{align-items:flex-end;padding:8px}.category-name{width:120px!important;font-size:.75rem!important}.category-amount{width:70px!important;font-size:.75rem!important}.category-pct{width:36px!important}.month-tabs{-webkit-overflow-scrolling:touch;padding-bottom:4px;overflow-x:auto;flex-wrap:nowrap!important}.month-tabs::-webkit-scrollbar{display:none}}@media (width<=480px){html{font-size:13px}.stat-grid{grid-template-columns:1fr!important}.filter-row{flex-direction:column}.filter-row>div{flex:100%!important}.modal-content{padding:14px}.main-content{padding:12px 12px 120px!important}th{padding:8px 10px;font-size:.65rem}td{padding:8px 10px;font-size:.8rem}.badge{padding:2px 8px;font-size:.65rem}.btn{padding:10px 14px;font-size:.85rem}.btn-sm{padding:6px 10px;font-size:.75rem}}
