*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--accent: #0ea5a0;--accent-soft: #e0f5f4;--accent-dark: #0b8a86;--bg: #f2f1ed;--surface: #ffffff;--surface2: #f8f7f4;--border: #e8e6e0;--border2: #d2cfc7;--text: #181816;--text2: #5c5955;--text3: #908d86;--green: #1a7230;--green-bg: #e6f7eb;--red: #b83223;--red-bg: #fdecea;--blue: #1a6bbd;--blue-bg: #e8f1fb;--amber: #92620a;--amber-bg: #fdf5e3;--purple: #5b48c4;--purple-bg: #eeedfb;--radius: 12px;--radius-lg: 16px;--radius-xl: 22px;--shadow: 0 1px 4px rgba(0,0,0,.07), 0 2px 8px rgba(0,0,0,.04);--shadow-md: 0 4px 20px rgba(0,0,0,.11), 0 1px 4px rgba(0,0,0,.06)}[data-theme=dark]{--accent: #14b8b3;--accent-soft: #0d3333;--accent-dark: #0ea5a0;--bg: #0f0f0e;--surface: #1a1a18;--surface2: #222220;--border: #2c2c2a;--border2: #3c3c38;--text: #f0ede8;--text2: #9e9b94;--text3: #636058;--green: #4ead3e;--green-bg: #162716;--red: #e05c52;--red-bg: #2c1412;--blue: #4d96e8;--blue-bg: #0e1e30;--amber: #dda030;--amber-bg: #271d08;--purple: #8b80e8;--purple-bg: #181430}html,body,#root{height:100%;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;font-size:15px;line-height:1.4}.screen{height:calc(100vh - 60px);display:flex;flex-direction:column;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.topbar-logo{font-size:20px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.topbar-right{display:flex;align-items:center;gap:8px}.topbar-icon-btn{width:38px;height:38px;border-radius:50%;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:17px;transition:background .15s}.topbar-icon-btn:hover{background:var(--border)}.dashboard-grid{display:grid;grid-template-columns:380px 1fr;flex:1;min-height:0;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:20px 16px;display:flex;flex-direction:column;gap:22px}.main-panel{overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:18px;background:var(--bg)}.topbar-nav{display:flex;align-items:center;gap:4px}.bottom-nav{display:none}@media (max-width: 720px){.topbar{height:52px;padding:0 14px}.topbar-logo{font-size:17px}.topbar-nav{display:none!important}.topbar-icon-btn{width:34px;height:34px;font-size:15px}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--surface);border-top:1px solid var(--border);z-index:50;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:transparent;border:none;color:var(--text3);cursor:pointer;transition:color .15s;min-height:44px}.bottom-nav-btn.active{color:var(--accent)}.bottom-nav-icon{font-size:18px;line-height:1}.bottom-nav-label{font-size:10px;font-weight:600;letter-spacing:.01em}.fab{bottom:80px!important;right:16px!important;width:52px!important;height:52px!important;font-size:24px;z-index:200!important}.dashboard-grid{grid-template-columns:1fr;height:auto;overflow:visible}.sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:220px;overflow-y:auto;padding:12px;gap:10px}.card-accent{padding:12px 14px;border-radius:var(--radius)}.nw-label{font-size:10px}.nw-amount{font-size:20px;margin:2px 0 8px;letter-spacing:-.5px}.nw-row{gap:6px}.nw-col{padding:6px 8px;border-radius:8px}.nw-col-label{font-size:10px}.nw-col-val{font-size:13px}.nw-breakdown{display:none}.mini-card{padding:9px 10px}.mini-icon{width:30px;height:30px;font-size:14px;border-radius:8px}.mini-name{font-size:12px}.mini-sub{font-size:10px}.main-panel{padding:12px 12px calc(126px + env(safe-area-inset-bottom));gap:12px}.section-label{font-size:10px}.card{padding:14px}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow)}.card-accent{background:linear-gradient(135deg,var(--accent) 0%,var(--purple) 100%);border:none;border-radius:var(--radius-lg);padding:22px;color:#fff;box-shadow:0 4px 20px #0ea5a04d}.nw-label{font-size:12px;font-weight:600;opacity:.75;text-transform:uppercase;letter-spacing:.07em}.nw-amount{font-size:34px;font-weight:800;letter-spacing:-1.5px;margin:6px 0 14px;line-height:1.1}.nw-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.nw-col{background:#ffffff26;border-radius:10px;padding:10px 12px}.nw-col-label{font-size:11px;opacity:.72;margin-bottom:3px;font-weight:500}.nw-col-val{font-size:15px;font-weight:700}.nw-breakdown{margin-top:12px;display:flex;flex-direction:column;gap:4px}.nw-line{display:flex;justify-content:space-between;font-size:12px;opacity:.82}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.section-label{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em}.section-add-btn{width:26px;height:26px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-size:17px;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1}.section-add-btn:hover{background:var(--accent);color:#fff}.mini-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;align-items:center;gap:12px;transition:border-color .15s}.mini-card:hover{border-color:var(--border2)}.mini-card:hover .item-actions{opacity:1}.mini-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.mini-info{flex:1;min-width:0}.mini-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-sub{font-size:12px;color:var(--text3);margin-top:2px}.mini-amount{font-size:14px;font-weight:700;flex-shrink:0}.list-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}.list-item{padding:14px 16px;display:flex;align-items:center;gap:12px;transition:background .1s}.list-item:hover{background:var(--surface2)}.list-item:hover .item-actions{opacity:1}.list-item+.list-item{border-top:1px solid var(--border)}.item-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}.item-info{flex:1;min-width:0}.item-name{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-sub{font-size:12px;color:var(--text3);margin-top:2px}.item-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.item-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.action-btn{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;background:var(--bg);color:var(--text2);border:1px solid var(--border);transition:all .1s}.action-btn:hover{background:var(--border2)}.action-btn.del:hover{background:var(--red-bg);color:var(--red);border-color:var(--red-bg)}.amount-pos{color:var(--green);font-weight:700;font-size:15px}.amount-neg{color:var(--red);font-weight:700;font-size:15px}.amount-neu{color:var(--text2);font-weight:600;font-size:15px}.bar-wrap{height:4px;background:var(--border);border-radius:2px;margin-top:6px;overflow:hidden}.bar-fill{height:100%;border-radius:2px;transition:width .4s}.progress-bar-wrap{height:4px;background:var(--border);border-radius:2px;margin-top:6px;overflow:hidden}.progress-bar{height:100%;border-radius:2px;transition:width .4s}.alert{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:3px 8px;border-radius:99px;background:var(--amber-bg);color:var(--amber);margin-top:3px}.alert-card{border-radius:var(--radius);padding:12px 14px;font-size:13px;border-left:3px solid var(--amber);background:var(--amber-bg)}.alert-card-title{font-weight:600;color:var(--amber);margin-bottom:5px}.alert-card-row{display:flex;justify-content:space-between;color:var(--amber)}.badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:99px}.badge-green{background:var(--green-bg);color:var(--green)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-amber{background:var(--amber-bg);color:var(--amber)}.badge-purple{background:var(--purple-bg);color:var(--purple)}.badge-accent{background:var(--accent-soft);color:var(--accent)}.badge-gray{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;color:var(--text2);font-weight:600}.field input,.field select{height:44px;border:1.5px solid var(--border2);border-radius:var(--radius);padding:0 14px;font-size:15px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.amount-input{height:62px!important;font-size:28px!important;font-weight:700!important;letter-spacing:-.5px}.btn{height:44px;border-radius:var(--radius);font-size:15px;font-weight:600;padding:0 20px;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:7px}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#fff;width:100%;box-shadow:0 2px 10px #0ea5a059}.btn-primary:hover{background:var(--accent-dark);box-shadow:0 4px 14px #0ea5a073}.btn-ghost{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--border);color:var(--text)}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-bg)}.btn-danger:hover{opacity:.85}.fab{position:fixed;bottom:28px;right:28px;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--purple));color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0ea5a073;z-index:20;transition:transform .2s,box-shadow .2s}.fab:hover{transform:scale(1.08);box-shadow:0 6px 28px #0ea5a08c}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:30;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);padding:20px}.modal{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:580px;max-height:92vh;overflow-y:auto;padding-bottom:28px;box-shadow:var(--shadow-md)}.modal-handle{width:40px;height:4px;background:var(--border2);border-radius:2px;margin:16px auto 18px}.modal-header{padding:0 24px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);margin-bottom:20px}.modal-title{font-size:18px;font-weight:700}.modal-body{padding:0 24px 4px;display:flex;flex-direction:column;gap:16px}.close-btn{width:34px;height:34px;border-radius:50%;background:var(--surface2);color:var(--text2);font-size:20px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);transition:background .15s}.close-btn:hover{background:var(--border);color:var(--text)}.type-scroll{display:flex;flex-wrap:wrap;gap:6px}.type-chip{padding:6px 14px;border-radius:99px;border:1.5px solid var(--border2);font-size:13px;font-weight:500;color:var(--text2);background:var(--surface);cursor:pointer;transition:all .13s;white-space:nowrap}.type-chip.active{border-width:2px;font-weight:600}.type-chip:hover{border-color:var(--accent);color:var(--accent)}.group-label{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;padding:10px 0 5px}.private-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface2);border-radius:var(--radius);cursor:pointer;border:1px solid var(--border)}.toggle{width:44px;height:24px;background:var(--border2);border-radius:99px;position:relative;transition:background .2s;flex-shrink:0}.toggle.on{background:var(--accent)}.toggle-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 4px #00000040}.toggle.on .toggle-knob{transform:translate(20px)}.info-box{font-size:13px;color:var(--text2);background:var(--accent-soft);padding:12px 14px;border-radius:var(--radius);line-height:1.55;border-left:3px solid var(--accent)}.info-box strong{color:var(--accent-dark)}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px 36px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:18px;box-shadow:var(--shadow-md)}.auth-logo{font-size:28px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-sub{font-size:15px;color:var(--text2)}.auth-switch{font-size:14px;color:var(--text2);text-align:center}.auth-switch button{color:var(--accent);font-size:14px;font-weight:600}.empty{text-align:center;padding:20px;color:var(--text3);font-size:13px}.spinner{width:34px;height:34px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:48px auto}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:96px;left:50%;transform:translate(-50%);background:var(--text);color:var(--bg);padding:11px 22px;border-radius:99px;font-size:14px;font-weight:600;z-index:50;white-space:nowrap;animation:toast-in .2s ease;box-shadow:var(--shadow-md)}.toast.error{background:var(--red);color:#fff}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}}@keyframes slide-up{0%{opacity:0;transform:translateY(40px)}}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-label{font-size:15px;font-weight:500}.settings-sub{font-size:13px;color:var(--text3);margin-top:3px}
