@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;animation:1.5s infinite shimmer}.stock-card-skeleton{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 1px 4px #00000014}.skeleton-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.skeleton-price{margin:.5rem 0}.loading,.error{text-align:center;padding:2rem;font-size:1.2rem}.error{color:#e53935}.dashboard h3{color:#374151;margin-top:1.5rem;margin-bottom:.5rem;font-size:1.1rem}.dashboard section:first-of-type h3{margin-top:0}.market-status-banner{border-radius:6px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.6rem 1rem;font-size:.85rem;font-weight:500;display:flex}.market-status-dot{border-radius:50%;width:8px;height:8px}.market-open{color:#065f46;background:#d1fae5}.market-open .market-status-dot{background:#10b981}.market-pre{color:#92400e;background:#fef3c7}.market-pre .market-status-dot{background:#f59e0b}.market-after{color:#5b21b6;background:#ede9fe}.market-after .market-status-dot{background:#8b5cf6}.market-closed{color:#6b7280;background:#f3f4f6}.market-closed .market-status-dot{background:#9ca3af}.stock-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem;display:grid}.indices-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.stock-card{background:#fff;border-radius:8px;padding:1rem;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 4px #00000014}.stock-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.index-card{border-left:3px solid #2563eb}.stock-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.stock-symbol{color:#1a1a2e;font-size:1rem;font-weight:600}.market-badge{border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:500}.market-badge.premarket,.market-badge.extendedhours{color:#92400e;background:#fef3c7}.market-badge.regular{color:#065f46;background:#d1fae5}.stock-market-state{color:#666;background:#f3f4f6;border-radius:4px;padding:.2rem .5rem;font-size:.75rem}.stock-price{color:#1a1a2e;font-size:1.5rem;font-weight:700}.index-card .stock-price{font-size:1.25rem}.stock-change{margin-top:.25rem;font-size:.9rem;font-weight:600}.stock-change.up{color:#10b981}.stock-change.down{color:#ef4444}.stock-volume{color:#6b7280;margin-top:.25rem;font-size:.85rem}.stock-exchange{color:#666;background:#f0f0f0;border-radius:4px;padding:.25rem .5rem;font-size:.8rem}.stock-name{color:#444;margin-bottom:.5rem}.stock-info{gap:.5rem;display:flex}.stock-currency{color:#666;font-size:.9rem}.watchlist h2{margin-bottom:.5rem}@keyframes slideUp{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.watchlist-controls{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.sort-controls{color:#666;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.sort-btn{cursor:pointer;color:#666;background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:.3rem .7rem;font-size:.85rem;transition:all .2s}.sort-btn:hover{background:#f9fafb}.sort-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.refresh-btn{cursor:pointer;color:#374151;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;padding:.4rem .8rem;font-size:.85rem}.create-watchlist-form{gap:.5rem;margin-bottom:1.5rem;display:flex}.watchlist-name-input{border:1px solid #e5e7eb;border-radius:6px;flex:1;max-width:300px;padding:.6rem 1rem;font-size:.95rem}.watchlist-name-input:focus{border-color:#2563eb;outline:none}.create-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;transition:background .2s}.create-btn:hover:not(:disabled){background:#1d4ed8}.create-btn:disabled{opacity:.6;cursor:not-allowed}.watchlist-section{margin-bottom:2rem}.watchlist-section h3{color:#374151;border-bottom:1px solid #e5e7eb;margin-bottom:.75rem;padding-bottom:.5rem;font-size:1rem}.watchlist-items{list-style:none}.watchlist-item{background:#fff;border-radius:8px;align-items:center;gap:1rem;margin-bottom:.5rem;padding:1rem;display:flex;box-shadow:0 1px 4px #00000014}.watchlist-item .symbol{color:#1a1a2e;min-width:60px;font-size:1rem;font-weight:700}.watchlist-item .price{color:#2563eb;min-width:80px;font-weight:600}.watchlist-item .volume{color:#6b7280;flex:1;font-size:.85rem}.loading-price{color:#9ca3af;font-size:.9rem;font-style:italic}.remove-btn{color:#fff;cursor:pointer;background:#e53935;border:none;border-radius:4px;padding:.4rem .8rem;font-size:.8rem;transition:background .2s}.remove-btn:hover{background:#c62828}.alerts h2{margin-bottom:.5rem}.empty-message{color:#666;padding:1rem;font-style:italic}.filter-tabs{gap:.5rem;margin-bottom:1rem;display:flex}.filter-tab{cursor:pointer;color:#6b7280;background:#fff;border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9rem;transition:all .2s;display:flex}.filter-tab:hover{background:#f9fafb}.filter-tab.active{color:#fff;background:#2563eb;border-color:#2563eb}.filter-tab .count{background:#0000001a;border-radius:10px;padding:.1rem .4rem;font-size:.8rem}.filter-tab.active .count{background:#fff3}.refresh-btn{float:right;cursor:pointer;color:#374151;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;margin-top:-2.5rem;padding:.4rem .8rem;font-size:.85rem}.refresh-btn:hover{background:#e5e7eb}.notification{color:#fff;z-index:1000;background:#1a1a2e;border-radius:8px;padding:.75rem 1.5rem;font-size:.9rem;animation:.3s slideUp;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}.alert-list{margin-top:.5rem;padding:0;list-style:none}.alert-item{background:#fff;border-left:3px solid #4caf50;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:1rem 1.5rem;display:flex;box-shadow:0 1px 4px #0000001a}.alert-item.disabled{opacity:.6;border-left-color:#9ca3af}.alert-item.triggered{background:#fffbeb;border-left-color:#f59e0b}.alert-info{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.alert-info .symbol{color:#1a1a2e;font-size:1.1rem;font-weight:700}.alert-info .type{color:#666;font-size:.9rem}.alert-info .threshold{color:#2563eb;font-weight:600}.triggered-badge{color:#92400e;background:#fef3c7;border-radius:4px;padding:.2rem .5rem;font-size:.75rem}.alert-actions{flex-shrink:0;gap:.5rem;display:flex}.reset-btn{color:#fff;cursor:pointer;background:#f59e0b;border:none;border-radius:4px;padding:.4rem .8rem;font-size:.8rem;font-weight:600;transition:background .2s}.reset-btn:hover{background:#d97706}.toggle-btn{cursor:pointer;border:none;border-radius:4px;padding:.5rem 1rem;font-weight:600;transition:background .2s}.toggle-btn.active{color:#fff;background:#4caf50}.toggle-btn:not(.active){color:#666;background:#e0e0e0}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.delete-btn{color:#fff;cursor:pointer;background:#e53935;border:none;border-radius:4px;padding:.5rem 1rem;transition:background .2s}.delete-btn:hover{background:#c62828}.indicators-container{background:#f8f9fa;border-radius:8px;margin-top:20px;padding:16px}.indicators-container h3{color:#333;margin:0 0 16px;font-size:1.1rem}.indicators-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.indicator-card{background:#fff;border-left:3px solid #6c757d;border-radius:6px;padding:12px;box-shadow:0 1px 3px #0000001a}.indicator-card.overbought{background:#fff5f5;border-left-color:#dc3545}.indicator-card.oversold{background:#f0fff4;border-left-color:#28a745}.indicator-label{color:#6c757d;margin-bottom:4px;font-size:.85rem;font-weight:600}.indicator-value{color:#333;font-size:1.4rem;font-weight:700}.indicator-status{border-radius:3px;margin-top:4px;padding:2px 6px;font-size:.75rem;display:inline-block}.indicator-card.overbought .indicator-status{color:#fff;background:#dc3545}.indicator-card.oversold .indicator-status{color:#fff;background:#28a745}.indicator-card:not(.overbought):not(.oversold) .indicator-status{color:#fff;background:#6c757d}.indicator-detail{color:#666;margin-top:4px;font-size:.8rem}.indicator-histogram{margin-top:2px;font-size:.8rem}.indicator-histogram.positive{color:#28a745}.indicator-histogram.negative{color:#dc3545}.indicator-values{flex-direction:column;gap:4px;display:flex}.indicator-row{justify-content:space-between;font-size:.85rem;display:flex}.indicator-key{color:#6c757d}.indicator-val{color:#333;font-weight:600}.indicators-loading,.indicators-error{text-align:center;color:#6c757d;padding:20px}.indicators-error{color:#dc3545}.stock-chart{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-top:1rem;padding:1rem}.stock-chart h4{color:#374151;margin:0 0 .75rem;font-size:.95rem}.chart-empty{text-align:center;color:#9ca3af;padding:2rem;font-size:.9rem}.search-wrapper{margin-bottom:1.5rem;position:relative}.search-form{gap:1rem;display:flex}.search-input{border:2px solid #ddd;border-radius:8px;flex:1;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.search-input:focus{border-color:#4fc3f7;outline:none}.search-btn{color:#fff;cursor:pointer;background:#1a1a2e;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:background .2s}.search-btn:hover:not(:disabled){background:#2a2a4e}.search-btn:disabled{opacity:.6}.suggestions-dropdown{z-index:50;background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-height:300px;margin-top:.25rem;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #00000026}.suggestion-item{text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #f3f4f6;align-items:center;gap:1rem;width:100%;padding:.75rem 1rem;transition:background .15s;display:flex}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:#f9fafb}.suggestion-symbol{color:#1a1a2e;min-width:60px;font-weight:700}.suggestion-name{color:#6b7280;font-size:.9rem}.suggestion-empty{text-align:center;color:#9ca3af;padding:1rem}.error-message{color:#e53935;margin-bottom:1rem}.stock-details{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 12px #0000001a}.stock-header{align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.stock-header .symbol{color:#1a1a2e;font-size:2rem;font-weight:700}.stock-header .exchange{color:#666;background:#f0f0f0;border-radius:4px;padding:.25rem .75rem;font-size:.9rem}.stock-name{color:#444;margin-bottom:.5rem;font-size:1.2rem}.stock-currency{color:#666;margin-bottom:1.5rem}.stock-actions{margin-bottom:1.5rem}.action-btn{cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:background .2s}.watchlist-btn{color:#1a1a2e;background:#4fc3f7}.watchlist-btn:hover:not(:disabled){background:#29b6f6}.watchlist-btn:disabled{color:#fff;background:#a0a0a0}.alert-form h3{margin-bottom:1rem;font-size:1.1rem}.alert-inputs{flex-wrap:wrap;gap:1rem;display:flex}.alert-select,.threshold-input{border:2px solid #ddd;border-radius:8px;padding:.75rem 1rem;font-size:1rem}.alert-select:focus,.threshold-input:focus{border-color:#4fc3f7;outline:none}.create-alert-btn{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:background .2s}.create-alert-btn:hover{background:#43a047}.chart-section{margin-top:1.5rem}.chart-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.chart-header h4{color:#374151;margin:0;font-size:1rem}.period-selector{gap:.25rem;display:flex}.period-btn{cursor:pointer;color:#666;background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:.3rem .6rem;font-size:.8rem;font-weight:600;transition:all .2s}.period-btn:hover:not(:disabled){background:#f9fafb}.period-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.period-btn:disabled{opacity:.6;cursor:not-allowed}.chart-loading{text-align:center;color:#9ca3af;background:#f9fafb;border-radius:8px;padding:3rem}.app{min-height:100vh}.navbar{color:#fff;z-index:100;background-color:#1a1a2e;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0;box-shadow:0 2px 4px #0000001a}.navbar h1{font-size:1.5rem}.nav-links{gap:2rem;list-style:none;display:flex}.nav-links a{color:#fff;border-radius:4px;padding:.25rem .5rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-links a:hover{color:#4fc3f7;background:#ffffff1a}.nav-links a.active{color:#4fc3f7;border-bottom:2px solid #4fc3f7}.main-content{max-width:1200px;margin:0 auto;padding:1.5rem}@media (width<=768px){.navbar{flex-direction:column;gap:1rem;padding:1rem}.navbar h1{font-size:1.25rem}.nav-links{flex-wrap:wrap;justify-content:center;gap:1rem}.nav-links a{font-size:.9rem}.main-content{padding:1rem}}@media (width<=480px){.navbar h1{font-size:1.1rem}.nav-links{gap:.5rem}.nav-links a{padding:.25rem .4rem;font-size:.85rem}}@media (width<=768px){.stock-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))!important;gap:.75rem!important}.indices-grid{grid-template-columns:repeat(2,1fr)!important}}@media (width<=480px){.stock-grid{grid-template-columns:1fr 1fr!important;gap:.5rem!important}.stock-card{padding:.75rem!important}.stock-price{font-size:1.25rem!important}}*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}#root{min-height:100vh}
