*,:before,:after{box-sizing:border-box}body{margin:0}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d1117;--surface:#161b22;--surface-2:#1c2128;--border:#21262d;--text:#e6edf3;--text-muted:#8b949e;--accent:#58a6ff;--danger:#f85149;--accent-crypto:#f7931a;--accent-stock-us:#3fb950;--accent-stock-etf:#a371f7;--accent-stock-id:#58a6ff;--accent-stock-id-growth:#f78166;--accent-stock-hk:#ffa657;--accent-metal:gold;--accent-forex:#79c0ff}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px}.app{flex-direction:column;min-height:100vh;display:flex}.navbar{border-bottom:1px solid var(--border);background:var(--surface);z-index:10;justify-content:space-between;align-items:center;height:56px;padding:0 28px;display:flex;position:sticky;top:0}.logo{color:var(--accent);letter-spacing:.5px;font-size:16px;font-weight:700}.navbar-right{align-items:center;gap:12px;display:flex}.search-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;width:200px;padding:7px 14px;font-size:13px;transition:border-color .15s}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--accent)}.btn-primary{background:var(--accent);color:var(--bg);cursor:pointer;border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:600;transition:opacity .15s}.btn-primary:hover{opacity:.85}.main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:28px}.state-text{color:var(--text-muted);text-align:center;margin-top:80px;font-size:15px}.state-text.error{color:var(--danger)}.state-text.muted{color:var(--text-muted)}.section-grid{flex-direction:column;gap:32px;display:flex}.category-section{flex-direction:column;gap:14px;display:flex}.cat-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-bottom:10px;display:flex}.cat-title-row{align-items:center;gap:8px;display:flex}.cat-name{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-size:11px;font-weight:700}.cat-count{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border);font-variant-numeric:tabular-nums;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600}.cat-sort-row{flex-wrap:wrap;gap:6px;display:flex}.sort-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:8px;padding:5px 12px;font-family:inherit;font-size:11px;font-weight:500;transition:all .15s}.sort-btn:hover{border-color:var(--accent);color:var(--accent)}.sort-btn.active{background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:600}.sort-btn.sort-clear{background:var(--surface-2);min-width:28px;padding:5px 8px}.sort-btn.sort-clear:hover{border-color:var(--danger);color:var(--danger)}.sort-btn.sort-clear.active{background:var(--danger);border-color:var(--danger);color:var(--text)}.card-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.asset-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-left-width:3px;border-radius:12px;flex-direction:column;gap:8px;padding:14px 16px;transition:all .18s;display:flex;position:relative;overflow:hidden}.asset-card:hover{background:var(--surface-2);border-color:var(--card-accent,var(--border));transform:translateY(-1px);box-shadow:0 6px 24px #00000059}.asset-card:active{transform:translateY(0)}.accent-crypto{--card-accent:var(--accent-crypto);border-left-color:var(--accent-crypto)}.accent-stock-us{--card-accent:var(--accent-stock-us);border-left-color:var(--accent-stock-us)}.accent-stock-etf{--card-accent:var(--accent-stock-etf);border-left-color:var(--accent-stock-etf)}.accent-stock-id{--card-accent:var(--accent-stock-id);border-left-color:var(--accent-stock-id)}.accent-stock-id-growth{--card-accent:var(--accent-stock-id-growth);border-left-color:var(--accent-stock-id-growth)}.accent-stock-hk{--card-accent:var(--accent-stock-hk);border-left-color:var(--accent-stock-hk)}.accent-metal{--card-accent:var(--accent-metal);border-left-color:var(--accent-metal)}.accent-forex{--card-accent:var(--accent-forex);border-left-color:var(--accent-forex)}.card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.card-symbol-col{flex-direction:column;gap:2px;min-width:0;display:flex}.card-symbol{letter-spacing:.5px;white-space:nowrap;text-overflow:ellipsis;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:16px;font-weight:700;line-height:1;overflow:hidden}.card-exchange{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-size:10px;font-weight:600}.card-idr{color:#c084fc;font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:500}.card-bottom{justify-content:space-between;align-items:flex-end;gap:8px;display:flex}.card-price{font-variant-numeric:tabular-nums;letter-spacing:.2px;font-size:15px;font-weight:600;line-height:1}.card-meta{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.card-change{font-variant-numeric:tabular-nums;font-size:14px;font-weight:700;line-height:1}.positive{color:#3fb950}.negative{color:#f85149}.card-volume{color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;letter-spacing:.3px;font-size:12px;font-weight:500}.card-remove{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:5px;padding:3px 6px;font-family:inherit;font-size:11px;line-height:1;transition:all .15s;position:absolute;top:10px;right:10px}.asset-card:hover .card-remove{opacity:1}.card-remove:hover{color:var(--danger)}.chart-overlay{z-index:100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.chart-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:92vw;max-width:960px;overflow:hidden}.chart-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;font-size:14px;font-weight:600;display:flex}.chart-header button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-family:inherit;font-size:16px;transition:color .15s}.chart-header button:hover{color:var(--text)}.tradingview-widget-container{height:520px}.add-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:480px;padding-bottom:20px;overflow:hidden}.add-form{flex-direction:column;gap:10px;padding:18px;display:flex}.add-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;width:100%;padding:11px 14px;font-family:SF Mono,Fira Code,monospace;font-size:14px;transition:border-color .15s}.add-input:focus{border-color:var(--accent)}.add-error{color:var(--danger);font-size:12px}.add-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.btn-cancel{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;transition:border-color .15s}.btn-cancel:hover{border-color:var(--text-muted);color:var(--text)}.btn-add{background:var(--accent);color:var(--bg);cursor:pointer;border:none;border-radius:8px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:opacity .15s}.btn-add:disabled{opacity:.5;cursor:not-allowed}.btn-add:not(:disabled):hover{opacity:.85}.add-hint{color:var(--text-muted);padding:0 18px;font-size:12px;line-height:1.6}.add-hint code{background:var(--bg);color:var(--accent);border-radius:3px;padding:1px 5px;font-family:SF Mono,Fira Code,monospace}@media (width<=768px){.app{-webkit-tap-highlight-color:transparent}.navbar{height:52px;padding:0 14px}.logo{font-size:14px}.search-input{width:130px;padding:6px 10px;font-size:12px}.btn-primary{padding:6px 12px;font-size:12px}.main{padding:16px 12px}.section-grid{gap:24px}.cat-header{flex-direction:column;align-items:flex-start;padding-bottom:8px}.cat-sort-row{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:6px;width:100%;overflow-x:auto}.cat-sort-row::-webkit-scrollbar{display:none}.sort-btn{flex-shrink:0;padding:6px 10px;font-size:11px}.card-grid{grid-template-columns:1fr;gap:8px}.asset-card{border-left-width:3px;border-radius:10px;padding:12px 14px}.card-symbol{font-size:15px}.card-price{font-size:14px}.card-change{font-size:13px}.card-idr{font-size:11px}.card-remove{opacity:1;font-size:12px;top:8px;right:8px}.state-text{margin-top:40px;font-size:13px}.add-modal{border-radius:0;flex-direction:column;width:100vw;height:100vh;padding-bottom:0;display:flex}.add-form{flex:1}.add-input{padding:14px;font-size:16px}.add-actions{padding:0 18px 18px}.add-hint{padding:0 18px 14px}.chart-modal{border-radius:0;width:100vw;max-width:none;height:100vh}.chart-overlay{align-items:flex-end}.tradingview-widget-container{height:calc(100vh - 60px)}}
