*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--surface: #111118;--surface2: #1a1a24;--border: rgba(255,255,255,.07);--accent: #00e5a0;--accent2: #7c6aff;--gold: #f5c842;--red: #ff4466;--green: #00e5a0;--text: #e8e8f0;--muted: #6b6b80;--font-main: "Outfit", sans-serif;--font-mono: "Space Mono", monospace}body.light{--bg: #f0f2f5;--surface: #ffffff;--surface2: #e8eaed;--border: rgba(0,0,0,.08);--accent: #00b87a;--accent2: #6c5ce7;--gold: #d4a017;--red: #e0264a;--green: #00b87a;--text: #1a1a2e;--muted: #8a8a9a}body.light:before{background-image:linear-gradient(rgba(0,184,122,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,184,122,.04) 1px,transparent 1px)}body.light .header{background:#f0f2f5eb}body.light .networth-bar{background:linear-gradient(135deg,#00b87a12,#6c5ce712);border-color:#00b87a40}body.light .pin-screen{background:var(--bg)}body.light .pin-key{background:var(--surface);border-color:var(--border);color:var(--text)}body.light .pin-key:hover:not(:disabled){background:var(--surface2)}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-main);font-size:14px;line-height:1.6;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,229,160,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,160,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}#root{position:relative;z-index:1}.header{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--border);background:#0a0a0fe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100}.logo{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--accent);letter-spacing:3px;display:flex;flex-direction:column;line-height:1.1}.logo span{font-size:9px;color:var(--muted);letter-spacing:4px;font-weight:400}.header-actions{display:flex;gap:8px;align-items:center}.main{max-width:1100px;margin:0 auto;padding:28px 20px 60px}.networth-bar{background:linear-gradient(135deg,#00e5a014,#7c6aff14);border:1px solid rgba(0,229,160,.2);border-radius:16px;padding:28px 32px;margin-bottom:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}.networth-main{display:flex;flex-direction:column;gap:4px}.networth-label{font-family:var(--font-mono);font-size:10px;letter-spacing:3px;color:var(--muted)}.networth-value{font-family:var(--font-mono);font-size:42px;font-weight:700;color:var(--accent);line-height:1}.networth-change{font-family:var(--font-mono);font-size:12px;margin-top:6px}.networth-breakdown{display:flex;gap:24px;flex-wrap:wrap}.nw-asset-type{display:flex;flex-direction:column;gap:2px}.nw-asset-label{font-size:10px;color:var(--muted);letter-spacing:2px;font-family:var(--font-mono)}.nw-asset-val{font-family:var(--font-mono);font-size:16px;font-weight:700;color:var(--text)}.view-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:4px}.tab{flex:1;text-align:center;padding:10px 16px;border-radius:9px;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:1.5px;color:var(--muted);transition:all .2s}.tab:hover{color:var(--text);background:var(--surface2)}.tab.active{background:var(--accent);color:#000;font-weight:700}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-family:var(--font-mono);font-size:11px;letter-spacing:3px;color:var(--muted)}.assets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-bottom:32px}.asset-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:10px;transition:border-color .2s;position:relative;overflow:hidden}.asset-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px}.asset-card.crypto:before{background:linear-gradient(90deg,#f7931a,#ffcd3c)}.asset-card.bank:before{background:linear-gradient(90deg,var(--accent2),#a78bfa)}.asset-card.cash:before{background:linear-gradient(90deg,var(--accent),#00b8ff)}.asset-card:hover{border-color:#ffffff26}.asset-top{display:flex;align-items:center;justify-content:space-between}.asset-icon-name{display:flex;align-items:center;gap:10px}.asset-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;background:var(--surface2)}.asset-name{font-weight:600;font-size:14px;color:var(--text)}.asset-type-label{font-size:10px;color:var(--muted);font-family:var(--font-mono);letter-spacing:1px}.asset-actions{display:flex;gap:6px;opacity:0;transition:opacity .2s}.asset-card:hover .asset-actions{opacity:1}.asset-balance{font-family:var(--font-mono);font-size:24px;font-weight:700;color:var(--text)}.asset-updated{font-size:10px;color:var(--muted);font-family:var(--font-mono)}.add-asset-card{background:transparent;border:1px dashed rgba(255,255,255,.1);border-radius:14px;padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s;min-height:130px;color:var(--muted)}.add-asset-card:hover{border-color:var(--accent);color:var(--accent);background:#00e5a00a}.add-asset-card .plus{font-size:28px;line-height:1}.add-asset-card span{font-family:var(--font-mono);font-size:10px;letter-spacing:2px}.monthly-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.month-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:14px;transition:border-color .2s}.month-card:hover{border-color:#ffffff26}.month-card-header{display:flex;align-items:center;justify-content:space-between}.month-label{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--accent);letter-spacing:1px}.month-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px}.month-stat{display:flex;flex-direction:column;gap:2px}.month-stat-label{font-size:9px;color:var(--muted);font-family:var(--font-mono);letter-spacing:2px}.month-stat-val{font-family:var(--font-mono);font-size:16px;font-weight:700}.month-categories{display:flex;flex-direction:column;gap:6px}.cat-row{display:flex;align-items:center;gap:8px;font-size:12px}.cat-row-icon{width:18px;text-align:center;font-size:13px}.cat-row-label{flex:1;color:var(--muted)}.cat-row-bar{width:60px;height:4px;background:var(--surface2);border-radius:2px;overflow:hidden}.cat-row-fill{height:100%;border-radius:2px;background:var(--accent2)}.cat-row-val{font-family:var(--font-mono);font-size:11px;width:60px;text-align:right}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}@media (max-width: 640px){.header{flex-direction:column;align-items:flex-start;gap:12px;padding:14px 16px}.header-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px;width:100%}.header-actions .btn{width:100%;text-align:center;font-size:10px;padding:8px 6px}.header-actions .btn:last-child{grid-column:1 / -1}.theme-toggle-wrap{position:fixed;top:14px;right:16px;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:4px 8px}.main{padding:16px 12px 80px}.networth-bar{flex-direction:column;align-items:flex-start;padding:20px 18px;gap:16px}.networth-value{font-size:32px}.networth-breakdown{gap:16px}.tab{padding:9px 4px;font-size:9px;letter-spacing:.5px}.assets-grid{grid-template-columns:1fr}.asset-actions{opacity:1}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.section-header>div{flex-wrap:wrap;width:100%}.section-header .btn{flex:1;min-width:0;text-align:center;font-size:9px;padding:7px 8px}.monthly-grid,.overview-grid{grid-template-columns:1fr}.overlay{padding:12px;align-items:flex-end}.modal{border-radius:18px 18px 12px 12px;padding:20px 16px;max-height:92vh}.form-grid{grid-template-columns:1fr}.field.full{grid-column:1}.cat-input-field{width:90px}.nw-asset-val,.month-stat-val{font-size:14px}.asset-balance{font-size:20px}}.overview-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px}.overview-card-title{font-family:var(--font-mono);font-size:10px;letter-spacing:3px;color:var(--muted);margin-bottom:16px}.chart-wrap{display:flex;align-items:flex-end;gap:6px;height:120px;padding-top:8px}.chart-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}.chart-bar{width:100%;border-radius:4px 4px 0 0;background:linear-gradient(180deg,var(--accent),rgba(0,229,160,.4));transition:height .5s ease;min-height:4px;cursor:pointer;position:relative}.chart-bar:hover{filter:brightness(1.2)}.chart-bar-label{font-family:var(--font-mono);font-size:8px;color:var(--muted);text-align:center;white-space:nowrap}.cashflow-rows{display:flex;flex-direction:column;gap:10px}.cf-row{display:flex;flex-direction:column;gap:4px}.cf-row-header{display:flex;justify-content:space-between;align-items:center}.cf-row-label{font-size:11px;color:var(--muted);font-family:var(--font-mono);letter-spacing:1px}.cf-row-val{font-family:var(--font-mono);font-size:12px;font-weight:700}.cf-bar{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}.cf-fill{height:100%;border-radius:3px}.top-expenses{display:flex;flex-direction:column;gap:8px}.te-row{display:flex;align-items:center;gap:10px}.te-icon{font-size:16px;width:24px;text-align:center}.te-label{flex:1;font-size:12px;color:var(--text)}.te-val{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--text)}.te-pct{font-family:var(--font-mono);font-size:10px;color:var(--muted);width:36px;text-align:right}.btn{padding:8px 16px;border:none;border-radius:8px;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:1px;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-accent{background:var(--accent);color:#000;font-weight:700}.btn-accent:hover{filter:brightness(1.1)}.btn-accent2{background:var(--accent2);color:#fff;font-weight:700}.btn-accent2:hover{filter:brightness(1.15)}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text);border-color:#fff3}.btn-danger{background:#ff446626;color:var(--red);border:1px solid rgba(255,68,102,.3)}.btn-danger:hover{background:#ff446640}.btn-sm{padding:5px 10px;font-size:10px}.btn-block{width:100%;padding:14px;text-align:center}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:var(--surface);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:28px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-family:var(--font-mono);font-size:13px;letter-spacing:2px;color:var(--accent);font-weight:700}.modal-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;padding:4px;transition:color .15s}.modal-close:hover{color:var(--text)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field.full{grid-column:1 / -1}.field label{font-family:var(--font-mono);font-size:9px;letter-spacing:2px;color:var(--muted);text-transform:uppercase}.field input,.field select,.field textarea{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-main);font-size:14px;padding:10px 12px;outline:none;transition:border-color .15s;width:100%}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}.field select option{background:var(--surface2)}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:6px 14px;border-radius:20px;border:1px solid var(--border);cursor:pointer;font-size:12px;color:var(--muted);transition:all .15s;-webkit-user-select:none;user-select:none}.chip:hover{border-color:#fff3;color:var(--text)}.chip.active{border-color:var(--accent);color:var(--accent);background:#00e5a01a}.cat-inputs{display:flex;flex-direction:column;gap:10px;margin-top:4px}.cat-input-row{display:flex;align-items:center;gap:10px}.cat-input-icon{font-size:16px;width:24px;text-align:center}.cat-input-label{flex:1;font-size:12px;color:var(--text)}.cat-input-field{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-mono);font-size:13px;padding:7px 10px;outline:none;width:110px;text-align:right;transition:border-color .15s}.cat-input-field:focus{border-color:var(--accent)}.cat-manage-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.cat-manage-icon-input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:16px;padding:7px 10px;width:52px;text-align:center;outline:none}.cat-manage-label-input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-main);font-size:13px;padding:7px 12px;flex:1;outline:none}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-family:var(--font-mono);font-size:13px;letter-spacing:4px;color:var(--accent)}.empty-state{text-align:center;padding:60px 20px;color:var(--muted);font-family:var(--font-mono);font-size:12px;letter-spacing:2px}.pos{color:var(--green)}.neg{color:var(--red)}.divider{height:1px;background:var(--border);margin:20px 0}.delete-confirm{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.theme-toggle{width:40px;height:22px;border-radius:11px;border:1px solid var(--border);background:var(--surface2);cursor:pointer;position:relative;transition:background .2s,border-color .2s;flex-shrink:0}.theme-toggle:after{content:"";position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:var(--muted);transition:transform .2s,background .2s}body.light .theme-toggle{background:#00b87a26;border-color:var(--accent)}body.light .theme-toggle:after{background:var(--accent);transform:translate(18px)}.theme-toggle-wrap{display:flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:1px}.pin-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:999;padding:20px}.pin-modal{display:flex;flex-direction:column;align-items:center;gap:0;width:100%;max-width:320px}.pin-logo{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--accent);letter-spacing:4px;margin-bottom:4px}.pin-subtitle{font-family:var(--font-mono);font-size:9px;color:var(--muted);letter-spacing:4px;margin-bottom:36px}.pin-label{font-family:var(--font-mono);font-size:10px;letter-spacing:3px;color:var(--muted);margin-bottom:20px}.pin-dots{display:flex;gap:16px;margin-bottom:8px}.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--muted);background:transparent;transition:all .15s}.pin-dot.filled{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px #00e5a080}.pin-error{font-family:var(--font-mono);font-size:10px;color:var(--red);letter-spacing:2px;margin-top:8px;height:16px}.pin-pad{display:grid;grid-template-columns:repeat(3,72px);gap:12px;margin-top:28px}.pin-key{width:72px;height:72px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:var(--font-mono);font-size:20px;font-weight:700;cursor:pointer;transition:all .12s;display:flex;align-items:center;justify-content:center}.pin-key:hover:not(:disabled){background:var(--surface2);border-color:var(--accent);color:var(--accent)}.pin-key:active:not(:disabled){transform:scale(.93);background:#00e5a01a}.pin-key-empty{background:transparent;border-color:transparent;cursor:default}.pin-key-del{font-size:16px;color:var(--muted)}@keyframes pin-shake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(10px)}60%{transform:translate(-8px)}80%{transform:translate(8px)}}.pin-shake{animation:pin-shake .4s ease}.pin-fab-wrap{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.pin-fab{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--surface);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:0 4px 16px #0006}.pin-fab:hover{border-color:var(--accent);background:var(--surface2)}.pin-menu{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 24px #0006;min-width:160px}.pin-menu button{background:none;border:none;color:var(--text);font-family:var(--font-mono);font-size:11px;letter-spacing:1px;padding:12px 16px;cursor:pointer;text-align:left;transition:background .15s;border-bottom:1px solid var(--border)}.pin-menu button:last-child{border-bottom:none}.pin-menu button:hover{background:var(--surface2);color:var(--accent)}
