*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f14;--surface:#1a1a24;--surface2:#22222e;--border:#2e2e3e;--text-primary:#f0f0f5;--text-secondary:#9090a8;--text-muted:#5a5a72;--green:#00c87f;--green-bg:#00c87f14;--red:#ff4d6a;--red-bg:#ff4d6a14;--accent:#6c8eff;--accent-hover:#8aa4ff;--alert-bg:orange;--radius:16px;--radius-sm:10px;-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}html,body,#root{background:var(--bg);height:100%;color:var(--text-primary);overscroll-behavior:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input{color:inherit;font-family:inherit}.app{flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}.app-header{background:var(--bg);z-index:50;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:10px;display:flex}.app-title{color:var(--text-primary);letter-spacing:-.3px;font-size:20px;font-weight:700}.title-icon{font-size:18px}.refresh-time{color:var(--text-muted);align-items:center;gap:4px;font-size:11px;display:flex}.header-right{align-items:center;gap:8px;display:flex}.notif-btn{background:var(--surface2);width:38px;height:38px;color:var(--alert-bg);border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.notif-btn:hover{background:var(--border)}.add-btn{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;transition:background .15s,transform .1s;display:flex;box-shadow:0 4px 14px #6c8eff59}.add-btn:active{transform:scale(.93)}.add-btn:hover{background:var(--accent-hover)}.error-bar{color:var(--red);text-align:center;background:#ff4d6a26;border-bottom:1px solid #ff4d6a4d;padding:6px 16px;font-size:12px}.main-content{flex:1;padding:14px 12px}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:80px 24px;display:flex}.empty-icon{font-size:52px}.empty-title{color:var(--text-primary);font-size:18px;font-weight:600}.empty-sub{color:var(--text-secondary);font-size:14px}.empty-add-btn{border-radius:var(--radius-sm);background:var(--accent);color:#fff;align-items:center;gap:6px;margin-top:8px;padding:12px 22px;font-size:15px;font-weight:600;transition:background .15s;display:flex}.empty-add-btn:hover{background:var(--accent-hover)}.tiles-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (width>=380px){.tiles-grid{gap:12px}}.stock-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:4px;padding:12px 12px 10px;transition:border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.stock-tile:before{content:"";border-radius:var(--radius) var(--radius) 0 0;height:2px;position:absolute;top:0;left:0;right:0}.tile-positive:before{background:var(--green)}.tile-negative:before{background:var(--red)}.tile-positive{border-color:#00c87f2e}.tile-negative{border-color:#ff4d6a2e}.tile-alert-fired{background:#ffa5000d;border-color:#ffa50066!important}.tile-header{justify-content:space-between;align-items:flex-start;gap:4px;display:flex}.tile-symbol-wrap{flex-direction:column;gap:3px;display:flex}.tile-symbol{color:var(--text-primary);letter-spacing:.3px;font-size:17px;font-weight:700}.tile-target-badge{color:var(--accent);background:#6c8eff26;border-radius:999px;align-items:center;gap:3px;padding:2px 6px;font-size:10px;font-weight:500;display:inline-flex}.badge-fired{color:var(--alert-bg);background:#ffa50033}.tile-remove-btn{width:26px;height:26px;color:var(--text-muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.tile-remove-btn:hover{color:var(--red);background:#ff4d6a26}.tile-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.tile-price-section{flex-direction:column;gap:2px;margin-top:4px;display:flex}.tile-price{color:var(--text-primary);letter-spacing:-.5px;font-size:20px;font-weight:700}.tile-change{align-items:center;gap:3px;font-size:12px;font-weight:500;display:flex}.change-positive{color:var(--green)}.change-negative{color:var(--red)}.tile-loading{align-items:center;height:42px;margin-top:4px;display:flex}.loading-dots:after{content:"ooo";color:var(--text-muted);letter-spacing:3px;font-size:20px;animation:1.2s infinite blink}@keyframes blink{0%,to{opacity:.3}50%{opacity:1}}.tile-footer{border-top:1px solid var(--border);margin-top:6px;padding-top:6px}.target-toggle-btn{color:var(--text-muted);align-items:center;gap:4px;padding:2px 0;font-size:11px;transition:color .15s;display:flex}.target-toggle-btn:hover{color:var(--accent)}.target-input-wrap{align-items:center;gap:4px;display:flex}.target-input-dollar{color:var(--text-secondary);font-size:13px}.target-input{background:var(--surface2);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;outline:none;flex:1;width:0;min-width:0;padding:5px 8px;font-size:13px}.target-input:focus{border-color:var(--accent)}.target-input::-webkit-inner-spin-button{-webkit-appearance:none}.target-input::-webkit-outer-spin-button{-webkit-appearance:none}.target-set-btn{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;padding:5px 9px;font-size:12px;font-weight:600;transition:background .15s}.target-set-btn:hover{background:var(--accent-hover)}.target-clear-btn{width:24px;height:24px;color:var(--text-muted);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.target-clear-btn:hover{color:var(--red);background:#ff4d6a26}.alert-banner-container{z-index:60;flex-direction:column;gap:4px;display:flex;position:sticky;top:65px}.alert-banner{background:#ffa50026;border-bottom:1px solid #ffa50066;align-items:center;gap:10px;padding:12px 16px;animation:.25s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.alert-icon{color:var(--alert-bg);flex-shrink:0}.alert-content{flex:1;min-width:0}.alert-symbol{color:var(--alert-bg);margin-right:6px;font-size:14px;font-weight:700}.alert-message{color:var(--text-secondary);font-size:12px;line-height:1.4}.alert-dismiss-btn{width:28px;height:28px;color:var(--text-muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.alert-dismiss-btn:hover{background:#ffffff1a}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:var(--surface);border-top:1px solid var(--border);border-radius:24px 24px 0 0;flex-direction:column;width:100%;max-width:480px;max-height:88dvh;margin:0 auto;animation:.25s cubic-bezier(.34,1.56,.64,1) slideUp;display:flex}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-handle{background:var(--border);border-radius:2px;width:40px;height:4px;margin:12px auto 0}.modal-header{justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.modal-title{font-size:18px;font-weight:700}.modal-close-btn{background:var(--surface2);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.modal-close-btn:hover{background:var(--border)}.search-bar-wrap{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:8px;margin:0 16px 10px;padding:10px 12px;display:flex}.search-icon{color:var(--text-muted);flex-shrink:0}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:15px}.search-input::placeholder{color:var(--text-muted)}.search-clear-btn{color:var(--text-muted);align-items:center;display:flex}.search-results{flex:1;padding:0 8px 24px;overflow-y:auto}.search-status{color:var(--text-muted);justify-content:center;align-items:center;gap:8px;padding:24px;font-size:14px;display:flex}.search-error{color:var(--red)}.search-result-item{border-radius:var(--radius-sm);text-align:left;justify-content:space-between;align-items:center;gap:10px;width:100%;padding:13px 10px;transition:background .12s;display:flex}.search-result-item:hover:not(:disabled){background:var(--surface2)}.search-result-item:disabled{opacity:.5;cursor:default}.result-info{flex-direction:column;gap:2px;min-width:0;display:flex}.result-symbol{color:var(--text-primary);font-size:15px;font-weight:700}.result-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:260px;font-size:12px;overflow:hidden}.result-exch{color:var(--text-muted);font-size:11px}.result-add-icon{color:var(--accent);flex-shrink:0}.result-added-label{color:var(--green);flex-shrink:0;font-size:12px;font-weight:500}.spin{animation:1s linear infinite spinAnim}@keyframes spinAnim{to{transform:rotate(360deg)}}.tile-missing{height:42px;color:var(--text-muted);align-items:center;margin-top:4px;font-size:12px;display:flex}.tile-drag-handle{width:24px;height:24px;color:var(--text-muted);cursor:grab;touch-action:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.tile-drag-handle:hover{color:var(--text-secondary);background:var(--surface2)}.tile-drag-handle:active{cursor:grabbing}
