*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #667eea;--primary-dark: #5568d3;--secondary: #764ba2;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--info: #3b82f6;--light: #f9fafb;--dark: #1f2937;--gray: #6b7280}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f3f4f6;color:#1f2937;line-height:1.6}#root{min-height:100vh}.container{max-width:1400px;width:100%;margin:0 auto;padding:2rem 1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-block;text-align:center}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.loading{text-align:center;padding:2rem;color:var(--gray)}.empty-state{text-align:center;padding:3rem;color:var(--gray);background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a}.error-message{background:#fee2e2;color:#991b1b;padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--danger)}@media(max-width:768px){.container{padding:1rem}.btn{padding:.625rem 1.25rem;font-size:.9rem}}.notification-settings-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.notification-settings{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb}.settings-header h3{margin:0;font-size:20px;color:#1f2937}.close-btn{background:none;border:none;font-size:32px;color:#9ca3af;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.close-btn:hover{background:#f3f4f6;color:#4b5563}.settings-body{padding:24px}.status-row{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f9fafb;border-radius:8px;margin-bottom:20px;font-weight:500}.status-badge{padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.enabled{background:#d1fae5;color:#065f46}.status-badge.disabled{background:#fee2e2;color:#991b1b}.status-badge.denied{background:#fef3c7;color:#92400e}.status-badge.default{background:#e5e7eb;color:#374151}.info-section{margin-bottom:24px}.info-section p{margin:0 0 12px;color:#4b5563;font-weight:500}.info-section ul{margin:0;padding-left:20px;color:#6b7280;line-height:1.8}.info-section li{margin-bottom:8px}.warning-message{background:#fffbeb;border:1px solid #fde047;border-radius:8px;padding:16px;margin-bottom:20px}.warning-message p{margin:0;color:#78350f;font-size:14px;line-height:1.6}.btn{width:100%;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:12px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn:disabled{opacity:.6;cursor:not-allowed}.message{padding:12px 16px;border-radius:8px;margin-top:16px;font-size:14px;font-weight:500}.message.success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.message.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.token-info{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.token-info small{color:#9ca3af;font-size:12px;word-break:break-all}@media(max-width:768px){.notification-settings{width:95%;max-height:95vh}.settings-header,.settings-body{padding:20px}}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:1000}.nav-container{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;gap:2rem}.nav-brand h1{color:#fff;font-size:1.5rem;margin:0}.nav-links{display:flex;gap:.5rem;flex:1;justify-content:center}.nav-link{color:#ffffffe6;text-decoration:none;padding:.5rem 1rem;border-radius:6px;transition:all .3s ease;font-weight:500}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#fff3;color:#fff}.nav-user{display:flex;align-items:center;gap:1rem}.notification-bell{background:#ffffff26;border:none;color:#fff;font-size:20px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:relative}.notification-bell:hover{background:#ffffff40;transform:scale(1.1)}.notification-bell:active{transform:scale(.95)}.user-email{color:#fff;font-size:.9rem}.btn-small{padding:.4rem .8rem;font-size:.85rem}.modal{display:flex;position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;background-color:#0009;align-items:center;justify-content:center}.modal-content{background-color:#fff;padding:2rem;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.auth-modal{max-width:450px}.auth-modal h2{text-align:center;margin-bottom:1.5rem;color:#333}.auth-tabs{display:flex;gap:1rem;margin-bottom:1.5rem;border-bottom:2px solid #e0e0e0}.auth-tab{flex:1;padding:.75rem;background:none;border:none;border-bottom:3px solid transparent;font-size:1rem;font-weight:600;color:#666;cursor:pointer;transition:all .3s ease}.auth-tab.active{color:#667eea;border-bottom-color:#667eea}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333;font-size:.9rem}.form-group input,.form-group textarea,.form-group select{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:6px;display:none}.error-message.show{display:block}.close{position:absolute;top:1rem;right:1rem;font-size:1.5rem;font-weight:700;color:#999;cursor:pointer;transition:color .3s ease}.close:hover{color:#333}.notification-toast{position:fixed;top:80px;right:20px;width:360px;max-width:calc(100vw - 40px);background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026,0 0 0 1px #0000000d;z-index:10000;transform:translate(400px);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer}.notification-toast.visible{transform:translate(0);opacity:1}.notification-toast.hiding{transform:translate(400px);opacity:0}.notification-toast:hover{box-shadow:0 6px 25px #0003,0 0 0 1px #0000000d;transform:translateY(-2px)}.notification-content{padding:16px}.notification-header{display:flex;align-items:flex-start;gap:12px}.notification-icon{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;overflow:hidden}.notification-icon img{width:100%;height:100%;object-fit:cover}.notification-icon .default-icon{font-size:20px}.notification-text{flex:1;min-width:0}.notification-title{margin:0 0 4px;font-size:15px;font-weight:600;color:#1f2937;line-height:1.3}.notification-body{margin:0;font-size:14px;color:#6b7280;line-height:1.4;word-wrap:break-word}.close-button{flex-shrink:0;width:24px;height:24px;border:none;background:transparent;color:#9ca3af;font-size:24px;line-height:1;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover{background:#f3f4f6;color:#4b5563}.notification-meta{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #f3f4f6}.notification-type,.notification-symbol{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.notification-type{background:#eff6ff;color:#1e40af}.notification-symbol{background:#f0fdf4;color:#15803d}@media(max-width:768px){.notification-toast{top:70px;right:10px;width:calc(100vw - 20px);max-width:400px}}.notification-toast:nth-child(2){top:100px;transform:translate(400px) scale(.95);opacity:.8}.notification-toast:nth-child(2).visible{transform:translate(0) scale(.95)}.notification-toast:nth-child(3){top:120px;transform:translate(400px) scale(.9);opacity:.6}.notification-toast:nth-child(3).visible{transform:translate(0) scale(.9)}.notification-prompt-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.notification-prompt{background:#fff;border-radius:16px;padding:32px;max-width:480px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out;text-align:center}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.prompt-icon{font-size:64px;margin-bottom:16px;animation:bell 1s ease-in-out infinite}@keyframes bell{0%,to{transform:rotate(0)}10%,30%{transform:rotate(-10deg)}20%,40%{transform:rotate(10deg)}}.notification-prompt h3{font-size:24px;margin-bottom:16px;color:#1a1a1a}.notification-prompt p{font-size:16px;color:#666;margin-bottom:16px;line-height:1.5}.features-list{list-style:none;padding:0;margin:24px 0;text-align:left}.features-list li{padding:12px 16px;margin-bottom:8px;background:#f5f5f5;border-radius:8px;font-size:15px;color:#333;transition:background .2s}.features-list li:hover{background:#e8f4f8}.prompt-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.prompt-actions button{padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-enable{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-enable:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-enable:active{transform:translateY(0)}.btn-later{background:#fff;color:#667eea;border:2px solid #667eea}.btn-later:hover{background:#f0f3ff}.btn-dismiss{background:transparent;color:#999;padding:10px 24px;font-size:14px}.btn-dismiss:hover{color:#666;background:#f5f5f5}.prompt-note{font-size:13px;color:#999;margin-top:16px;margin-bottom:0}@media(prefers-color-scheme:dark){.notification-prompt{background:#2a2a2a;color:#e0e0e0}.notification-prompt h3{color:#fff}.notification-prompt p{color:#b0b0b0}.features-list li{background:#3a3a3a;color:#e0e0e0}.features-list li:hover{background:#404040}.btn-later{background:#2a2a2a;color:#667eea}.btn-later:hover,.btn-dismiss:hover{background:#3a3a3a}}@media(max-width:600px){.notification-prompt{padding:24px;margin:16px}.prompt-icon{font-size:48px}.notification-prompt h3{font-size:20px}.notification-prompt p{font-size:14px}.features-list li{font-size:14px;padding:10px 12px}.prompt-actions button{padding:12px 20px;font-size:15px}}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.live-indicator{display:flex;align-items:center;gap:8px;background:#fff;padding:8px 16px;border-radius:20px;box-shadow:0 2px 8px #0000001a}.status-dot{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-dot.live{background:#10b981}.status-dot.offline{background:#ef4444;animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.update-text{font-size:.875rem;color:#6b7280;font-weight:500}.live-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;margin-bottom:2rem;color:#fff;box-shadow:0 10px 30px #667eea4d}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{margin:0;color:#fff;font-size:1.5rem}.btn-refresh{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-refresh:hover{background:#ffffff4d}.movers-quick{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:20px}.movers-quick-card{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:16px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.movers-quick-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #00000026}.movers-quick-card.gainers{background:linear-gradient(135deg,#10b98140,#05966940);border:1px solid rgba(9,107,74,.4)}.movers-quick-card.losers{background:linear-gradient(135deg,#ef444440,#dc262640);border:1px solid rgba(143,29,29,.4)}.movers-quick-card h4{margin:0 0 12px;font-size:1rem;color:#000;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.1)}.movers-list-compact{display:flex;flex-direction:column;gap:8px}.mover-compact{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:10px 12px;background:#ffffff26;border-radius:8px;font-size:.875rem;transition:all .2s ease;border:1px solid rgba(255,255,255,.1)}.mover-compact:hover{background:#ffffff40;transform:translate(4px)}.mover-symbol{font-weight:700;color:#000;font-size:.9rem;text-shadow:0 1px 2px rgba(0,0,0,.1)}.mover-price{color:#000000f2;font-weight:600;font-size:.85rem}.mover-change{font-weight:700;padding:4px 10px;border-radius:6px;font-size:.8rem;text-shadow:0 1px 2px rgba(0,0,0,.2);letter-spacing:.02em}.mover-change.positive{background:#10b98166;color:#000;border:1px solid rgba(16,185,129,.6)}.mover-change.negative{background:#ef444466;color:#000;border:1px solid rgba(239,68,68,.6)}.live-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.live-data-table{width:100%;border-collapse:collapse}.live-data-table thead{background:#f9fafb}.live-data-table th{padding:12px;text-align:left;font-weight:600;color:#374151;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;position:relative}.sortable:hover{background:#0000000d;color:#667eea}.sortable:hover .sort-icon{opacity:1}.live-data-table td{padding:12px;border-bottom:1px solid #f3f4f6;color:#1f2937;font-size:.9rem}.live-data-table tbody tr{transition:all .2s}.live-data-table tbody tr:hover{background:#f9fafb}.live-data-table tbody tr.positive-row{border-left:3px solid #10b981}.live-data-table tbody tr.negative-row{border-left:3px solid #ef4444}.clickable-symbol{cursor:pointer;color:#3b82f6;transition:color .2s}.clickable-symbol:hover{color:#2563eb;text-decoration:underline}.ltp-cell{font-weight:600;font-size:.95rem}.live-data-table .positive{color:#10b981;font-weight:500}.live-data-table .negative{color:#ef4444;font-weight:500}.view-all-link{margin-top:16px;text-align:center}.view-all-link .btn{background:#fff;color:#667eea;font-weight:600;box-shadow:0 2px 8px #0000001a}.view-all-link .btn:hover{background:#f9fafb;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .2s}.stat-card:hover{transform:translateY(-5px);box-shadow:0 4px 12px #00000026}.stat-card.buy{border-left:4px solid #10b981}.stat-card.sell{border-left:4px solid #ef4444}.stat-card.hold{border-left:4px solid #f59e0b}.stat-icon{font-size:2.5rem}.stat-content h3{margin:0;font-size:2rem;color:#1f2937}.stat-content p{margin:.25rem 0 0;color:#6b7280;font-size:.9rem}.section{background:#fff;border-radius:10px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.section h3{margin-top:0;margin-bottom:1rem;color:#1f2937}.report-summary{padding:1rem;background:#f9fafb;border-radius:8px;border-left:4px solid #667eea}.report-summary p{margin:.5rem 0;line-height:1.6}.report-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1rem}.report-stat-item{display:flex;flex-direction:column;gap:.25rem}.report-label{font-size:.875rem;color:#6b7280;font-weight:500}.report-value{font-size:1.25rem;font-weight:600;color:#1f2937}.report-value.buy-text{color:#10b981}.report-value.sell-text{color:#ef4444}.report-value.hold-text{color:#f59e0b}.report-description{padding-top:1rem;border-top:1px solid #e5e7eb;margin-top:1rem;font-size:.95rem;color:#4b5563}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:#f9fafb}.data-table th,.data-table td{padding:1rem;text-align:left;border-bottom:1px solid #e5e7eb}.data-table th{font-weight:600;color:#374151}.data-table tbody tr:hover{background:#f9fafb}.signal-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;text-transform:uppercase}.signal-badge.buy{background:#d1fae5;color:#065f46}.signal-badge.sell{background:#fee2e2;color:#991b1b}.signal-badge.hold{background:#fef3c7;color:#92400e}.btn-small{padding:.5rem 1rem;font-size:.875rem}.loading{text-align:center;padding:2rem;color:#6b7280}@media(max-width:768px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:12px}.live-indicator{width:100%;justify-content:center}.movers-quick{grid-template-columns:1fr}.live-table-container{overflow-x:auto}.live-data-table{min-width:800px}.live-data-table th,.live-data-table td{padding:8px;font-size:.8rem}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.view-all-link .btn{width:100%}}.opportunities-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 4px 12px #00000026}.header-content h2{margin:0 0 .5rem;font-size:2rem}.date-badge{background:#fff3;padding:.5rem 1rem;border-radius:20px;display:inline-block;margin-top:.5rem;font-size:.9rem}.filter-controls{display:flex;gap:1rem;margin-top:1.5rem}.filter-btn{flex:1;padding:.75rem 1.5rem;border:2px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:600}.filter-btn:hover{background:#fff3;transform:translateY(-2px)}.filter-btn.active{background:#fff;color:#667eea}.filter-btn.buy-btn.active{background:#10b981;color:#fff;border-color:#10b981}.filter-btn.sell-btn.active{background:#ef4444;color:#fff;border-color:#ef4444}.loading-state{text-align:center;padding:4rem}.spinner{width:50px;height:50px;border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:4rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.empty-state h3{color:#1f2937;margin-bottom:1rem}.empty-state p{color:#6b7280;margin-bottom:.5rem}.empty-state .note{font-size:.9rem;color:#9ca3af}.opportunities-section{margin-bottom:3rem}.section-title{font-size:1.5rem;margin-bottom:.5rem}.section-title.buy-title{color:#10b981}.section-title.sell-title{color:#ef4444}.section-description{color:#6b7280;margin-bottom:1.5rem}.opportunities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.opportunity-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border-left:4px solid}.opportunity-card.buy-card{border-left-color:#10b981}.opportunity-card.sell-card{border-left-color:#ef4444}.opportunity-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026}.card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.card-title{display:flex;align-items:center;gap:.75rem}.card-title h3{margin:0;color:#1f2937;font-size:1.25rem}.signal-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.signal-badge.buy-badge{background:#d1fae5;color:#065f46}.signal-badge.sell-badge{background:#fee2e2;color:#991b1b}.confidence-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:1.1rem;min-width:60px;text-align:center}.card-content{margin-bottom:1rem}.stock-name{font-size:.9rem;color:#6b7280;margin:0 0 .25rem}.stock-sector{font-size:.85rem;color:#9ca3af;margin:0 0 1rem;font-weight:500}.price-info{background:#f9fafb;padding:.75rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.price-label{color:#6b7280;font-size:.9rem}.price-value{font-size:1.25rem;font-weight:700;color:#1f2937}.reasons-section h4{font-size:.9rem;color:#4b5563;margin:0 0 .5rem}.reasons-list{list-style:none;padding:0;margin:0}.reasons-list li{padding:.4rem .6rem;margin-bottom:.3rem;background:#f9fafb;border-radius:6px;font-size:.85rem;color:#4b5563;line-height:1.4}.reasons-list li:before{content:"→";margin-right:.5rem;color:#667eea;font-weight:700}.card-footer{padding-top:1rem;border-top:1px solid #e5e7eb}.view-chart-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.view-chart-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.disclaimer{background:#fef3c7;border:2px solid #fbbf24;border-radius:12px;padding:1.5rem;margin-top:3rem}.disclaimer h4{color:#92400e;margin:0 0 1rem}.disclaimer p{color:#78350f;margin:0 0 .5rem;line-height:1.6}.disclaimer .note{font-weight:600;background:#fff;padding:.75rem;border-radius:8px;margin-top:1rem}@media(max-width:768px){.opportunities-grid{grid-template-columns:1fr}.filter-controls{flex-direction:column}.header-content h2{font-size:1.5rem}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;color:#1f2937}.modal-close{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.modal-close:hover{background:#f3f4f6}.modal-form{padding:1.5rem}.stock-info{background:#f9fafb;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.stock-info p{margin:.5rem 0;color:#374151}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500}.form-group input,.form-group select{width:100%;padding:.625rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.total-display{background:#f0f9ff;border-left:4px solid #3b82f6;padding:1rem;margin:1.5rem 0;border-radius:4px}.total-display strong{color:#1e40af}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.modal-actions .btn{min-width:100px}.portfolio-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.portfolio-header .header-left{display:flex;flex-direction:column;gap:.5rem}.portfolio-header h2{margin:0;color:#1f2937}.update-info{display:flex;gap:1rem;align-items:center;font-size:.875rem}.live-indicator{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:20px;font-weight:600;font-size:.8rem;animation:pulse 2s ease-in-out infinite}.offline-indicator{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;background:#6b7280;color:#fff;border-radius:20px;font-weight:600;font-size:.8rem}.last-update{color:#6b7280}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.performance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.performance-card{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.performance-card h4{margin:0 0 .5rem;color:#6b7280;font-size:.875rem;font-weight:500;text-transform:uppercase}.performance-card .amount{margin:0;font-size:1.75rem;font-weight:700;color:#1f2937}.amount.profit{color:#10b981}.amount.loss{color:#ef4444}.profit{color:#10b981;font-weight:600}.loss{color:#ef4444;font-weight:600}.realtime-badge{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:.65rem;font-weight:700;letter-spacing:.5px;vertical-align:middle}.change-positive-small{color:#10b981;font-size:.75rem;font-weight:600;margin-left:.25rem}.change-negative-small{color:#ef4444;font-size:.75rem;font-weight:600;margin-left:.25rem}.trade-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;text-transform:uppercase}.trade-badge.buy{background:#d1fae5;color:#065f46}.trade-badge.sell{background:#fee2e2;color:#991b1b}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;position:relative}.data-table th.sortable:hover{background:#0000000d;color:#667eea}.data-table th.sortable:hover .sort-icon{opacity:1}.chart-header{margin-bottom:1.5rem}.chart-header h2{margin:0 0 1rem;color:#1f2937;font-size:1.5rem}.chart-controls{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.chart-select{padding:.625rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;background:#fff;cursor:pointer;transition:border-color .2s;min-width:200px}.chart-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.reset-zoom-btn{padding:.625rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;box-shadow:0 2px 8px #667eea4d}.reset-zoom-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.reset-zoom-btn:active{transform:translateY(0)}.chart-layout{display:grid;grid-template-columns:280px 1fr;gap:1rem;background:#f9fafb;border-radius:8px;padding:1rem}.chart-sidebar{background:#fff;border-radius:8px;padding:1rem;height:fit-content;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.sidebar-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #f3f4f6}.sidebar-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.sidebar-title{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.info-grid{display:flex;flex-direction:column;gap:.5rem}.info-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.info-label{color:#6b7280;font-weight:500}.info-value{color:#1f2937;font-weight:600;font-family:Courier New,monospace}.info-value.green{color:#10b981}.info-value.red{color:#ef4444}.chart-main{display:flex;flex-direction:column;gap:1rem}.chart-panel{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.panel-title{font-size:.875rem;font-weight:600;color:#374151}.panel-indicators{display:flex;gap:.5rem;flex-wrap:wrap}.indicator-tag{padding:.25rem .625rem;border-radius:4px;font-size:.75rem;font-weight:500;color:#fff}.indicator-tag.sma{background:#f59e0b}.indicator-tag.ema{background:#8b5cf6}.indicator-tag.bb{background:#3b82f6}.chart-container{position:relative;width:100%;padding:1rem}.main-panel .chart-container{height:450px}.macd-panel .chart-container{height:250px}.volume-panel .chart-container{height:180px}@media(max-width:1200px){.chart-layout{grid-template-columns:250px 1fr}.main-panel .chart-container{height:400px}}@media(max-width:992px){.chart-layout{grid-template-columns:1fr}.chart-sidebar{order:2;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.sidebar-section{margin-bottom:0;padding-bottom:0;border-bottom:none}}@media(max-width:768px){.chart-controls{flex-direction:column}.chart-select{width:100%}.chart-layout{padding:.5rem}.chart-sidebar{grid-template-columns:1fr}.main-panel .chart-container{height:300px}.macd-panel .chart-container{height:200px}.volume-panel .chart-container{height:150px}.panel-indicators{display:none}}.realtime-container{padding:20px;max-width:1400px;margin:0 auto}.realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e5e7eb}.realtime-header h1{margin:0 0 10px;color:#1f2937;font-size:2rem}.subtitle{margin:5px 0;color:#6b7280;font-size:1rem}.status-live{font-weight:600;color:#10b981}.status-closed{font-weight:600;color:#ef4444}.last-update{font-size:.875rem;color:#9ca3af;margin:5px 0 0}.market-movers{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:30px}.movers-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 6px #0000001a}.gainers-card{border-left:4px solid #10b981}.losers-card{border-left:4px solid #ef4444}.movers-card h3{margin:0 0 15px;font-size:1.25rem;color:#1f2937}.movers-list{display:flex;flex-direction:column;gap:12px}.mover-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#f9fafb;border-radius:8px;transition:background .2s}.mover-item:hover{background:#f3f4f6}.mover-item strong{display:block;color:#1f2937;font-size:.95rem}.stock-price{display:block;color:#6b7280;font-size:.875rem;margin-top:2px}.realtime-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:20px;flex-wrap:wrap}.filter-tabs{display:flex;gap:10px}.filter-tabs button{padding:10px 20px;border:2px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s;color:#6b7280}.filter-tabs button:hover{border-color:#3b82f6;color:#3b82f6}.filter-tabs button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.search-input{padding:10px 15px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;min-width:300px;transition:border-color .2s}.search-input:focus{outline:none;border-color:#3b82f6}.table-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;overflow:hidden}.realtime-table{width:100%;border-collapse:collapse}.realtime-table thead{background:#f9fafb}.realtime-table th{padding:15px;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb}.realtime-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;position:relative}.realtime-table th.sortable:hover{background:#0000000d;color:#667eea}.sort-icon{display:inline-block;margin-left:4px;opacity:.5;font-size:.75rem;transition:opacity .2s}.realtime-table th.sortable:hover .sort-icon{opacity:1}.realtime-table td{padding:15px;border-bottom:1px solid #f3f4f6;font-size:.95rem}.realtime-table tbody tr{transition:background .2s}.realtime-table tbody tr:hover{background:#f9fafb}.stock-name{color:#6b7280;font-size:.875rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ltp{font-weight:600;color:#1f2937}.change-positive{color:#10b981;font-weight:600}.change-negative{color:#ef4444;font-weight:600}.market-closed-notice{margin-top:20px;padding:15px 20px;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:8px;color:#92400e;font-weight:500}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.realtime-header{flex-direction:column;align-items:flex-start}.realtime-header .btn{margin-top:15px}.realtime-controls{flex-direction:column;align-items:stretch}.filter-tabs{flex-wrap:wrap}.search-input{width:100%;min-width:auto}.table-container{overflow-x:auto}.realtime-table{font-size:.875rem}.realtime-table th,.realtime-table td{padding:10px 8px}}#root{min-height:100vh;display:flex;flex-direction:column}
