:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--background-color);color:var(--text-primary);transition:background-color .2s ease-in-out,color .2s ease-in-out}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}a{font-weight:500;color:var(--primary-color);text-decoration:inherit;transition:color .2s ease-in-out}a:hover{color:var(--primary-hover)}button{border-radius:.5rem;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--surface-color);color:var(--text-primary);cursor:pointer;transition:all .2s ease-in-out}button:hover{border-color:var(--primary-color);background-color:var(--surface-hover)}button:focus,button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media (prefers-color-scheme: dark){:root:not([data-theme]){--background-color: #0f172a;--surface-color: #1e293b;--surface-hover: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--border-color: #334155;--primary-color: #3b82f6;--primary-hover: #2563eb}}@media (prefers-color-scheme: light){:root:not([data-theme]){--background-color: #f8fafc;--surface-color: #ffffff;--surface-hover: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--primary-color: #2563eb;--primary-hover: #1d4ed8}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,var(--background-color, #f8fafc) 0%,var(--card-background, #ffffff) 50%,var(--background-color, #f8fafc) 100%);padding:20px;overflow:hidden;color:var(--text-color, #1f2937)}[data-theme=dark] .login-container{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);color:#f8fafc}.login-background{position:absolute;inset:0;overflow:hidden;opacity:.05;pointer-events:none}.floating-icon{position:absolute;color:#3b82f6;animation:float 6s ease-in-out infinite}[data-theme=dark] .floating-icon{color:#60a5fa}.floating-icon.icon-1{top:10%;left:10%;width:40px;height:40px;animation-delay:0s}.floating-icon.icon-2{top:20%;right:15%;width:30px;height:30px;animation-delay:2s}.floating-icon.icon-3{bottom:20%;left:20%;width:35px;height:35px;animation-delay:4s}.floating-icon.icon-4{bottom:10%;right:10%;width:45px;height:45px;animation-delay:1s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}.login-content{display:grid;grid-template-columns:1fr auto;gap:60px;max-width:1000px;width:100%;align-items:center;position:relative;z-index:1}.theme-toggle-login{position:absolute;top:-60px;right:0;background:#fffffff2;border:2px solid rgba(229,231,235,.8);border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a;outline:none}[data-theme=dark] .theme-toggle-login{background:#1e293bf2;border:2px solid rgba(71,85,105,.8)}.theme-toggle-login:hover{transform:scale(1.1);border-color:#3b82f6}.theme-toggle-login:focus{outline:none;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633}.theme-toggle-login .theme-icon{width:22px;height:22px;color:#3b82f6}[data-theme=dark] .theme-toggle-login .theme-icon{color:#60a5fa}.login-card{background:#fffffff2;border-radius:20px;padding:40px;box-shadow:0 20px 40px #0000001a,0 0 0 1px #e5e7ebcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(229,231,235,.5);min-width:400px;position:relative;overflow:hidden}[data-theme=dark] .login-card{background:#1e293bf2;box-shadow:0 20px 40px #0000004d,0 0 0 1px #475569cc;border:1px solid rgba(71,85,105,.5)}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--success-color) 0%,var(--accent-color) 50%,var(--success-color) 100%)}.login-header{text-align:center;margin-bottom:40px}.logo-section{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:10px}.logo-icon{width:40px;height:40px;color:var(--accent-color)}.login-header h1{font-size:28px;font-weight:700;margin:0;color:#3b82f6;text-shadow:0 1px 2px rgba(0,0,0,.1)}[data-theme=dark] .login-header h1{color:#60a5fa;text-shadow:0 1px 2px rgba(0,0,0,.3)}@supports (-webkit-background-clip: text){.login-header h1{background:linear-gradient(135deg,#3b82f6,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=dark] .login-header h1{background:linear-gradient(135deg,#60a5fa,#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}}.login-header h1::selection{background:#3b82f6;color:#fff;-webkit-text-fill-color:white}.tagline{color:#6b7280;font-size:16px;margin:0;font-weight:500}[data-theme=dark] .tagline{color:#9ca3af}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;width:20px;height:20px;z-index:2}[data-theme=light] .input-icon{color:#6b7280}[data-theme=dark] .input-icon{color:#9ca3af}.form-input{width:100%;padding:16px 16px 16px 50px;border:2px solid;border-radius:12px;font-size:16px;font-weight:500;transition:all .3s ease;box-sizing:border-box}[data-theme=light] .form-input{border-color:#e5e7eb;background:#ffffffe6;color:#1f2937}[data-theme=dark] .form-input{border-color:#374151;background:#111827cc;color:#f9fafb}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;transform:translateY(-1px)}[data-theme=light] .form-input::placeholder{color:#6b7280;opacity:.7}[data-theme=dark] .form-input::placeholder{color:#9ca3af;opacity:.7}.password-toggle{position:absolute;right:16px;background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;z-index:2;outline:none}[data-theme=light] .password-toggle{color:#6b7280}[data-theme=dark] .password-toggle{color:#9ca3af}.password-toggle:hover{color:#3b82f6;background:#3b82f61a}.error-message{display:flex;align-items:center;gap:8px;color:#dc2626;font-size:14px;font-weight:500;background:#dc26261a;border:1px solid rgba(220,38,38,.2);border-radius:8px;padding:12px 16px;margin-top:-8px}.error-icon{width:16px;height:16px;flex-shrink:0}.login-button,.demo-button{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.login-button{background:linear-gradient(135deg,#3b82f6,#10b981);color:#fff;box-shadow:0 8px 20px #3b82f64d}.login-button,.login-button:hover,.login-button:active,.login-button:focus{color:#fff!important}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px #3b82f666;background:linear-gradient(135deg,#2563eb,#059669)}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.demo-button{background:#fffffff2;color:#3b82f6;border:2px solid #3b82f6}[data-theme=dark] .demo-button{background:#1e293bf2;color:#60a5fa;border:2px solid #60a5fa}.demo-button:hover:not(:disabled){background:#3b82f6;color:#fff;transform:translateY(-1px)}[data-theme=dark] .demo-button:hover:not(:disabled){background:#60a5fa;color:#fff}.button-icon{width:18px;height:18px}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.demo-section{margin-top:32px}.divider{display:flex;align-items:center;margin:24px 0;text-align:center}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.divider span{color:var(--text-secondary);font-size:14px;font-weight:500;padding:0 16px;background:var(--card-background)}.login-footer{margin-top:32px;padding-top:24px;border-top:1px solid var(--border-color)}.demo-credentials{background:var(--background-color);border-radius:8px;padding:16px;border:1px solid var(--border-color)}.demo-credentials h4{margin:0 0 12px;color:var(--accent-color);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.demo-credentials p{margin:4px 0;font-size:13px;color:var(--text-secondary);font-family:Courier New,monospace}.demo-credentials strong{color:var(--text-color)}.features-section{background:var(--card-background);border-radius:16px;padding:32px;border:1px solid var(--border-color);box-shadow:0 10px 25px #0000001a;max-width:300px}.features-section h3{color:var(--accent-color);font-size:20px;font-weight:700;margin:0 0 20px;text-align:center}.features-section ul{list-style:none;padding:0;margin:0}.features-section li{color:var(--text-secondary);font-size:14px;font-weight:500;position:relative;padding:8px 0 8px 20px}.features-section li:before{content:"✓";position:absolute;left:0;color:var(--success-color);font-weight:700}@media (max-width: 768px){.login-content{grid-template-columns:1fr;gap:40px}.login-card{min-width:unset;width:100%;padding:30px 24px}.features-section{max-width:unset;width:100%}.theme-toggle-login{top:-50px;right:10px}}@media (max-width: 480px){.login-container{padding:10px}.login-card{padding:24px 20px}.login-header h1{font-size:24px}.form-input{font-size:16px}}.intraday-view{width:100%;padding:1rem}.intraday-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary)}.intraday-loading .spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.intraday-controls{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:var(--card-background);border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.date-selector{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.date-selector .icon{color:var(--primary-color);width:20px;height:20px}.date-selector label{font-weight:600;color:var(--text-primary);white-space:nowrap}.date-select{padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;background:var(--background-color);color:var(--text-primary);font-size:.95rem;transition:all .2s ease;min-width:200px}.date-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha)}.table-tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--border-color);padding-bottom:.5rem}.tab-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--background-color);border:2px solid var(--border-color);border-radius:8px 8px 0 0;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s ease}.tab-button:hover{background:var(--card-background);color:var(--text-primary);border-color:var(--primary-color-light)}.tab-button.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.tab-icon{width:18px;height:18px}.refresh-button{padding:.75rem 1rem;background:var(--success-color);color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-left:auto}.refresh-button:hover:not(:disabled){background:#047857;transform:translateY(-1px)}.refresh-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.intraday-content{margin-top:1rem}.table-section{background:var(--card-background);border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);overflow:hidden}.table-title{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background:var(--header-background);border-bottom:1px solid var(--border-color);margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.count{font-size:.9rem;color:var(--text-secondary);font-weight:500;background:var(--background-color);padding:.25rem .75rem;border-radius:20px;border:1px solid var(--border-color)}.table-container{overflow-x:auto;overflow-y:auto;max-height:600px}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table th{background:var(--header-background);color:var(--text-primary);font-weight:600;padding:1rem .75rem;text-align:left;border-bottom:2px solid var(--border-color);position:sticky;top:0;z-index:10;-webkit-user-select:none;user-select:none}.data-table th.sortable{cursor:pointer;transition:background-color .2s ease;position:relative}.data-table th.sortable:hover{background:var(--primary-color-light)}.data-table th.sorted-asc,.data-table th.sorted-desc{background:var(--primary-color-light);color:var(--primary-color)}.sort-indicator{margin-left:.5rem;font-weight:700;color:var(--primary-color)}.data-table td{padding:.875rem .75rem;border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.data-row:hover{background:var(--row-hover-background)}.symbol-cell{font-weight:600;color:var(--primary-color);font-family:Courier New,monospace}.name-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.positive{color:var(--success-color)!important;font-weight:600!important}.negative{color:var(--danger-color)!important;font-weight:600!important}.data-table td.positive{color:var(--success-color)!important;font-weight:600!important}.data-table td.negative{color:var(--danger-color)!important;font-weight:600!important}.no-data{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary);text-align:center}.no-data-icon{width:48px;height:48px;color:var(--text-muted);margin-bottom:1rem}.no-data p{font-size:1.1rem;margin:0}@media (max-width: 768px){.intraday-view{padding:.5rem}.intraday-controls{padding:1rem;gap:1rem}.date-selector{flex-direction:column;align-items:flex-start;gap:.5rem}.date-select{width:100%;min-width:unset}.table-tabs{flex-direction:column;gap:.5rem}.tab-button{justify-content:center;padding:1rem}.table-title{flex-direction:column;align-items:flex-start;gap:.5rem;padding:1rem}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:.5rem .375rem}.name-cell{max-width:120px}}.qualified-table{width:100%;border-collapse:collapse;font-size:.85rem}.qualified-table th{background:var(--header-background);color:var(--text-primary);font-weight:600;padding:1rem .75rem;text-align:left;border-bottom:2px solid var(--border-color);position:sticky;top:0;z-index:10;min-width:180px}.qualified-table .cell-content{display:flex;flex-direction:column;gap:.25rem;padding:.25rem 0}.qualified-table .cell-content>div{font-size:.8rem;line-height:1.2}.stock-info-cell .symbol{font-weight:700;color:var(--primary-color);font-size:.9rem;font-family:Courier New,monospace}.stock-info-cell .name{color:var(--text-primary);font-size:.75rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stock-info-cell .source{color:var(--text-muted);font-size:.7rem;text-transform:uppercase}.price-details-cell .current-price{font-weight:600;color:var(--text-primary);font-size:.85rem}.price-details-cell .original-price{color:var(--text-secondary);font-size:.75rem}.price-details-cell .price-change{font-weight:600;font-size:.8rem}.technical-cell .vwap,.technical-cell .ema{color:var(--text-primary);font-weight:500}.technical-cell .volume-ratio,.technical-cell .trend-score{color:var(--text-secondary);font-size:.75rem}.qualification-cell .qualification-score{font-weight:700;color:var(--primary-color);font-size:.9rem}.qualification-cell .criteria-met{color:var(--text-primary);font-weight:500}.qualification-cell .indicators{display:flex;gap:.375rem;flex-wrap:wrap;margin-top:.25rem}.qualification-cell .indicator{padding:.125rem .375rem;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase;border:1px solid;min-width:60px;text-align:center;display:inline-block}.qualification-cell .indicator.positive{background:var(--success-color)!important;color:#fff!important;border-color:var(--success-color)!important;text-shadow:0 0 1px rgba(0,0,0,.5)}.qualification-cell .indicator.negative{background:var(--danger-color)!important;color:#fff!important;border-color:var(--danger-color)!important;text-shadow:0 0 1px rgba(0,0,0,.5)}.ranking-cell .screener-rank{font-weight:700;color:var(--primary-color);font-size:.85rem}.ranking-cell .screener-volume{color:var(--text-primary);font-weight:500}.ranking-cell .evaluation-time{color:var(--text-muted);font-size:.7rem}@media (max-width: 1200px){.qualified-table{font-size:.75rem}.qualified-table th{padding:.75rem .5rem;min-width:140px}.qualified-table .cell-content>div{font-size:.7rem}.stock-info-cell .symbol{font-size:.8rem}.qualification-cell .indicators{gap:.25rem}.qualification-cell .indicator{font-size:.6rem;padding:.1rem .25rem}}@media (max-width: 768px){.qualified-table th{min-width:120px;padding:.5rem .375rem}.qualified-table .cell-content{gap:.125rem}.qualified-table .cell-content>div{font-size:.65rem}.stock-info-cell .name{max-width:100px}.qualification-cell .indicators{flex-direction:column;gap:.125rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--border-radius: .5rem;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--transition: all .2s ease-in-out}:root[data-theme=light]{--primary-color: #2563eb;--primary-hover: #1d4ed8;--primary-color-light: #dbeafe;--primary-color-alpha: rgba(37, 99, 235, .1);--secondary-color: #64748b;--success-color: #059669;--danger-color: #dc2626;--warning-color: #d97706;--background-color: #f8fafc;--surface-color: #ffffff;--surface-hover: #f1f5f9;--card-background: #ffffff;--header-background: #f8fafc;--row-hover-background: #f8fafc;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-hover: #cbd5e1;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--header-gradient: linear-gradient( 135deg, var(--primary-color) 0%, #1d4ed8 100% )}:root[data-theme=dark]{--primary-color: #3b82f6;--primary-hover: #2563eb;--primary-color-light: #1e3a8a;--primary-color-alpha: rgba(59, 130, 246, .1);--secondary-color: #64748b;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--background-color: #0f172a;--surface-color: #1e293b;--surface-hover: #334155;--card-background: #1e293b;--header-background: #0f172a;--row-hover-background: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: #334155;--border-hover: #475569;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .15);--header-gradient: linear-gradient(135deg, #1e293b 0%, #334155 100%)}body{font-family:var(--font-family);background-color:var(--background-color);color:var(--text-primary);line-height:1.5;transition:var(--transition)}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--header-gradient);color:#fff;padding:2rem 0;box-shadow:var(--shadow-lg)}.header-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%;position:relative}.header-main{flex:1}.header-actions{display:flex;align-items:center;gap:16px}.user-info{color:var(--text-secondary);font-size:14px;font-weight:500;padding:8px 12px;background:var(--card-background);border-radius:8px}.logout-button{display:flex;align-items:center;gap:6px;background:var(--danger-color);color:#fff;border:none;border-radius:8px;padding:8px 12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#dc2626;transform:translateY(-1px)}.logout-icon{width:16px;height:16px}.header-main h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;display:flex;align-items:center;gap:.75rem}.header-icon{width:2.5rem;height:2.5rem}.header-main p{font-size:1.125rem;opacity:.9}.theme-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.75rem;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.theme-toggle:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.theme-icon{width:1.25rem;height:1.25rem}.tab-navigation{display:flex;justify-content:center;align-items:center;gap:.5rem;padding:1rem 2rem;background:var(--surface-color);border-bottom:2px solid var(--border-color);box-shadow:var(--shadow)}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:var(--background-color);border:2px solid var(--border-color);border-radius:10px;color:var(--text-secondary);font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.tab-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.tab-btn:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.tab-btn:hover:before{left:100%}.tab-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-3px);box-shadow:0 6px 20px #2563eb4d}.tab-btn.active:hover{background:var(--primary-hover);transform:translateY(-3px)}.tab-icon{width:1.125rem;height:1.125rem;transition:transform .3s ease}.tab-btn:hover .tab-icon{transform:scale(1.1)}.tab-btn.active .tab-icon{transform:scale(1.15)}.main{flex:1;max-width:1200px;margin:0 auto;padding:2rem 1rem;width:100%}.controls{margin-bottom:2rem;padding:1.5rem;background:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid var(--border-color);transition:var(--transition);display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.date-selector{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;flex:1}.date-selector .icon{width:1.25rem;height:1.25rem;color:var(--primary-color)}.date-selector label{font-weight:500;color:var(--text-primary)}.date-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--surface-color);color:var(--text-primary);font-size:.875rem;min-width:280px;cursor:pointer;transition:var(--transition)}.date-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.date-select:hover{border-color:var(--border-hover)}.latest-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);color:#fff;border:none;border-radius:var(--border-radius);font-weight:500;font-size:.875rem;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow);white-space:nowrap}.latest-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-hover) 0%,#1d4ed8 100%);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.latest-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.latest-btn .icon{width:1rem;height:1rem}.refresh-prices-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,var(--warning-color) 0%,#ea8a00 100%);color:#fff;border:none;border-radius:var(--border-radius);font-weight:500;font-size:.875rem;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow);white-space:nowrap}.refresh-prices-btn:hover:not(:disabled){background:linear-gradient(135deg,#ea8a00,#d97706);transform:translateY(-1px);box-shadow:0 4px 12px #d977064d}.refresh-prices-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.refresh-prices-btn .icon{width:1rem;height:1rem}.compare-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,var(--secondary-color) 0%,#475569 100%);color:#fff;border:none;border-radius:var(--border-radius);font-weight:500;font-size:.875rem;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow);white-space:nowrap}.compare-btn:hover{background:linear-gradient(135deg,#475569,#374151);transform:translateY(-1px);box-shadow:0 4px 12px #64748b4d}.compare-btn .icon{width:1rem;height:1rem}.compare-controls{width:100%;display:flex;flex-direction:column;gap:1rem}.compare-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.compare-header h3{margin:0;color:var(--text-primary);font-size:1.125rem;font-weight:600}.close-compare-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--danger-color);color:#fff;border:none;border-radius:var(--border-radius);font-weight:500;font-size:.875rem;cursor:pointer;transition:var(--transition)}.close-compare-btn:hover{background:#b91c1c;transform:translateY(-1px)}.close-compare-btn .icon{width:1rem;height:1rem}.compare-selectors{display:flex;align-items:end;gap:1rem;flex-wrap:wrap}.compare-selector{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:250px}.compare-selector label{font-weight:500;color:var(--text-primary);font-size:.875rem}.compare-execute-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);color:#fff;border:none;border-radius:var(--border-radius);font-weight:500;font-size:.875rem;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow);white-space:nowrap;height:fit-content}.compare-execute-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-hover) 0%,#1d4ed8 100%);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.compare-execute-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.data-container{display:flex;flex-direction:column;gap:1.5rem}.data-summary{background:var(--surface-color);border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border-color);transition:var(--transition)}.data-summary h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.data-summary p{color:var(--text-secondary);font-size:.875rem}.data-table-container{background:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid var(--border-color);overflow:hidden;transition:var(--transition);margin:1rem 0}.data-table{width:100%;border-collapse:collapse;font-size:.875rem;table-layout:fixed;display:table}.data-table thead{background:var(--background-color);border-bottom:2px solid var(--border-color);display:table-header-group}.data-table thead tr{display:table-row;width:100%}.data-table thead th{display:table-cell;background:var(--header-bg);color:var(--header-text);padding:12px 8px;text-align:left;font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.3px;border-bottom:2px solid var(--border-color);position:relative;vertical-align:middle;white-space:nowrap}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease;width:100%;text-align:left;background:transparent;border:none;font-family:inherit;font-size:inherit;font-weight:inherit;color:inherit;text-transform:inherit;letter-spacing:inherit;padding:0;margin:0}.sortable-header:hover{background-color:#0000000d}[data-theme=dark] .sortable-header:hover{background-color:#ffffff0d}.sort-arrow{font-size:12px;color:var(--accent-color);margin-left:4px}.sort-arrow{font-size:12px;color:var(--accent-color);flex-shrink:0}.data-table tbody tr{border-bottom:1px solid var(--border-color);transition:all .2s ease;position:relative}.data-table tbody tr:hover{background:var(--surface-hover);transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.data-table tbody tr.expanded{background:var(--surface-hover);box-shadow:0 0 0 1px var(--primary-color)}.data-table tbody tr.expanded:hover{transform:none}.data-row{cursor:pointer}.data-row:active{transform:scale(.995)}.chart-row,.chart-row:hover{background:var(--surface-color)!important}.chart-cell{padding:0!important;border:none!important}.chart-container{width:100%;background:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;margin:1rem 0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:var(--transition)}.chart-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));border-bottom:1px solid var(--border-color);position:relative}.chart-header:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);pointer-events:none}.chart-header h3{margin:0;color:#fff;font-size:1.125rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1);position:relative;z-index:1}.chart-title{display:flex;flex-direction:column;gap:.25rem}.chart-subtitle{color:#fffc;font-size:.875rem;font-weight:400;text-shadow:0 1px 2px rgba(0,0,0,.1)}.close-chart-btn{background:var(--danger-color);color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.125rem;font-weight:700;transition:var(--transition);box-shadow:0 2px 4px #0000001a;line-height:1;padding:0;min-width:32px;flex-shrink:0}.close-chart-btn:hover{background:#b91c1c;transform:scale(1.05);box-shadow:0 4px 8px #00000026}.close-chart-btn:active{transform:scale(.95)}.stock-chart-iframe{display:block;border:none;background:#fff;width:100%;transition:opacity .3s ease-in-out}.stock-chart-iframe:loading{opacity:.7}.data-row{transition:all .3s ease;position:relative}.data-row:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.data-row.expanded{background:var(--surface-hover);box-shadow:0 0 0 2px var(--primary-color)}.data-row.expanded:hover{transform:none}.chart-cell{padding:1.5rem!important;border:none!important;background:var(--background-color)!important}@keyframes chartLoad{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chart-container{animation:chartLoad .4s ease-out}.data-table tbody tr:last-child{border-bottom:none}.data-table td{padding:.75rem;vertical-align:middle;color:var(--text-primary)}.symbol-cell strong{color:var(--primary-color);font-weight:700;font-size:.875rem}.company-cell{max-width:200px;color:var(--text-secondary);font-size:.8125rem}.price-cell .price-value{font-weight:600;color:var(--text-primary)}.change-cell .change-value{display:flex;align-items:center;gap:.25rem;font-weight:500}.change-value.positive{color:var(--success-color)}.change-value.negative{color:var(--danger-color)}.trend-icon-small{width:.75rem;height:.75rem}.change-percent{font-weight:600;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;text-align:center;min-width:50px}.price-change.positive,.change-percent.positive{background:#0596691a;color:var(--success-color)}.price-change.negative,.change-percent.negative{background:#dc26261a;color:var(--danger-color)}.volume-cell{font-variant-numeric:tabular-nums;text-align:right}.market-cap-cell{font-variant-numeric:tabular-nums;text-align:right;font-weight:500}.pe-ratio-cell{font-variant-numeric:tabular-nums;text-align:right}.range-cell .range-value{display:flex;flex-direction:column;gap:.125rem;font-size:.75rem}.range-low{color:var(--danger-color);font-weight:500}.range-high{color:var(--success-color);font-weight:500}.range-separator{color:var(--text-muted);text-align:center}.data-table,.data-table *{box-sizing:border-box}.data-table thead,.data-table tbody{display:table-header-group}.data-table tbody{display:table-row-group}.data-table tr{display:table-row!important}.data-table th,.data-table td{display:table-cell!important}.data-table .stock-cell{width:16%}.data-table .price-change-cell{width:20%}.data-table .volume-cell,.data-table .market-cap-cell{width:12%}.data-table .metrics-cell,.data-table .company-info-cell{width:20%}.data-table td{padding:12px 10px;text-align:left;border-bottom:1px solid var(--border-color);vertical-align:top;overflow:hidden;height:auto;min-height:70px;box-sizing:border-box}.stock-cell{min-width:140px}.stock-info{display:flex;flex-direction:column;gap:4px;height:100%;justify-content:flex-start}.symbol-name{display:flex;flex-direction:column;gap:2px}.stock-info .symbol{font-size:14px;font-weight:700;color:var(--primary-color);line-height:1.3}.stock-info .company-name{font-size:11px;color:var(--text-secondary);line-height:1.3;word-break:break-word}.exchange-badge-small{display:inline-block;background:var(--accent-color);color:#fff;font-size:8px;padding:2px 6px;border-radius:6px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;align-self:flex-start;margin-top:2px}.price-change-cell{min-width:120px}.price-change-info{display:flex;flex-direction:column;gap:8px;height:100%;justify-content:flex-start}.current-price{font-size:14px;font-weight:700;color:var(--text-color);line-height:1.3}.latest-price{font-size:12px;color:var(--text-secondary);line-height:1.3;margin-top:2px;display:flex;align-items:center;gap:4px}.latest-price-label{font-weight:500;opacity:.8}.latest-price-value{font-weight:600;color:var(--primary-color)}.price-diff{font-size:10px;font-weight:500;margin-left:4px;padding:1px 4px;border-radius:2px}.price-diff.positive{color:var(--success-color);background:#0596691a}.price-diff.negative{color:var(--danger-color);background:#dc26261a}.latest-price.loading{opacity:.6}.loading-indicator{font-size:10px;color:var(--text-muted);animation:spin 1s linear infinite}.change-info{display:flex;flex-direction:column;gap:4px}.combined-change{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;line-height:1.3;padding:4px 8px;border-radius:4px;flex-wrap:wrap}.combined-change.positive{background:#0596691a;color:var(--success-color)}.combined-change.negative{background:#dc26261a;color:var(--danger-color)}.change-amount{font-weight:700}.change-percentage{font-weight:600;opacity:.9}.day-range{display:flex;flex-direction:column;gap:3px;margin-top:2px}.range-label{font-size:9px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.3px;line-height:1.2}.range-values{display:flex;align-items:center;gap:8px;font-size:10px;line-height:1.2}.range-low{font-weight:600;color:#dc2626}.range-high{font-weight:600;color:#059669}.range-separator{color:var(--text-secondary);font-weight:500}.volume-cell,.market-cap-cell{min-width:85px}.volume-info,.market-cap-info{display:flex;flex-direction:column;gap:6px;height:100%;justify-content:flex-start;align-items:flex-start}.volume-label,.market-cap-label{font-size:10px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;line-height:1.2;margin-bottom:2px}.volume-value,.market-cap-value{font-size:12px;color:var(--text-color);font-weight:700;font-variant-numeric:tabular-nums;line-height:1.3}.metrics-cell{min-width:130px}.financial-metrics{display:flex;flex-direction:column;gap:8px;height:100%;justify-content:flex-start}.metric-row{display:flex;justify-content:space-between;align-items:center;gap:8px;min-height:16px;padding:2px 0}.metric-label{color:var(--text-secondary);font-weight:600;font-size:10px;min-width:30px;text-transform:uppercase;letter-spacing:.3px;line-height:1.2;flex-shrink:0}.metric-value{color:var(--text-color);font-weight:700;font-size:11px;text-align:right;font-variant-numeric:tabular-nums;line-height:1.2}.company-info-cell{min-width:130px}.company-details{display:flex;flex-direction:column;gap:8px;height:100%;justify-content:flex-start}.sector-info{display:flex;flex-direction:column;gap:3px}.sector-name{font-size:11px;font-weight:700;color:var(--text-color);line-height:1.3}.industry-name{font-size:10px;color:var(--text-secondary);font-style:italic;line-height:1.3}.week-52-range{display:flex;flex-direction:column;gap:4px;margin-top:2px}.week-52-range .range-label{font-size:9px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.3px;line-height:1.2}.week-52-range .range-values{display:flex;gap:6px;font-size:10px;flex-wrap:wrap;line-height:1.2}.week-low,.week-high{font-weight:700;padding:2px 4px;border-radius:4px}.website-info{margin-top:4px}.website-link-small{font-size:9px;color:var(--accent-color);text-decoration:none;padding:2px 6px;border:1px solid var(--accent-color);border-radius:4px;transition:all .2s ease;text-transform:uppercase;font-weight:600;letter-spacing:.3px;line-height:1.2}.website-link-small:hover{background:var(--accent-color);color:#fff;transform:scale(1.05)}.eps-cell{font-variant-numeric:tabular-nums;text-align:right;font-weight:500;color:var(--text-primary)}.sector-cell{max-width:120px}.sector-info{display:flex;flex-direction:column;gap:.25rem}.sector-name{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.exchange-badge{background:var(--primary-color);color:#fff;font-size:.6875rem;padding:.125rem .375rem;border-radius:.25rem;width:fit-content;font-weight:500;text-transform:uppercase}.info-cell{min-width:180px;max-width:200px}.stock-metrics{display:flex;flex-direction:column;gap:.25rem}.metric-item{display:flex;justify-content:space-between;align-items:center;padding:.125rem .25rem;background:var(--surface-hover);border-radius:.25rem;font-size:.75rem}.metric-label{color:var(--text-muted);font-weight:500}.metric-value{color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}.stock-details{padding:1.5rem;background:var(--background-color);border-bottom:1px solid var(--border-color)}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.detail-section h4{color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.detail-items{display:flex;flex-direction:column;gap:.5rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--surface-color);border-radius:.375rem;border:1px solid var(--border-color)}.detail-label{color:var(--text-secondary);font-weight:500;font-size:.8125rem}.detail-value{color:var(--text-primary);font-weight:600;font-size:.8125rem;font-variant-numeric:tabular-nums}.website-link{color:var(--primary-color);text-decoration:none;font-weight:500;transition:var(--transition)}.website-link:hover{color:var(--primary-hover);text-decoration:underline}.business-summary{margin-top:1rem;padding:1rem;background:var(--surface-color);border-radius:.5rem;border:1px solid var(--border-color)}.business-summary h4{color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.business-summary p{color:var(--text-secondary);font-size:.8125rem;line-height:1.5;margin:0}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:var(--text-secondary)}.spinner{width:3rem;height:3rem;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.no-data{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:20vh;gap:1rem;color:var(--text-secondary)}.no-data-icon{width:3rem;height:3rem;opacity:.5}@media (max-width: 768px){.header-content{flex-direction:column;gap:12px;text-align:center}.header-actions{gap:12px}.user-info,.logout-button{font-size:12px;padding:6px 10px}.header-main h1{font-size:2rem}.header-icon{width:2rem;height:2rem}.header-content{flex-direction:column;align-items:flex-start;gap:1rem}.theme-toggle{align-self:flex-end}.tab-navigation{padding:.75rem 1rem;gap:.5rem}.tab-btn{flex:1;justify-content:center;padding:.75rem 1rem;font-size:.9rem}.tab-icon{width:1rem;height:1rem}.main,.data-summary{padding:1rem}.data-summary h2{font-size:1.25rem}.data-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:1000px}.data-table th,.data-table td{padding:.5rem .375rem}.date-selector{flex-direction:column;align-items:flex-start;gap:.5rem}.date-select{width:100%}.range-cell .range-value{flex-direction:row;align-items:center;gap:.25rem}.range-separator{margin:0 .25rem}.info-cell{min-width:160px}.metric-item{font-size:.6875rem;padding:.1rem .2rem}.details-grid{grid-template-columns:1fr;gap:1rem}.stock-details{padding:1rem}.chart-header{padding:1rem;flex-direction:column;align-items:flex-start;gap:.75rem}.chart-title{flex:1}.close-chart-btn{align-self:flex-end;margin-top:-2rem}.chart-cell{padding:1rem!important}.stock-chart-iframe{height:400px}}@media (max-width: 480px){.header{padding:1.5rem 0}.header-main h1{font-size:1.75rem}.header-content{padding:0 .75rem}.controls{flex-direction:column;align-items:stretch;gap:1rem}.date-selector{flex-direction:column;align-items:stretch;gap:.5rem}.date-select{min-width:auto;width:100%}.latest-btn,.compare-btn{align-self:center;width:fit-content}.compare-selectors{flex-direction:column;align-items:stretch}.compare-selector{min-width:auto}.compare-execute-btn{align-self:center;width:fit-content}.data-summary{padding:.75rem}.data-table th,.data-table td{padding:.375rem .25rem;font-size:.75rem}.data-table th{font-size:.6875rem}.theme-toggle{padding:.5rem}.theme-icon{width:1rem;height:1rem}.data-table .pe-ratio-cell,.data-table .range-cell,.data-table .eps-cell,.data-table .info-cell{display:none}.data-table th:nth-child(8),.data-table th:nth-child(9),.data-table th:nth-child(10),.data-table th:nth-child(12){display:none}}*{transition:background-color .2s ease-in-out,border-color .2s ease-in-out,color .2s ease-in-out}.theme-toggle:focus-visible{outline:2px solid rgba(255,255,255,.8);outline-offset:2px}[data-theme=dark] .theme-toggle:focus-visible{outline:2px solid var(--primary-color)}@media (max-width: 1200px){.data-table .stock-cell{width:18%}.data-table .price-change-cell{width:22%}.data-table .volume-cell,.data-table .market-cap-cell{width:11%}.data-table .metrics-cell{width:18%}.data-table .company-info-cell{width:20%}.stock-info .symbol{font-size:12px}.stock-info .company-name{font-size:9px}.current-price{font-size:12px}}@media (max-width: 768px){.data-table-container{margin:.5rem 0;border-radius:8px}.data-table th{padding:8px 4px;font-size:10px}.data-table td{padding:6px 4px}.stock-info .symbol{font-size:11px}.stock-info .company-name{font-size:8px}.current-price{font-size:11px}.price-changes{font-size:9px;gap:4px}.day-range{font-size:8px}.metric-row,.sector-name{font-size:9px}.industry-name{font-size:8px}}@media (max-width: 480px){.data-table .stock-cell{width:20%}.data-table .price-change-cell{width:25%}.data-table .volume-cell,.data-table .market-cap-cell{width:12%}.data-table .metrics-cell{width:16%}.data-table .company-info-cell{width:15%}.data-table th,.data-table td{padding:4px 2px}.stock-info .company-name,.day-range,.industry-name{display:none}}
